H78+4tH7VgmkK3c~|tNCb6AN^CN{wt$@%jgF)`o@etG^2mb
z=yx;q$r*iiM&F)IUGll9I7iiC=O%r(d+9iKR%(qz)R+3UU01?8#ExRMRYJ{3-X*q-
z_lWIOgE88S_0s*3U$kF|W>dPeD3pkED_KI-EA``1t?4YSy*zkIYv;wWexB0WO}!M!
z+f@-w{&wB%0^T7U`4`dTPb~5;;61{T|3HlPWxX_(?D5b7%gr8i!@MOG&!a6?N~4`t
zlRm@q<&J$SS#QZWelHqpxtHd{AC)FNf!$TVy+nA@gMD6kLNves=un1x?J~+@a)fKj
zsD8;E>wn~NiXGe3VlSim0k^Ebl*fT3JeXIYbZAxoVP&h!DEmb#VG*r_br~sPZ6z$C
zm9Q>jxrFB`rCo4ixU4~C)l$a(J$U;=WREgyRw{XvzYE!-lu?!^(^w9dkTxDR#_~eb
zThe%LB}V(_i~EhneMqguTv^_?w12nL{t)%1DQgj}#KcnK0&1?D5*N`*Ol&M+ld8lT
zOOFaKb!D#34bKv=izm~
z_%{Wkdn^A7frnIE;ye67HxqtYd^jNS@0-6Ixuo#Aj=yid<@7t>3-mt+`ahfs4+IAP
zt#IA9e&F%n`k~WrtK9s3do|EYfj$xFhXegspq~o#^MQUL&@To0l|a85=v#q)FVG(Z
z`a`GxW+u?pKraRQM4%rI^kad3D$vgd`h`Hh6zEq1{c50Z1^T@}e-P*oo&MXIKvx63
z6zCIyemKyN1^TH#KOg890{v2;UkUW9fxZ>!_X7Pvpg(l_otZ#a1HBaJ6M=p>(2oWB
zsX#v;=obS0QlMW6^s9ls<&-G^Up)IheP0gm>%fnp4m{vT_QXei`|rK}{By58xBl@L
z)?a_&YPwzfq{^|91&4Ye=*ONSt240_SDybUd;BT8lU*GgE
zel>Mz^7q}ZCtto0_ub#~3%(z|(%)BF{=UC%#321zz8$W6JKXbaJqmwshjeeB4Cng7
z^Y`|;k?QTOKz9SZ66lRUZwLBVpic$*Y@l_Ze=yLW4D_Rc{#2lUEYP10^iKu)@jyQr
z=*xkACeSwm{am2G5a^qM{)Ir>f&P_1|5~7bBhW7f`ga5Ul|cV~pkEI3*8=^=f&SA#
zeigq
+
+
+ {title_text}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {contents}
+
+
+
\ No newline at end of file
diff --git a/HTML/WMarkDown.web.base.html b/HTML/WMarkDown.web.base.html
new file mode 100644
index 0000000..9a2a1fc
--- /dev/null
+++ b/HTML/WMarkDown.web.base.html
@@ -0,0 +1,83 @@
+
+
+
+ {title_text}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ {contents}
+
+
+
\ No newline at end of file
diff --git a/JSON/I18N/Python/WMarkDown.py.i18n.espanol.json b/JSON/I18N/Python/WMarkDown.py.i18n.espanol.json
new file mode 100644
index 0000000..817731b
--- /dev/null
+++ b/JSON/I18N/Python/WMarkDown.py.i18n.espanol.json
@@ -0,0 +1,6 @@
+{
+ "espanol" : {
+ "wmarkdown" : "WMarkDown",
+ "wmd" : "WMarkDown"
+ }
+}
\ No newline at end of file
diff --git a/JSON/WMarkDown.py.routes.json b/JSON/WMarkDown.py.routes.json
new file mode 100644
index 0000000..25ccf1a
--- /dev/null
+++ b/JSON/WMarkDown.py.routes.json
@@ -0,0 +1,3 @@
+[
+ "get:/ /WMarkDown/Public"
+]
\ No newline at end of file
diff --git a/JSON/WMarkDown.py.settings.json b/JSON/WMarkDown.py.settings.json
new file mode 100644
index 0000000..1f875bf
--- /dev/null
+++ b/JSON/WMarkDown.py.settings.json
@@ -0,0 +1,49 @@
+{
+ "wmarkdown_host_name" : "/^(https?\\:\\/{2})?wm(arkdown|d)\\.(k3y\\.pw|(anprm\\.)?local|anprm)/",
+ "wmarkdown_default_settings_files" : [
+ "/JSON/WMarkDown.py.settings.json"
+ ],
+ "wmarkdown_default_secrets_files" : [
+ "/JSON/WMarkDown.py.settings.secrets.json"
+ ],
+ "wmarkdown_default_i18n_files" : [
+ "/JSON/I18N/Python/WMarkDown.py.i18n.espanol.json"
+ ],
+ "wmarkdown_default_routes_files" : [
+ "/JSON/WMarkDown.py.routes.json",
+ "/JSON/WMarkDown.py.routes.secrets.json"
+ ],
+ "wmarkdown_resources" : {
+ "charset" : "utf-8",
+ "logo" : "/images/WMarkDown.png",
+ "link" : "https://wmarkdown.k3y.pw/",
+ "git" : "https://git.k3y.pw/Whalers/WMarkDown",
+ "project" : "WMarkDown",
+ "web" : "https://wmarkdown.k3y.pw",
+ "authors" : ["Tarsier", "KyMAN"],
+ "class" : "wmarkdown-web",
+ "snake" : "wmarkdown",
+ "metas" : {},
+ "styles" : ["/scss/WMarkDown.web.scss"],
+ "menu" : [
+ ["web", "_self", "/"],
+ ["git", "_blank", "https://git.k3y.pw/Whalers/WMarkDown"]
+ ],
+ "licenses" : [
+ ["copyright", null, null, {
+ "year" : "2019-2025",
+ "entity" : "Tarsier & KyMAN"
+ }],
+ ["cc_by_nc_sa_4"]
+ ],
+ "dictionary" : "https://wmarkdown.{domain}/json/WMarkDown.dict.es.kyman.json"
+ },
+ "__COMMENTS__" : {
+ "wmarkdown_default_views_files" : [],
+ "wmarkdown_charset" : "utf-8",
+ "wmarkdown_logo" : "/images/WMarkDown.png",
+ "wmarkdown_link" : "https://wmarkdown.k3y.pw/",
+ "wmarkdown_git" : "https://git.k3y.pw/Whalers/WMarkDown",
+ "wmarkdown_base_html" : "/HTML/WMarkDown.base.html"
+ }
+}
\ No newline at end of file
diff --git a/Public/.htaccess b/Public/.htaccess
deleted file mode 100755
index 81d9bac..0000000
--- a/Public/.htaccess
+++ /dev/null
@@ -1 +0,0 @@
-Header set Access-Control-Allow-Origin "*"
diff --git a/Public/css/WMarkDown.icons.FontAwesome.css b/Public/css/WMarkDown.icons.FontAwesome.css
new file mode 100644
index 0000000..2850493
--- /dev/null
+++ b/Public/css/WMarkDown.icons.FontAwesome.css
@@ -0,0 +1,25 @@
+.wmd-icon.checkbox>input+span::before{content : "\f0c8"; font-family : "FA6FR";}
+.wmd-icon.checkbox>input:disabled+span::before{content : "\f0c8"; font-family : "FA6FS"; opacity : .5;}
+.wmd-icon.checkbox>input:checked+span::before{content : "\f14a"; font-family : "FA6FR";}
+.wmd-icon.radio-button>input+span::before{content : "\f111"; font-family : "FA6FR";}
+.wmd-icon.radio-button>input:disabled+span::before{content : "\f111"; font-family : "FA6FS"; opacity : .5;}
+.wmd-icon.radio-button>input:checked+span::before{content : "\f192"; font-family : "FA6FR";}
+.wmd-icon.tick>input+span::before{content : "\f00d"; font-family : "FA6FS";}
+.wmd-icon.tick>input:disabled+span::before{content : "\f560"; font-family : "FA6FS";}
+.wmd-icon.tick>input:checked+span::before{content : "\f00c"; font-family : "FA6FS";}
+.wmarkdown [data-icon=warning]::before,.wmarkdown [data-icon=warn]::before{content : "\f071"; font-family : "FA6FS";}
+.wmarkdown [data-icon=ask]::before,.wmarkdown [data-icon=question]::before{content : "\f059"; font-family : "FA6FS";}
+.wmarkdown [data-icon=answer]::before{content : "\f138"; font-family : "FA6FS";}
+.wmarkdown [data-icon=comment]::before{content : "\f075"; font-family : "FA6FR";}
+.wmarkdown [data-icon=note]::before{content : "\f249"; font-family : "FA6FR";}
+.wmarkdown [data-icon=characters]::before{content : "\f031"; font-family : "FA6FS";}
+.wmarkdown [data-icon=lines]::before{content : "\f039"; font-family : "FA6FS";}
+.wmd-code-block [data-icon=type]::before{content : "\f15b"; font-family : "FA6FR";}
+.wmd-code-block[data-type=html] [data-icon]::before{content : "\f1c9"; font-family : "FA6FR";}
+.wmarkdown [data-icon=link]::before{content : "\f0c1"; font-family : "FA6FS";}
+.wmarkdown [data-deployed=true]>[data-icon=deploy]::before,
+.wmd-main-menu [data-deployed=true]>[data-icon=deploy]::before{content : "\f146"; font-family : "FA6FR";}
+.wmarkdown [data-deployed=false]>[data-icon=deploy]::before,
+.wmd-main-menu [data-deployed=false]>[data-icon=deploy]::before{content : "\f0fe"; font-family : "FA6FR";}
+.wmd-main-menu-button [data-icon=menu]::before{content : "\f0c9"; font-family : "FA6FS";}
+.wmarkdown [data-icon=view_switch]::before{content : "\f074"; font-family : "FA6FS";}
\ No newline at end of file
diff --git a/Public/css/WMarkDown.icons.css b/Public/css/WMarkDown.icons.css
old mode 100755
new mode 100644
index b29149e..ed1e721
--- a/Public/css/WMarkDown.icons.css
+++ b/Public/css/WMarkDown.icons.css
@@ -1,35 +1,9 @@
-.wmarkdown [data-icon=show]::before{content : "\f06e"; font-family : "FA5FS";}
-.wmarkdown [data-icon=hide]::before{content : "\f070"; font-family : "FA5FS";}
-.wmarkdown [type=checkbox]+[data-icon=checkbox]::before{content : "\f0c8";}
-.wmarkdown [type=checkbox]:checked+[data-icon=checkbox]::before{content : "\f14a";}
-.wmarkdown [type=checkbox]:disabled+[data-icon=checkbox]::before{content : "\f0c8"; font-family : "FA5FS"; opacity : .5;}
-.wmarkdown [type=radio]+[data-icon=radio]::before{content : "\f111";}
-.wmarkdown [type=radio]:checked+[data-icon=radio]::before{content : "\f192";}
-.wmarkdown [type=radio]:disabled+[data-icon=radio]::before{content : "\f111"; font-family : "FA5FS"; opacity : .5;}
-.wmarkdown [type=checkbox]+[data-icon=tick]::before{content : "\f00d"; font-family : "FA5FS";}
-.wmarkdown [type=checkbox]:checked+[data-icon=tick]::before{content : "\f00c"; font-family : "FA5FS";}
-.wmarkdown [data-icon=language]::before{content : "\f1c9";}
-.wmarkdown [data-icon=characters]::before{content : "\f031"; font-family : "FA5FS";}
-.wmarkdown [data-icon=lines]::before{content : "\f036"; font-family : "FA5FS";}
-.wmarkdown [data-icon=link]::before{content : "\f0c1"; font-family : "FA5FS";}
-.wmarkdown [data-deployed=false]>[data-icon=deploy]::before{content : "\f054"; font-family : "FA5FS";}
-.wmarkdown [data-deployed=true]>[data-icon=deploy]::before{content : "\f078"; font-family : "FA5FS";}
-.wmarkdown [data-levels='0']>[data-icon=deploy]::before{content : " ";}
-.wmarkdown [data-icon=likes]::before{content : "\f164"; font-family : "FA5FS";}
-.wmarkdown [data-icon=dislikes]::before{content : "\f165"; font-family : "FA5FS";}
-.wmarkdown [data-icon=views]::before{content : "\f06e";}
-.wmarkdown [data-icon=comments]::before{content : "\f086";}
-.wmarkdown [data-icon=note]::before{content : "\f27a";}
-.wmarkdown [data-icon=alert]::before{content : "\f0f3";}
-.wmarkdown [data-icon=important]::before{content : "\f0a1"; font-family : "FA5FS";}
-.wmarkdown [data-icon=warning]::before,.wmarkdown [data-icon=warn]::before{content : "\f12a"; font-family : "FA5FS";}
-.wmarkdown [data-icon=danger]::before{content : "\f071"; font-family : "FA5FS";}
-.wmarkdown [data-icon=ask]::before{content : "\f128"; font-family : "FA5FS";}
-.wmarkdown [data-icon=home]::before{content : "\f015"; font-family : "FA5FS";}
-.wmarkdown [data-icon=developt]::before{content : "\f121"; font-family : "FA5FS";}
-.wmarkdown [data-icon=git]::before{content : "\f841"; font-family : "FA5FB";}
-.wmarkdown [data-icon=game]::before{content : "\f11b";font-family : "FA5FS";}
-.wmarkdown [data-icon=documentation]::before{content : "\f02d";font-family : "FA5FS";}
-.wmarkdown [data-icon=menu]::before{content : "\f0c9";font-family : "FA5FS";}
-.wmarkdown [data-icon=content]::before{content : "\f570";font-family : "FA5FS";}
-.wmarkdown [data-icon=files]::before{content : "\f0c5";font-family : "FA5FS";}
+.wmd-icon.checkbox>input+span::before{content : "\2610";}
+.wmd-icon.checkbox>input:disabled+span::before{content : "\25A3"; opacity : .5;}
+.wmd-icon.checkbox>input:checked+span::before{content : "\2612";}
+.wmd-icon.radio-button>input+span::before{content : "\25CB";}
+.wmd-icon.radio-button>input:disabled+span::before{content : "\25CE"; opacity : .5;}
+.wmd-icon.radio-button>input:checked+span::before{content : "\25C9";}
+.wmd-icon.tick>input+span::before{content : "\2714";}
+.wmd-icon.tick>input:disabled+span::before{content : "\25CB";}
+.wmd-icon.tick>input:checked+span::before{content : "\2718";}
\ No newline at end of file
diff --git a/Public/css/WMarkDown.web.icons.css b/Public/css/WMarkDown.web.icons.css
new file mode 100644
index 0000000..db6d0ca
--- /dev/null
+++ b/Public/css/WMarkDown.web.icons.css
@@ -0,0 +1,5 @@
+.main-menu [data-icon=web]::before{content : "\f0ac"; font-family : "FA6FS";}
+.main-menu [data-icon=git]::before{content : "\f841"; font-family : "FA6FB";}
+.main-menu [data-icon=home]::before{content : "\f015"; font-family : "FA6FS";}
+.main-menu [data-icon=game]::before{content : "\f11b"; font-family : "FA6FS";}
+.main-menu [data-icon=blog]::before{content : "\f27a"; font-family : "FA6FR";}
\ No newline at end of file
diff --git a/Public/doc/es/bugs.w.md b/Public/doc/es/bugs.w.md
new file mode 100644
index 0000000..07f9b6d
--- /dev/null
+++ b/Public/doc/es/bugs.w.md
@@ -0,0 +1,48 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_bugs
+title_text = Bugs y errores - WMarkDown
+```
+
+
+
+## Bugs y errores
+
+Esta sección va orientada a exponer los posibles errores que se puedan encontrar dentro del proyecto y el estado al cual se atañen.
+
+### Párrafos incompletos
+
+Se aprecia que los párrafos creados con saltos de línea los fracciona en Python.
+
+* [X] Localizar el error.
+* [X] Arreglo del error.
+
+> [!@Srx00] El problema estaba en que cuando se llamaba de forma recursiva al método "analyse" éste no llevaba si era un subelemento o no pues omití sin querer en el desarrollo ese factor y sólo enviaba en su lugar el lenguaje con el que tenía que trabajar. Afectaba a todo el lenguaje. Esto vislumbró otro fallo con el orden de los patrones que también fue corregido.
+
+### Modulo Cursivas en bucle
+
+Cuando hay un único asterisco suelto, el patrón de este módulo entra en bucle infinito con un consumo de procesador elevado.
+
+* [X] Localizar el error.
+* [X] Arreglo del error.
+
+> [!@Srx00] Con la ayuda de ChatGPT se llegó a una conclusión pues dicho error sólo sucede con el caso de los asteriscos simples en Python, mientras que en JavaScript y otros no pasa. El problema radica en el motor de interpretación del patrón regular, siendo diferente, siguiendo el ejemplo, la librería "re" de Python y el motor de interpretación V8. El cambio fue con respecto a como formular el patrón regular. No encontré más información que ésta.
+
+> [!@Srx00] Aún así, no funciona en todos los casos, dando errores cuando existen 2 asterisco y luego otro sin que éste contenga final. Insisto que sólo pasa con los asteriscos pues con el uso del resto de marcas no sucede pese a ser la misma casuística.
+
+### Negrillas y Cursivas
+
+Cuando se juntan ambos elementos en un único elemento, éste reacciona de forma inoportuna, por ejemplo, en el siguiente caso:
+
+```md
+
+Esto es un ejemplo del error, donde el ***elemento1*** y el ***elemento2*** tendrían que estar en negrilla y cursiva simultáneamente.
+
+```
+
+* [X] Localizar el error.
+* [X] Arreglo del error.
+
+> [!Srx00] El problema radica, en el ejemplo aquí expuesto, en que la cursiva sólo afectaría por posición de los atributos de WMarkDown por defecto, al fragmento de texto " y el ", dejando el resto en negrilla y con dos asteriscos sin procesar. Para arreglar dicho error hay que crear un subelemento que monte negrilla y cursiva de golpe, aunque lo ideal es que lo procese directamente tal como está. Es un poco chapuzas el arreglo pero inicialmente, y en base a la filosofía de funcionamiento, esta es la solución más plausible.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/description.md b/Public/doc/es/description.md
new file mode 100644
index 0000000..266ebd5
--- /dev/null
+++ b/Public/doc/es/description.md
@@ -0,0 +1,11 @@
+El WMarkDown es un pequeño lenguaje de marcas orientado a formatear un texto en un esquema más complejo con formato. Está basado principalmente en MarkDown y el lenguaje de marcas de MediaWiki, motivo por el cual existe éste. Tiene numerosos elementos personalizados por lo que tampoco podemos encajarlo dentro de estos dos entornos.
+
+Actualmente cuenta con soporte para Python y formatea el texto contra HTML y SASS/CSS.
+
+Esta versión del proyecto es la segunda que hay, siendo la primera desarrollada por 2020 entre Srx01 y Srx00, con influencia de Srx02. Hubo testeos por parte de Srx03 y Srx04.
+
+> Esta Web ya puede servir como ejemplo de resultado HTML sobre el fichero "index.w.md" pues está integrado como fichero Index de la Web y está procesado en caliente con la petición. El servidor de trabajo sobre que el se soporta la Web es un servidor AnP, desarrollado en Python por el propio desarrollador de este proyecto, Srx00.
+
+Es importante mencionar que tanto el lenguaje como el diseño tuvo una evolución, siendo el logo original creado por Srx01, así como el segundo logo que se tuvo. Este tercer logo está basado en el segundo logo de Srx01 pero fue creado por Srx00. También se cambiaron los colores originales establecidos por Srx01 por los actuales establecidos por Srx00. También es importante destacar que cambia la filosofía de trabajo e interpretación de las marcas, basado en un proyecto privado creado para una entidad por parte de Srx00, cogiendo dicha parte que no era privada y fue plenamente desarrollada por él mismo.
+
+> Para ir a la página de pruebas sería [aquí](/doc/tests.w.md Página de pruebas).
\ No newline at end of file
diff --git a/Public/doc/es/design.w.md b/Public/doc/es/design.w.md
new file mode 100644
index 0000000..283ff7c
--- /dev/null
+++ b/Public/doc/es/design.w.md
@@ -0,0 +1,51 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_design
+title_text = Estilo y diseño - WMarkDown
+```
+
+
+
+## Estilo y diseño
+
+El estilo y el diseño del proyecto WMarkDown está basado a su vez tanto en el proyecto original así como se construyeron visualmente otros proyectos como AnP. A nivel de colores, éste tiene los siguientes:
+
+[|
+|= Tipo | Hexadecimal | RGBA | Muestra
+| Fondo | #EFEFEF | rgba\(239, 239, 239, 1) | [[#EFEFEF]]
+| Frontal | #222 | rgba\(34, 34, 34, 1) | [[#222]]
+| Primario | #008844 | rgba\(0, 136, 68, 1) | [[#008844]]
+| Secundario | #880044 | rgba\(136, 0, 68, 1) | [[#880044]]
+| Gris | #888 | rgba\(136, 136, 136, 1) | [[#888]]
+| Tabla título | #19888888 | rgba\(136, 136, 136, 0.1) | [[color rgba(136, 136, 136, 0.1)]]
+| Tabla Select | #19888888 | rgba\(136, 136, 136, 0.1) | [[color rgba(136, 136, 136, 0.1)]]
+| Tabla impar | #38888888 | rgba\(136, 136, 136, 0.2) | [[color rgba(136, 136, 136, 0.2)]]
+| Tabla par | #00FFFFFF | rgba\(255, 255, 255, 0) | [[color rgba(255, 255, 255, 0)]]
+| Borde interno | #19888888 | rgba\(136, 136, 136, 0.5) | [[color rgba(136, 136, 136, 0.5)]]
+| Diccionario | #115533 | rgba\(17, 85, 51, 1) | [[#115533]]
+| Diccionario en | #551133 | rgba\(85, 17, 51, 1) | [[#551133]]
+| Code impar | #38C8C8C8 | rgba\(200, 200, 200, 0.2) | [[color rgba(200, 200, 200, 0.2)]]
+|]
+
+> [!!] Es importante entender que el diseño se basa en el resultado de la Web como diseño general pues el uso del WMarkDown se condicionará a como lo diseñe el usuario que lo implemente en su proyecto. Inicialmente está diseñado para ser independiente con un diseño monocromático en escala de grises, pero éste puede ser alterado según características del usuario. En el caso de la Web del propio proyecto se basa en el estilo de AnP pero con los códigos de color que le fueron asignados en la tabla anterior.
+
+Se utilizaron 3 fuentes distintas para visualizar el proyecto, las cuales son:
+
+* **Roboto**. Para el texto en general.
+ * https://fonts.google.com/specimen/Roboto?query=roboto
+* **Roboto Mono**. Para los bloques de código.
+ * https://fonts.google.com/specimen/Roboto+Mono?query=roboto
+* **Font Awesome**. Para la iconificación general de la Web.
+ * https://fontawesome.com/
+
+El tamaño general del proyecto se basa en un sistema porcentual que imita parcialmente el sistema de DPI existente en los dispositivos móviles o aplicaciones orientadas a la densidad de puntos por pulgada de la pantalla donde se ejecutan. En este caso, la filosofía se basa en unificar la visualización general en todos los dispositivos independientemente del tamaño y resolución de la pantalla, y que permita, de alguna forma, ampliar o disminuir los objetos según permisos por parte de los desarrolladores y, si así lo permiten los desarrolladores, por necesidades del propio usuario. El sistema se basa en buscar, dentro del rectángulo que contiene la aplicación (Pantalla), el lado más estrecho y trabajar sobre éste, dividiéndolo en celdas, en este caso, 40 celdas, así pues, se cambie el tamaño de la pantalla, o navegador en este caso, la aplicación seguirá viéndose exactamente igual.
+
+La cabecera consta de 4 celdas de alto; mientras que el pie de página consta de 2. Ambos elementos están entablados mediante un Flex que permite posicionar los elementos internamente de una forma ágil, flexible y visual, permitiendo añadir nuevos elementos y condicionándolos a éstos.
+
+El logo, partiendo de los colores primario y secundario, consta de 3 rectángulos alterados a formas específicas y separadas con angulos de entre 10 para los externos, y 20 para los internos. La intención es generar una W que parta de la idea de Srx01 de hacer, mediante una M, como respresentación de MarkDown, y la flecha integrada dentro del final de la misma, haciendo una simulación de vela gráfica. De esta forma nos desmarcamos de MarkDown. El resultado de éste es los siguiente.
+
+((!image /images/WMarkDown.svg))
+
+> [!!] En PNG tiene un borde de color blanco para destacar sobre ciertos fondos que puedan coincidir en colores con los del propio logo SVG.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/donates.w.md b/Public/doc/es/donates.w.md
new file mode 100644
index 0000000..5ee5f10
--- /dev/null
+++ b/Public/doc/es/donates.w.md
@@ -0,0 +1,55 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_donates
+title_text = Donaciones - WMarkDown
+```
+
+
+
+## Donaciones
+
+Este proyecto es plenamente gratuito pues es un proyecto orientado a complementar otros proyectos de los mismos desarrolladores. No tiene ningún plan de ingresos ni pasivos ni activos más allá de lo que se expone en este título. Si alguien quisiere colaborar en que este proyecto no sólo esté abierto por requisitos de los autores, sino también cara un mantenimiento hacia terceros, a continuación presentamos unas direcciones de Cryptoactivos donde se podrá donar sin ninguna cuantía mínima establecida.
+
+- **Bitcoin** o *BTC*: [bitcoin:bc1qu82ravz56qt9j44wza6p9tcqn5gyyhqyufpnu2?label=WMarkDownDonation bc1qu82ravz56qt9j44wza6p9tcqn5gyyhqyufpnu2]
+- **Litecoin** o *LTC*: [litecoin:ltc1qqj93dxr7kyas3resnws4mr5hudlvqm4c7xf3x6?label=WMarkDownDonation ltc1qqj93dxr7kyas3resnws4mr5hudlvqm4c7xf3x6]
+- **Dogecoin** o *DOGE*: [dogecoin:DEXrwydRVE5HrAnwogoUe9UxVQbRWSRetQ?label=WMarkDownDonation DEXrwydRVE5HrAnwogoUe9UxVQbRWSRetQ]
+- **Dash**: [dash:XpzAZSHGXDwzYFSNhgxLiayY7WJTgAsnus?label=WMarkDownDonation XpzAZSHGXDwzYFSNhgxLiayY7WJTgAsnus]
+- **Faircoin** o *FAIR*: [faircoin:fLJfTuSt3MYwbgt7E4KtUprbkmadiaN5xq?label=WMarkDownDonation fLJfTuSt3MYwbgt7E4KtUprbkmadiaN5xq]
+
+> [!!] Mientras no halla ninguna condición de recursos que impida el mantenimiento gratuito de este servicio, éste permanecerá mantenido y público independientemente de los ingresos obtenidos a partir de los donativos.
+
+> [!#] Los usuarios que colaboren y quieran ser referenciados, éstos serán referenciados en este apartado mediante un Quote de comentario de usuario con el Nick y avatar correspondiente, pero sólo en caso de que ellos quieran aparecer aquí.
+
+> [!#] Se mantendrá informados a los usuarios de todo aquel donativo dado y la cantidad económica adquirida, y será publicado su uso y tenencia para que halla constancia pública del uso que se le dé a dichos recursos.
+
+> [!@Srx00] Quería agredecer de forma persona aquellas aportaciones que serán bien recibidas y valoradas para este proyecto, ya sea como valor simbólico como de mantenimiento. Así, que desde el desarrollo y como desarrollador de este proyecto, muchas gracias a todos aquellos que ponen su granito de arena para este proyecto y por lo tanto, en pro de todos. Muchas gracias, de verdad.
+
+### Balance
+
+A continuación se mostrará una tabla de balance con respecto a las cantidades y usos dados.
+
+[|
+|= Activo | Cantidad | Motivo | Usuario | Cantidad total actual
+| **BTC** | 0 BTC | Inicio del contador de unidades de BTC. | | 0 BTC
+| **LTC** | 0 LTC | Inicio del contador de unidades de LTC. | | 0 LTC
+| **DOGE** | 0 DOGE | Inicio del contador de unidades de DOGE. | | 0 DOGE
+| **DASH** | 0 DASH | Inicio del contador de unidades de DASH. | | 0 DASH
+| **FAIR** | 0 FAIR | Inicio del contador de unidades de FAIR. | | 0 FAIR
+|]
+
+Cómputo total actual en tenencia.
+
+[|
+|= Activo | Cantidad | Número de Operaciones
+| **BTC** | 0 BTC | 0
+| **LTC** | 0 LTC | 0
+| **DOGE** | 0 DOGE | 0
+| **DASH** | 0 DASH | 0
+| **FAIR** | 0 FAIR | 0
+|]
+
+### Donantes
+
+A continuación, los comentarios de los donantes.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/faq.w.md b/Public/doc/es/faq.w.md
new file mode 100644
index 0000000..a001f8f
--- /dev/null
+++ b/Public/doc/es/faq.w.md
@@ -0,0 +1,25 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_faq
+title_text = F.A.Q. - WMarkDown
+```
+
+
+
+## F.A.Q.
+
+En este apartado se irán haciendo preguntas y respuestas acorde a motivos sobre las decisiones que se tomaron para llevar a cabo dicho proyecto.
+
+> [!?] **¿Por qué utilizas el Syntax Highlighter para MarkDown para representar en código el propio lenguaje de marcas del WMarkDown?** Pues al no existir oficialmente el propio lenguaje WMarkDown, éste no tiene asignado un lenguaje oficial y menos, un desarrollo ajeno a este proyecto que pueda ayudar y complementar dicho proyecto de momento. Al ser el lenguaje más parecido, éste es el que se quedará inicialmente.
+
+> [!?] **¿Por qué usas guiones bajos para marcar fragmentos de texto subrayados pues es una de las marcas de MarkDown para representar la negrilla y la cursiva?** Los guiones bajos son una alternativa en MarkDown para representar ambos formatos, pero el principal es el uso de los asteriscos. Al no existir una manera eficiente de representar textos tachados o subrayados se decidió cambiar estas marcas para los fragmentos de texto subrayados.
+
+> [!?] **¿Cómo distingue WMarkDown de un título una lista ordenada numerada mediante la marca almuadilla o "#"?** Pues básicamente los títulos requieren de al menos dos saltos de línea por debajo de ellos, mientras que en una lista, en cuanto halla más de un elemento tras de él se sabe que es una lista ordenada numerada.
+
+> [!?] **¿Puede dar problemas el WMarkDown?** Como toda tecnología digital compleja, ésta puede responder de forma inesperada no contemplada por los desarrolladores de la misma, además, actualmente sólo hay un único desarrollador, por lo que posiblemente dé resultados inesperados pues sólo se contempla el propósito de acción de dicho desarrollador. A medida que se haga uso de éste se irán reportando problemas y se irán haciendo las correcciones pertinentes según el tiempo que se le pueda dedicar pues este proyecto es un proyecto Free Open Source que mientras no genere un dinero que permita mantenimiento sobre otros proyectos, éste irá limitado a dicho contexto, en conjunto con el número de desarrolladores que puedan ser partícipes.
+
+> [!?] **¿Por qué se decidió poner la licencia general de Creative Commons para Atribución, No Comercial y que se permite el Compartir o *CC-BY-NC-SA*?** Pues por el hecho de que se quiere dejar el proyecto para uso libre en Internet para cualquiera que quiera implementarlo dentro de su proyecto, sin embargo, licencias como el MIT o GPL no obliga a reconocer la autoría, cosa que creo que es de vital importancia para ayudar a los autores originales tanto a su visibilización como mostrar su trabajo y de una forma indirecta, favorecer su currículum profesional, de ahí que tenga el **BY de Atribución o By en inlgés**; tampoco nos interesa que dicho proyecto se venda a terceros cuando éste es totalmente gratuito, sin embargo, no nos importa que este proyecto sea usado en un proyecto comercial siempre que la fuente de ingresos no sea el servicio que se ofrece con este proyecto, de ahí que sea **NC de No Comercial**; y finalmente, como dijimos hasta ahora, que éste pueda ser compartido, manipulado y trabajado libremente con las dos condiciones anteriores, de ahí que sea **SA de Compartir o Shared Alike**. Un ejemplo de uso comercial puede ser la creación de un Blog o Foro donde la gente escriba a partir de WMarkDown, donde el producto no es el propio WMarkDown, sino el servicio del Blog o foro.
+
+> [!?] **¿Por qué se seleccionó el nombre WMarkDown pese a que el logo sea una W con la flecha alzada pudiendo encajar mejor __WMarkUp__?** El problema es que la base principal del lenguaje se basa plenamente en MarkDown, donde la lógica me dice que Down viene a simplificar la forma de escribir en un formato de estilos mediante marcas de texto. Poner Up sería ir a la contra, y creemos desde WMarkDown, que no es éste el propósito.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/integration.w.md b/Public/doc/es/integration.w.md
new file mode 100644
index 0000000..3c14427
--- /dev/null
+++ b/Public/doc/es/integration.w.md
@@ -0,0 +1,33 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_integration
+title_text = Integración - WMarkDown
+```
+
+
+
+## Integración
+
+El WMarkDown puede ser integrado directamente en un proyecto si éste tiene el lenguaje de ejecución del mismo. Actualmente contamos con los siguientes lenguajes, los cuales irán acompañados de su sistema de adjunción.
+
+### HTML
+
+Para poder integrar WMarkDown sobre HTML se requiere de agregar las siguientes etiquetas en la cabecera para que éstas recreen las condiciones de funcionamiento del mismo.
+
+```html
+
+```
+
+> [!! Importante] Es importante tener en cuenta que el código HTML no sigue el estándar puro de HTML5 por motivos de filosofía del desarrollador. Ésto se puede percibir con el autocierre de la etiqueta LINK, así como los atributos "data-" expuestos.
+
+También es importante mencionar que si se usa un servidor que permita la interpretación directa de archivos
+
+### Python
+
+Para poder integrar el lado de Python es necesario la tenencia local del archivo que se referencia contra el Git:
+
+- https://git.k3y.pw/Whalers/WMarkDown/src/branch/main/Python/WMarkDown.py
+
+Con dicho fichero nosotros seríamos libres de integrarlo como librería cara el usuario de ejecución o dentro de nuestro proyecto en cuestión.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/manual.w.md b/Public/doc/es/manual.w.md
new file mode 100644
index 0000000..769dc9d
--- /dev/null
+++ b/Public/doc/es/manual.w.md
@@ -0,0 +1,47 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_manual
+title_text = Manual - WMarkDown
+```
+
+
+
+## Manual
+
+Cara el modo de uso de esta tecnología contamos que parte de la idea de ser implementado en entornos Web, por lo que es totalmente compatible con HTML, es decir, que a parte de las propias funcionalidades del HTML que se le puedan dar de forma nativa, éste contará con otros elementos específicos del mismo basado en tecnologías como MarkDown o el lenguaje de marcas utilizado para el proyecto MediaWiki.
+
+> [!!] El resultado del proceso del WMarkDown, inicialmente será completamente HTML por lo que puede ser alterado mediante JavaScript, ECMAScript, SASS y CSS para personalizarlo al usuario.
+
+A continuación iremos detallando las diferentes marcas para dar lugar a cada uno de los elementos.
+
+[[include manual/paragraphs.w.md]]
+
+[[include manual/text_formats.w.md]]
+
+[[include manual/checks.w.md]]
+
+[[include manual/titles.w.md]]
+
+[[include manual/links.w.md]]
+
+[[include manual/color_sample.w.md]]
+
+[[include manual/tables.w.md]]
+
+[[include manual/lists.w.md]]
+
+[[include manual/quotes.w.md]]
+
+[[include manual/code_block.w.md]]
+
+[[include manual/presentation_links.w.md]]
+
+[[include manual/exclude.w.md]]
+
+[[include manual/includes.w.md]]
+
+[[include manual/dictionaries.w.md]]
+
+[[include manual/code_doc.w.md]]
+
+
\ No newline at end of file
diff --git a/Public/doc/es/manual/checks.w.md b/Public/doc/es/manual/checks.w.md
new file mode 100644
index 0000000..45d703f
--- /dev/null
+++ b/Public/doc/es/manual/checks.w.md
@@ -0,0 +1,38 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_checks
+title_text = Ticks, Checks y Radios - WMarkDown
+```
+
+
+
+### Ticks, Checks y Radios
+
+Los Ticks, Checkboxes y los Radio Buttons son elementos bastante básicos con los que trabajar en un apartado documental pues pueden ser indicativos de selección o marcas que determinan elementos seleccionados. A continuación se deja una tabla con las marcas y valor que representan.
+
+[[!]]
+
+[| class="wmd-checks-viewer"
+|=| Marca |
+|= Upper | Lower | Valor
+| \[ ] | \[ ] | [ ]
+| \[X] | \[x] | [x]
+| \[-] | \[-] | [-]
+| \( ) | \( ) | ( )
+| \(X) | \(x) | (x)
+| \(-) | \(-) | (-)
+| \{V} | \{v} | {v}
+| \{W} | \{w} | {w}
+| \{X} | \{x} | {x}
+|]
+
+> [!#] Estas marcas no están condicionadas entre sí como puede ser cuando se trabajan en formularios los Radio Buttons, lo que significa que son de libre uso.
+
+> [!!] Estas marcas ignoran si son en mayúsculas o minúsculas, es decir, que funcionarán independientemente de cómo se escriban.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/manual/code_block.w.md b/Public/doc/es/manual/code_block.w.md
new file mode 100644
index 0000000..a137d86
--- /dev/null
+++ b/Public/doc/es/manual/code_block.w.md
@@ -0,0 +1,131 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_checks
+title_text = Bloques de código - WMarkDown
+```
+
+
+
+### Bloques de código
+
+Los bloques de código están diseñados para poder mostrar códigos, Scripts, etc. De forma que el texto esté monoespaciado, con conteo de líneas y caracteres, así como visualización del número de línea donde te encuentras y con la posibilidad de ir visiblemente ayudado de un Syntax Highlighter. Básicamente viene siendo un bloque que se generará a nivel visual, a modo de caja donde se incluirá el código dado y formateado de la forma anteriormente descrita.
+
+> [!#] Los bloques de código siguen la filosofía de MarkDown por simplicidad a la hora de se implementados. Los bloques de código de MediaWiki son ignorados aquí por el hecho de que acaban siendo bloques HTML, cosa que ya se pueden integrar manualmente.
+
+'''wmd-examples
+
+A continuación se expone un bloque de HTML.
+
+```html
+Ejemplo
+Esto es un ejemplo de HTML .
+```
+
+'''
+
+Estos bloques también pueden ser usados para módulos que requieran de un bloque con las órdenes, parámetros o descripciones necesarias. Dichos módulos son los siguientes:
+
+- **math**, **maths** o **[[!mathjax]]**: El módulo "maths" o de matemáticas nos permite visualizar funciones y operaciones matemáticas a partir de código MathJax a partir de la librería "mathjax.js".
+- **mermaid** o **[[!mermaidjs]]**: Este módulo se utiliza para representar gráficos, flujos, esquemas, etc. A partir de la librería "mermaid.js".
+- **[[!wmd-examples]]**: Este módulo es específico para WMarkDown y nos permite hacer ejemplos dinámicos contra el cliente de textos formateados en WMarkDown.
+- **[[!wmd-options]]**: Este módulo nos permite especificar las opciones cara un documento WMarkDown, por lo general el título y el código de idioma utilizado.
+- **[[!wmd]]** o **[[!wmarkdown]]**: Vienen siendo bloques especiales que se ponen fuera de lo que son textos WMarkDown que identifican en un texto plano, bloques que han de ser procesados como WMarkDown.
+
+> [!!] Estos bloques se procesarán en el cliente pues no afecta inicialmente al SEO para su salida directa en HTML, por lo tanto, éstos aparecerán reflejados en HTML como bloques de código convencionales.
+
+'''wmd-examples
+
+A continuación tenemos un Script JS.
+
+```js
+console.log("Esto es un ejemplo de impresión por consola en JavaScript.");
+```
+
+Ahora mostramos un ejemplo de un flujo.
+
+```mermaid
+flowchart TD
+
+A["Elemento A"]
+B["Elemento B"]
+C["Elemento C"]
+
+A --> B
+B --> C
+
+```
+
+Finalmente, mostramos un ejemplo de función matemática.
+
+```maths
+# Ejemplo hallando el siguiente punto.
+(x_3, y_3) = (x_1, y_1) - (x_2, y_2)
+```
+
+'''
+
+También puede ser usado simplemente para representar texto plano.
+
+'''wmd-examples
+
+```txt
+Esto es un texto plano.
+```
+
+```
+Esto es otro texto plano sin nombre de formato.
+```
+
+```lenguaje-desconocido
+Al ser un lenguaje desconocido, éste saldrá también como texto plano.
+```
+
+'''
+
+Para poder representar los bloques de código tenemos varias marcas las cuales son las siguientes:
+
+[[!]]
+
+[| class="wmd-blocks-marks-viewer"
+|=| Marca
+|= Compactado | Espaciado
+| ``` | ` ` `
+| ''' | ' ' '
+| """ | " " "
+|]
+
+> [!?] **¿Por qué existen varias formas de llamar a los bloques de código?** Básicamente por versatilidad pues habrá lenguajes o fragmentos de código que se quieran representar y éstos contengan conjuntos de caracteres que puedan hacer conflicto con el propio bloque de código, por tanto, hay estas opciones para que el usuario pueda elegir entre ellas. Este es el motivo por el cual se pudo ejemplificar los bloques de código en el propio WMarkDown.
+
+Por otro lado, y terminando con los bloques de código, también hay un tipo de bloques de código especiales que son los *[[!wmd]]* o *[[!wmarkdown]]*, que nos sirven para identificar bloques de código WMarkDown para ser procesados dentro de un bloque de texto plano, como se explicó anteriormente. Normalmente se suelen poner en documentos directos como HTML para que éstos sean procesados parcialmente y ahorrar proceso y recursos, así como posibles errores y complicaciones.
+
+'''html
+
+Ejemplo de incrustación
+
+Esto es un bloque de código HTML normal.
+
+" " "wmd
+
+## Ejemplo
+
+Aquí empieza un bloque de código WMarkDown el cual será procesado en HTML, pero se ignorará lo que esté fuera de este bloque.
+
+```txt
+Ejemplo de bloque dentro de otro bloque, pero éste será procesado como bloque de código WMarkDown.
+```
+
+" " "
+
+Esto ya está fuera del dominio anterior.
+
+'''
+
+Los bloques de código incrustados, como el que vemos en este ejemplo también pueden ir encapsulados entre dos comentarios XML.
+
+<!-- \[\[[[!WMD]]]] -->
+
+Esto nos permite no salir del formato HTML ni XML en el IDE.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/manual/code_doc.w.md b/Public/doc/es/manual/code_doc.w.md
new file mode 100644
index 0000000..1f00293
--- /dev/null
+++ b/Public/doc/es/manual/code_doc.w.md
@@ -0,0 +1,62 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_code_doc
+title_text = Documentación de Código - WMarkDown
+```
+
+
+
+### Documentación de Código
+
+El módulo de Documentación de Código o Code Doc es un módulo que sirve para identificar elementos concretos dentro del código fuente del proyecto de forma genérica. Está basado en documentar funciones y métodos principalmente aunque permite más funciones que éstas. Las funciones y los métodos, en base a la filosofía de este módulo, están diseñadas en base a un entorno fuertemente tipado con estructuras de sobrecargas y argumentos opciones. Su estructura se basa en marcas que identifican las diferentes partes.
+
+```wmd-examples
+
+[[@ [String] WMarkDown.process(!String data, Integer lanuage = 1, ?String path = null)]]
+
+[[@ [String] WMarkdown.analyse(!String data, Integer language = 1, Integer mode = 0, ?String path = null)]]
+
+```
+
+El módulo crearía una capa adaptada al espacio del párrafo el cual tendría el bloque de llamada explicado a nivel de código y una tabla con los argumentos definidos de una forma simplificada para ayudar en su comprensión.
+
+La sintaxis es sencilla, parte de lo siguiente:
+
+* **Tipado de respuesta**: Es un elemento opcional comprendido entre corchetes que determina el tipado de respuesta. Si no se especifica, por defecto será **void** (Vacío).
+* **Acceso**: Es un elemento opcional que determina el acceso a dicho elemento, donde si no se nombra se entenderá como elemento público, pero sino, indicaría lo siguiente:
+ * **Privado**: Determina que el elemento del que se habla tiene acceso únicamente privado y se representa mediante el caracter "**!**".
+ * **Protegido**: Determina que el elemento del que se habla tiene acceso protegido por su herencia y se representa mediante el caracter "**?**".
+* **Espacio de nombres**: Es un elemento opcional que determina el espacio de nombres para llegar hasta éste, ya sea por nombre de Clase, por el propio espacio de nombres, o ambos juntos como puede suceder en PHP.
+* **Ámbito**: Es un elemento opcional que determina el la separación entre el espacio de nombres y el nombre del elemento se separan por un caracter el cual indica uno de estos dos casos.
+ * **Objeto**: Se indica con un punto ("**.**") e indica que parte de la creación de un objeto a partir de la clase que lo nombra. En caso de no haber nombre
+ * **Estático**: Se indica con dos puntos ("**:**") e indica que parte de la clase que lo nombra.
+* **Método** o **Elemento**: Nombre del método o elemento al que se hace referencia.
+* **Argumentos**: Bloque opcional que se especifica únicamente en caso de ser un método o una función, entre paréntesis tendrá los argumentos de entrada. Cada argumento tendría lo siguiente:
+ * **Obligatorio**: El primer elemento es opcional e indica si es opcional u obligatorio donde si hay al inicio del argumento un cierre de exclamación ("**!**") indica que es obligatorio, sino nos indica que es opcional.
+ * **Nulleable**: El segundo elemento es opcional e indica si es nulleable o no donde si hay al inicio del argumento un cierre de interrogación ("**?**") indica que es nulleable, sino, no admite valores nulos.
+ * **Tipado**: El tercer elemento es obligatorio e indica el tipado del argumento.
+ * **Nombre**: El cuarto elemento es obligatorio e indica el nombre del argumento.
+ * **Valor por defecto**: El quinto elemento es opcional y especifica el valor por defecto que tiene ese argumento. Sólo se especifica para argumentos opcionales cuando éstos tienen un valor por defecto. Se identifica por ir separado con el signo igual ("**=**") del nombre hasta la coma que lo separa. En caso de ser un String, diccionario o Array se identifica su final con el cierre del mismo.
+* **Valor por defecto**: Bloque opcional diseñado para valores de variables y constantes que representa su valor por defecto. Se distingue de los argumentos mediante la separación con el nombre del método con el caracter iguale ("**=**").
+
+> [!!] El Espacio de nombres y el Ámbito van juntos, es decir, si se especifican han de existir los dos, si no, no se ha de especificar ninguno de los dos.
+
+> [!!] Puede haber más de un tipado alternativo. Éstos se separan con el caracter tubería ("**|**").
+
+Cara los tipados, el nombre que se le dé dependerá del desarrollador y del propio nombre de las clases de los que parten los posibles objetos, sin embargo, hay que destacar que se espera encapsulados entre diamantes en casos de ser Vectores o definición de diccionarios y/o objetos.
+
+```wmd-examples
+
+
+[[@ [Array>] ejemplo]]
+
+```
+
+> [!#] Cuando hablamos de variables o métodos y funciones que no tienen argumentos, la tabla de definición de argumentos no aparecerá, o en caso de ser alterado el CSS original del WMarkDown, saldrá vacía.
+
+> [!#] Para especificar valores nulos o cualquier valor aconsejamos, por mantener un estándar basado en JSDoc \(No se sigue plenamente la filosofía de JSDoc, pero si se basa bastante en ésta) el uso de **Null** y **Any** consecutivamente. También destacar que Any no representa entre sus valores ni a Null ni a "undefined" en el caso de JavaScript.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/manual/color_sample.w.md b/Public/doc/es/manual/color_sample.w.md
new file mode 100644
index 0000000..bbcfd7a
--- /dev/null
+++ b/Public/doc/es/manual/color_sample.w.md
@@ -0,0 +1,33 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_color_sample
+title_text = Muestra de color - WMarkDown
+```
+
+
+
+### Muestra de color
+
+Las muestras de color no son más que unas cajitas para mostrar un color concreto de una forma rápida y ágil.
+
+```wmd-examples
+
+Esta muestra [[#F00]] es el color rojo.
+
+Esta muestra [[#FF0000]] es el color rojo.
+
+Esta muestra [[#f00]] es el color rojo.
+
+Esta muestra [[color rgb(255, 0, 0)]] es el color rojo.
+
+Esta muestra [[color red]] es el color rojo.
+
+Esta muestra [[color #F00]] es el color rojo.
+
+```
+
+> [!!] Es cierto que tenemos la capacidad de poner bloques de color vía HTML, ya sea con la etiqueta SPAN o DIV, pero esta forma es más eficiente y permite que sin tener conocimientos de HTML poder aplicar colores sólo a su nombre en inglés, código hexadecimal o RGB y RGBA.
+
+Las muestras de color se pueden poner simplemente entre dobles corchetes si éstas son hexadecimal; o bien, entre corchetes se nombra "color" y luego, separado por espacio o tabulación, el código de color, independientemente de ser hexadecima, RGB, RGBA, HLS o HLSA; así como con el nombre del color en inglés.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/manual/dictionaries.w.md b/Public/doc/es/manual/dictionaries.w.md
new file mode 100644
index 0000000..609ac61
--- /dev/null
+++ b/Public/doc/es/manual/dictionaries.w.md
@@ -0,0 +1,69 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_dictionaries
+title_text = Diccionarios - WMarkDown
+```
+
+
+
+### Diccionarios
+
+Los diccionarios en WMarkDown son una herramienta para ayudar a escribir sin preocuparse en definir elementos que puedan resultar complejos, profesionales o simples interpretaciones. La idea simplemente es la creación de un diccionar JSON el cual será cargado y en base a los patrones establecidos éste los implementará en los textos del propio WMarkDown para que el usuario, al Clickar en dichos elementos les salga qué es para ti, además de permitir el muestreo de definiciones de forma anidada.
+
+La implementación de los diccionarios es automática siempre que se le halla dado algún archivo de diccionario. Si éste no fue dado, los diccionarios no se post-procesarán.
+
+El formato JSON de los diccionarios viene siendo un Array donde se implementará en cada elemento del mismo un término, y los términos tendrían un formato también de Array donde:
+
+1. **Patrón y corrección**: Éste puede ser un único Array con un patrón regular y el texto corregido que quieres que se tenga uniformemente; o bien, un Array de elementos los cuales, como antes, sería un Array con un patrón y el texto corregido que quieres que se tenga uniformemente.
+2. **Definición**: Viene siendo la definición, el cual puede ser un simple String o un Array para poder hacer saltos de línea.
+3. **Links**: Links de interés tanto para más información como Webs oficiales y proyectos.
+
+Un ejemplo de ésto puede ser el siguiente:
+
+```json
+[[
+ [
+ ["/\\bwmarkdown\\b/ig", "WMarkDown"],
+ ["/\\b(wmd\\b|w\\.m\\.d\\.|w\\. +m\\. +d\\. +)/ig", "WMD"]
+ ], [
+ "El WMarkDown es un proyecto que nos permite hacer documentación y textos ",
+ "formateados desde un lenguaje de marcas sencillo que parte como idea de ",
+ "lenguajes de marcas como MarkDown y MediaWiki, personalizado a usos más ",
+ "extensos, flexibles y fáciles."
+ ], [
+ "https://wmarkdown.k3y.pw/",
+ "https://git.k3y.pw/Whalers/WMarkDown"
+ ]
+], [
+ ["/\\bmedia *wiki\\b/gi", "MediaWiki"], [
+ "MediaWiki es un proyecto Free Open Source que viene siendo la base de Webs ",
+ "como Wikipedia entre otros, el cual permite gestionar publicaciones y ",
+ "documentación en un entorno flexible, abierto y extendido con una gran ",
+ "comunidad que lo sustenta."
+ ], [
+ "https://www.mediawiki.org/",
+ "https://es.wikipedia.org/wiki/MediaWiki",
+ "https://github.com/wikimedia/mediawiki"
+ ]
+], [
+ [
+ ["/\\bmarkdown\\b/gi", "Markdown"],
+ ["/(? [!!] Si nos fijamos en el ejemplo, los patrones utilizados se basan en patrones regulares de JavaScript. El propio WMarkDown se encargará de adaptarlo al entorno correspondiente, pero es importante seguir este sistema.
+
+Este ejemplo busca patrones que tengan que ver con WMarkDown, MediaWiki y Markdown, marcando en el texto procesado como elementos consultables y los cuales desplegarán un elemento flotante a su altura con la información requerida.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/manual/exclude.w.md b/Public/doc/es/manual/exclude.w.md
new file mode 100644
index 0000000..7e975d6
--- /dev/null
+++ b/Public/doc/es/manual/exclude.w.md
@@ -0,0 +1,27 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_exclude
+title_text = Módulo de exclusión - WMarkDown
+```
+
+
+
+### Módulo de exclusión
+
+El módulo de exclusión está diseñado para ignorar fragmentos de texto para que éstos no se representen con marcas. Esto es muy importante para poder representar bloques de HTML, ejemplos o simplemente, exponer fragmentos de texto con caracteres que pertenecen a las marcas. Hay dos formas de excluir estos elementos.
+
+```wmd-examples
+
+Exclusión completa de un texto.
+
+[[!Esto es un bloque de texto excluído, y esto [x] no es un Checkbox seleccioando. Tampoco funcionará el diccionario.]]
+
+Exclusión de caracteres.
+
+Esto es un texto no excluído y esto [x] sí es un Checkbox seleccionado, pero \[x] esto ya no lo es. Aquí sí funcionaría el diccionario.
+
+```
+
+> [!!] Es importante mencionar que los Slashes escapan sólo una serie de caracteres pues en la anterior versión escapaban todo tipo de caracteres y podía llegar a complicar ciertas cosas. Actualmente está la filosofía de que si hay algo que requiere de escaparse constantemente implica que está mal, por lo que la limitación de caracteres escapados ha de ser mínima.
+
+
diff --git a/Public/doc/es/manual/includes.w.md b/Public/doc/es/manual/includes.w.md
new file mode 100644
index 0000000..64df2e5
--- /dev/null
+++ b/Public/doc/es/manual/includes.w.md
@@ -0,0 +1,35 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_includes
+title_text = Inclusiones - WMarkDown
+```
+
+
+
+### Inclusiones
+
+Una de las características principales de WMarkDown es la capacidad de éste para poder integrar dentro de sí mismo otros recursos externos, por ejemplo, otro archivo HTML, MarkDown o WMarkDown, permitiendo así poder gestionar una documentación ordenada a partir de directorios y ficheros y a la par, poder crear OnePages donde visualizar dicho contenido. Para poder llevar a cabo dicha tarea podemos seguir el siguiente ejemplo:
+
+```wmd-examples
+
+## Ejemplo inclusión
+
+Esto es un párrafo de presentación del título donde nos encontramos.
+
+[[include otro.fichero.w.md]]
+
+Ahora podemos continuar con nuestro fichero habiendo incluído el contenido del fichero "otro.fichero.w.md".
+
+```
+
+De esta forma podemos integrar dentro de nuestro documento diferentes ficheros con el fin de tenerlos ordenados para su trabajo así como generar documentación OnePage para facilitar la accesibilidad a los usuarios a ésta.
+
+Las inclusiones crean secciones o bloques donde se meterá todo su contenido a modo de capa, y las inclusiones de primer nivel tendrán un link que permita ir al documento en cuestión. Con esto se entiende que se permite el anidamiento de inclusiones de archivos.
+
+> [!!] Es importante destacar que se pueden producir **bucles infinitos** cuando un fichero llama a otro el cual llama al primero de forma directa o indirecta. Es muy importante controlar este proceso de forma adecuada y correcta.
+
+> [!!] También es importante destacar que los **títulos anidados** tendrán su valor de origen pudiendo dar lugar a problemas si no se gestionan de una forma adecuada.
+
+> [!!] Por otro lado, decir que los Links que genera para ir a la página o documento a la que hace referencia sólo se mostrará en las de primer nivel porque dichos **Links** son **dinámicos a su punto de origen** donde si el origen es un elemento incluído anidadamente éste podría alojar un Path erróneo.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/manual/links.w.md b/Public/doc/es/manual/links.w.md
new file mode 100644
index 0000000..6218926
--- /dev/null
+++ b/Public/doc/es/manual/links.w.md
@@ -0,0 +1,77 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_links
+title_text = Links o enlaces - WMarkDown
+```
+
+
+
+### Links o enlaces
+
+Para identificar o marcar un Link o enlace en WMarkDown, tenemos varias opciones según nos convenga en su momento, ya sea por comodidad o necesidad. En nuestro caso tenemos los estándares de MarkDown y MediaWiki, así como un sistema propio y detección automática de enlaces mediante búsqueda de protocolos de red con su división al Path, URL o código que lo sigan "://", de esta forma podemos identificar protocolos como:
+
+- FILE.
+- HTTP y HTTPS.
+- FTP y FTPS.
+- SFTP, SSH, etc.
+- Etcétera.
+
+Así pues, contando con los distintos métodos que tenemos para generar Links nos encontramos con los siguientes modos.
+
+> [!!] Para poder ignorar un Link el cual no se quiere que aparezca o que posiblemente se haga uso de un texto el cual no sea un Link hemos de usar las marcas para ignorar el formato de fragmentos de texto que se relata en el [/doc/es/exclude.w.md Módulo de Exclusión] o "[/doc/es/exclude.w.md Ignore]". También se puede hacer uso de los escapes o de código Ampersand para impedir que dichos contenidos se vean afectados.
+
+> [!!] Es importante mencionar que los Links, teóricamente no deben de contener espacios, motivo por el cual, si éstos poseen espacios, como pueden ser los casos de los números de teléfono, en el propio enlace éstos se compactarán, aunque se mostrará íntegramente como se hallan escrito por el usuario.
+
+#### Link directo
+
+Al escribir un Link identificable mediante protocolo o por si es un elemento como una dirección E-Mail, éste puede ser escrito de forma directa.
+
+```wmd-examples
+
+Aquí te pongo un Link directo: https://wmarkdown.k3y.pw/
+
+También se puede hacer un Link directo de una dirección de E-Mail tal como kyman-ficticio@wmarkdown.k3y.pw
+
+```
+
+> [!!] Es importante destacar que este modo de trabajo no permite definirle un texto directo al enlace quedando únicamente el propio texto del enlace como texto tanto de título como de muestreo.
+
+> [!! ¡OJO!] En este caso, por ejemplo, en un párrafo el cual acabe en un signo como el punto o la coma, si éste va pegado al Link éste lo entenderá como parte del mismo.
+
+#### Link MediaWiki
+
+El Link de MediaWiki se integra a partir de apertura y cierre de corchetes de forma directa, y todo lo que se comprenda ahí dentro se entenderá como Link. También hay que destacar que si hay un espacio éste se entenderá como separador del texto que se quiere que represente el Link. Este modo también distingue ciertos protocolos como el de los teléfonos.
+
+```wmd-examples
+
+Web de [https://wmarkdown.k3y.pw/].
+
+Para ver más información, por favor, presione [https://wmarkdown.k3y.pw/ aquí].
+
+Esto es un número de teléfono [+65 9127 92 35 533] y este es otro [723 564 123] y este el mismo de antes pero más obfuscado [723564123].
+
+Y esto es una dirección E-Mail [kyman-ficticio@wmarkdown.k3y.pw].
+
+También puedes poner direcciones como Cryptomonedas como [bitcoin:tb1qujswuek3mefsm3m84g94ek40drysxe9z09yfnc tb1qujswuek3mefsm3m84g94ek40drysxe9z09yfnc] o [litecoin:tltc1q4xy8sg2hf6nqqrhp69aukn6md3rx8v6jlqc67s tltc1q4xy8sg2hf6nqqrhp69aukn6md3rx8v6jlqc67s] entre otras.
+
+```
+
+#### Link MarkDown
+
+El Link MarkDown es el Link más complejo. Por su versatilidad fue integrado pero por la complejidad hubo dudas a la hora de integrarlo. Éste se basa en un bloque opcional comprendido entre corchetes que contempla el texto que se quiere que aparezca; luego el Link entre paréntesis el cual, dentro del paréntesis puede ir acompañado de tras un espacio o tabulación, de forma opcional, ya sea entre comillas simples dobles o nada, un texto que sea el título que se presente con el puntero.
+
+```wmd-examples
+
+Web de (https://wmarkdown.k3y.pw/).
+
+Para ver más información, por favor, presione [aquí](https://wmarkdown.k3y.pw/ Link a WMarkDown.).
+
+Esto es un número de teléfono [+65 9127 92 35 533](tel:+6591279235533 Un teléfono inventado xD) y este es otro [723 564 123](723 564 123 También admite espacios.) y este el mismo de antes pero más obfuscado [723564123](723564123).
+
+Y esto es una dirección E-Mail [kyman-ficticio@wmarkdown.k3y.pw].
+
+También puedes poner direcciones como Cryptomonedas como [tb1qujswuek3mefsm3m84g94ek40drysxe9z09yfnc](bitcoin:tb1qujswuek3mefsm3m84g94ek40drysxe9z09yfnc Dirección Bitcoin TestNet) o [tltc1q4xy8sg2hf6nqqrhp69aukn6md3rx8v6jlqc67s](litecoin:tltc1q4xy8sg2hf6nqqrhp69aukn6md3rx8v6jlqc67s Dirección Litecoin TestNet) entre otras.
+
+```
+
+
\ No newline at end of file
diff --git a/Public/doc/es/manual/lists.w.md b/Public/doc/es/manual/lists.w.md
new file mode 100644
index 0000000..cb9cdb9
--- /dev/null
+++ b/Public/doc/es/manual/lists.w.md
@@ -0,0 +1,186 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_lists
+title_text = Listas - WMarkDown
+```
+
+
+
+### Listas
+
+Los listas en WMarkDown se basan en una mezcla entre lo que son las listas crudas de MarkDown así como en las listas de MediaWiki, con un concepto de personalización para determinar si un elemento está contraído o no, permitiendo así controlar la visualización inicial de la lista.
+
+> [!!] Es importante mencionar que la visualización de los elementos compactados depende plenamente de que JavaScript esté habilitado en el navegador pues por defecto no se mostrarán y las acciones dinámicas dependerán plenamente de que éste esté habilitado.
+
+Partiendo de la idea de MarkDown para la gestión de Listas y sus marcas alternativas se creó un subprotocolo que condiciona qué marca se usar'para qué fin pues no todas las marcas funcionan igual, además, éste sistema altera la guía de buenas prácticas de MarkDown pues éste dice de usar siempre la misma marca en la misma lista o nivel de la misma, mientras que aquí se podrá ir alternando según intereses. Las marcas con sus significados son los siguientes:
+
+- *****: El asterisco nos indica una lista desordenada estándar, sin posibilidad de desplegar o compactar.
+- **+**: El signo más nos dice que será una lista desordenada y que ésta estará desplegada por defecto con opción a compactar.
+- **−**: El signo menos nos dice que será una lista desordenada y que ésta estará compactada por defecto con opción a desplegar.
+- **#**: El signo comodín, o sostenido o numérico indica que será una lista ordenada mediante números que parten del valor "1".
+- **1.**: Cualquier número seguido de un punto nos indica una lista ordenada numérica cuyo valor inicial será el del primer elemento puesto.
+- **a.**: Cualquier letra, a excepción de la letra **i** latina, seguida de un punto nos indica que será una lista ordenada alfabéticamente. Éste puede ser en mayúsculas para indicar que las letras sean mayúsculas, o minúsculas para lo contrario.
+- **i.**: Un número romano seguido de un punto nos indica que la lista será ordenada con números romanos. Si éstos están en mayúsculas aparecerán en mayúsculas, y si son en minúsculas, éstos aparecerán en minúsculas.
+
+> [!!] En el caso de los elementos ordenados, éstos seguirán las pautas única y exclusivamente del primer elemento dado. Si por el medio se hacen saltos, se repiten o se mantienen valores, así como si se integran marcas de listas desordenadas, éstas continuarán su orden interpretando corrección del usuario.
+
+Los tipos de listas que hay se pueden ver reflejadas en los siguientes ejemplos:
+
+```wmd-examples
+
+Ejemplo de lista desordenada:
+
+* Elemento 1.
+* Elemento 2.
+* Elemento 3.
+* Elemento 4.
+* Elemento N.
+
+Ejemplo de lista ordenada numérica:
+
+# Elemento 1.
+# Elemento 2.
+# Elemento 3.
+# Elemento 4.
+# Elemento N.
+
+Ejemplo de lista ordenada con inicio en otro valor que no sea uno.
+
+4. Elemento 1.
+5. Elemento 2.
+6. Elemento 3.
+7. Elemento 4.
+8. Elemento N.
+
+La lista anterior sería igual que hacer lo siguiente:
+
+4. Elemento 1.
+4. Elemento 2.
+4. Elemento 3.
+4. Elemento 4.
+4. Elemento N.
+
+O incluso lo siguiente:
+
+4. Elemento 1.
+# Elemento 2.
+# Elemento 3.
+# Elemento 4.
+# Elemento N.
+
+```
+
+Las listas se pueden anidar, lo que hacen que crezcan en árbol. Para ello tenemos tanto la filosofía base de MarkDown mediante espacios y/o tabulaciones; como la filosofía de MediaWiki mediante el conjunto de marcas que determinan el nivel del elemento dentro de la lista.
+
+```wmd-examples
+
+Listas anidadas por el método de MarkDown.
+
+* Elemento 1.
+* Elemento 2.
+ * Elemento 2-1.
+ * Elemento 2-2.
+ * Elemento 2-2-1.
+ * Elemento 2-3.
+* Elemento 3.
+* Elemento 4.
+ * Elemento 4-1.
+* Elemento N.
+
+Listas anidadas por el método de MediaWiki.
+
+* Elemento 1.
+* Elemento 2.
+** Elemento 2-1.
+** Elemento 2-2.
+*** Elemento 2-2-1.
+** Elemento 2-3.
+* Elemento 3.
+* Elemento 4.
+** Elemento 4-1.
+* Elemento N.
+
+Ambas darán el mismo resultado.
+
+```
+
+Dentro de las listas anidadas hay dos marcas que permiten controlar si salen compactadas o desplegadas, lo que determina también que serían compactables o desplegables por el usuario final.
+
+```wmd-examples
+
+* Elemento 1. Elemento desplegado pero no desplegable o compactable.
+ * Elemento 1-1.
+ * Elemento 1-2.
+ * Elemento 1-3.
+- Elemento 2. Elemento desplegable que por defecto está plegado.
+ * Elemento 2-1.
+ + Elemento 2-2. Elemento desplegable, desplegado por defecto.
+ * Elemento 2-2-1.
+ - Elemento 2-3. Elemento desplegable que por defecto está plegado.
+ * Elemento 2-3-1.
+* Elemento 3.
++ Elemento 4. Elemento desplegable que por defecto está desplegado.
+ * Elemento 4-1.
+* Elemento N.
+
+```
+
+> [!!] Como podemos observar, la guía de las buenas prácticas de MarkDown cara las listas, con este concepto se rompe.
+
+También se pueden anidar listas ordenadas y desordenadas entre sí.
+
+```wmd-examples
+
+Ejemplo en filosofía MarkDown.
+
+* Elemento 1.
+* Elemento 2.
+ # Elemento 2-1.
+ # Elemento 2-2.
+ * Elemento 2-2-1.
+ # Elemento 2-3.
+* Elemento 3.
+* Elemento 4.
+ # Elemento 4-1.
+* Elemento N.
+
+Ejemplo en filosofía MediaWiki.
+
+* Elemento 1.
+* Elemento 2.
+*# Elemento 2-1.
+*# Elemento 2-2.
+*#* Elemento 2-2-1.
+*# Elemento 2-3.
+* Elemento 3.
+* Elemento 4.
+*# Elemento 4-1.
+* Elemento N.
+
+```
+
+Mediante la filosofía de poder cambiar la marca tanto en una lista ordenada como desordenada, a excepción del primer valor de las listas ordenadas, en una lista ordenada se pueden establecer elementos plegados y desplegados.
+
+```wmd-examples
+
+4. Elemento 1.
++ Elemento 2.
+ # Elemento 2-1.
+ # Elemento 2-2.
+ # Elemento 2-3.
+* Elemento 3.
+ # Elemento 3-1.
+ # Elemento 3-2.
+ # Elemento 3-3.
+- Elemento 4.
+ # Elemento 4-1.
+ # Elemento 4-2.
+ # Elemento 4-3.
+* Elemento N.
+ # Elemento N-1.
+ # Elemento N-2.
+ # Elemento N-3.
+
+```
+
+
\ No newline at end of file
diff --git a/Public/doc/es/manual/paragraphs.w.md b/Public/doc/es/manual/paragraphs.w.md
new file mode 100644
index 0000000..85abebe
--- /dev/null
+++ b/Public/doc/es/manual/paragraphs.w.md
@@ -0,0 +1,22 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_paragraphs
+title_text = Párrafos - WMarkDown
+```
+
+
+
+### Párrafos
+
+Para poder crear párrafos, simplemente hemos de crear textos separados por doble salto de línea al menos. Un único salto entre líneas se considerará parte del mismo párrafo.
+
+```wmd-examples
+Esto es un párrafo.
+
+Esto es otro párrafo.
+Esto sigue siendo parte de éste segundo párrafo.
+
+Este es un tercer párrafo.
+```
+
+
\ No newline at end of file
diff --git a/Public/doc/es/manual/presentation_links.w.md b/Public/doc/es/manual/presentation_links.w.md
new file mode 100644
index 0000000..e0e68e7
--- /dev/null
+++ b/Public/doc/es/manual/presentation_links.w.md
@@ -0,0 +1,64 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_presentation_links
+title_text = Módulo de Links de presentación - WMarkDown
+```
+
+
+
+### Módulo de Links de presentación
+
+Este módulo está orientado a facilitar una presentación visual y estética de elementos.
+
+> [!#] Este módulo nació con la idea de presentar proyectos externos de los que depende el proyecto actual que se documenta mediante WMarkDown; lenguajes de programación y tecnologías usadas; o bien, para mostrar proyectos que hacen uso público de la tecnología que se presenta. Es un poco a modo de créditos pero se puede usar para otras muchas cosas, como presentación de usuarios, personas, miembros, etc.
+
+Este elemento consta de 3 partes:
+
+* **Título**: Viene siendo un texto de presentación o nombre del elemento en cuestión.
+* **Avatares**: Links a imágenes que representen dicho elemento. Éste permite más de una imagen pues, en orden vertical irá cogiendo el primero que le salga sin error. Al ser normalmente un recurso externo, éste puede fallar, por lo que teniendo más de una opción, éste tendrá más dificultades a que falle.
+* **Links**: Los Links son enlaces a Webs, ya sean oficiales, de información o de proyectos, entre otros, que se le pueden vincular. Por defecto, el icono del Link será el favicon del sitio Web al que se hace referencia.
+
+Para definir cada uno de los elementos, basándose en la estructura sintáctica de Python, se usarán líneas, las cuales determinan que si no tienen espacios de inicio es el título; si empieza con un asterísco es una opción para avatar; y si no, sería un Link de referencia.
+
+```wmd-examples
+
+El siguiente bloque sería un ejemplo de este módulo:
+
+[["""
+AnP
+ *https://anp.k3y.pw/images/AnP.png
+ *https://anp.k3y.pw/images/AnP-512.png
+ *https://anp.k3y.pw/favicon.ico
+ https://anp.k3y.pw/
+ https://git.k3y.pw/AnP/AnP
+CDN de KyMAN
+ *https://cdn.k3y.pw/images/CDN.png
+ *https://cdn.k3y.pw/images/CDN-512.png
+ *https://cdn.k3y.pw/favicon.ico
+ https://cdn.k3y.pw/
+ https://git.k3y.pw/KyMAN/CDN
+ErrorsManager
+ *https://errorsmanager.k3y.pw/images/ErrorsManager.png
+ *https://errorsmanager.k3y.pw/images/ErrorsManager-512.png
+ *https://errorsmanager.k3y.pw/favicon.ico
+ https://errorsmanager.k3y.pw/
+ https://git.k3y.pw/KyMAN/ErrorsManager
+Kanvas
+ *https://kanvas.k3y.pw/images/Kanvas.png
+ *https://kanvas.k3y.pw/images/Kanvas-512.png
+ *https://kanvas.k3y.pw/favicon.ico
+ https://kanvas.k3y.pw/
+ https://git.k3y.pw/KyMAN/Kanvas
+MuWeb
+ *https://muweb.k3y.pw/images/MuWeb.png
+ *https://muweb.k3y.pw/images/MuWeb-512.png
+ *https://muweb.k3y.pw/favicon.ico
+ https://muweb.k3y.pw/
+ https://git.k3y.pw/KyMAN/MuWeb
+"""]]
+
+```
+
+> [!!] Para describir alguna cosa concreta de alguno de estos elementos ha de hacerse fuera del módulo.
+
+
diff --git a/Public/doc/es/manual/quotes.w.md b/Public/doc/es/manual/quotes.w.md
new file mode 100644
index 0000000..95726bc
--- /dev/null
+++ b/Public/doc/es/manual/quotes.w.md
@@ -0,0 +1,55 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_quotes
+title_text = Quotes y comentarios - WMarkDown
+```
+
+
+
+### Quotes o comentarios
+
+Los Quotes o comentarios vienen siendo fragmentos de texto que se usan generalmente para matizar cosas dentro de lo que se quiera decir, remarcar información o simplemente añadir notas adicionales.
+Para referenciar el bloque Quote hemos de encabezar el párrafo mediante el caracter ">", lo que determinará que es un comentario o fragmento de texto explicativo.
+
+```wmd-examples
+Esto es un párrafo normal.
+
+> Esto es un Quote o comentario.
+
+Esto es otro párrafo normal.
+
+> Esto es otro Quote.
+Esto pertenece al mismo Quote.
+
+> Esto es otro Quote distinto.
+
+```
+
+Los Quotes tienen 3 modos: los comentarios comunes añadidos o notas; lo mismo pero con iconificación de contenido para advertencias, preguntas, respuestas, etc., el cual puede ser personalizado a la Web en cuestión; y como comentario de usuarios específicos, que requiere de registrar a los usuarios en el propio gestor WMarkDown.
+
+```wmd-examples
+> Esto es un comentario común o nota.
+
+> [!comment] Esto es lo mismo que lo anterior pero iconificado.
+
+> [!#] Esto es exactamente lo mismo que lo anterior pero simplificado.
+
+> [!# Comentario] Esto es lo mismo que lo anterior pero aclarando que es un comentario. El resultado se verá visualmente.
+
+> [!!] Esto es una advertencia o nota importante.
+
+> [!Q] Esto es un comentario directo.
+
+> [!?] Esto es para realizar preguntas dentro del texto.
+
+> [!>] Esto es para responder preguntas.
+
+> [!icono_personalizado Personalizado] Esto es un Quote con icono personalizado y con texto que advierte de que es un contenido personalizado.
+
+> [!@Usuario] Esto es un Quote a modo de comentario específico a una persona registrada.
+
+```
+
+Todos los los elementos pueden ser personalizables y nombrables.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/manual/tables.w.md b/Public/doc/es/manual/tables.w.md
new file mode 100644
index 0000000..fc7225d
--- /dev/null
+++ b/Public/doc/es/manual/tables.w.md
@@ -0,0 +1,73 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_tables
+title_text = Tablas - WMarkDown
+```
+
+
+
+### Tablas
+
+Las tablas en WMarkDown no siguen ningún estandar concreto pues desde WMarkDown las consideramos altamente ineficientes, muy posiblemente por desconocimiento pero hemos hecho algunos cambios que tiran más hacia MediaWiki que a Markdown, aun así, el parecido y la funcionalidad son similares.
+
+Teniendo en cuenta que tanto a nivel de texto plano sobre WMarkDown como a nivel gráfico proceso han de ser altamente visibles, así cmo simplificar en la medida de lo posible la composición de una de éstas, se hizo de la siguiente forma.
+
+```wmd-examples
+
+A continuación montaremos una tabla.
+
+[| class="jojo"
+|^ Cabecera 1 | Cabecera 2 | Cabecera 3 | Cabecera N
+|= Título 1 | Título 2 | Título 3 | Título N
+| Elemento 1 | Elemento 2 | Elemento 3 | Elemento N
+| Elemento 1 | Elemento 2 | Elemento 3 | Elemento N
+| Elemento 1 | Elemento 2 | Elemento 3 | Elemento N
+|_ Pie 1 | Pie 2 | Pie 3 | Pie N
+|]
+
+```
+
+Como podemos observar, las tablas se abren mediante corchete y exclamación, donde la primera línea nos permite poner atributos a la misma, pero a nivel de la etiqueta TABLE en HTML. Por otro lado, tenemos los títulos, que se hacen a partir de acento circunflejo ("^") para indicar que será para la cabecera; el guión bajo ("_") para indicar que es para el pie de página; y el igual ("=") que indica que es para ambos. Las cabecerás se irán creando verticalmente según aparezcan en la tabla y no tienen que ir en ninguna posición específica.
+
+Por otro lado, decir que se puede hacer Span de las columnas, es decir, unir dos o más columnas de una forma visual y sencilla. Para ello se unirán tuberías, caracter que divide cada columna. Si no hay espacios ni nada que las separe, éstas se unirán en una única celda en esa tupla concreta.
+
+```wmd-examples
+
+[|
+|= Columna 1 | Columna 2 | Columna 3 | Columna 4 | Columna 5
+| Columna 1 | Columna 2 | Columna 3 | Columna 4 | Columna 5
+||| Columna 1-3 | Columna 4 | Columna 5
+| Columna 1 | *Columna* 2 ||| Columna 3-5
+| Columna 1 || Columna 2-3 | [https://wmarkdown.k3y.pw/#tablas Columna 4] | Columna 5
+|]
+
+```
+
+> [!#] Los Span o uniones de columnas en una celda se pueden realizar tanto en los títulos como en el cuerpo.
+
+> [!!] También hay que destacar que hay que controlar bien el número de columnas por fila para que éstas sean igual y comunes en todas.
+
+> [!!] Es importante destacar también que las celdas también serán formateadas según los parámetros de WMarkDown, como las negrillas u otras marcas que pueda haber en éstas.
+
+Finalmente, también decir que se pueden hacer celdas que pueden tener saltos de línea. Ésto se puede llevar a cabo mediante comillas tanto dobres como simples.
+
+```wmd-examples
+
+[|
+|= Columna 1 | Columna 2 | Columna 3
+| Celda 1-A | Celda 2-A | Celda 3-A
+| Celda 1-B | "Celda 2-B
+
+Esto es más contenido de la celda 2-B." | Celda 3-B
+| Celda 1-C | 'Celda 2-C
+
+Esto es más contenido de la celda 2-C.' | Celda 3-C
+|]
+
+```
+
+> [!!] Es importante destacar que las celdas se consideran subelementos, es decir, no son considerados elementos de bloque como párrafos o similares y quedan plenamente condicionadas a subelementos de bloque, por eso, en el ejemplo aquí mostrad, pese a haber doble salto de línea, éste permanece como una única línea.
+
+> [!!] Es importante mencionar también que si un texto empieza y acaba por comillas dobles o comillas simples, éstas se omitirán en el resultado final pues se entenderá que son conjuntos para gestionar en multilínea.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/manual/text_formats.w.md b/Public/doc/es/manual/text_formats.w.md
new file mode 100644
index 0000000..1307a0e
--- /dev/null
+++ b/Public/doc/es/manual/text_formats.w.md
@@ -0,0 +1,44 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_text_formats
+title_text = Formatos de texto - WMarkDown
+```
+
+
+
+### Formatos de texto
+
+Los formatos de texto en WMarkDown se pueden generar de una forma muy básica a partir de marcas. Los más habituales son los que se representan en el siguiente ejemplo:
+
+```wmd-examples
+
+- *Esto es un texto en cursiva.*
+- **Esto es un texto en negrilla.**
+- ~~Esto es un texto tachado.~~
+- __Esto es un texto subrayado.__
+- ``Esto es un bloque de código o texto monospaciado como tal.``
+- ***Esto es un texto negrilla y cursiva.***
+- ~~*Esto es un texto tachado y en cursiva.*~~
+- ~~**Esto es un texto tachado y en negrilla.**~~
+- ~~***Esto es un texto tachado, en negrilla y cursva.***~~
+- __*Esto es un texto subrayado y en cursiva.*__
+- __**Esto es un texto subrayado y en negrilla.**__
+- __***Esto es un texto subrayado, en negrilla y cursva.***__
+- __***Esto es un texto subrayado, en negrilla y cursiva.***__
+- __~~*Esto es un texto subrayado, tachado y en cursiva.*~~__
+- __~~**Esto es un texto subrayado, tachado y en negrilla.**~~__
+- __~~***Esto es un texto subrayado, tachado, en negrilla y cursva.***~~__
+
+```
+
+> [!!] Todas estas marcas se pueden entremezclar, pero es muy importante tener encuenta que las aperturas y los cierres de estos elementos han de corresponder de dentro a fuera siempre. Si se abre, por ejemplo, una cursiva y luego una negrilla, y se cierra primero negrilla y luego cursiva, el resultado no será el esperado, siendo ejecutado sólo el primero de la lista y pudiendo ser afectado tras éste en el resto del documento.
+
+Como resumen o conclusión final tenemos los siguientes formatos:
+
+- *****: Cursiva mediante un único asterisco.
+- ******: Negrilla mediante doble asterisco.
+- **˜˜**: Texto tachado mediante doble virgulilla.
+- **__**: Texto subrayado mediante doble guión bajo.
+- **``**: Texto monoespaciado o para código mediante doble comilla o acento agudo.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/manual/titles.w.md b/Public/doc/es/manual/titles.w.md
new file mode 100644
index 0000000..4a0a6d8
--- /dev/null
+++ b/Public/doc/es/manual/titles.w.md
@@ -0,0 +1,49 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_titles
+title_text = Títulos - WMarkDown
+```
+
+
+
+### Títulos
+
+Los títulos en WMarkDown no sólo son un formato, sino también una referencia dentro de página. Es muy importante su buen uso dentro del documento para evitar no sólo conflictos con los estándares, sino también dentro del propio WMarkDown. Los títulos serían los siguientes:
+
+```wmd-examples
+## Esto sería un H2.
+
+### Esto sería un H3.
+
+#### Esto sería un H4.
+
+##### Esto sería un H5.
+
+###### Esto sería un H6.
+
+```
+
+> [!!] Hay que tener en cuenta que el WMarkDown permite **incluir** contenido entre distintos **ficheros**, y éstos pueden ir gestionados con títulos. Éstos no cambiarán tras la carga por lo que si se adjunta un archivo con títulos a la altura o superiores al actual pueden romper la dinámica del documento resultante.
+
+> [!!] También es importante destacar que el **tamaño de los títulos** va porcentuado al texto actual según formato del WMarkDown.
+
+> [!!] También es importante mencionar que **no hay títulos por encima de H6**, y **se desaconseja**, por estándar de HTML, el uso de **H1**, salvo de forma manual en la cabecera de la Web para representar el logo y/o nombre del sitio o documento.
+
+Como alternativa para seguir los estándares de MarkDown y MediaWiki, tenemos la opción de hacer los títulos de la siguiente manera:
+
+```wmd-examples
+== Esto sería un H2 ==
+
+=== Esto sería un H3 ===
+
+==== Esto sería un H4 ====
+
+===== Esto sería un H5 =====
+
+====== Esto sería un H6 ======
+
+```
+
+> [!!] Existe una alternativa en MarkDown oficial que sería para los H1 y los H2 con respecto a subrayar una línea con caracteres de igual ("=") para los H1; y con guines medios ("-") para los H2. Al trabajar H1 y H2, pese a poderlos adaptar a H2 y H3 por la filosofía de trabajo de WMarkDown, éstos no se implementaron, tanto por la complejidad a la hora de ser interpretados como por el poco uso que se vio tras un análisis inicial.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/opinions.w.md b/Public/doc/es/opinions.w.md
new file mode 100644
index 0000000..ecee62a
--- /dev/null
+++ b/Public/doc/es/opinions.w.md
@@ -0,0 +1,17 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_opinions
+title_text = Opiniones y comentarios - WMarkDown
+```
+
+
+
+## Opiniones y comentarios
+
+Esta sección va dedicada a publicar las opiniones y comentarios de usuarios cercanos a los desarrolladores del proyecto para que halla una visión externa a éste, aprobechando la confianza en éstos tanto para lo bueno como para lo malo.
+
+> [!@Srx00] Quería agradecer personalmente a todos aquellos que me han dado una opinión y/o comentario acerca de este proyecto. Lo valor mucho pues sea como crítica para aprender como apoyo a continuar con este tipo de trabajos, me son realmente importantes. ¡Muchas gracias!
+
+> [!@Srx00] Como opinión personal, es un proyecto raro, que le da mayor complejidad a la aplicación en desarrollo como cuando le metes cualquier librería que añade una nueva funcionalidad, sin embargo, es cierto que si lo vemos desde el punto de vista de la gestión de errores, creo, a nivel personal, por mi experiencia, que éste puede ser una herramienta fuerte para gestionar los errores tanto a nivel local como entre plataformas o diferentes entornos del lenguaje dentro de un mismo proyecto, sin embargo, creo de vital importancia destacar que si se puede omitir el uso de dichas funciones, por ejemplo, para aquellos errores que contengan menos de 28 verificaciones, ahorraría tanto coste de dificultad como coste de proceso. Al ser una herramienta compatible directamente con enteros, es una forma de darle eficiencia a tu proyecto y no rompería mucho la estructura de funcionamiento con esta librería en la medida de lo posible.
+
+
\ No newline at end of file
diff --git a/Public/doc/es/projects.w.md b/Public/doc/es/projects.w.md
new file mode 100644
index 0000000..4926274
--- /dev/null
+++ b/Public/doc/es/projects.w.md
@@ -0,0 +1,86 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_projects
+title_text = Proyectos - WMarkDown
+```
+
+
+
+## Proyectos
+
+El propio proyecto WMarkDown se nutre de otros proyectos para ganar propiedades y/o características. La mayoría de estos proyectos tienen licencia MIT, pero por filosofía interna creemos que es importante mencionar las tecnologías y herramientas externas que hallan sido usadas para el desarrollo de este proyecto, ayudando a la visualización de estos proyectos, tecnologías, etc. Así como ayudando a sus creadores y mantenedores dentro de un nivel profesional a nivel curricular como personal por visualización de su trabajo y habilidades compartidas con la comunidad. Es por esto que a continuación se hace una lista de las tecnologías usadas, datos básicos de las mismas, motivos de uso y los Links pertientes.
+
+[["""
+Mermaid JS
+ *https://mermaid.js.org/favicon.ico
+ *https://mermaid.js.org/mermaid-logo.svg
+ https://mermaid.js.org/
+ https://mermaid.live/
+ https://github.com/mermaid-js/mermaid
+ https://www.mediawiki.org/wiki/Extension:Mermaid
+MathJax
+ *https://www.mathjax.org/favicon.ico
+ https://www.mathjax.org/
+ https://github.com/mathjax/MathJax
+ https://es.wikipedia.org/wiki/MathJax
+highlight.js
+ *https://highlightjs.org/icon.png
+ *https://highlightjs.org/favicon.ico
+ https://highlightjs.org/
+ https://github.com/highlightjs/highlight.js
+AnP
+ *https://anp.k3y.pw/images/AnP.png
+ *https://anp.k3y.pw/images/AnP-512.png
+ *https://anp.k3y.pw/favicon.ico
+ https://anp.k3y.pw/
+ https://git.k3y.pw/AnP/AnP
+CDN de KyMAN
+ *https://cdn.k3y.pw/images/CDN.png
+ *https://cdn.k3y.pw/images/CDN-512.png
+ *https://cdn.k3y.pw/favicon.ico
+ https://cdn.k3y.pw/
+ https://git.k3y.pw/KyMAN/CDN
+"""]]
+
+Por otro lado, también tenemos tecnologías que de una forma pública hacen uso de esta tecnología, el WMarkDown para diversos fines según intereses de los autores de dichos proyectos. A continuación dejamos la lista con dichas tecnologías para visibilizar el uso de WMarkDown.
+
+[["""
+AnP
+ *https://anp.k3y.pw/images/AnP.png
+ *https://anp.k3y.pw/images/AnP-512.png
+ *https://anp.k3y.pw/favicon.ico
+ https://anp.k3y.pw/
+ https://git.k3y.pw/AnP/AnP
+CDN de KyMAN
+ *https://cdn.k3y.pw/images/CDN.png
+ *https://cdn.k3y.pw/images/CDN-512.png
+ *https://cdn.k3y.pw/favicon.ico
+ https://cdn.k3y.pw/
+ https://git.k3y.pw/KyMAN/CDN
+ErrorsManager
+ *https://errorsmanager.k3y.pw/images/ErrorsManager.png
+ *https://errorsmanager.k3y.pw/images/ErrorsManager-512.png
+ *https://errorsmanager.k3y.pw/favicon.ico
+ https://errorsmanager.k3y.pw/
+ https://git.k3y.pw/KyMAN/ErrorsManager
+PythonMapper
+ *https://pythonmapper.k3y.pw/images/PythonMapper.png
+ *https://pythonmapper.k3y.pw/images/PythonMapper-512.png
+ *https://pythonmapper.k3y.pw/favicon.ico
+ https://pythonmapper.k3y.pw/
+ https://git.k3y.pw/KyMAN/PythonMapper
+Kanvas
+ *https://kanvas.k3y.pw/images/Kanvas.png
+ *https://kanvas.k3y.pw/images/Kanvas-512.png
+ *https://kanvas.k3y.pw/favicon.ico
+ https://kanvas.k3y.pw/
+ https://git.k3y.pw/KyMAN/Kanvas
+MuWeb
+ *https://muweb.k3y.pw/images/MuWeb.png
+ *https://muweb.k3y.pw/images/MuWeb-512.png
+ *https://muweb.k3y.pw/favicon.ico
+ https://muweb.k3y.pw/
+ https://git.k3y.pw/KyMAN/MuWeb
+"""]]
+
+
\ No newline at end of file
diff --git a/Public/doc/es/targets.w.md b/Public/doc/es/targets.w.md
new file mode 100644
index 0000000..3007196
--- /dev/null
+++ b/Public/doc/es/targets.w.md
@@ -0,0 +1,82 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_targets
+title_text = Objetivos - WMarkDown
+```
+
+
+
+## Objetivos
+
+Los objetivos para poder llevar a cabo este proyecto son los siguientes:
+
++ [X] Actualizar base del proyecto.
+ + [X] Montar la aplicación AnP sobre Python y agregarlo a los servidores.
+ + [X] Preparar el HTML para las páginas WMarkDown.
+ + [X] Reestablecer el dominio local de pruebas contra AnP en vez de Apache.
++ [X] Montar estilos genéricos.
+ + [X] Adjuntar el SASS de configuración y de elementos comunes de AnP.
+ + [X] Establecer colores primarios y secundarios.
+ + [X] Rehacer el logo del WMarkDown.
++ [-] CSS.
+ + [X] Visualización general.
+ + [X] Checkboxes y Radio Buttons.
+ + [-] Visualización de los bloques de código.
+ + [X] Estilos del menú dinámico.
++ [-] ECMAScript/JavaScript.
+ + [ ] Gestión de la visuazalición de bloques de código y condición de bloques especiales.
+ + [X] Crear menú dinámico sobre entorno cliente a partir de los ID de los Headers o títulos.
+ + [X] Integrar los diccionarios del WDictionaries para unificar proyectos y actualizar formato.
+ + [X] Formatear los archivos de diccionario JSON.
+ + [X] Carga asíncrona de los diccionarios.
+ + [X] Identificación de los elementos de los diccionarios en los textos al nivel establecido.
+ + [X] Generar las cajas de muestreo de información del elemento de diccionario.
++ [-] Python.
+ + [X] Crear base independiente para que pueda ser adjuntado en cualquier proyecto.
+ + [X] Crear gestión de módulos dinámicos de forma simplificada sobre diccionarios y sistemas de Callbacks sobre patrones regulares.
+ + [X] Crear módulo de análisis directo.
+ + [X] Crear módulo de análisis vía bloque.
+ + [X] Módulo para los párrafos.
+ + [X] Módulo para los títulos y subtítulos.
+ + [X] Módulo para las listas ordenadas y desordenadas.
+ + [X] Módulo para la gestión de las tablas.
+ + [X] Módulo para fragmentos de texto en negrita.
+ + [X] Módulo para fragmentos de texto en itálica.
+ + [X] Módulo para fragmentos de texto tachado.
+ + [X] Módulo para fragmentos de texto subrayado.
+ + [X] Módulo para fragmentos de texto monoespaciado o de código.
+ + [X] Módulo para la visualización de Links.
+ + [X] Links marcados.
+ + [X] Links y Paths directos.
+ + [X] Módulo para la visualización de imagen.
+ + [-] Módulo para la visualización de vídeo.
+ + [-] Vídeo nativo.
+ + [ ] Vídeo de Youtube.
+ + [ ] Vídeo de Vimeo.
+ + [-] Módulo para la reproducción de audio.
+ + [ ] Audio nativo.
+ + [ ] Audio de Soundcloud.
+ + [ ] Reproductor de múltiples audios.
+ + [ ] Slider de imágenes y vídeos.
+ + [X] Módulo de bloques de código.
+ + [-] Quotes o comentarios.
+ + [X] Bloques crudos.
+ + [X] Bloques iconificados.
+ + [X] Bloques de comentario de usuario.
+ + [ ] Bloques anidados.
+ + [X] Inclusiones de archivos externos.
+ + [X] Integrar el WDictionaries en el proyecto WMarkDown para unificar gestión documental.
+ + [ ] Aplicar un sistema de tabulaciones adecuada para facilitar acceso al código fuente HTML.
+ + [ ] Implementar sistema de comentarios para ignorar fragmentos de texto y que no salgan como resultado futuro.
+ + [X] Implementar módulo de definición de método y/o función para documentación.
+ + [X] Módulo para visualizar muestra de color.
+ + [X] Módulo para visibilizar proyectos y recursos.
+ + [ ] Módulo para visualizar direcciones de monedas o de pago mediante String y QR con Link integrado.
+ + [ ] Módulo para comentar fragmentos que no resulten en el String de salida.
++ [X] Implementar SyntaxHightlighter para el módulo de bloque de código.
++ [X] Implementar MathJax.
++ [X] Implementar MermaidJS.
++ [ ] Implementar ejemplificación de uso del lenguaje WMarkDown "[[!wmd-examples]]".
++ [ ] Gestionar cacheados automáticos de los ficheros contra HTML para precompilaciones.
+
+
\ No newline at end of file
diff --git a/Public/doc/tests.w.md b/Public/doc/tests.w.md
new file mode 100644
index 0000000..e12ad86
--- /dev/null
+++ b/Public/doc/tests.w.md
@@ -0,0 +1,159 @@
+```wmd-options
+language = es
+title_i18n = wmarkdown_title_tests
+title_text = Tests - WMarkDown
+```
+
+
+
+## Tests
+
+Esto es una prueba de ***Italic-Bold***. ¿Funca? ¿Y si *ponemos esto **con negrilla**, funcionaría*?
+
+Bloque de Flowcharts de Mermaid JS:
+
+```mermaid
+flowchart TD
+
+A --> B
+B --> C
+```
+
+Bloque de funciones matemáticas:
+
+```maths
+
+f(x) = a + bc + c
+
+```
+
+Este elemento [[#F00]], que es lo mismo que [[color #F00]] y [[color red]], es una prueba de muestra de color rojo.
+
+[[@ [Integer|String|Array] ErrorsManager.bitwise(!Integer | String | Array code = "jojo", !Integer bits)]]
+
+Imagen:
+
+((!image https://images.unsplash.com/photo-1597852074816-d933c7d2b988 Esto es una prueba xD))
+
+((!picture https://images.unsplash.com/photo-1597852074816-d933c7d2b988 Esto es una prueba xD))
+
+Y esto sería un icono ((!icon https://images.unsplash.com/photo-1597852074816-d933c7d2b988 Esto es una prueba xD)) xD
+
+* Elemento A
+* Elemento B
+* Elemento C
+
+- Elemento A
+- Elemento B
+ - JoJo
+- Elemento C
+
++ Elemento A
++ Elemento B
+ - jojo
++ Elemento C
+
+# Elemento A
+# Elemento B
+#* Elemento BA
+#* Elemento BB
+#*# Elemento BBA
+# Elemento C
+
+1. Elemento A
+2. Elemento B
+3. Elemento C
+
+a. Elemento A
+b. Elemento B
+c. Elemento C
+
+A. Elemento A
+B. Elemento B
+C. Elemento C
+
+i. Elemento A
+i. Elemento B
+i. Elemento C
+
+i. Elemento A
+ii. Elemento B
+iii. Elemento C
+
+I. Elemento A
+I. Elemento B
+I. Elemento C
+
+4. Elemento 1.
++ Elemento 2.
+ # Elemento 2-1.
+ # Elemento 2-2.
+ # Elemento 2-3.
+* Elemento 3.
+ # Elemento 3-1.
+ # Elemento 3-2.
+ # Elemento 3-3.
+- Elemento 4.
+ # Elemento 4-1.
+ # Elemento 4-2.
+ # Elemento 4-3.
+* Elemento N.
+ # Elemento N-1.
+ # Elemento N-2.
+ # Elemento N-3.
+
+> [!@Srx00] jojo xDDD
+
+Esto es un texto ~~-tachado-~~ xDDD.
+
+Y esto es un texto __subrayado__ xDD.
+
+##### Esto sería un H5.
+
+###### Esto sería un H6.
+
+https://wmarkdown.k3y.pw/
+
+kyman@wmarkdown.k3y.pw
+
+[+94 683 43 12 441]
+
+===== Esto sería un H5. =====
+
+====== Esto sería un H6. ======
+
+También puedes poner direcciones como Cryptomonedas como [bitcoin:tb1qujswuek3mefsm3m84g94ek40drysxe9z09yfnc tb1qujswuek3mefsm3m84g94ek40drysxe9z09yfnc] o [litecoin:tltc1q4xy8sg2hf6nqqrhp69aukn6md3rx8v6jlqc67s tltc1q4xy8sg2hf6nqqrhp69aukn6md3rx8v6jlqc67s] entre otras.
+
+También puedes poner direcciones como Cryptomonedas como [tb1qujswuek3mefsm3m84g94ek40drysxe9z09yfnc](bitcoin:tb1qujswuek3mefsm3m84g94ek40drysxe9z09yfnc Dirección Bitcoin TestNet) o [tltc1q4xy8sg2hf6nqqrhp69aukn6md3rx8v6jlqc67s](litecoin:tltc1q4xy8sg2hf6nqqrhp69aukn6md3rx8v6jlqc67s Dirección Litecoin TestNet) entre otras.
+
+A continuación montaremos una tabla.
+
+[| class="jojo"
+|^ Cabecera 1 | Cabecera 2 | Cabecera 3 | Cabecera N
+|= Título 1 | Título 2 | Título 3 | Título N
+| Elemento 1 | Elemento 2 | Elemento 3 | Elemento N
+| Elemento 1 | Elemento 2 | Elemento 3 | Elemento N
+| Elemento 1 | Elemento 2 | Elemento 3 | Elemento N
+|_ Pie 1 | Pie 2 | Pie 3 | Pie N
+|]
+
+[|
+|= Columna 1 | Columna 2 | Columna 3 | Columna 4 | Columna 5
+| Columna 1 | Columna 2 | Columna 3 | Columna 4 | Columna 5
+||| Columna 1-3 | Columna 4 | Columna 5
+| Columna 1 | *Columna* 2 ||| Columna 3-5
+| Columna 1 || Columna 2-3 | [https://wmarkdown.k3y.pw/#tablas Columna 4] | Columna 5
+|]
+
+[|
+|= Columna 1 | Columna 2 | Columna 3
+| Celda 1-A | Celda 2-A | Celda 3-A
+| Celda 1-B | "Celda 2-B
+
+Esto es más contenido de la celda 2-B." | Celda 3-B
+| Celda 1-C | 'Celda 2-C
+
+Esto es más contenido de la celda 2-C.' | Celda 3-C
+|]
+
+
\ No newline at end of file
diff --git a/Public/ecma/WMarkDown.Dictionary.ecma.js b/Public/ecma/WMarkDown.Dictionary.ecma.js
deleted file mode 100755
index b5761a8..0000000
--- a/Public/ecma/WMarkDown.Dictionary.ecma.js
+++ /dev/null
@@ -1,338 +0,0 @@
-WMarkDown.Dictionary = function(wmarkdown){
-
- const self = this;
- let started = false,
- scroll_event = null,
- z_index = 5,
- thread = null,
- cache = "";
-
- const construct = () => {};
-
- const scroll_event_function = event => {
-
- const content_box = wmarkdown.item_self.querySelector(".content"),
- half_width = content_box.offsetWidth / 2,
- half_height = content_box.offsetHeight / 2,
- font_size = window.getComputedStyle(wmarkdown.item_self, null).getPropertyValue("font-size");
-
- content_box.querySelectorAll(".content .data-dictionary-item").forEach(item => {
-
- const properties = item.getBoundingClientRect();
-
- item.setAttribute("data-left", properties.x - content_box.offsetLeft > half_width);
- item.setAttribute("data-top", properties.y - content_box.offsetTop < half_height);
- item.querySelector(".box").style.fontSize = font_size;
-
- });
-
- };
-
- const autosearch = () => wmarkdown.item_self.querySelectorAll(".data-dictionary-table").forEach(searcher => searcher.querySelector("[name=autosearch]").checked && self.search(searcher, null));
-
- this.start = () => {
-
- if(started)
- return;
- started = true;
-
- const dictionary_links = wmarkdown.settings("dictionary_links");
- dictionary_title = wmarkdown.settings("dictionary_title") || "Dictionary";
-
- scroll_event = wmarkdown.item_self.querySelector(".content").addEventListener("scroll", scroll_event_function);
- self.build();
- thread = wmarkdown.threads_add(autosearch);
-
- if(dictionary_links)
- load_links(dictionary_links.push ? dictionary_links : [dictionary_links], dictionary => {
-
- const content_box = wmarkdown.item_self.querySelector(".content-box");
- let hash = dictionary_title.toLowerCase().replace(/[^a-z\d]+/g, "-");
-
- if(!/^(.+\-)(\d+)$/.test(hash))
- hash += "-0";
- while(document.getElementById(hash))
- hash = hash.replace(/^(.+\-)(\d+)$/, (...arguments) => arguments[1] + (Number(arguments[2]) + 1));
-
- with(content_box.appendChild(document.createElement("h1"))){
- setAttribute("id", hash);
- innerText = dictionary_title;
- };
- with(wmarkdown.item_self.querySelector(".headers-menu>nav>ul").appendChild(document.createElement("li"))){
- setAttribute("data-level", 1);
- setAttribute("data-deployed", false);
- setAttribute("data-levels", 0);
- setAttribute("data-parent-deployed", true);
- setAttribute("data-id", wmarkdown.hash());
- innerHTML = (`
-
- ` + dictionary_title + `
- `);
- };
- build(dictionary, content_box.appendChild(document.createElement("form")));
-
- });
-
- };
-
- const process_description = description => {
- if(!description)
- return "";
- if(description.substr)
- return description;
- if(typeof description != "object")
- return "" + description;
-
- let html = ``;
-
- description.forEach(line => html += " " + (line || ` `));
- html += ` `;
-
- return html;
- }
-
- const mount = (dictionary, item) => item.childNodes.forEach(node => {
- if(node.hasAttribute && node.hasAttribute("data-ignore") && node.getAttribute("data-ignore") == "true")
- return;
- if(node.nodeType != Node.TEXT_NODE){
- !(node.tagName && ["noscript", "a"].includes(node.tagName.toLowerCase())) && !(node.classList && node.classList.contains("code-block")) && mount(dictionary, node);
- return;
- };
-
- let html = node.textContent;
-
- if(!node.textContent || !/[^\r\n\s\t]/.test(html))
- return;
-
- const nodes = [];
-
- dictionary.forEach(item => item.patterns.forEach((pattern, i) => pattern && (html = html.replace(pattern, (...values) => {
-
- let html = ``;
- const result = (item.results[i] || item.results[0]).replace(/\$(\d)/g, (all, i) => values[Number(i)] || "");
-
- (item.links ? item.links.push ? item.links : [item.links] : []).forEach(link => html += ` `);
- nodes.push((`
-
- ` + result + `
- ` + process_description(item.description) + `
- ` + html + `
- ` + result + `
- `).trim());
-
- return '###' + (nodes.length - 1) + "###";
- }))));
-
- html = html.replace(/\#{3}(\d+)\#{3}/g, (...arguments) => nodes[Number(arguments[1])]);
-
- if(html == node.textContent)
- return;
-
- const span = node.parentNode.insertBefore(document.createElement("span"), node);
-
- span.setAttribute("class", "data-dictionary-block");
- span.innerHTML = html;
-
- node.remove();
-
- });
-
- const load = (files, i, callback, dictionary, patterns_used) => {
-
- if(i >= files.length){
- callback(dictionary);
- return;
- };
-
- wmarkdown.load_file(files[i], data => {
- if(data){
- try{
- JSON.parse(data).forEach(item => {
-
- const json = item.pattern.substr ? item.pattern : JSON.stringify(item.pattern);
-
- if(patterns_used.includes(json))
- return;
- patterns_used.push(json);
-
- let pattern;
- const patterns = [];
-
- if(!item.pattern)
- return;
-
- (item.pattern.push ? item.pattern : [item.pattern]).forEach(pattern => {
-
- const pattern_closed = pattern.lastIndexOf("/");
-
- try{
- pattern_closed && (pattern = new RegExp(pattern.substr(1, pattern_closed - 1), pattern.substr(pattern_closed + 1)));
- }catch(exception){};
-
- patterns.push(pattern || null);
-
- });
-
- patterns && dictionary.push(Object.assign({}, item, {
- patterns : patterns,
- results : item.result.push ? item.result : [item.result]
- }));
-
- });
- }catch(exception){console.error(exception);};
- };
- load(files, i + 1, callback, dictionary, patterns_used);
- });
-
- };
-
- const build = (dictionary, item) => {
-
- const header = (`
-
- i
- Patterns
- Results
- Words
- Meanings
- URLs
-
- `),
- hashes = {};
- let body = ``;
-
- ["search", "autosearch", "meanings", "case_sensitive"].forEach(key => hashes[key] = wmarkdown.hash());
-
- dictionary.forEach((item, i) => {
-
- let urls = ``,
- words = '';
- const results = item.words || item.results;
-
- (item.links ? item.links.push ? item.links : [item.links] : []).forEach(link => urls += `` + link + ` `);
- (results.push ? results : [results]).forEach(word => words += '' + word + ' ');
-
- body += (`
-
- ` + i + `
- ` + item.patterns.join(` `) + `
- ` + item.results.join(` `) + `
-
- ` + (item.description.push ? item.description.join(" ") : item.description) + `
-
-
- `);
- });
-
- item.setAttribute("class", "data-dictionary-table");
- item.setAttribute("action", window.location.hash);
- item.setAttribute("method", "get");
- item.setAttribute("onsubmit", "return false;");
- item.innerHTML = (`
-
- Search
-
- Search
-
-
-
-
-
- Meanings
-
-
-
-
- Case sensitive
-
-
-
-
- Autosearch
-
-
-
- Search
-
-
-
-
-
- ` + header + `
- ` + body + `
- ` + header + `
-
-
-
- `);
- }
-
- const load_links = (links, callback) => load(links, 0, dictionary => {
-
- mount(dictionary, wmarkdown.item_self.querySelector(".content>.content-box"));
- setTimeout(scroll_event_function, 10);
-
- typeof callback == "function" && callback(dictionary);
-
- }, [], []);
-
- this.build = () => wmarkdown.item_self.querySelectorAll(".wdictionary[data-status=unloaded]").forEach(items => {
- items.setAttribute("data-status", "loading");
-
- load_links(JSON.parse(wmarkdown.utf8_decode(atob(items.getAttribute("data-json")))), dictionary => {
- build(dictionary, items.parentNode.insertBefore(document.createElement("form"), items));
- });
-
- });
-
- this.show = (element, event) => {
- element.style.zIndex = ++ z_index;
- element.setAttribute("data-show", true);
- };
- this.hide = (element, event) => element.setAttribute("data-show", false);
-
- this.search = (element, event) => {
- if(!element)
- return;
-
- while((!element.classList || !element.classList.contains("data-dictionary-table")) && (element = element.parentNode));
-
- let text = element.querySelector("[name=search]").value;
-
- if(text == cache)
- return;
- cache = text;
-
- const meanings = element.querySelector("[name=meanings]").checked,
- case_sensitive = element.querySelector("[name=case_sensitive]").checked;
-
- !case_sensitive && (text = text.toLowerCase());
-
- element.querySelectorAll("tbody>tr").forEach(word => {
-
- let words = word.querySelector("[data-field=words]").innerText,
- description = word.querySelector("[data-field=description]").innerText;
-
- if(!case_sensitive){
- words = words.toLowerCase(),
- description = description.toLowerCase();
- };
-
- word.setAttribute("data-visible", (
- !text ||
- words.indexOf(text) != -1 ||
- (meanings && description.indexOf(text) != -1)
- ));
-
- });
-
- };
-
- construct();
-
-};
diff --git a/Public/ecma/WMarkDown.Dictionary.old.ecma.js b/Public/ecma/WMarkDown.Dictionary.old.ecma.js
deleted file mode 100755
index 4a5239a..0000000
--- a/Public/ecma/WMarkDown.Dictionary.old.ecma.js
+++ /dev/null
@@ -1,299 +0,0 @@
-WMarkDown.Dictionary = function(wmarkdown){
-
- const self = this;
- let started = false,
- scroll_event = null,
- z_index = 5,
- thread = null,
- cache = "";
-
- const construct = () => {};
-
- const scroll_event_function = event => {
-
- const content_box = wmarkdown.item_self.querySelector(".content"),
- half_width = content_box.offsetWidth / 2,
- half_height = content_box.offsetHeight / 2,
- font_size = window.getComputedStyle(wmarkdown.item_self, null).getPropertyValue("font-size");
-
- content_box.querySelectorAll(".content .data-dictionary-item").forEach(item => {
-
- const properties = item.getBoundingClientRect();
-
- item.setAttribute("data-left", properties.x - content_box.offsetLeft > half_width);
- item.setAttribute("data-top", properties.y - content_box.offsetTop < half_height);
- item.querySelector(".box").style.fontSize = font_size;
-
- });
-
- };
-
- const autosearch = () => wmarkdown.item_self.querySelectorAll(".data-dictionary-table").forEach(searcher => {if(searcher.querySelector("[name=autosearch]").checked)self.search(searcher, null)});
-
- this.start = () => {
-
- if(started)
- return;
- started = true;
-
- scroll_event = wmarkdown.item_self.querySelector(".content").addEventListener("scroll", scroll_event_function);
- self.build();
- thread = wmarkdown.threads_add(autosearch);
-
- };
-
- const process_description = description => {
- if(!description)
- return "";
- if(description.substr)
- return description;
- if(typeof description != "object")
- return "" + description;
-
- let html = ``;
-
- description.forEach(line => html += " " + (line || ` `));
- html += ` `;
-
- return html;
- }
-
- const mount = (dictionary, item) => item.childNodes.forEach(node => {
- if(node.nodeType != Node.TEXT_NODE){
- if(!(node.tagName && node.tagName.toLowerCase() == "a") && !(node.classList && node.classList.contains("code-block")))
- mount(dictionary, node);
- return;
- };
-
- let html = node.textContent;
-
- if(!node.textContent || !/[^\r\n\s\t]/.test(html))
- return;
-
- const nodes = [];
-
- dictionary.forEach(item => item.patterns.forEach((pattern, i) => {if(pattern)html = html.replace(pattern, (...values) => {
-
- let html = ``;
- const result = item.results[i].replace(/\$(\d)/g, (all, i) => values[Number(i)] || "");
-
- (item.links ? item.links.push ? item.links : [item.links] : []).forEach(link => html += ` `);
- nodes.push(`
-
-
- ` + result + `
- ` + process_description(item.description) + `
- ` + html + `
-
- ` + result + `
-
- `);
-
- return '###' + (nodes.length - 1) + "###";
- })}));
-
- html = html.replace(/\#{3}(\d+)\#{3}/g, (...arguments) => nodes[Number(arguments[1])]);
-
- if(html == node.textContent)
- return;
-
- const span = node.parentNode.insertBefore(document.createElement("span"), node);
-
- span.setAttribute("class", "data-dictionary-block");
- span.innerHTML = html;
-
- node.remove();
-
- });
-
- this.build = () => {
-
- const dictionary = [],
- patterns_used = [];
-
- wmarkdown.item_self.querySelectorAll(".data-dictionary[data-json]").forEach(items => {
-
- const data = JSON.parse(wmarkdown.utf8_decode(atob(items.getAttribute("data-json"))));
-
- if(typeof data != "object")
- return;
-
- if(data.dictionary)
- data.dictionary.forEach(item => {
-
- const json = item.pattern.substr ? item.pattern : JSON.stringify(item.pattern);
-
- if(patterns_used.includes(json))
- return;
- patterns_used.push(json);
-
- let pattern;
- const patterns = [];
-
- if(!item.pattern)
- return;
-
- (item.pattern.push ? item.pattern : [item.pattern]).forEach(pattern => {
-
- const pattern_closed = pattern.lastIndexOf("/");
-
- try{
- if(pattern_closed)
- pattern = new RegExp(pattern.substr(1, pattern_closed - 1), pattern.substr(pattern_closed + 1));
- }catch(exception){};
-
- patterns.push(pattern || null);
-
- });
-
- if(patterns)
- dictionary.push(Object.assign({}, item, {
- patterns : patterns,
- results : item.result.push ? item.result : [item.result]
- }));
-
- });
-
- });
-
- mount(dictionary, wmarkdown.item_self.querySelector(".content>.content-box"));
- setTimeout(scroll_event_function, 10);
-
- const dictionary_input = wmarkdown.item_self.querySelector(".data-dictionary");
-
- if(!dictionary_input)
- return;
-
- const item = dictionary_input.parentNode.insertBefore(document.createElement("form"), dictionary_input),
- header = (`
-
- i
- Patterns
- Results
- Words
- Meanings
- URLs
-
- `),
- hashes = {};
- let body = ``;
-
- ["search", "autosearch", "meanings", "case_sensitive"].forEach(key => hashes[key] = wmarkdown.hash());
-
- dictionary.forEach((item, i) => {
-
- let urls = ``,
- words = '';
- const results = item.words || item.results;
-
- (item.links ? item.links.push ? item.links : [item.links] : []).forEach(link => urls += `` + link + ` `);
- (results.push ? results : [results]).forEach(word => words += '' + word + ' ');
-
- body += (`
-
- ` + i + `
- ` + item.patterns.join(` `) + `
- ` + item.results.join(` `) + `
-
- ` + (item.description.push ? item.description.join(" ") : item.description) + `
-
-
- `);
- });
-
- item.setAttribute("class", "data-dictionary-table");
- item.setAttribute("action", window.location.hash);
- item.setAttribute("method", "get");
- item.setAttribute("onsubmit", "return false;");
- item.innerHTML = (`
-
- Search
-
- Search
-
-
-
-
-
- Meanings
-
-
-
-
- Case sensitive
-
-
-
-
- Autosearch
-
-
-
- Search
-
-
-
-
-
- ` + header + `
- ` + body + `
- ` + header + `
-
-
-
- `);
-
- };
-
- this.show = (element, event) => {
- element.style.zIndex = ++ z_index;
- element.setAttribute("data-show", true);
- };
- this.hide = (element, event) => element.setAttribute("data-show", false);
-
- this.search = (element, event) => {
- if(!element)
- return;
-
- while((!element.classList || !element.classList.contains("data-dictionary-table")) && (element = element.parentNode));
-
- let text = element.querySelector("[name=search]").value;
-
- if(text == cache)
- return;
- cache = text;
-
- const meanings = element.querySelector("[name=meanings]").checked,
- case_sensitive = element.querySelector("[name=case_sensitive]").checked;
-
- if(!case_sensitive)
- text = text.toLowerCase();
-
- element.querySelectorAll("tbody>tr").forEach(word => {
-
- let words = word.querySelector("[data-field=words]").innerText,
- description = word.querySelector("[data-field=description]").innerText;
-
- if(!case_sensitive){
- words = words.toLowerCase(),
- description = description.toLowerCase();
- };
-
- word.setAttribute("data-visible", (
- !text ||
- words.indexOf(text) != -1 ||
- (meanings && description.indexOf(text) != -1)
- ));
-
- });
-
- };
-
- construct();
-
-};
diff --git a/Public/ecma/WMarkDown.Multimedia.ecma.js b/Public/ecma/WMarkDown.Multimedia.ecma.js
deleted file mode 100755
index 6342bbc..0000000
--- a/Public/ecma/WMarkDown.Multimedia.ecma.js
+++ /dev/null
@@ -1,241 +0,0 @@
-WMarkDown.Multimedia = function(wmarkdown){
-
- const self = this;
- let started = false;
-
- const construct = () => {};
-
- const error = (element, type) => {
-
- element.parentNode.setAttribute("data-status", "error");
- element.parentNode.setAttribute("data-error-type", type);
-
- return null;
- };
-
- this.image_try_next = (element, event) => {
- if(!element.hasAttribute("data-i") || !element.hasAttribute("data-src"))
- return error(element, "no_data");
-
- let images;
-
- try{
- if(!(images = JSON.parse(atob(element.getAttribute("data-src")))))
- return error(element, "no_json");
- }catch(exception){
- console.error(exception);
- return error(element, "exception");
- };
-
- const i = Number(element.getAttribute("data-i"));
-
- if(isNaN(i))
- return error(element, "i_is_nan");
- if(i >= images.length)
- return error(element, "ended")
-
- const image = new Image();
-
- image.src = images[i];
- image.onload = () => {
-
- const anchor = element.parentNode.querySelector("a");
-
- element.setAttribute("src", images[i]);
- element.parentNode.setAttribute("data-status", "loaded");
- element.parentNode.querySelector(".image-style").style.backgroundImage = "url('" + images[i] + "')";
-
- if(anchor){
- anchor.setAttribute("href", images[i]);
- anchor.innerText = images[i];
- };
-
- };
- image.onerror = () => {
- element.setAttribute("data-i", i + 1);
- self.image_try_next(element, event);
- };
-
- };
-
- this.video_try_next = (element, event) => {
- if(!element.hasAttribute("data-i") || !element.hasAttribute("data-src"))
- return error(element, "no_data");
-
- let videos;
-
- try{
- if(!(videos = JSON.parse(atob(element.getAttribute("data-src")))))
- return error(element, "no_json");
- }catch(exception){
- console.error(exception);
- return error(element, "exception");
- };
-
- const i = Number(element.getAttribute("data-i"));
-
- if(isNaN(i))
- return error(element, "i_is_nan");
- if(i >= videos.length)
- return error(element, "ended")
-
- const video = document.createElement("video");
-
- video.src = videos[i];
- video.onloadstart = () => {
- element.setAttribute("src", videos[i]);
- wmarkdown.get_mime(videos[i], mime => element.setAttribute("type", mime));
- with(element.parentNode.querySelector("a")){
- setAttribute("href", videos[i]);
- innerText = videos[i];
- };
- element.parentNode.setAttribute("data-status", "loaded");
- video.remove();
- };
- video.onerror = () => {
- element.setAttribute("data-i", i + 1);
- self.image_try_next(element, event);
- video.remove();
- };
-
- };
-
- this.audio_try_next = (element, event) => {
- if(!element.hasAttribute("data-i") || !element.hasAttribute("data-src"))
- return error(element, "no_data");
-
- let audios;
-
- try{
- if(!(audios = JSON.parse(atob(element.getAttribute("data-src")))))
- return error(element, "no_json");
- }catch(exception){
- console.error(exception);
- return error(element, "exception");
- };
-
- const i = Number(element.getAttribute("data-i"));
-
- if(isNaN(i))
- return error(element, "i_is_nan");
- if(i >= audios.length)
- return error(element, "ended")
-
- const audio = new Audio();
-
- audio.src = audios[i];
- audio.onloadstart = () => {
- element.setAttribute("src", audios[i]);
- wmarkdown.get_mime(audios[i], mime => element.setAttribute("type", mime));
- with(element.parentNode.querySelector("a")){
- setAttribute("href", audios[i]);
- innerText = audios[i];
- };
- element.parentNode.setAttribute("data-status", "loaded");
- };
- audio.onerror = () => {
- element.setAttribute("data-i", i + 1);
- self.image_try_next(element, event);
- };
-
- };
-
- const embed_try = embed => {
- if(!embed.hasAttribute("data-platform") || !embed.hasAttribute("data-id"))
- return;
- embed.setAttribute("data-status", "mounted");
-
- switch(embed.getAttribute("data-platform")){
- case "youtube":
- with(embed.appendChild(document.createElement("iframe"))){
- setAttribute("src", "https://www.youtube.com/embed/" + embed.getAttribute("data-id"));
- setAttribute("title", "YouTube video player");
- setAttribute("frameborder", 0);
- setAttribute("style", "position:absolute;top:0em;left:0em;width:100%;height:100%;");
- setAttribute("allow", "accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture");
- setAttribute("allowfullscreen", true);
- };
- break;
- case "vimeo":
- with(embed.appendChild(document.createElement("iframe"))){
- setAttribute("src", "https://player.vimeo.com/video/" + embed.getAttribute("data-id"));
- setAttribute("frameborder", 0);
- setAttribute("style", "position:absolute;top:0em;left:0em;width:100%;height:100%;");
- setAttribute("allow", "autoplay; fullscreen; picture-in-picture");
- setAttribute("allowfullscreen", true);
- };
- break;
- case "facebook":
- //
- //
- // https://www.facebook.com/gaming/497870250231404/videos/830479191217676/
- with(embed.appendChild(document.createElement("iframe"))){
- setAttribute("src", "https://www.facebook.com/video.php?v=" + embed.getAttribute("data-id"));
- setAttribute("style", "position:absolute;top:0em;left:0em;width:100%;height:100%;border:none;overflow:hidden;");
- setAttribute("scrolling", "no");
- setAttribute("frameborder", 0);
- setAttribute("allow", "autoplay; clipboard-write; encrypted-media; picture-in-picture; web-share");
- setAttribute("allowfullscreen", true);
- };
- break;
- case "twitch":
- //
- // https://www.twitch.tv/videos/1025807282
- with(embed.appendChild(document.createElement("iframe"))){
- setAttribute("src", "https://player.twitch.tv/?video=" + embed.getAttribute("data-id") + "&parent=wmarkdown.k3y.pw");
- setAttribute("style", "position:absolute;top:0em;left:0em;width:100%;height:100%;");
- setAttribute("scrolling", "no");
- setAttribute("frameborder", 0);
- setAttribute("allow", "autoplay; clipboard-write; encrypted-media; picture-in-picture; web-share");
- setAttribute("allowfullscreen", true);
- };
- break;
- };
-
- };
-
- const execute_in_range = (item, range, callback) => {
-
- const y = item.getBoundingClientRect().y;
-
- if(y < range && y > -range){
- item.setAttribute("data-status", "loading");
- callback();
- };
-
- };
-
- this.on_scroll = (event) => {
-
- const range = wmarkdown.item_self.querySelector(".content").offsetHeight * wmarkdown.settings("onload_media_range");
-
- wmarkdown.item_self.querySelectorAll(".multimedia-box>[data-status=unloaded]").forEach(item => execute_in_range(item, range, () => {
-
- const media = item.querySelector("audio[onerror]") || item.querySelector("[onerror]");
-
- media.onerror(media);
-
- }));
-
- wmarkdown.item_self.querySelectorAll(".multimedia-box>[data-type=embed]>[data-status=unmounted]").forEach(item => execute_in_range(item, range, () => embed_try(item)));
-
- };
-
- this.start = () => {
-
- if(started)
- return;
- started = true;
-
- const content = wmarkdown.item_self.querySelector(".content");
-
- self.on_scroll(null);
- wmarkdown.item_self.querySelector(".content").addEventListener("scroll", self.on_scroll);
-
- };
-
- this.go = (element, event) => window.open(element.querySelector("[src]").getAttribute("src"), "_blank");
-
- construct();
-
-};
diff --git a/Public/ecma/WMarkDown.WMonitor.ecma.js b/Public/ecma/WMarkDown.WMonitor.ecma.js
deleted file mode 100755
index a923481..0000000
--- a/Public/ecma/WMarkDown.WMonitor.ecma.js
+++ /dev/null
@@ -1,78 +0,0 @@
-WMarkDown.WMonitor = function(wmarkdown){
-
- const self = this;
- let started = false;
-
- const construct = () => {};
-
- this.start = () => {
-
- if(started)
- return;
- started = true;
-
- self.build();
-
- };
-
- this.build = () => {
-
- const blocks = [];
-
- wmarkdown.item_self.querySelectorAll("[data-wmonitor][data-status=unloaded]").forEach(item => {
-
- item.setAttribute("data-status", "loading");
- item.innerHTML = (`
-
- `);
- blocks.push(item.getAttribute("data-wmonitor"));
-
- });
-
- console.log(blocks);
-
- };
-
- this.set_like = (item, event) => {
-
- console.log("like");
-
- };
-
- this.set_dislike = (item, event) => {
-
- console.log("dislike");
-
- };
-
- this.view_comments = (item, event) => {
-
- console.log("comments");
-
- };
-
- construct();
-
-};
diff --git a/Public/ecma/WMarkDown.ecma.js b/Public/ecma/WMarkDown.ecma.js
old mode 100755
new mode 100644
index 2455722..c073c22
--- a/Public/ecma/WMarkDown.ecma.js
+++ b/Public/ecma/WMarkDown.ecma.js
@@ -1,711 +1,804 @@
-WMarkDown = function(input){
-
- const self = this,
- default_settings = {
- nulls : true,
- default_value : null,
- autostart : true,
- object_name : "wmarkdown",
- frames_per_second : 24,
- timeout : 2000,
- preload_timeout : 2000,
- preload_wmarkdown : true,
- hash_alphabet : "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz",
- hash_length : 11,
- meanings : true,
- case_sensitive : false,
- autosearch : true,
- onload_media_range : 1.4,
- ajax_timeout : 2000,
- mime_extension_file : "/json/mime_to_extension.json",
- extension_mime_file : "/json/extension_to_mime.json",
- default_mime : "application/octet-stream",
- default_extension : "txt",
- variable_name : "wmd",
- wmd_file : "wmd.php",
- display_view : null,
- cells : 40,
- item : ".wmarkdown",
- size_multiplier : 1,
- automultiplier : 1,
- default_font_size : 14,
- size_range : [.5, 4],
- wmd_options : "wmd-options",
- wmd_options_position : "header",
- screen_sizes : [2560, 1920, 1280, 960, 640],
- default_view : "content",
- nulls : false,
- default_value : null
- },
- custom_settings = {},
- threads = [],
- hashes = [],
- mime_extension = {},
- extension_mime = {},
- screen = {
- x : 0,
- y : 0,
- multiplier : 0,
- automultiplier : 0,
- sizes : []
- },
- on_ready_events = [];
- let started = false,
- thread = null,
- threads_l = 0,
- screen_size_change_thread = null,
- last_change = 0,
- on_ready_ok = false;
-
- let object_name = this.object_name;
- let item_self = this.item_self = document;
- let hash_self = this.hash_self;
-
- let dictionary = this.dictionary;
- let multimedia = this.multimedia;
- let wmonitor = this.wmonitor;
-
- const null_or_undefined = this.null_or_undefined = value => value === undefined || value === null;
-
- const settings_priority = inputs => [].concat(!inputs ? [] : inputs.push ? inputs : [inputs], [input, custom_settings, default_settings]);
-
- const default_value = this.default_value = (_default, nulls) => _default !== undefined && ((typeof nulls == "boolean" ? nulls : settings("nulls", null, false, false)) || _default !== null ? _default : settings("default_value"), null, null, true);
-
- const settings = this.settings = (names, inputs, _default, nulls) => {
- if(!names)
- return default_value(_default, nulls);
-
- const l = (names.push ? names : names = [names]).length,
- m = (inputs = (inputs ? inputs.push ? inputs : [inputs] : []).concat([input, default_settings])).length;
-
- typeof nulls != "boolean" && (nulls = settings("nulls", null, false, false));
-
- for(let j = 0; j < m; j ++)
- if(typeof inputs[j] == "object")
- for(let i = 0; i < l; i ++)
- if(names[i] && inputs[j][names[i]] !== undefined && (nulls || inputs[j][names[i]] !== null))
- return inputs[j][names[i]];
- return default_value(_default, nulls);
- };
-
- const threads_function = () => {
-
- const date = Date.now();
-
- threads.forEach(thread => thread && thread());
-
- if(item_self && date - last_change > 2000){
- last_change = date;
-
- const mobile = self.is_mobile();
-
- item_self.setAttribute("data-mobile", mobile);
- item_self.setAttribute("data-display-view", mobile ? "mobile" : "pc");
-
- };
-
- };
-
- const threads_add = this.threads_add = method => {
- if(typeof method != "function")
- return null;
-
- let i = 0;
-
- for(; i < threads_l; i ++)
- if(!threads[i])
- break;
-
- threads[i] = method;
- threads_l = threads.length;
-
- return i;
- };
-
- const threads_remove = this.threads_remove = i => !isNaN(i) && threads[i] && (threads[i] = null);
-
- const threads_start = this.threads_start = frames_per_second => thread === null && (thread = setInterval(threads_function, 1000 / (frames_per_second || settings("frames_per_second"))));
-
- const threads_stop = this.threads_stop = () => {
- if(thread === null)
- return;
-
- clearInterval(thread);
- thread = null;
-
- };
-
- const is_dom_item = item => (
- typeof HTMLElement == "object" ? item instanceof HTMLElement :
- typeof Node == "object" ? item instanceof Node :
- item && typeof item === "object" && !isNaN(item.nodeType) && item.nodeName == "string"
- );
-
- const preload = this.preload = (selector, callback) => {
- if(typeof callback != "function")
- return;
-
- if(!selector){
- callback(null, false, "NO_SELECTOR");
- return;
- };
- if(is_dom_item(selector)){
- callback(selector, false, "OK");
- return;
- };
- if(!selector.substr){
- callback(null, false, "NO_DOM_ITEM");
- return;
- };
-
- let item;
-
- try{
- if(item = item_self.querySelector(selector)){
- callback(item, false, "OK");
- return;
- };
- }catch(error){
- callback(null, false, "BAD_SELECTOR");
- return;
- };
-
- const date = Date.now(),
- timeout = settings(["preload_timeout", "timeout"]);
- let preload = threads_add(() => {
- if(item = item_self.querySelector(selector)){
- threads_remove(preload);
- callback(item, true, "OK");
- }else if(Date.now() - date > timeout){
- threads_remove(preload);
- callback(null, true, "TIMEOUT");
- };
- });
-
- };
-
- const screen_size_change = () => {
-
- if(!item_self)
- return;
-
- const multiplier = Number(item_self.getAttribute("data-size-multiplier")),
- automultiplier = Number(item_self.getAttribute("data-size-automultiplier"));
-
- if(screen.x == item_self.offsetWidth && screen.y == item_self.offsetHeight && screen.multiplier == multiplier && screen.automultiplier == automultiplier)
- return;
-
- screen.x = item_self.offsetWidth;
- screen.y = item_self.offsetHeight;
- screen.multiplier = multiplier;
- screen.automultiplier = automultiplier;
-
- const x_higher = screen.x > screen.y;
- let size = "0";
-
- !screen.sizes.some((value, i) => i && !(value > screen.x && (size += " " + i)));
-
- item_self.setAttribute("data-direction", x_higher ? "horizontal" : "vertical");
- item_self.style.fontSize = ((
- item_self.getAttribute("data-mobile") == "true" ?
- screen[x_higher ? "y" : "x"] / Number(item_self.getAttribute("data-cells")) :
- item_self.getAttribute("data-font-size")
- ) * multiplier * automultiplier) + "px";
- item_self.setAttribute("data-screen-size", size.trim());
-
- };
-
- const button = this.button = (name, action, default_text) => {
-
- const text = default_text;
-
- return (`
-
-
- ` + text + `
-
- `);
- };
-
- const preload_wmarkdown = this.preload_wmarkdown = callback => {
- if(typeof callback != "function")
- return;
-
- if(item_self && item_self.classList && item_self.classList.contains("wmarkdown")){
- callback(item_self, false, "OK");
- return;
- };
-
- preload(".wmarkdown", wmarkdown => {
-
- if(!wmarkdown){
- callback(null, false, "NO_WMARKDOWN");
- return;
- };
-
- const mobile = self.is_mobile(),
- display_view = settings("display_view"),
- multiplier = settings(["size_multiplier", "multiplier"]),
- view_menu_items = {
- menu : item_self.querySelector(".headers-menu [data-i18n=headers_menu]"),
- content : item_self.querySelector("fieldset.content h1,h2,h3,h4,h5,h6"),
- files : item_self.querySelector("fieldset.files [data-i18n=files]")
- };
-
- item_self = self.item_self = wmarkdown;
-
- item_self.setAttribute("data-mobile", mobile);
- item_self.setAttribute("data-display-view", display_view || (mobile ? "mobile" : "pc"));
- item_self.setAttribute("data-cells", settings("cells"));
- item_self.setAttribute("data-size-multiplier", multiplier);
- item_self.setAttribute("data-size-automultiplier", settings(["size_automultiplier", "automultiplier"]));
- item_self.setAttribute("data-font-size", settings(["default_font_size", "font_size"]));
- item_self.setAttribute("data-view", settings(["default_view", "view"]));
-
- screen_size_change_thread = threads_add(screen_size_change);
-
-
- with(item_self.querySelector("header").appendChild(document.createElement("div"))){
- setAttribute("class", "view-menu buttons group");
- for(const key in view_menu_items)
- view_menu_items[key] && (innerHTML += button(key, object_name + ".view_show(this, event, '" + key + "');", view_menu_items[key]));
- };
-
- preload(settings("item"), () => {
-
- const menu_items = item_self.querySelectorAll(".headers-menu [data-levels]");
-
- menu_items.forEach((item, i) => {
- if(!i)
- return;
-
- const level = Number(item.getAttribute("data-level")),
- j = i - 1;
-
- if(level > Number(menu_items[j].getAttribute("data-level")))
- menu_items[j].setAttribute("data-levels", Number(menu_items[j].getAttribute("data-levels")) + 1);
-
- });
-
- });
-
- preload("[data-preload=wmarkdown-preloader]", preloader => {
-
- if(!preloader){
- callback(null, false, "NO_PRELOADER");
- return;
- };
-
- preloader.remove();
- setTimeout(() => callback(item_self, true, "OK"), 1000);
-
- const options_class = settings(["wmd_options", "options"]);
- let options = item_self.querySelector("." + options_class);
-
- !options && (options = item_self.querySelector(settings(["wmd_options_position", "options_position"])).appendChild(document.createElement("div"))).setAttribute("class", options_class);
-
- if(!options.querySelector("[name=multiplier]")){
-
- const range = settings(["size_range", "multiplier_range"]);
-
- with(options.appendChild(document.createElement("span"))){
- setAttribute("class", "multiplier");
- innerHTML = (`
-
-
- Less
-
-
-
-
-
-
-
- More
-
- `);
- // setAttribute("data-clicked", false);
- // setAttribute("onmousedown", object_name + ".multiplier_mouse_down(this, event);");
- // setAttribute("onmouseup", object_name + ".multiplier_mouse_up(this, event);");
- // setAttribute("onmouseout", object_name + ".multiplier_mouse_up(this, event);");
- // setAttribute("onmousemove", object_name + ".multiplier_change(this, event);");
- // innerHTML = ` `;
- };
-
- };
-
- });
-
- });
-
- };
-
- this.start = () => {
-
- if(started)
- return;
- started = true;
-
- threads_start();
-
- screen.sizes = settings("screen_sizes");
-
- preload_wmarkdown(wmarkdown => {
- if(!wmarkdown)
- return;
-
- const references = {},
- logo = wmarkdown.querySelector(".logo img"),
- temporary_image = new Image();
-
- logo.setAttribute("data-status", "loading");
- temporary_image.src = logo.getAttribute("src");
-
- temporary_image.addEventListener("load", event => logo.parentNode.setAttribute("data-status", "ok"));
- temporary_image.addEventListener("error", event => logo.parentNode.setAttribute("data-status", "error"));
-
- try{
- typeof mermaid !== undefined && mermaid.initialize({startOnLoad : true});
- }catch(no_mermaid){console.error(["MERMAID_ERROR", no_mermaid])};
-
- try{
- typeof hljs !== undefined && item_self.querySelectorAll(".code-block:not([data-special=true])>.code-box").forEach(block => block.innerHTML = hljs.highlight(block.innerHTML.replace(/&(gt|lt|amp);/g, (...arguments) => {
- return {
- amp : "&",
- gt : ">",
- lt : "<"
- }[arguments[1]] || arguments[0];
- }), {language : block.parentNode.getAttribute("data-lang")}).value);
- }catch(no_highlighter){console.error(["HIGHLIGHTER_ERROR", no_highlighter])};
-
- item_self.querySelectorAll("[type=hidden][data-index]").forEach(reference => references[reference.getAttribute("data-index")] = reference.getAttribute("data-link"));
- item_self.querySelectorAll("a[data-index]").forEach(link => link.setAttribute("href", references[link.getAttribute("data-index")] || link.getAttribute("href")));
-
- item_self.querySelectorAll(".code-block[data-lang=maths]>div").forEach(item => {
- try{
-
- const formula = MathJax.tex2chtml(item.innerText);
-
- item.innerHTML = '';
- item.appendChild(formula);
-
- }catch(no_maths){console.error(["MATHS_ERROR", no_maths])};
- });
- MathJax.startup.document.clear();
- MathJax.startup.document.updateDocument();
-
- item_self.querySelectorAll("fieldset.headers-menu nav a,fieldset.files nav a+a").forEach(anchor => anchor.setAttribute("onclick", (anchor.getAttribute("onclick") || "") + object_name + ".go_to_item(this, event);"))
-
- dictionary && dictionary.start();
- multimedia && multimedia.start();
- wmonitor && wmonitor.start();
-
- on_ready_ok = true;
- on_ready_events.forEach(event => event && event());
-
- });
-
- };
-
- const construct = () => {
-
- object_name = self.object_name = settings("object_name");
-
- WMarkDown.Dictionary && (dictionary = self.dictionary = new WMarkDown.Dictionary(self));
- WMarkDown.Multimedia && (multimedia = self.multimedia = new WMarkDown.Multimedia(self));
- WMarkDown.WMonitor && (wmonitor = self.wmonitor = new WMarkDown.WMonitor(self));
-
- settings("autostart") && self.start();
-
- };
-
- const get_menu = menu => {
-
- if(menu)
- while(menu.tagName && menu.tagName.toLowerCase() != "fieldset" && (menu = menu.parentNode));
-
- return menu || null;
- };
-
- const show_menu = (element, visible) => {
-
- const menu = get_menu(element);
-
- menu && document.querySelector(".wmarkdown>.body").setAttribute("data-" + menu.getAttribute("class").split("-")[0] + "-menu-deployed", visible);
-
- };
-
- this.hide_menu = (element, event) => show_menu(element, false);
- this.show_menu = (element, event) => show_menu(element, true);
-
- this.block_code_scroll = (element, event) => element.parentNode.querySelector("ol").style.marginTop = -element.scrollTop + "px";
-
- this.deploy = (element, event, deployed) => {
- if(!element)
- return;
-
- while(!element.hasAttribute("data-level") && (element = element.parentNode));
- if(!element)
- return;
-
- const level = Number(element.getAttribute("data-level")) + 1,
- items = element.parentNode.querySelectorAll("[data-id=" + element.getAttribute("data-id") + "]~li"),
- l = items.length;
- let parent_deployed = [];
-
- element.setAttribute("data-deployed", typeof deployed == "boolean" ? deployed : deployed = element.getAttribute("data-deployed") == "false");
-
- for(let i = 0; i < l; i ++){
-
- const current_level = Number(items[i].getAttribute("data-level"));
-
- if(current_level < level)
- break;
-
- if(deployed){
- items[i].setAttribute("data-parent-deployed", current_level == level || parent_deployed[current_level - 1]);
- parent_deployed[current_level] = items[i].getAttribute("data-deployed") == "true";
- }else
- items[i].setAttribute("data-parent-deployed", false);
-
- };
-
- };
-
- this.hash = () => {
-
- let hash,
- alphabet = settings("hash_alphabet");
- const length = settings("hash_length"),
- l = (alphabet.push ? alphabet : alphabet = ("" + alphabet).split("")).length;
-
- do{
- hash = "";
- while((hash += alphabet[Math.random() * l >> 0]).length < length);
- }while(
- hashes.includes(hash) ||
- /^\d/.test(hash) ||
- document.querySelector("." + hash + ",#" + hash + ",[name=" + hash + "]")
- );
- hashes.push(hash);
-
- return hash;
- };
-
- this.utf8_encode = string => unescape(encodeURIComponent(string));
- this.utf8_decode = string => decodeURIComponent(escape(string));
-
- const load_file = this.load_file = (url, callback) => {
-
- let ended = false;
- const ajax = new XMLHttpRequest(),
- timeout = settings(["ajax_timeout", "timeout"]),
- end = error => {
- if(ended)
- return;
- ended = true;
- typeof callback == "function" && callback(ajax.responseText, ajax.status, ajax.readyState, error == "OK", error);
- },
- date = Date.now();
-
- ajax.open("get", url, true);
- ajax.timeout = timeout;
- ajax.onreadystatechange = () => {
- if(ended)
- return;
- if(ajax.readyState == 4)
- end("OK");
- else if(Date.now() - date > timeout)
- end("FORCED_TIMEOUT");
- };
- ajax.send(null);
-
- ajax.ontimeout = () => end("TIMEOUT");
- ajax.onabort = () => end("ABORTED");
- ajax.onerror = () => end("ERROR");
-
- return ajax;
- };
-
- this.send = (variables, callback) => {
-
- let ended = false;
- const ajax = new XMLHttpRequest(),
- timeout = settings(["ajax_timeout", "timeout"]),
- end = error => {
- if(ended)
- return;
- ended = true;
- typeof callback == "function" && callback(ajax.responseText, ajax.status, ajax.readyState, error == "OK", error);
- },
- date = Date.now();
-
- ajax.open("post", settings("wmd_file"), true);
- ajax.timeout = timeout;
- ajax.setRequestHeader("content-type", "application/x-www-form-urlencoded");
- ajax.onreadystatechange = () => {
- if(ended)
- return;
- if(ajax.readyState == 4)
- end("OK");
- else if(Date.now() - date > timeout)
- end("FORCED_TIMEOUT");
- };
- ajax.send(encodeURIComponent(settings("variable_name")) + "=" + btoa(JSON.stringify(variables)));
-
- ajax.ontimeout = () => end("TIMEOUT");
- ajax.onabort = () => end("ABORTED");
- ajax.onerror = () => end("ERROR");
-
- return ajax;
- };
-
- this.get_mime = (path, callback) => {
-
- const extension = path.match(/^.+\.([^\.\/]+)$/);
-
- if(!extension)
- return callback(settings("default_mime"));
-
- if(extension_mime.length){
- callback(extension_mime[extension[1]] || settings("default_mime"));
- return;
- };
-
- load_file(settings("extension_mime_file"), data => {
-
- let json = null;
-
- try{
- if(json = JSON.parse(data))
- for(const extension in json)
- extension_mime[extension] = json[extension];
- }catch(exception){};
-
- callback(extension_mime[extension[1]] || settings("default_mime"));
-
- });
-
- };
-
- this.get_extensions = (mime, callback) => {
-
- if(!mime)
- return callback(settings("default_extension"));
- if(mime_extension.length){
- callback(mime_extension[mime[1]] || settings("default_extension"));
- return;
- };
-
- load_file(settings("mime_extension_file"), data => {
-
- let json = null;
-
- try{
- if(json = JSON.parse(data))
- for(const mime in json)
- mime_extension[mime] = json[mime];
- }catch(exception){};
-
- callback(mime_extension[mime[1]] || settings("default_extension"));
-
- });
-
- };
-
- // http://detectmobilebrowsers.com
- this.is_mobile = () => {
-
- const user_agent = (navigator.userAgent || navigator.vendor || window.opera);
-
- return (
- /(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino/i.test(user_agent) ||
- /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(user_agent.substr(0, 4))
- );
- };
-
- // this.multiplier_change = (item, event) => item_self.setAttribute("data-size-multiplier", item.value);
- this.multiplier_mouse_down = (item, event) => item.setAttribute("data-clicked", true);
- this.multiplier_mouse_up = (item, event) => item.setAttribute("data-clicked", false);
- const multiplier_delimiter = (position, total) => position < 0 ? 0 : position > total ? total : position;
- const multiplier_resize = () => {
-
- const mark = item_self.querySelector(".wmd-options .multiplier .range-position"),
- total = item_self.querySelector(".wmd-options .multiplier .range-box").offsetWidth - mark.offsetWidth,
- range = settings("size_range"),
- position = ((range[1] - range[0]) * (mark.offsetLeft / total)) + range[0];
-
- item_self.setAttribute("data-size-multiplier", ((range[1] - range[0]) * (position / total)) + range[0]);
-
- };
- this.multiplier_change = (item, event) => {
-
- if(item.getAttribute("data-clicked") != "true")
- return;
-
- const mark = item.querySelector(".range-position"),
- total = item.offsetWidth - mark.offsetWidth,
- range = settings("size_range");
- let position = multiplier_delimiter(event.clientX - event.target.getBoundingClientRect().left - (mark.offsetWidth / 2));
-
- mark.style.left = position + "px";
- multiplier_resize();
-
- };
- this.multiplier_less = (item, event) => {
-
- const mark = item.parentNode.querySelector(".range-position"),
- total = item.offsetWidth - mark.offsetWidth;
- let position = multiplier_delimiter(mark.offsetLeft - (total / 10));
-
- mark.style.left = position + "px";
- // console.log([position, mark.offsetLeft, (total / 10), mark.style.left, mark.offsetLeft]);
- multiplier_resize();
-
- };
- this.multiplier_more = (item, event) => {
-
- const mark = item.parentNode.querySelector(".range-position"),
- total = item.offsetWidth - mark.offsetWidth;
- let position = multiplier_delimiter(mark.offsetLeft + (total / 10));
-
- mark.style.left = position + "px";
- // console.log([position, mark.offsetLeft, (total / 10), mark.style.left, mark.offsetLeft]);
- multiplier_resize();
-
- };
-
- this.view_show = (item, event, key) => item_self.setAttribute("data-view", key);
-
- this.go_to_item = (item, event) => item_self.setAttribute("data-view", "content");
-
- this.on_ready = callback => {
- if(typeof callback != "function")
- return null;
- if(on_ready_ok){
- callback();
- return null;
- };
-
- let i = 0;
- const l = on_ready_events.length;
-
- for(; i < l; i ++)
- if(!on_ready_events[i])
- break;
-
- on_ready_events[i] = callback;
-
- return i;
- };
-
- this.remove_on_ready = i => !isNaN(i) && on_ready_events[i] && (on_ready_events[i] = null);
-
- construct();
-
-};
+"use strict";
+
+/**
+ * @callback wmarkdown_ajax_callback
+ * @param {?string} response
+ * @param {!number} status
+ * @param {!number} state
+ * @param {!boolean} ok
+ * @param {!string} message
+ * @return {void}
+ */
+
+/**
+ * @constructor
+ * @param {?string|Object.} [inputs]
+ * @returns {void}
+ * @access public
+ */
+const WMarkDown = function(inputs){
+
+ /** @type {WMarkDown} */
+ const self = this,
+ /** @type {Array.} */
+ dictionary_done = [],
+ /** @type {Array.|Array.>>} */
+ dictionary = [],
+ /** @type {Array.} */
+ root_boxes = [],
+ /** @type {string} */
+ hash_alphabet = "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz",
+ /** @type {number} */
+ hash_length = 11,
+ /** @type {Array.} */
+ hashes = [],
+ /** @type {Array.>} */
+ type_dictionary = [
+ ["JavaScript/ECMAScript", "js", "javascript", "ecma", "ecmascript", "node", "nodejs", "typescript", "ts"],
+ ["Python", "python", "py"]
+ ];
+ /** @type {number|null} */
+ let thread_inteval = null,
+ /** @type {boolean} */
+ dictionary_loaded = false,
+ /** @type {Array. {
+
+ if(typeof inputs == "string")
+ inputs = {dictionary : inputs};
+
+ thread_inteval = setInterval(thread_method, 250);
+
+ if(inputs.dictionary){
+
+ /** @type {number} */
+ let loaded = 0;
+ /** @type {Array.} */
+ const dictionaries = inputs.dictionary instanceof Array ? inputs.dictionary : [inputs.dictionary],
+ /**
+ * @returns {void}
+ */
+ end = () => ++ loaded == dictionaries.length && (dictionary_loaded = true);
+
+ dictionaries.forEach(url => WMarkDown.prototype.get(url, data => {
+ try{
+ self.add_to_dictionary(JSON.parse(data));
+ }catch(exception){
+ console.error(exception);
+ };
+ end();
+ }));
+
+ };
+
+ };
+
+ /**
+ * @param {!Array., Array., Array.>} data
+ * @returns {void}
+ * @access public
+ */
+ this.add_to_dictionary = data => data.forEach(([patterns, definition, links]) => {
+
+ /** @type {number|null} */
+ let i = null;
+
+ patterns[0] instanceof Array || (patterns = [patterns]);
+
+ patterns.forEach(([pattern, text]) => {
+ if(!dictionary_done.includes(text)){
+ if(i === null)
+ dictionary[i = dictionary.length] = {
+ patterns : [[WMarkDown.prototype.format_pattern(pattern), text]],
+ definition : typeof definition == "string" ? definition : definition.join(""),
+ links : links
+ };
+ else
+ dictionary[i].patterns.push([WMarkDown.prototype.format_pattern(pattern), text]);
+ };
+ });
+
+ });
+
+ /**
+ * @returns {string}
+ * @access public
+ */
+ this.get_hash = () => {
+
+ /** @type {string} */
+ let hash;
+ /** @type {number} */
+ const l = hash_alphabet.length;
+
+ do{
+ hash = "";
+ while((hash += hash_alphabet[Math.random() * l >> 0]).length < hash_length);
+ }while(
+ hashes.includes(hash) ||
+ /^[0-9]/.test(hash) ||
+ document.querySelector("." + hash + ",#" + hash + ",[name=" + hash + "]")
+ );
+ hashes.push(hash);
+
+ return hash;
+ };
+
+ /**
+ * @param {!NodeList} block
+ * @returns {void}
+ * @access public
+ */
+ this.format_dictionary = block => block.childNodes.forEach((item, i) => {
+
+ /** @type {Array.>} */
+ const blocks = [];
+
+ if(item.nodeName == "#text"){
+ if(item.textContent.trim()){
+
+ /** @type {string} */
+ let html = item.textContent;
+ /** @type {Array.} */
+ const items = [];
+
+ dictionary.forEach((item, k) => {
+ item.patterns.forEach(([pattern, text]) => {
+ html = html.replace(pattern, (...matches) => {
+
+ /** @type {number} */
+ const j = items.length;
+
+ items.push([k, matches, text.replace(/\$([0-9])/g, (all, match_i) => {
+ return matches[match_i] !== null && matches[match_i] !== undefined ? matches[match_i] : "";
+ })]);
+
+ return dictionary_item_mark[0] + j + dictionary_item_mark[1];
+ });
+ });
+ });
+
+ if(html != item.textContent){
+
+ /** @type {HTMLSpanElement} */
+ const element = document.createElement("span");
+
+ blocks.push([i, element]);
+
+ element.innerHTML = html.replace(dictionary_item_mark[2], (_, j) => {
+
+ /** @type {Array.} */
+ const [k, matches, text] = items[Number(j)];
+
+ return `` + text + ` `;
+ });
+
+ };
+
+ };
+ }else if(
+ !["img", "a", "audio", "canvas", "picture"].includes((item.tagName || item.nodeName).toLowerCase()) &&
+ !["wmd-excluded", "wmd-code-block", "wmd-code-doc"].some(class_name => item.classList && item.classList.contains(class_name))
+ ){
+ self.format_dictionary(item);
+ addEventListener("click", self.dictionary_out);
+ };
+
+ blocks.forEach(([i, element]) => {
+ block.insertBefore(element, block.childNodes[i]);
+ block.childNodes[i + 1].remove();
+ });
+
+ });
+
+ /**
+ * @param {!HTMLElement} item
+ * @returns {HTMLElement|null}
+ * @access public
+ */
+ this.get_root_box = item => {
+
+ /** @type {HTMLElement|null} */
+ let box = null;
+
+ while(item && item.classList && (item = item.parentNode))
+ item.classList && item.classList.contains("wmarkdown") && (box = item);
+
+ return box;
+ };
+
+ /**
+ * @param {!HTMLUListElement} data_box
+ * @param {!String} i18n
+ * @param {!String} text
+ * @param {!String} action
+ * @returns {HTMLLIElement}
+ * @access private
+ */
+ const add_button_data = (data_box, i18n, text, action) => {
+
+ /** @type {HTMLLIElement} */
+ const button = data_box.appendChild(document.createElement("li"));
+
+ button.setAttribute("data-i18n", i18n);
+ button.setAttribute("data-i18n-without", true);
+ button.setAttribute("title", text);
+ button.setAttribute("onclick", action);
+ button.innerHTML = (`
+
+ ` + text + `
+ ` + text + `
+ `);
+
+ return button;
+ };
+
+ /**
+ * @param {!HTMLElement} box
+ * @param {!String} name
+ * @param {!Array.} [buttons]
+ * @returns {void}
+ * @access private
+ */
+ const set_special_type = (box, name, buttons) => {
+
+ while(!box.classList.contains("wmd-code-block") && (box = box.parentNode));
+
+ /** @type {HTMLUListElement} */
+ const data = box.querySelector(".data");
+
+ box.querySelector("li[data-i18n=type]>.value").innerHTML = name;
+ add_button_data(data, "view_switch", "View switch", "WMarkDown.prototype.view_switch(this, event);");
+
+ buttons && buttons.forEach(([i18n, text, action]) => add_button_data(data, i18n, text, action));
+
+ };
+
+ /**
+ * @param {!HTMLElement} content
+ * @param {!String} language
+ * @returns {HTMLDivElement}
+ * @access private
+ */
+ const build_special_type = (content, language) => {
+ content.parentNode.childNodes.forEach(item => item.tagName && item.setAttribute("data-visible", false));
+
+ /** @type {HTMLDivElement} */
+ const box = content.parentNode.appendChild(document.createElement("div"));
+
+ box.setAttribute("class", "view");
+ box.setAttribute("data-visible", true);
+ set_special_type(content, language);
+
+ return box;
+ };
+
+ /**
+ * @returns {void}
+ * @access private
+ */
+ const thread_method = () => {
+
+ /** @type {HTMLBodyElement} */
+ const body = document.querySelector("body");
+
+ document.querySelectorAll(".wmd-code-block[data-processed=false]").forEach(block => {
+
+ /** @type {string} */
+ const language = block.getAttribute("data-type").toLowerCase(),
+ /** @type {HTMLElement} */
+ content = block.querySelector(".content"),
+ /** @type {String} */
+ type = block.getAttribute("data-type").toLowerCase();
+
+ block.setAttribute("data-processed", true);
+
+ if(["math", "maths", "mathjax"].includes(language)){
+ build_special_type(content, "MathJax").innerHTML = MathJax.tex2chtml(content.innerText).outerHTML;
+ MathJax.startup.document.clear();
+ MathJax.startup.document.updateDocument();
+ }else if(["mermaid", "mermaidjs", "mermaid_js"].includes(language)){
+
+ /** @type {HTMLDivElement} */
+ const box = build_special_type(content, "Mermaid JS");
+
+ mermaid.render(self.get_hash(), content.innerText).then(graph => box.innerHTML = graph.svg);
+
+ }else
+ try{
+ content.innerHTML = hljs.highlight(content.innerText, {language : (
+ ["wmd-examples", "wmd", "wmarkdown"].includes(language) ? "markdown" :
+ language)}).value;
+ type_dictionary.some(alternatives => {
+ if(alternatives.includes(type)){
+ block.querySelector("[data-i18n=type]>.value").innerText = alternatives[0];
+ return true;
+ };
+ return false;
+ });
+ }catch(exception){};
+
+ });
+
+ if(dictionary_loaded){
+
+ /** @type {HTMLElement} */
+ const block = document.querySelector("[data-dictionary-processed=false]");
+
+ if(block && [...block.childNodes].slice(-3).some(item => (
+ item.classList &&
+ item.classList.contains("wmd-process-and-loaded")
+ ))){
+
+ block.querySelectorAll(".wmd-process-and-loaded").forEach(item => {
+ item.parentNode.hasAttribute("data-dictionary-processed") &&
+ item.parentNode.setAttribute("data-dictionary-processed", true);
+ item.remove();
+ });
+
+ self.format_dictionary(block);
+
+ };
+
+ };
+
+ document.querySelectorAll("[data-list-unprocessed=true]").forEach(list => {
+
+ /** @type {HTMLSpanElement} */
+ const deployer = list.parentNode.insertBefore(document.createElement("span"), list.parentNode.childNodes[0]);
+
+ [
+ ["data-deployed", list.getAttribute("data-deployed")],
+ ["onclick", "WMarkDown.prototype.deploy(this, event);"]
+ ].forEach(([key, value]) => deployer.setAttribute(key, value));
+ deployer.innerHTML = (`
+
+ Deploy
+ `);
+
+ list.setAttribute("data-list-unprocessed", false);
+
+ });
+
+ document.querySelectorAll(".wmd-media[data-status=unprocessed]").forEach(item => item.setAttribute("data-status", "unloaded"));
+
+ if(body){
+
+ document.querySelectorAll(".wmd-media[data-status=unloaded]").forEach((item, i) => {
+
+ /** @type {DOMRect} */
+ const bounds = item.getBoundingClientRect();
+
+ if(
+ (bounds.y + bounds.height > -100 && bounds.y < body.offsetHeight + 100) &&
+ (bounds.x + bounds.width > -100 && bounds.x < body.offsetWidth + 100)
+ ){
+
+ /** @type {HTMLElement} */
+ const main_item = item.querySelector("noscript+*");
+
+ item.setAttribute("data-status", "loading");
+
+ if(main_item.tagName.toLowerCase() == "img"){
+ [
+ ["onload", "WMarkDown.prototype.image_loaded(this, event);"],
+ ["onerror", "WMarkDown.prototype.image_load(this, event);"]
+ ].forEach(([key, value]) => main_item.setAttribute(key, value));
+ item.setAttribute("data-status", "loading");
+ self.image_load(main_item);
+ };
+
+ };
+
+ });
+
+ document.querySelectorAll(".wmarkdown[data-menu-processed=false]").forEach(block => {
+ if(block.getAttribute("data-menu-processed") == "true")
+ return;
+
+ /** @type {HTMLUListElement|null} */
+ let menu = document.querySelector(".wmd-main-menu>ul");
+ /** @type {Array.} */
+ const items = block.querySelectorAll("h1,h2,h3,h4,h5,h6");
+
+ if(items.length){
+
+ /** @type {number} */
+ let current_level = 0;
+
+ if(!menu){
+
+ /** @type {HTMLDivElement} */
+ const button = document.querySelector("header").appendChild(document.createElement("div"));
+
+ (menu = (
+ document.querySelector("[data-cells]") || document.querySelector("body")
+ ).appendChild(document.createElement("nav"))).appendChild(document.createElement("ul"));
+ menu.setAttribute("class", "wmd-main-menu");
+ menu.setAttribute("data-visible", false);
+ menu = menu.childNodes[0];
+
+ addEventListener("click", WMarkDown.prototype.hide_menu);
+
+ button.innerHTML += (`
+
+
+ Menu
+
+ `);
+ button.setAttribute("class", "wmd-main-menu-button");
+
+ };
+
+ current_level = [...items].reduce((lower, item) => {
+
+ const level = Number(item.tagName[1]);
+
+ return level < lower ? level : lower
+ }, 6);
+ items.forEach(item => {
+
+ const level = Number(item.tagName[1]),
+ menu_item = document.createElement("li"),
+ anchor = menu_item.appendChild(document.createElement("a"));
+
+ menu_item.setAttribute("data-level", level);
+ anchor.innerText = item.innerText;
+ anchor.setAttribute("href", "#" + item.getAttribute("id"));
+ anchor.setAttribute("target", "_self");
+ anchor.setAttribute("title", item.innerText);
+
+ if(current_level < level){
+
+ const subblock = menu.childNodes[menu.childNodes.length - 1];
+
+ if(!(menu = subblock.childNodes[menu.childNodes.length - 1]) || menu.tagName.toLowerCase() != "ul"){
+
+ const button_deployer = subblock.insertBefore(document.createElement("span"), subblock.childNodes[0]);
+
+ menu = subblock.appendChild(document.createElement("ul"));
+
+ button_deployer.setAttribute("data-deployed", false);
+ button_deployer.setAttribute("onclick", "WMarkDown.prototype.deploy(this, event);");
+ button_deployer.innerHTML = (`
+
+ Deploy
+ `);
+
+ };
+
+ current_level ++;
+
+ }else
+ while(current_level > level && menu.parentNode.parentNode.tagName.toLowerCase() == "ul"){
+ current_level --;
+ menu = menu.parentNode.parentNode;
+ };
+
+ menu.appendChild(menu_item);
+
+ });
+
+ };
+
+ block.setAttribute("data-menu-processed", true);
+ block.querySelectorAll(".wmarkdown[data-menu-processed=false]").forEach(subblock => subblock.setAttribute("data-menu-processed", true));
+
+ window.location.hash && (window.location.href = window.location.hash);
+
+ });
+
+ };
+
+ };
+
+ /**
+ * @param {!HTMLElement} item
+ * @param {!MouseEvent} event
+ * @returns {void}
+ * @access public
+ */
+ this.dictionary_over = (item, event) => setTimeout(() => {
+
+ /** @type {string|null} */
+ const hash = item.getAttribute("data-hash");
+
+ if(!hash || dictionary_boxes.includes(hash))
+ return;
+
+ /** @type {HTMLBodyElement} */
+ const body = document.querySelector("body"),
+ /** @type {HTMLDivElement} */
+ box = document.querySelector("body").appendChild(document.createElement("div")),
+ /** @type {DOMRect} */
+ bounds = item.getBoundingClientRect(),
+ /** @type {number} */
+ x = bounds.x + (bounds.width / 2),
+ /** @type {number} */
+ y = bounds.y + (bounds.height / 2),
+ /** @type {number} */
+ i = Number(item.getAttribute("data-i")),
+ own_keys = [];
+
+ box.setAttribute("class", "wmd-dictionary-box");
+ box.setAttribute("data-dictionary-box", hash);
+
+ dictionary_boxes.push(hash);
+
+ box.innerHTML = (`
+ ` + dictionary[i].patterns.reduce((definition, [pattern, text]) => (
+ definition.replace(pattern, () => {
+ own_keys.push(text.replace(/\$[0-9]/g, ""));
+ return dictionary_item_mark[0] + (own_keys.length - 1) + dictionary_item_mark[1];
+ })
+ ), dictionary[i].definition).replace(dictionary_item_mark[2], (all, i) => `` + own_keys[i] + ` `) + `
+ ` + dictionary[i].links.map(link => ` `).join("") + `
+ `);
+
+ box.style.zIndex = dictionary_z ++;
+ if(x > body.offsetWidth / 2)
+ box.style.right = (body.offsetWidth - x) + "px";
+ else
+ box.style.left = x + "px";
+ if(y > body.offsetHeight / 2)
+ box.style.bottom = (body.offsetHeight - y) + "px";
+ else
+ box.style.top = y + "px";
+
+ setTimeout(() => self.format_dictionary(box.querySelector(".definition")), 100);
+
+ }, 100);
+
+ /**
+ * @param {!HTMLElement} item
+ * @param {!MouseEvent} event
+ * @returns {void}
+ * @access public
+ * @static
+ */
+ this.dictionary_out = event => {
+
+ /** @type {string|null} */
+ let hash = null,
+ /** @type {HTMLElement} */
+ item = event.target,
+ /** @type {string|null} */
+ box_hash = null,
+ /** @type {string|null} */
+ item_hash = null;
+
+ while(item.classList){
+ if(item.classList.contains("wmd-dictionary-box")){
+ box_hash = hash = item.getAttribute("data-dictionary-box");
+ break;
+ }else if(item.classList.contains("wmd-dictionary-item"))
+ item_hash = hash = item.getAttribute("data-hash");
+ item = item.parentNode;
+ };
+
+ if(hash){
+
+ /** @type {number} */
+ let i = dictionary_boxes.indexOf(hash);
+
+ if(++ i){
+
+ /** @type {number} */
+ let j,
+ /** @type {number} */
+ k;
+
+ if(box_hash)
+ [j, k] = (
+ !dictionary_boxes.includes(item_hash) ? [i, dictionary_boxes.length] :
+ [i = dictionary_boxes.indexOf(item_hash) + 1, dictionary_boxes.length]);
+ else{
+ [j, k] = [0, dictionary_boxes.length];
+ i = 0;
+ };
+
+ dictionary_boxes.slice(j, k).forEach(hash => {
+ document.querySelector(".wmd-dictionary-box[data-dictionary-box=" + hash + "]").remove();
+ dictionary_boxes.splice(i, 1);
+ });
+
+ return;
+ };
+
+ };
+
+ document.querySelectorAll(".wmd-dictionary-box").forEach(box => box.remove());
+ dictionary_boxes = [];
+
+ };
+
+ constructor();
+
+};
+
+/**
+ * @param {!string} pattern
+ * @returns {RegExp}
+ * @access public
+ * @static
+ */
+WMarkDown.prototype.format_pattern = pattern => {
+
+ /** @type {RegExpMatchArray} */
+ const matches = pattern.match(/^\/(.+)\/([a-z]*)$/);
+
+ matches || console.log([pattern, matches]);
+
+ return new RegExp(matches[1], matches[2]);
+};
+
+/**
+ * @param {!string} url
+ * @param {!wmarkdown_ajax_callback} callback
+ * @returns {XMLHttpRequest}
+ * @access public
+ * @static
+ */
+WMarkDown.prototype.get = (url, callback) => {
+
+ /** @type {boolean} */
+ let ended = false;
+ /** @type {XMLHttpRequest} */
+ const ajax = new XMLHttpRequest(),
+ /** @type {number} */
+ time = Date.now(),
+ /**
+ * @param {!string} message
+ * @returns {void}
+ */
+ end = message => !ended && (ended = true) && typeof callback == "function" && callback(
+ ajax.responseText,
+ ajax.status,
+ ajax.readyState,
+ message == "OK",
+ message
+ );
+
+ ajax.open("get", url, true);
+ ajax.timeout = 2000;
+ ajax.onreadystatechange = () => {
+ if(ended)
+ return;
+ if(ajax.readyState == 4)
+ end((ajax.status >= 200 && ajax.status < 300) || [301, 302, 304].includes(ajax.status) ? "OK" : "HTTP_ERROR");
+ else if(Date.now() - time > 2000)
+ end("FORCED_TIMEOUT");
+ };
+ ajax.send(null);
+
+ ajax.onerror = () => end("ERROR");
+ ajax.onabort = () => end("ABORTED");
+ ajax.ontimeout = () => end("TIMEOUT");
+
+ return ajax;
+};
+
+/**
+ * @param {!HTMLSpanElement} item
+ * @param {!MouseEvent} event
+ * @returns {void}
+ * @access public
+ * @static
+ */
+WMarkDown.prototype.deploy = (item, event) => item.setAttribute("data-deployed", item.getAttribute("data-deployed") == "false");
+
+/**
+ * @param {!HTMLImageElement} item
+ * @param {!ErrorEvent} [event]
+ * @returns {void}
+ * @access public
+ * @static
+ */
+WMarkDown.prototype.image_load = (item, event) => {
+
+ /** @type {Array.} */
+ const images = JSON.parse(atob(item.getAttribute("data-sources"))),
+ /** @type {number} */
+ i = Number(item.getAttribute("data-i"));
+
+ if(i >= images.length){
+ item.parentNode.setAttribute("data-status", "error");
+ return;
+ };
+
+ item.setAttribute("src", images[i]);
+ item.setAttribute("data-i", i + 1);
+
+};
+
+/**
+ * @param {!HTMLImageElement} item
+ * @param {!EventTarget} [event]
+ * @returns {void}
+ * @access public
+ * @static
+ */
+WMarkDown.prototype.image_loaded = (item, event) => {
+
+ /** @type {HTMLSpanElement|Null} */
+ const span_image = item.parentNode.querySelector(".image");
+
+ item.parentNode.setAttribute("data-status", "success");
+
+ span_image && (span_image.style.backgroundImage = "url('" + item.src + "')");
+
+};
+
+/**
+ * @param {!HTMLElement} [item]
+ * @param {!EventTarget} [event]
+ * @returns {void}
+ * @access public
+ * @static
+ */
+WMarkDown.prototype.show_menu = (item, event) => document.querySelector(".wmd-main-menu").setAttribute("data-visible", true);
+
+/**
+ * @param {!EventTarget} event
+ * @returns {void}
+ * @access public
+ * @static
+ */
+WMarkDown.prototype.hide_menu = event => {
+ if(
+ event.target.parentNode.parentNode.classList &&
+ event.target.parentNode.parentNode.classList.contains("wmd-main-menu-button")
+ )
+ return;
+
+ /** @type {HTMLElement|null} */
+ const main_menu = document.querySelector(".wmd-main-menu");
+
+ if(!main_menu || main_menu.getAttribute("data-visible") == "false")
+ return;
+
+ /** @type {HTMLElement} */
+ let item = event.target;
+
+ while(item.tagName.toLowerCase() != "body" && item != main_menu)
+ item = item.parentNode;
+
+ item != main_menu && main_menu.setAttribute("data-visible", false);
+
+};
+
+/**
+ * @param {!HTMLElement} item
+ * @param {!MouseEvent} [event]
+ * @returns {void}
+ * @access public
+ * @static
+ */
+WMarkDown.prototype.view_switch = (item, event) => {
+
+ /** @type {HTMLDivElement} */
+ const box = item.parentNode.parentNode.querySelector(".code");
+
+ if(!box)
+ return;
+
+ /** @type {HTMLDivElement} */
+ const view = box.querySelector(".view"),
+ /** @type {Boolean} */
+ visible = view.getAttribute("data-visible") != "true";
+
+ view.setAttribute("data-visible", visible);
+ ["lines", "content"].forEach(key => box.querySelector("." + key).setAttribute("data-visible", !visible));
+
+};
\ No newline at end of file
diff --git a/Public/ecma2/WMarkDown.Converter.ecma.js b/Public/ecma2/WMarkDown.Converter.ecma.js
deleted file mode 100644
index ac552a8..0000000
--- a/Public/ecma2/WMarkDown.Converter.ecma.js
+++ /dev/null
@@ -1,63 +0,0 @@
-WMarkDown.converter = function(wmd, input){
-
- const self = this,
- cache = [];
- let started = false;
-
- let modules = this.modules;
-
- const construct = () => {
-
- WMarkDown.Converter.Modules && (modules = self.modules = new WMarkDown.Converter.Modules(wmd, input));
-
- };
-
- this.start = callback => {
-
- const end = status => typeof callback == "function" && callback(status)
-
- if(started){
- end(false);
- return false;
- };
- started = true;
-
- end(true);
-
- return true;
- };
-
- this.process = wmd_script => {
-
- let i = 0,
- html = ``;
- const l = cache.length,
- indexes = {},
- modules_keys = modules.get_keys();
-
- for(; i < l; i ++)
- if(cache[i] === null)
- break;
- cache[i] = {};
-
- while(modules_keys.length){
-
- const clean_i = [];
-
- modules_keys.forEach((key, i) => {
- if(!indexes[key] || indexes[key].index < 0){
- };
- });
-
- clean_i.reverse().forEach(i => {
- delete indexes[modules_keys[i]];
- modules_keys.splice(i, 1);
- });
-
- };
-
- };
-
- construct();
-
-};
\ No newline at end of file
diff --git a/Public/ecma2/WMarkDown.ecma.js b/Public/ecma2/WMarkDown.ecma.js
deleted file mode 100644
index aa92b98..0000000
--- a/Public/ecma2/WMarkDown.ecma.js
+++ /dev/null
@@ -1,37 +0,0 @@
-WMarkDown = function(input){
-
- const self = this;
- let started = false;
-
- let converter = this.converter;
-
- const construct = () => {
-
- WMarkDown.Converter && (converter = self.converter = new WMarkDown.Converter(self, input));
-
- };
-
- this.start = callback => {
-
- const end = status => typeof callback == "function" && callback(status)
-
- if(started){
- end(false);
- return false;
- };
- started = true;
-
- end(true);
-
- self.launch(["converter"], () => end(true));
-
- return true;
- };
-
- this.launch = (blocks, callback, i) => self[blocks[i || (i = 0)]] && self[blocks[i]].start ? self[blocks[i]].start(() => launch(blocks, callback, i + 1)) : launch(blocks, callback, i + 1);
-
- this.convert = wmd_code => self.converter ? self.converter.process(wmd_code) : null
-
- construct();
-
-};
\ No newline at end of file
diff --git a/Public/ecma2/converter/WMarkDown.Converter.Modules.ecma.js b/Public/ecma2/converter/WMarkDown.Converter.Modules.ecma.js
deleted file mode 100644
index 2549580..0000000
--- a/Public/ecma2/converter/WMarkDown.Converter.Modules.ecma.js
+++ /dev/null
@@ -1,49 +0,0 @@
-WMarkDown.Converter.Modules = function(wmd, input){
-
- const self = this,
- excluded_keys = ["start", "get_keys"],
- modules_keys = [];
- let started = false;
-
- const construct = () => {
-
- const to_snake_fragment = string => string ? " " + string.toLowerCase() : "";
-
- Object.keys(WMarkDown.Converter.Modules).forEach(key => {
- if(!excluded_keys.includes(key)){
-
- const key = key.replace(/([A-Z]+)?([A-Z])/g, (...matches) => (" " +
- to_snake_fragment(matches[1]) +
- to_snake_fragment(matches[2])
- ));
-
- self[key] = new WMarkDown.Converter.Modules[key](wmd);
- !(self[key].pattern instanceof Array) && (self[key].pattern = [self[key].pattern]);
-
- modules_keys.push(key);
-
- };
- });
-
- };
-
- this.start = callback => {
-
- const end = status => typeof callback == "function" && callback(status)
-
- if(started){
- end(false);
- return false;
- };
- started = true;
-
- end(true);
-
- return true;
- };
-
- this.get_keys = () => [].concat(modules_keys);
-
- construct();
-
-};
\ No newline at end of file
diff --git a/Public/ecma2/converter/modules/WMarkDown.Converter.Modules.Headers.ecma.js b/Public/ecma2/converter/modules/WMarkDown.Converter.Modules.Headers.ecma.js
deleted file mode 100644
index 8e42d80..0000000
--- a/Public/ecma2/converter/modules/WMarkDown.Converter.Modules.Headers.ecma.js
+++ /dev/null
@@ -1,10 +0,0 @@
-WMarkDown.converter.Modules.Headers = function(wmd){
-
- this.pattern = [
- /^(\#{1,6})([^\r\n\#]+)(\#{1,6})?$/m,
- /^(\={1,6})([^\r\n\=]+)(\={1,6})?$/m
- ];
-
- this.process = matches => `` + matches[2].trim() + ` `;
-
-};
\ No newline at end of file
diff --git a/Public/favicon.ico b/Public/favicon.ico
new file mode 100644
index 0000000000000000000000000000000000000000..ff78a5c8ee365ad47a2122b2b346d2fd883f9b5a
GIT binary patch
literal 4286
zcma)9c}$c?6#tgRVoa-TJbENWQY5vhwx)^E+COUQBB)igYOh!#ZLKzH)Y`_hS|Lhx
z7eVC^$|1;6EXo;JL=f3U<&sNo5fHfq7Fc#+-Gx1-Z&qfR?^x=$dHd#gzxR7H-^`o&
z7)As?7Z(QqGylHIFpC(5SqcJ8%vuoK{(p~Ft7U`)-|8qj*;@DuBNR-UYe<1CuI;3MNPp7@XeOePZOs$;)gb-^}vj6Lv8Br+O}@>C?$>9&y4!l2AsOKUXYYbLj4pP+7)?1LO_-BH|PIOqN%%ayDB7HW6@o-t!?~XM+
zt}m8I9eDhE!neZQ8Ga)CSWg%xzu)5(&hvv~xTmadhBe%@@HPVqicE6bXy`7v&LeVUu>PT+t-Q`
zd2@#2NK;41$Lf$XKZ=+?9}?(^1*cO&PgwsfU&q$
zG?kVRPFf#}+lx$Q(>5+YuERd`@cSi+H+~!g%;^C5oii}fA4JZP_MS)4#!2Ju#<~vM
z*#%?&73^l`mSv65yrdkL_qQ4P-x1=6_O~J58p)Vx9UplU<6JO~dxmoBVCNQlBiu|l
zX`NS|Jp}#MyvvON+GoKy`)FQLK5;MspI4i?7@@k!WZZG|vJdaw<2Wi?%1ePq2xeV_
zwNMp6A_5{{H?#Fvi{8oq5_jbbiAd0lYQf
z4*R01;c=?H*oi~j-`G)~fzL>K-f?+%m?u8Be-?|y#GI#LpL_5BI+Dka-@~1v+Gg<2
z${Sn<(C?tEx%H6CjqB&G`$0Ea!^O~b=>I4zAj?ADJFQcbl{jxMpzXP3=zle%IK?2u
zpHh@yfc}MC3|)u*IoWCV#%NwrK7R^NKUz)OlQKR-r({h~>M7pb<9L*{h4{R7z;@jG
zBk=?MA~?J12q&$5HiqH5z&=MuM`CW(fMLdT+W7p6oQA^6yeHhd3Ym+mg;&OJmgh9U
z`m6v9>;6a_Vqa~oJ@M{y_<7i4p$v6(_J^K6eVUltG~~1$A(>Lv`9OH5wFspuli}KE
z{1)@rd$bze(XUnu=i$n-<`N++w22`fmTfw>Sa9xf43}?QGQ+*&h!CER1>TRu|5&o%
z9>~is9|k-xf8lq6aS8cRf_d*knm^uqGQiHbe{dXN^Hy@~E!KUOtb@3S8#oWU(eaWp
z_T8)MmVXhnf;9)eNk@=cI}!{1_BTFp@|@qXsGz!=aMJp>A7hcpWZq7hvx>m60`{Nn
z-g6l4zk?(FInX|vWjI3x?~Mo5Z8`WGg678ME$;@R;USH$Jvi_%D)r!%T_K+#pRf(6
zd*BJq_jB#p3$?qsxiL@shGZMz8-o6xvX{as4+q!?qry0nP(7p&NDcT5^)-(ehQJnNg)Pt0xK+FJ-XN=Hhc==
LYZBwnPlWyhX`~G}
literal 0
HcmV?d00001
diff --git a/Public/git_update.php b/Public/git_update.php
deleted file mode 100755
index 7db4694..0000000
--- a/Public/git_update.php
+++ /dev/null
@@ -1,18 +0,0 @@
-&1");
-
- // header("content-type: text/plain");
- //
- // $fetch = trim(shell_exec("git fetch 2>&1"));
- //
- // if(!preg_match('/(From|Desde) https:\/\//', $fetch)){
- // echo "There are not any updates.";
- // // echo "There is no update.";
- // exit(0);
- // };
- //
- // $pull = shell_exec("git pull 2>&1");
- //
- // echo $fetch . "\n\n" . $pull . "\n\nIt is already updated successfully.";
diff --git a/Public/images/WMarkDown-180.png b/Public/images/WMarkDown-180.png
new file mode 100644
index 0000000000000000000000000000000000000000..a3951817448cd7560ec49686930b854e07cdea92
GIT binary patch
literal 14760
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
literal 0
HcmV?d00001
diff --git a/Public/images/WMarkDown-192.png b/Public/images/WMarkDown-192.png
new file mode 100644
index 0000000000000000000000000000000000000000..1b4d20a1438256648fa1410bb1a8ad0e48ec7d92
GIT binary patch
literal 12883
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
I+AQ>c0J*z9XaE2J
literal 0
HcmV?d00001
diff --git a/Public/images/WMarkDown-270.png b/Public/images/WMarkDown-270.png
new file mode 100644
index 0000000000000000000000000000000000000000..1e98c015ed876c21a7cd1fecd0b01358f8718399
GIT binary patch
literal 13105
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