fix: Migrating project to the new Gitea Host.
This commit is contained in:
parent
0abd9a1ebc
commit
b4b8a4f019
7
.gitignore
vendored
Executable file
7
.gitignore
vendored
Executable file
@ -0,0 +1,7 @@
|
||||
Public/data
|
||||
PHP/JSReports.Secrets.php
|
||||
JSReports.apache2.conf
|
||||
Public/index.html
|
||||
Public/dev
|
||||
Public/es
|
||||
JSON/html.files.json
|
183
HTML/base.jsreports.html
Executable file
183
HTML/base.jsreports.html
Executable file
@ -0,0 +1,183 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="es" dir="ltr">
|
||||
<head>
|
||||
<title>{title}</title>
|
||||
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
|
||||
<meta charset="utf-8" />
|
||||
<meta name="viewport" content="width=device-width,initial-scale=1.0" />
|
||||
<link rel="icon" href="/images/JSReports-32.png" sizes="32x32" />
|
||||
<link rel="icon" href="/images/JSReports-192.png" sizes="192x192" />
|
||||
<link rel="icon" href="/images/JSReports-512.png" sizes="512x512" />
|
||||
<link rel="apple-touch-icon-precomposed" href="/images/JSReports-180.png" />
|
||||
<meta name="msapplication-TileImage" content="/images/JSReports-270.png" />
|
||||
|
||||
<meta name="licence:text" content="© 2020-2021 CopyLeft. GPLv3" />
|
||||
<meta name="licence:link" content="https://www.gnu.org/licenses/gpl-3.0.txt" />
|
||||
<meta name="licence:icon" content="https://www.gnu.org/graphics/gplv3-88x31.png" />
|
||||
|
||||
<meta name="xdoc:link" content="{url}" />
|
||||
<meta name="xdoc:author" content="{author}" />
|
||||
<meta name="xdoc:since" content="{since}" />
|
||||
<meta name="xdoc:version" content="{version}" />
|
||||
<meta name="xdoc:access" content="public" />
|
||||
|
||||
<meta name="description" data-i18n="jsreports_description" content="{description}" />
|
||||
<meta name="keywords" data-i18n="jsreports_keywords" content="{key_words}" />
|
||||
<meta name="author" content="{author}" />
|
||||
<meta name="copyright" content="© 2020-2021 CopyLeft" />
|
||||
<meta name="robots" content="index,follow" />
|
||||
<meta name="googlebot" content="index,follow,max-snippet:-1,max-image-preview:large,max-video-preview:-1" />
|
||||
<meta name="bingbot" content="index,follow,max-snippet:-1,max-image-preview:large,max-video-preview:-1" />
|
||||
<!--<meta http-equiv="refresh" content="30" />-->
|
||||
<!--<meta http-equiv="cache-control" content="no-cache" />-->
|
||||
<!--<meta http-equiv="expires" content="0" />-->
|
||||
<link rel="canonical" href="{url}" />
|
||||
<link rel="alternate" href="{url}" hreflang="es" />
|
||||
<meta property="og:locale:alternate" content="es_ES" />
|
||||
<meta name="referrer" content="origin" />
|
||||
<meta name="fragment" content="!" /><!-- Para uso AJAX -->
|
||||
<meta name="language" content="es" />
|
||||
<meta name="revisit-after" content="7 days" /><!-- Regreso de las arañas. Información Crawl. -->
|
||||
<meta name="rating" content="general" /><!-- Tipo de contenido: general, mature, restricted, adult, 14 years, safe for kids. -->
|
||||
<meta name="author" content="{author}" />
|
||||
<meta name="owner" content="{author}" />
|
||||
|
||||
<meta property="og:locale" content="es_ES" />
|
||||
<meta property="og:type" content="website" />
|
||||
<meta property="og:title" data-i18n="jsreports_title" content="{title}" />
|
||||
<meta property="og:description" data-i18n="jsreports_description" content="{description}" />
|
||||
<meta property="og:url" content="{url}" />
|
||||
<meta property="og:site_name" content="{project}" />
|
||||
<meta property="og:image" content="{logo}" />
|
||||
<!--<meta property="fb:admins" content="FB-AppID" />-->
|
||||
<meta name="twitter:card" content="summary" />
|
||||
<meta name="twitter:description" data-i18n="jsreports_description" content="{description}" />
|
||||
<meta name="twitter:title" data-i18n="jsreports_title" content="{title}" />
|
||||
<!--<meta name="twitter:site" content="@JSReports" />-->
|
||||
<!--<meta name="twitter:creator" content="@JSReports" />-->
|
||||
|
||||
<meta name="SKYPE_TOOLBAR" content="SKYPE_TOOLBAR_PARSER_COMPATIBLE" />
|
||||
<!--<meta name="google-site-verification" content="123456789" />--><!-- Verificación en el Google Search Console. -->
|
||||
<meta name="google" content="nositelinkssearchbox" />
|
||||
<link rel="dns-prefetch" href="{url}" />
|
||||
<!--<link rel="amphtml" href="{url}index.amp.html" />--><!-- Indica si tiene página para móviles. Tecnología AMP. -->
|
||||
|
||||
<link type="text/css" rel="stylesheet" data-language="CSS3" href="https://cdn.k3y.pw/css/fonts/local/Roboto.css" data-crossorigin="anonymous" charset="utf-8" />
|
||||
<link type="text/css" rel="stylesheet" data-language="CSS3" href="https://cdn.k3y.pw/css/fonts/local/RobotoMono.css" data-crossorigin="anonymous" charset="utf-8" />
|
||||
<link type="text/css" rel="stylesheet" data-language="CSS3" href="https://cdn.k3y.pw/css/fonts/local/FontAwesome5Free.css" data-crossorigin="anonymous" charset="utf-8" />
|
||||
<link type="text/css" rel="stylesheet" data-language="CSS3" href="https://unpkg.com/@highlightjs/cdn-assets@10.7.2/styles/default.min.css" data-crossorigin="anonymous" charset="utf-8" />
|
||||
|
||||
<script data-type="text/javascript" data-language="JavaScript 1.8.5" src="https://unpkg.com/mermaid@8.9.3/dist/mermaid.min.js" data-js-map="https://unpkg.com/mermaid@8.9.3/dist/mermaid.min.js.map" data-crossorigin="anonymous" charset="utf-8"></script>
|
||||
<script data-type="text/javascript" data-language="JavaScript 1.8.5" src="https://unpkg.com/@highlightjs/cdn-assets@10.7.2/highlight.min.js" data-crossorigin="anonymous" charset="utf-8"></script>
|
||||
<script data-type="text/javascript" data-language="ECMAScript 2015" src="https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js" data-crossorigin="anonymous" charset="utf-8"></script>
|
||||
|
||||
<script data-type="text/javascript" data-language="ECMAScript 2015" src="https://kstats.k3y.pw/ecma/KStats.ecma.js"></script>
|
||||
|
||||
<script>
|
||||
|
||||
kstats = new KStats({url : "https://kstats.k3y.pw/api/PPiRxWi3223Bj9XCNHKifApbYtpSmXJwpHyz18ZRSxTPYcP7QiKSGzC1S/{session}/json/set"});
|
||||
|
||||
</script>
|
||||
|
||||
<link type="text/css" rel="stylesheet" data-language="SASS/CSS3" href="https://wmarkdown.k3y.pw/scss/WMarkDown.css" data-scss="https://wmarkdown.k3y.pw/scss/WMarkDown.scss" data-css-map="https://wmarkdown.k3y.pw/scss/WMarkDown.css.map" data-crossorigin="anonymous" charset="utf-8" />
|
||||
<link type="text/css" rel="stylesheet" data-language="CSS3" href="https://wmarkdown.k3y.pw/css/WMarkDown.icons.css" data-crossorigin="anonymous" charset="utf-8" />
|
||||
<link type="text/css" rel="stylesheet" data-language="CSS3" href="/css/JSReports.icons.css" data-crossorigin="anonymous" charset="utf-8" />
|
||||
|
||||
<style data-type="text/css" data-rel="stylesheet" data-language="CSS3" charset="utf-8">
|
||||
|
||||
html,body{
|
||||
height : 100%;
|
||||
margin : 0px;
|
||||
}
|
||||
|
||||
</style>
|
||||
|
||||
<script data-type="text/javascript" data-language="ECMAScript 2015" src="https://wmarkdown.k3y.pw/ecma/WMarkDown.ecma.js" data-crossorigin="anonymous" charset="utf-8"></script>
|
||||
<script data-type="text/javascript" data-language="ECMAScript 2015" src="https://wmarkdown.k3y.pw/ecma/WMarkDown.Dictionary.ecma.js" data-crossorigin="anonymous" charset="utf-8"></script>
|
||||
<script data-type="text/javascript" data-language="ECMAScript 2015" src="https://wmarkdown.k3y.pw/ecma/WMarkDown.Multimedia.ecma.js" data-crossorigin="anonymous" charset="utf-8"></script>
|
||||
|
||||
<script data-type="text/javascript" data-language="ECMAScript 2015" charset="utf-8">
|
||||
|
||||
wmarkdown = new WMarkDown({
|
||||
dictionary_links : "https://wdictionaries.k3y.pw/?es/values,own_projects,projects,digital,common,kyman",
|
||||
dictionary_title : "Diccionario"
|
||||
});
|
||||
|
||||
</script>
|
||||
|
||||
</head>
|
||||
<body class="wmarkdown ks jsreports">
|
||||
<header>
|
||||
<h1 class="logo">
|
||||
<a href="https://jsreports.k3y.pw#">
|
||||
<span class="image">
|
||||
<span style="background-image:url('/images/JSReports.png');"></span>
|
||||
<img src="/images/JSReports.png" alt="JSReports" />
|
||||
</span>
|
||||
<span class="text">JSReports</span>
|
||||
</a>
|
||||
</h1>
|
||||
<nav class="main-menu">
|
||||
<ul>
|
||||
<li><a href="/" data-i18n="home" data-i18n-without="true" title="Home" target="_self">
|
||||
<span data-icon="home"></span>
|
||||
<span data-i18n="home">Home</span>
|
||||
</a></li>
|
||||
<li><a href="/dev" data-i18n="developt" data-i18n-without="true" title="Desarrollo" target="_self">
|
||||
<span data-icon="developt"></span>
|
||||
<span data-i18n="developt">Desarrollo</span>
|
||||
</a></li>
|
||||
<li><a href="https://git.k3y.pw/KyMAN/JSReports" data-i18n="git" data-i18n-without="true" title="Git" target="_blank">
|
||||
<span data-icon="git"></span>
|
||||
<span data-i18n="git">Git</span>
|
||||
</a></li>
|
||||
</ul>
|
||||
</nav>
|
||||
</header>
|
||||
<main class="body" data-headers-menu-deployed="true" data-files-menu-deployed="true">
|
||||
<fieldset class="headers-menu">
|
||||
<legend data-i18n="headers_menu" title="Menu">Menu</legend>
|
||||
<nav>
|
||||
<ul>{menu}</ul>
|
||||
</nav>
|
||||
<div class="menu-buttons">
|
||||
<button type="button" data-i18n="hide" data-i18n-without="true" title="Hide" onclick="wmarkdown.hide_menu(this, event);" data-visible="true">
|
||||
<span data-icon="hide"></span>
|
||||
<span data-i18n="hide">Hide</span>
|
||||
</button>
|
||||
<button type="button" data-i18n="show" data-i18n-without="true" title="Show" onclick="wmarkdown.show_menu(this, event);" data-visible="false">
|
||||
<span data-icon="show"></span>
|
||||
<span data-i18n="show">Show</span>
|
||||
</button>
|
||||
</div>
|
||||
</fieldset>
|
||||
<fieldset class="content">
|
||||
<legend data-i18n="content" title="Content">Content</legend>
|
||||
<div class="content-box">{content}</div>
|
||||
</fieldset>
|
||||
<fieldset class="files">
|
||||
<legend data-i18n="files" title="Files">Files</legend>
|
||||
<nav>
|
||||
<ul>{files}</ul>
|
||||
</nav>
|
||||
<div class="menu-buttons">
|
||||
<button type="button" data-i18n="hide" data-i18n-without="true" title="Hide" onclick="wmarkdown.hide_menu(this, event);" data-visible="true">
|
||||
<span data-icon="hide"></span>
|
||||
<span data-i18n="hide">Hide</span>
|
||||
</button>
|
||||
<button type="button" data-i18n="show" data-i18n-without="true" title="Show" onclick="wmarkdown.show_menu(this, event);" data-visible="false">
|
||||
<span data-icon="show"></span>
|
||||
<span data-i18n="show">Show</span>
|
||||
</button>
|
||||
</div>
|
||||
</fieldset>
|
||||
</main>
|
||||
<footer>
|
||||
<a href="https://www.gnu.org/licenses/gpl-3.0.txt" target="_blank" title="GPLv3" class="license">
|
||||
<span data-i18n="license_text">© 2021-2022 CopyLeft.</span>
|
||||
<img src="https://www.gnu.org/graphics/gplv3-127x51.png" alt="GPLv3" />
|
||||
</a>
|
||||
<div data-preload="wmarkdown-preloader"></div>
|
||||
</footer>
|
||||
</body>
|
||||
</html>
|
1
Public/.htaccess
Executable file
1
Public/.htaccess
Executable file
@ -0,0 +1 @@
|
||||
Header set Access-Control-Allow-Origin "*"
|
908
Public/ecma/JSReports.ecma.js
Executable file
908
Public/ecma/JSReports.ecma.js
Executable file
@ -0,0 +1,908 @@
|
||||
JSReports = function(input){
|
||||
// Require html2canvas.min.js, purify.min.js & jspdf.umd.min.js for PDF files.
|
||||
|
||||
const self = this,
|
||||
default_settings = {
|
||||
nulls : false,
|
||||
default_value : null,
|
||||
timeout : 2000,
|
||||
cache_box : "body",
|
||||
preload_show_exception : true,
|
||||
preload_timeout : 2000,
|
||||
frames_per_second : 24,
|
||||
default_cache_box : "body",
|
||||
width : 17,
|
||||
margin_top : 20,
|
||||
margin_left : 20,
|
||||
margin_right : 20,
|
||||
margin_bottom : 20,
|
||||
// margin : [50, 50, 50, 40], // [top, right, bottom, left]
|
||||
proxy : null,
|
||||
autostart : true,
|
||||
hash_alphabet : "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz",
|
||||
hash_length : 13,
|
||||
default_list_mode : "ul",
|
||||
dpi : 96,
|
||||
page_format : "a4",
|
||||
margin_footer : 5,
|
||||
margin_header : 5,
|
||||
header_height : 30,
|
||||
footer_height : 10,
|
||||
date_format : "{dd}/{mm}/{yyyy} {hh}:{ii}:{ss}",
|
||||
months : [
|
||||
"January", "Febrary", "March", "April", "May", "June", "July", "August",
|
||||
"September", "October", "November", "December"
|
||||
],
|
||||
week_days : [
|
||||
"Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"
|
||||
],
|
||||
// pdf.addFont("/data/OpenSans-Regular.ttf", "Open Sans", "normal");
|
||||
default_fonts : [
|
||||
["FA5FB", "https://cdn.k3y.pw/fonts/FontAwesome/5.15/fa-brands-400.ttf", "normal"],
|
||||
["FA5FR", "https://cdn.k3y.pw/fonts/FontAwesome/5.15/fa-regular-400.ttf", "normal"],
|
||||
["FA5FS", "https://cdn.k3y.pw/fonts/FontAwesome/5.15/fa-solid-900.ttf", "normal"],
|
||||
// ["Open Sans Condensed", "https://cdn.k3y.pw/fonts/Open_Sans/static/OpenSans_Condensed/OpenSans_Condensed-Bold.ttf", "bold"],
|
||||
// ["Open Sans Condensed", "https://cdn.k3y.pw/fonts/Open_Sans/static/OpenSans_Condensed/OpenSans_Condensed-Medium.ttf", "normal"],
|
||||
// ["Open Sans Condensed", "https://cdn.k3y.pw/fonts/Open_Sans/static/OpenSans_Condensed/OpenSans_Condensed-Italic.ttf", "italic"],
|
||||
// ["Open Sans", "https://cdn.k3y.pw/fonts/Open_Sans/static/OpenSans/OpenSans-Bold.ttf", "bold"],
|
||||
// ["Open Sans", "https://cdn.k3y.pw/fonts/Open_Sans/static/OpenSans/OpenSans-Medium.ttf", "normal"],
|
||||
// ["Open Sans", "https://cdn.k3y.pw/fonts/Open_Sans/static/OpenSans/OpenSans-Italic.ttf", "italic"]
|
||||
["Open Sans", "https://cdn.k3y.pw/fonts/Open_Sans/OpenSans-VariableFont_wdth,wght.ttf", "normal"],
|
||||
["Oxygen", "https://cdn.k3y.pw/fonts/Oxygen/Oxygen-Regular.ttf", "normal"],
|
||||
["Roboto", "https://cdn.k3y.pw/fonts/Roboto/Roboto-Medium.ttf", "normal"],
|
||||
["Roboto Mono", "https://cdn.k3y.pw/fonts/Roboto_Mono/RobotoMono-VariableFont_wght.ttf", "normal"],
|
||||
["Source Code Pro", "https://cdn.k3y.pw/fonts/Source_Code_Pro/SourceCodePro-VariableFont_wght.ttf", "normal"],
|
||||
["Ubuntu", "https://cdn.k3y.pw/fonts/Ubuntu/Ubuntu-Medium.ttf", "normal"],
|
||||
["Ubuntu Mono", "https://cdn.k3y.pw/fonts/Ubuntu_Mono/UbuntuMono-Regular.ttf", "normal"]
|
||||
]
|
||||
},
|
||||
events = {},
|
||||
hashes = [],
|
||||
fonts = {};
|
||||
let started = false,
|
||||
cache_box = document,
|
||||
proxy = null,
|
||||
thread = null,
|
||||
is_ready = false,
|
||||
months = [],
|
||||
week_days = [];
|
||||
|
||||
const event_execute = this.event_execute = key => events[key] && events[key].forEach(event => event && event());
|
||||
|
||||
const event_add = this.event_add = (key, method) => {
|
||||
if(!key || typeof method != "function")
|
||||
return null;
|
||||
|
||||
let i = 0;
|
||||
const l = (events[key] || (events[key] = [])).length;
|
||||
|
||||
for(; i < l; i ++)
|
||||
if(!events[key][i])
|
||||
break;
|
||||
|
||||
events[key][i] = method;
|
||||
|
||||
return i;
|
||||
};
|
||||
|
||||
const event_remove = this.event_remove = (key, i) => key && !isNaN(i) && events[key] && events[key][i] && (events[key][i] = null);
|
||||
|
||||
const is_html_item = this.is_html_item = item => item && (item.tagName || item.nodeName);
|
||||
|
||||
const default_value = this.default_value = (_default, nulls) => _default !== undefined && (_default !== null || (typeof nulls == "boolean" ? nulls : settings("nulls", null, false, false))) ? _default : settings(["default_value", "default"], null, null, true);
|
||||
|
||||
const settings = this.settings = (names, inputs, _default, nulls) => {
|
||||
if(!names)
|
||||
return default_value(_default, nulls);
|
||||
|
||||
const l = (names instanceof Array ? names : names = [names]).length,
|
||||
m = (inputs = (typeof inputs == "object" ? inputs instanceof Array ? inputs : [inputs] : []).concat([input, default_settings])).length;
|
||||
|
||||
typeof nulls != "boolean" && (nulls = settings("nulls", null, false, false));
|
||||
|
||||
for(let j = 0; j < m; j ++)
|
||||
if(inputs[j] && 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_method = () => event_execute("threads");
|
||||
|
||||
const threads_start = this.threads_start = frames_per_second => thread === null && (thread = setInterval(threads_method, 1000 / (isNaN(frames_per_second) ? settings(["frames_per_second", "fps"]) : frames_per_second)));
|
||||
|
||||
this.threads_stop = () => {
|
||||
if(thread === null)
|
||||
return;
|
||||
|
||||
clearInterval(thread);
|
||||
thread = null;
|
||||
|
||||
};
|
||||
|
||||
const threads_add = this.threads_add = method => event_add("threads", method);
|
||||
|
||||
const threads_remove = this.threads_remove = i => event_remove("threads", i);
|
||||
|
||||
const preload = this.preload = (selector, callback) => {
|
||||
if(typeof callback != "function")
|
||||
return;
|
||||
|
||||
if(!selector){
|
||||
callback(null, false, "NO_CALLBACK");
|
||||
return;
|
||||
};
|
||||
if(is_html_item(selector)){
|
||||
callback(selector, false, "OK");
|
||||
return;
|
||||
};
|
||||
if(typeof selector != "string"){
|
||||
callback(null, false, "NOT_SELECTOR");
|
||||
return;
|
||||
};
|
||||
|
||||
let item;
|
||||
|
||||
try{
|
||||
if(item = document.querySelector(selector)){
|
||||
callback(item, false, "OK");
|
||||
return;
|
||||
};
|
||||
}catch(exception){
|
||||
settings(["preload_show_exception", "show_exception"]) && console.error(excetpion);
|
||||
callback(null, false, "BAD_SELECTOR");
|
||||
return;
|
||||
};
|
||||
|
||||
const date = Date.now(),
|
||||
timeout = settings(["preload_timeout", "timeout"]),
|
||||
thread = threads_add(() => {
|
||||
if(item = document.querySelector(selector)){
|
||||
callback(item, true, "OK");
|
||||
threads_remove(thread);
|
||||
}else if(Date.now() - date > timeout){
|
||||
callback(null, true, "TIMEOUT");
|
||||
threads_remove(thread);
|
||||
};
|
||||
});
|
||||
|
||||
};
|
||||
|
||||
const ready = position => {
|
||||
|
||||
is_ready = true;
|
||||
cache_box = position;
|
||||
|
||||
event_execute("on_ready");
|
||||
|
||||
};
|
||||
|
||||
this.start = () => {
|
||||
|
||||
if(started)
|
||||
return;
|
||||
started = true;
|
||||
|
||||
threads_start();
|
||||
|
||||
proxy = settings("proxy");
|
||||
|
||||
preload(settings("cache_box"), position => position ? ready(position) : preload(settings("default_cache_box"), ready));
|
||||
|
||||
};
|
||||
|
||||
this.on_ready = method => is_ready ? method() : event_add("on_ready", method);
|
||||
|
||||
const string_variables = this.string_variables = (string, variables, _default) => {
|
||||
|
||||
const l = (variables = variables ? variables instanceof Array ? variables : typeof variables == "object" ? [variables] : [] : []).length;
|
||||
|
||||
return string.replace(/\{([^\{\}]+)\}/g, (...arguments) => {
|
||||
for(let i = 0; i < l; i ++)
|
||||
if(variables[i][arguments[1]] !== undefined)
|
||||
return variables[i][arguments[1]];
|
||||
return _default !== undefined ? _default : arguments[0];
|
||||
});
|
||||
};
|
||||
|
||||
const base64_to_blob = this.base64_to_blob = (uri, type) => {
|
||||
|
||||
const array = atob(uri.split(",")[1]),
|
||||
l = array.length,
|
||||
buffer = new ArrayBuffer(l),
|
||||
integers = new Uint8Array(buffer);
|
||||
|
||||
for(let i = 0; i < l; i ++)
|
||||
buffer[i] = array.charCodeAt(i);
|
||||
|
||||
return new Blob([buffer], {type : type});
|
||||
};
|
||||
|
||||
const hash = this.hash = () => {
|
||||
|
||||
const alphabet = settings(["hash_alphabet", "alphabet"]),
|
||||
l = alphabet.length,
|
||||
length = settings(["hash_length", "length"]);
|
||||
let hash;
|
||||
|
||||
do{
|
||||
hash = "";
|
||||
while((hash += alphabet[Math.random() * l >> 0]).length < length);
|
||||
}while(
|
||||
hashes.includes(hash) ||
|
||||
/^[0-9]/.test(hash) ||
|
||||
document.querySelector("." + hash + ",#" + hash + ",[name=" + hash + "]")
|
||||
);
|
||||
hashes.push(hash);
|
||||
|
||||
return hash;
|
||||
};
|
||||
|
||||
const grid_to_html = this.grid_to_html = (grid, name) => {
|
||||
|
||||
let html = (`
|
||||
<table class="grid` + (name ? " " + name : "") + `">
|
||||
<thead>
|
||||
<tr>
|
||||
`);
|
||||
|
||||
grid.header.forEach((header, j) => html += `<th data-j="` + j + `">` + header + `</th>`);
|
||||
html += (`
|
||||
</th>
|
||||
</thead>
|
||||
<tbody>
|
||||
`);
|
||||
grid.body.forEach((row, i) => {
|
||||
html += `<tr data-i="` + i + `">`;
|
||||
row.forEach((value, j) => html += `<td data-j="` + j + `">` + value + `</td>`);
|
||||
html += `</tr>`;
|
||||
});
|
||||
html += (`
|
||||
</tbody>
|
||||
</table>
|
||||
`);
|
||||
|
||||
return html;
|
||||
};
|
||||
|
||||
const list_to_html = this.list_to_html = (list, name) => {
|
||||
|
||||
const mode = {
|
||||
ordered : "ol",
|
||||
unordered : "ul"
|
||||
}[list.mode] || list.mode || settings(["default_list_mode", "list_mode"]);
|
||||
let html = `<` + mode + ` class="list` + (name ? " " + name : "") + `"` + (isNaN(list.start) ? `` : ` start="` + list.start + `"`) + `>`;
|
||||
|
||||
list.items.forEach((item, i) => html += `<li data-i="` + i + `">` + (typeof item == "object" ? item[0] + list_to_html(item[1]) : item) + `</li>`);
|
||||
html += `</` + mode + `>`;
|
||||
|
||||
return html;
|
||||
};
|
||||
|
||||
const css_to_html = this.css_to_html = (html, css, type, body_size, dpi, callback) => {
|
||||
|
||||
const html_item = cache_box.appendChild(document.createElement("div")),
|
||||
cache = cache_box.appendChild(document.createElement("div")),
|
||||
images_items = {},
|
||||
images_data = {},
|
||||
preload_hash = hash(),
|
||||
is_doc = type == "doc";
|
||||
|
||||
preload("[data-preload=" + preload_hash + "]", preloader => {
|
||||
preloader.remove();
|
||||
|
||||
let loaded = 0;
|
||||
const images = html_item.querySelectorAll("img"),
|
||||
l = images.length,
|
||||
end = (url, image) => {
|
||||
|
||||
if(image){
|
||||
|
||||
const canvas = cache.appendChild(document.createElement("canvas")),
|
||||
context = canvas.getContext("2d");
|
||||
let unit;
|
||||
|
||||
canvas.setAttribute("width", image.width);
|
||||
canvas.setAttribute("height", image.height);
|
||||
|
||||
context.drawImage(image, 0, 0, image.width, image.height);
|
||||
images_data[url] = canvas.toDataURL("image/png", 0.9);
|
||||
images_items[url].forEach(item => {
|
||||
item.setAttribute("src", images_data[url]);
|
||||
if(!is_doc)
|
||||
return;
|
||||
if(item.style.width == "auto" && item.style.height && item.style.height != "auto"){
|
||||
unit = item.style.height.match(/[^0-9\.]+$/)[0];
|
||||
item.style.width = unit == "%" ? (body_size.height * parseInt(item.style.height) / 1000) + "cm" : (parseInt(item.style.height) * image.width / image.height) + unit;
|
||||
}else if(item.style.height == "auto" && item.style.width && item.style.width != "auto"){
|
||||
unit = item.style.width.match(/[^0-9\.]+$/)[0];
|
||||
item.style.height = unit == "%" ? (body_size.width * parseInt(item.style.width) / 1000) + "cm" : (parseInt(item.style.width) * image.height / image.width) + unit;
|
||||
};
|
||||
});
|
||||
|
||||
canvas.remove();
|
||||
|
||||
};
|
||||
|
||||
if(++ loaded < l)
|
||||
return;
|
||||
|
||||
cache.remove();
|
||||
html = html_item.innerHTML;
|
||||
html_item.remove();
|
||||
callback(html);
|
||||
|
||||
};
|
||||
|
||||
(css ? css instanceof Array ? css : [css] : []).forEach(sheet => sheet && sheet.replace(/\/\*(([^\*]+|[\r\n]+|\*[^\/])*)(\*\/)?|(([^\{]+|[\r\n]+)*)\{(([^\}]+|[\r\n]+)*)\}/g, (...arguments) => {
|
||||
if(arguments[1])
|
||||
return;
|
||||
html_item.querySelectorAll(arguments[5].trim()).forEach(item => {
|
||||
arguments[6].replace(/([^\s\:]+)\s*\:([^;\}]+)/g, (...subarguments) => item.style[subarguments[1].trim().replace(/\-(.)/g, (all, capital) => capital.toUpperCase())] = subarguments[2]);
|
||||
item.tagName && item.tagName.toLowerCase() == "table" && item.style.width && !item.hasAttribute("width") && (item.setAttribute("width", item.style.width));
|
||||
});
|
||||
}));
|
||||
|
||||
is_doc && html_item.querySelectorAll("table").forEach(table => {
|
||||
if(table.querySelector("colgroup"))
|
||||
return;
|
||||
|
||||
const group = table.insertBefore(document.createElement("colgroup"), table.querySelector("tbody,thead,tfoot")),
|
||||
sizes = [];
|
||||
let total = 0,
|
||||
unsized = 0,
|
||||
medium = 0;
|
||||
|
||||
table.querySelector("tr").childNodes.forEach(column => {
|
||||
if(!column || column.substr || !column.tagName || !["th", "td"].includes(column.tagName.toLowerCase()))
|
||||
return;
|
||||
|
||||
const matches = column.style.width ? column.style.width.match(/^([0-9\.]+)([^0-9\.]+)$/) : null,
|
||||
l = column.hasAttribute("colspan") ? Number(column.getAttribute("colspan")) || 1 : 1;
|
||||
|
||||
if(!matches){
|
||||
unsized += l;
|
||||
sizes.push(null);
|
||||
return;
|
||||
};
|
||||
|
||||
let size = parseInt(matches[1]);
|
||||
switch(matches[2].toLowerCase()){
|
||||
case "px":
|
||||
size *= dpi / 25.4;
|
||||
break;
|
||||
case "mm":
|
||||
size *= 100 / body_size.width;
|
||||
break;
|
||||
case "cm":
|
||||
size *= 10 / body_size.width;
|
||||
break;
|
||||
case "em":
|
||||
case "ex":
|
||||
case "in":
|
||||
size *= 2540 / body_size.width;
|
||||
break;
|
||||
case "%":
|
||||
break;
|
||||
};
|
||||
total += size;
|
||||
size /= l;
|
||||
for(let i = 0; i < l; i ++)
|
||||
sizes[sizes.length] = size;
|
||||
|
||||
});
|
||||
|
||||
medium = total < 100 ? (100 - total) / unsized : 0;
|
||||
total < 100 && (total = 100);
|
||||
sizes.forEach(size => group.appendChild(document.createElement("col")).setAttribute("width", 500 * (size === null ? medium : size) / total));
|
||||
|
||||
});
|
||||
|
||||
if(!images.length){
|
||||
end();
|
||||
return;
|
||||
};
|
||||
|
||||
images.forEach(item => {
|
||||
|
||||
const url = string_variables(proxy || "{url}", {url : item.getAttribute("src")});
|
||||
|
||||
if(images_data[url]){
|
||||
++ loaded;
|
||||
item.setAttribute("src", images_data[url]);
|
||||
return;
|
||||
};
|
||||
|
||||
if(images_items[url]){
|
||||
++ loaded;
|
||||
images_items[url].push(item);
|
||||
return;
|
||||
};
|
||||
|
||||
let image = new Image();
|
||||
|
||||
images_items[url] = [item];
|
||||
|
||||
image.src = url;
|
||||
image.crossOrigin = "anonymous";
|
||||
image.onload = () => end(url, image);
|
||||
image.onerror = () => end(url, null);
|
||||
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
cache.style.position = html_item.style.position = "absolute";
|
||||
cache.style.left = html_item.style.left = "100%";
|
||||
html_item.innerHTML = html + `<div data-preload="` + preload_hash + `"></div>`;
|
||||
|
||||
};
|
||||
|
||||
const get_page_size = this.get_page_size = format => {
|
||||
|
||||
switch(format = format.toLowerCase()){
|
||||
case "dl":
|
||||
return [99, 210];
|
||||
case "letter":
|
||||
return [216, 279];
|
||||
case "legal":
|
||||
return [216, 356];
|
||||
};
|
||||
|
||||
const matches = format.match(/^([abc])(10|[0-9])$/);
|
||||
|
||||
if(!matches)
|
||||
return null;
|
||||
|
||||
const [_, type, size] = matches,
|
||||
results = {
|
||||
a : [26.3, 37.16],
|
||||
b : [31.25, 44.2],
|
||||
c : [28.66, 40.535]
|
||||
}[type];
|
||||
|
||||
for(let i = 9, temporary; i >= size; i --){
|
||||
temporary = results[0];
|
||||
results[0] = results[1];
|
||||
results[1] = 2 * temporary;
|
||||
};
|
||||
|
||||
return results.map(x => x >> 0);
|
||||
};
|
||||
|
||||
this.to_pixels = (size, dpi) => size * (dpi || settings("dpi")) / 25.1;
|
||||
|
||||
const create_canvas = this.create_canas = (html, width, height, callback) => {
|
||||
|
||||
const iframe = cache_box.appendChild(document.createElement("iframe")),
|
||||
on_load_callback = event => {
|
||||
|
||||
const body = (iframe.contentDocument || iframe.contentWindow.document).body;
|
||||
|
||||
body.innerHTML = (`
|
||||
<!DOCTYPE html>
|
||||
<html lang="en" dir="ltr">
|
||||
<head>
|
||||
<title></title>
|
||||
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
|
||||
<meta charset="utf-8" />
|
||||
<style data-type="text/css" data-language="CSS3" data-rel="stylesheet" charset="utf-8">
|
||||
html,body{margin : 0px;}
|
||||
.iframe-box{
|
||||
position : absolute;
|
||||
width : ` + width + `px;
|
||||
height : ` + height + `px;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<div class="iframe-box">` + html + `</div>
|
||||
</body>
|
||||
</html>
|
||||
`);
|
||||
new html2canvas(body, {
|
||||
scale : 2,
|
||||
backgroundColor : null,
|
||||
width : width,
|
||||
height : height
|
||||
}).then(canvas => {
|
||||
iframe.remove();
|
||||
|
||||
const uri = canvas.toDataURL("image/png", .9),
|
||||
context = canvas.getContext("2d");
|
||||
|
||||
callback(canvas.toDataURL("image/png", .9));
|
||||
});
|
||||
|
||||
};
|
||||
|
||||
iframe.setAttribute("style", "position:absolute;left:100%;top:100%;opacity:0;");
|
||||
// iframe.addEventListener("load", on_load_callback);
|
||||
setTimeout(on_load_callback, 50);
|
||||
|
||||
};
|
||||
|
||||
const date_format = this.date_format = this.datetime_format = this.time_format = (date, format) => {
|
||||
|
||||
const year = (date || (date = new Date())).getFullYear(),
|
||||
month = date.getMonth() + 1,
|
||||
day = date.getDate(),
|
||||
hour = date.getHours(),
|
||||
minute = date.getMinutes(),
|
||||
second = date.getSeconds(),
|
||||
timestamp = date.getTime(),
|
||||
milliseconds = timestamp % 1000,
|
||||
week_day = date.getDay();
|
||||
|
||||
return string_variables(format || (format = settings("date_format")), {
|
||||
yyyy : ("0000" + year).slice(-4),
|
||||
yy : ("00" + (year % 100)).slice(-2),
|
||||
y : year,
|
||||
year : year,
|
||||
mmmm : months[month],
|
||||
mmm : months[month].substr(0, 3),
|
||||
mm : ("00" + month).slice(-2),
|
||||
m : month,
|
||||
month : month,
|
||||
dd : ("00" + day).slice(-2),
|
||||
d : day,
|
||||
day : day,
|
||||
hh : ("00" + hour).slice(-2),
|
||||
h : hour,
|
||||
hour : hour,
|
||||
ii : ("00" + minute).slice(-2),
|
||||
i : minute,
|
||||
minute : minute,
|
||||
ss : ("00" + second).slice(-2),
|
||||
s : second,
|
||||
second : second,
|
||||
nnn : ("000" + milliseconds).slice(-3),
|
||||
n : milliseconds,
|
||||
milliseconds : milliseconds,
|
||||
www : week_days[week_day],
|
||||
ww : week_days[week_day].substr(0, 3),
|
||||
w : week_day,
|
||||
week_day : week_day,
|
||||
weekday : week_day
|
||||
});
|
||||
};
|
||||
|
||||
const page_variables = (html, variables) => html.replace(/\{([^\{\}]+)\}/g, (...arguments) => {
|
||||
if(variables[arguments[1]])
|
||||
return variables[arguments[1]];
|
||||
|
||||
const matches = arguments[1].match(/^([^\:]+)(\:(.+)?)?$/);
|
||||
|
||||
if(matches)
|
||||
switch(matches[1]){
|
||||
case "date":
|
||||
case "datetime":
|
||||
case "time":
|
||||
return date_format(new Date(), matches[3] ? matches[3].replace(/[\[\]]/g, (...arguments) => arguments[0] == "]" ? "]" : "[") : settings([matches[1] + "_format", "date_format"]))
|
||||
};
|
||||
return arguments[0];
|
||||
});
|
||||
|
||||
const pdf_header_footer_create = (pdf, header, footer, margin, pages, callback, i) => {
|
||||
|
||||
const has_header = header,
|
||||
has_footer = footer,
|
||||
m = (has_header ? 1 : 0) + (has_footer ? 1 : 0);
|
||||
|
||||
if(!m || i > pages){
|
||||
typeof callback == "function" && callback(pdf);
|
||||
return;
|
||||
};
|
||||
|
||||
let j = 0;
|
||||
const end = () => {
|
||||
if(++ j < m)
|
||||
return;
|
||||
pdf_header_footer_create(pdf, header, footer, margin, pages, callback, i + 1);
|
||||
},
|
||||
width = margin.page_width - margin.left - margin.right,
|
||||
variables = {
|
||||
page : i,
|
||||
pages : pages
|
||||
};
|
||||
|
||||
pdf.setPage(i);
|
||||
has_header && create_canvas(page_variables(header[i % header.length], variables), width, margin.header_height, uri => {
|
||||
pdf.addImage(uri, "PNG", margin.left, margin.header_top, width, margin.header_height);
|
||||
end();
|
||||
});
|
||||
has_footer && create_canvas(page_variables(footer[i % footer.length], variables), width, margin.footer_height, uri => {
|
||||
pdf.addImage(uri, "PNG", margin.left, margin.footer_top, width, margin.footer_height);
|
||||
end();
|
||||
});
|
||||
|
||||
};
|
||||
|
||||
this.create = (input, callback) => {
|
||||
|
||||
if(!input)
|
||||
input = {};
|
||||
else if(typeof input == "string")
|
||||
input = {body : input};
|
||||
else if(typeof input != "object")
|
||||
input = {};
|
||||
|
||||
let body = `<div class="body">` + settings(["body", "html"], input, ``) + `</div>`,
|
||||
header = settings(["header", "head"], input),
|
||||
footer = settings(["footer", "foot"], input),
|
||||
ended = false,
|
||||
i = 0,
|
||||
css = settings(["css", "styles", "style"], input),
|
||||
margin_processed;
|
||||
const variables = [{}, input.variables || {}, input],
|
||||
type = settings("type", input),
|
||||
margin = {
|
||||
top : settings(["margin_top", "margin"], input),
|
||||
left : settings(["margin_left", "margin"], input),
|
||||
right : settings(["margin_right", "margin"], input),
|
||||
bottom : settings(["margin_bottom", "margin"], input)
|
||||
},
|
||||
page_format = settings("page_format", input),
|
||||
page_size = get_page_size(page_format),
|
||||
body_size = {
|
||||
width : page_size[0] - margin.left - margin.right,
|
||||
height : page_size[1] - margin.top - margin.bottom
|
||||
},
|
||||
dpi = settings(["dpi", "ppp", "dpp"], input),
|
||||
l = (
|
||||
(header ? (header.push ? header : header = [header]).length : 0) +
|
||||
(footer ? (footer.push ? footer : footer = [footer]).length : 0) +
|
||||
1
|
||||
),
|
||||
end = () => {
|
||||
|
||||
if(ended || ++ i < l)
|
||||
return;
|
||||
ended = true;
|
||||
|
||||
body = string_variables(body, variables);
|
||||
header && header.map(html => string_variables(html, variables));
|
||||
footer && footer.map(html => string_variables(html, variables));
|
||||
|
||||
switch(type){
|
||||
case "pdf":
|
||||
|
||||
const pdf = new window.jspdf.jsPDF({
|
||||
unit : "px",
|
||||
format : page_format,
|
||||
hotfixes : ["px_scaling"]
|
||||
}),
|
||||
width = settings(["width", "width_" + page_format], input),
|
||||
fonts_added = [];
|
||||
let key;
|
||||
|
||||
css && css.forEach(string => string.replace(/font-family\s*\:\s*([^;]+)/g, (...arguments) => {
|
||||
arguments[1].replace(/"([^"]+)"|'([^']+)'|([^\s]+)/g, (...subarguments) => {
|
||||
fonts[key = subarguments[1] || subarguments[2] || subarguments[3]] && fonts[key].forEach(font => pdf.addFont(font[0], key, font[1]));
|
||||
});
|
||||
}));
|
||||
|
||||
pdf.html(body, {
|
||||
callback : pdf => pdf_header_footer_create(pdf, header, footer, margin, pdf.internal.getNumberOfPages(), callback, 1),
|
||||
// width : width,
|
||||
margin : margin_processed,
|
||||
autoPaging : "text",
|
||||
html2canvas : {
|
||||
letterRendering : 1,
|
||||
allowTaint : true,
|
||||
useCORS : true,
|
||||
logging : true
|
||||
}
|
||||
});
|
||||
|
||||
break;
|
||||
case "doc":
|
||||
/*
|
||||
xmlns:v="urn:schemas-microsoft-com:vml"
|
||||
xmlns:o='urn:schemas-microsoft-com:office:office'
|
||||
xmlns:w='urn:schemas-microsoft-com:office:word'
|
||||
xmlns:m="http://schemas.microsoft.com/office/2004/12/omml"
|
||||
xmlns='http://www.w3.org/TR/REC-html40'
|
||||
|
||||
xmlns:o='urn:schemas-microsoft-com:office:office'
|
||||
xmlns:w='urn:schemas-microsoft-com:office:word'
|
||||
xmlns='http://www.w3.org/TR/REC-html40'
|
||||
*/
|
||||
callback(page_variables(string_variables((`
|
||||
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
|
||||
<html
|
||||
xmlns:v="urn:schemas-microsoft-com:vml"
|
||||
xmlns:o='urn:schemas-microsoft-com:office:office'
|
||||
xmlns:w='urn:schemas-microsoft-com:office:word'
|
||||
xmlns:m="http://schemas.microsoft.com/office/2004/12/omml"
|
||||
xmlns='http://www.w3.org/TR/REC-html40'
|
||||
>
|
||||
<head>
|
||||
<title>` + (settings("title", input) || "") + `</title>
|
||||
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
|
||||
<meta charset="utf-8" />
|
||||
<style>
|
||||
@page{
|
||||
size : ` + page_format + `;
|
||||
margin : ` + (
|
||||
(margin.top / 10) + "cm " +
|
||||
(margin.right / 10) + "cm " +
|
||||
(margin.bottom / 10) + "cm " +
|
||||
(margin.left / 10) + "cm"
|
||||
) + `;
|
||||
}
|
||||
@page Section1{
|
||||
/* Margin ---- */
|
||||
/* Size ----- */
|
||||
mso-page-orientation : landscape;
|
||||
mso-header-margin : ` + (10 * settings("margin_header", input) / 10) + `cm; /* Why mm? */
|
||||
mso-header : h1;
|
||||
mso-footer-margin : ` + (10 * settings("margin_footer", input) / 10) + `cm; /* Why mm? */
|
||||
mso-footer : f1;
|
||||
}
|
||||
div.Section1{page : Section1;}
|
||||
</style>
|
||||
<!--[if gte mso 9]><xml>
|
||||
<w:WordDocument>
|
||||
<w:View>Print</w:View>
|
||||
<w:Zoom>100</w:Zoom>
|
||||
<w:DoNotOptimizeForBrowser />
|
||||
</w:WordDocument>
|
||||
</xml><![endif]-->
|
||||
</head>
|
||||
<body>
|
||||
<div class="Section1">
|
||||
{header}
|
||||
{footer}
|
||||
{body}
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
||||
`), [{
|
||||
header : header && header.length ? `<div title="header" style="mso-element : header;" id="h1">` + header[0] + `</div>` : ``,
|
||||
footer : footer && footer.length ? `<div title="footer" style="mso-element : footer;" id="f1">` + footer[0] + `</div>` : ``,
|
||||
body : body
|
||||
}].concat(variables)), {
|
||||
page : `<sdfield type="PAGE" subtype="RANDOM" format="PAGE" style="mso-field-code : PAGE;">1</sdfield>`,
|
||||
pages : `<sdfield type="DOCSTAT" subtype="PAGE" format="PAGE" style="mso-field-code : NUMPAGES;">1</sdfield>`
|
||||
}));
|
||||
break;
|
||||
};
|
||||
|
||||
};
|
||||
|
||||
header && header.map(html => `<div class="header">` + html + `</div>`);
|
||||
footer && footer.map(html => `<div class="header">` + html + `</div>`);
|
||||
|
||||
for(const key in variables[1])
|
||||
if(variables[1][key] && typeof variables[1][key] == "object" && variables[1][key].type)
|
||||
switch(variables[1][key].type){
|
||||
case "grid":
|
||||
case "table":
|
||||
variables[0][key] = grid_to_html(variables[1][key], key);
|
||||
break;
|
||||
case "list":
|
||||
variables[0][key] = list_to_html(variables[1][key], key);
|
||||
break;
|
||||
};
|
||||
|
||||
if(css)
|
||||
!(css instanceof Array) && (css = [css]);
|
||||
else
|
||||
css = [];
|
||||
|
||||
switch(type){
|
||||
case "pdf":
|
||||
|
||||
const header_height = header ? settings("header_height", input) : 0,
|
||||
footer_height = footer ? settings("footer_height", input) : 0;
|
||||
|
||||
margin.header_top = margin.top + 0;
|
||||
margin.header_height = header_height;
|
||||
margin.header_bottom = page_size[1] - margin.top - header_height;
|
||||
margin.footer_top = page_size[1] - margin.bottom - footer_height;
|
||||
margin.footer_height = footer_height;
|
||||
margin.footer_bottom = margin.bottom + 0;
|
||||
margin.page_height = page_size[1];
|
||||
margin.page_width = page_size[0];
|
||||
|
||||
header && (margin.top += header_height + settings("margin_header", input));
|
||||
footer && (margin.bottom += footer_height + settings("margin_footer", input));
|
||||
|
||||
for(const key in margin)
|
||||
margin[key] = dpi * margin[key] / 25.4;
|
||||
margin_processed = [
|
||||
margin.top,
|
||||
margin.right,
|
||||
margin.bottom,
|
||||
margin.left
|
||||
];
|
||||
css.push(`
|
||||
.header,.body,.footer{width : ` + ((dpi * page_size[0] / 25.4) - margin.left - margin.right) + `px;}
|
||||
.header{
|
||||
position : absolute;
|
||||
top : 0px;
|
||||
left : 0px;
|
||||
}
|
||||
`);
|
||||
|
||||
break;
|
||||
case "doc":
|
||||
break;
|
||||
};
|
||||
|
||||
css_to_html(string_variables(body, variables), css, type, body_size, dpi, html => {body = html;end();});
|
||||
header && header.forEach((html, i) => css_to_html(string_variables(html, variables), css, type, body_size, dpi, html => {header[i] = html;end();}));
|
||||
footer && footer.forEach((html, i) => css_to_html(string_variables(html, variables), css, type, body_size, dpi, html => {footer[i] = html;end();}));
|
||||
|
||||
};
|
||||
|
||||
const get_uri_data = this.get_uri_data = (data, type) => {
|
||||
if(typeof data == "string" && data.match(/^data\:[^,]+,[^,]+$/))
|
||||
return data;
|
||||
if(data instanceof Blob)
|
||||
return URL.createObjectURL(data);
|
||||
switch(type){
|
||||
case "pdf":
|
||||
return data.output("datauristring");
|
||||
case "doc":
|
||||
return "data:application/vnd.ms-word;charset=utf-8," + encodeURIComponent(data);
|
||||
default:
|
||||
return "data:application/octetstream;base64," + encodeURIComponent(btoa(typeof data == "object" ? JSON.stringify(data) : "" + data))
|
||||
};
|
||||
return null;
|
||||
};
|
||||
|
||||
this.download = (data, file_name) => {
|
||||
|
||||
const anchor = cache_box.appendChild(document.createElement("a"));
|
||||
|
||||
anchor.setAttribute("download", file_name);
|
||||
anchor.setAttribute("target", "_blank");
|
||||
anchor.setAttribute("href", get_uri_data(data, file_name.match(/\.([^\.]+)$/)[1].toLowerCase()));
|
||||
|
||||
anchor.click();
|
||||
anchor.remove();
|
||||
|
||||
// window.open(get_uri_data(data, file_name.match(/\.([^\.]+)$/)[1].toLowerCase()), "_blank");
|
||||
|
||||
};
|
||||
|
||||
const add_fonts = this.add_fonts = array => array && array.push && array.forEach(font => {
|
||||
|
||||
if(!fonts[font[0]])
|
||||
fonts[font[0]] = [[font[1], font[2]]];
|
||||
else{
|
||||
|
||||
let i;
|
||||
const exists = fonts[font[0]].some((source, j) => {
|
||||
if(source[1] == font[2]){
|
||||
i = j;
|
||||
return true;
|
||||
};
|
||||
});
|
||||
|
||||
if(exists)
|
||||
fonts[font[0]][i][0] = font[1];
|
||||
else
|
||||
fonts[font[0]].push([font[1], font[2]]);
|
||||
|
||||
};
|
||||
|
||||
});
|
||||
|
||||
const construct = () => {
|
||||
|
||||
week_days = settings("week_days");
|
||||
months = settings("months");
|
||||
|
||||
["default_fonts", "fonts"].forEach(key => add_fonts(settings(key)));
|
||||
|
||||
settings("autostart") && self.start();
|
||||
|
||||
};
|
||||
|
||||
construct();
|
||||
|
||||
};
|
4
Public/git_update.php
Executable file
4
Public/git_update.php
Executable file
@ -0,0 +1,4 @@
|
||||
<?php
|
||||
|
||||
header("content-type: text/plain");
|
||||
echo shell_exec("git pull 2>&1");
|
164
Public/test.html
Executable file
164
Public/test.html
Executable file
@ -0,0 +1,164 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en" dir="ltr">
|
||||
<head>
|
||||
<title>JSReports - Tests</title>
|
||||
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
|
||||
<meta charset="utf-8" />
|
||||
|
||||
<link type="text/css" rel="stylesheet" data-language="CSS3" href="https://cdn.k3y.pw/css/fonts/local/Roboto.css" data-crossorigin="anonymous" charset="utf-8" />
|
||||
|
||||
<script data-type="text/javascript" data-language="JavaScript 1.8.5" src="/data/html2canvas.min.js" data-crossorigin="anonymous" charset="utf-8"></script>
|
||||
<script data-type="text/javascript" data-language="JavaScript 1.8.5" src="/data/jspdf.umd.min.js" data-crossorigin="anonymous" charset="utf-8"></script>
|
||||
<script data-type="text/javascript" data-language="JavaScript 1.8.5" src="/data/purify.min.js" data-map="/data/purify.min.js.map" data-crossorigin="anonymous" charset="utf-8"></script>
|
||||
<script data-type="text/javascript" data-language="JavaScript 1.8.5" src="/data/html-docx.js" data-crossorigin="anonymous" charset="utf-8"></script>
|
||||
<script data-type="text/javascript" data-language="ECMAScript 2015" src="/ecma/JSReports.ecma.js" data-crossorigin="anonymous" charset="utf-8"></script>
|
||||
|
||||
<script data-type="text/javascript" data-language="ECMAScript 2015" charset="utf-8">
|
||||
|
||||
const grid_a = {
|
||||
type : "grid",
|
||||
header : ["Cabecera A", "Cabecera B", "Cabecera C", "Cabecera D"],
|
||||
body : []
|
||||
};
|
||||
let format = window.location.hash.substr(1).toLowerCase();
|
||||
|
||||
!["pdf", "doc"].includes(format) && (format = "doc");
|
||||
|
||||
for(let i = 0; i < 100; i ++){
|
||||
grid_a.body[i] = [];
|
||||
for(let j = 0; j < 4; j ++)
|
||||
grid_a.body[i].push(Math.random() * 10 ** 8 >> 0);
|
||||
};
|
||||
|
||||
["pdf", "doc"].includes(format) && (js_reports = new JSReports({
|
||||
proxy : "https://proxycors.k3y.pw/api/DHkwPBhzp78Gz8g3BmG4VFnDgnt5kU9J6XQPjWMGDKwjr6s3f9nV7545B/{url}"
|
||||
})).on_ready(() => js_reports.create({
|
||||
header : (`
|
||||
<table class="header-box">
|
||||
<tbody>
|
||||
<tr class="row-1">
|
||||
<td rowspan="2" class="logo"><img src="https://kyman.k3y.pw/images/KyMAN.png" /></td>
|
||||
<td class="entity">Entity</td>
|
||||
</tr>
|
||||
<tr class="row-2">
|
||||
<td class="title">Title</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
`),
|
||||
body : (`
|
||||
<h1>Funciona xD</h1>
|
||||
<p><a href="https://kyman.k3y.pw" target="_blank" title="KyMAN"><img src="https://kyman.k3y.pw/images/KyMAN.png" /></a></p>
|
||||
<p>{grid_a}</p>
|
||||
<p>Probando un <a href="https://kyman.k3y.pw" target="_blank" title="KyMAN">Link</a>.</p>
|
||||
<table>
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Cabecera A</th>
|
||||
<th>Cabecera B</th>
|
||||
<th>Cabecera C</th>
|
||||
<th>Cabecera D</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr><td>Jaja 1</td><td>Jaja 2</td><td>Jaja 3</td><td>Jaja 4</td></tr>
|
||||
<tr><td>Jaja 1</td><td>Jaja 2</td><td>Jaja 3</td><td>Jaja 4</td></tr>
|
||||
<tr><td>Jaja 1</td><td>Jaja 2</td><td>Jaja 3</td><td>Jaja 4</td></tr>
|
||||
<tr><td>Jaja 1</td><td>Jaja 2</td><td>Jaja 3</td><td>Jaja 4</td></tr>
|
||||
<tr><td>Jaja 1</td><td>Jaja 2</td><td>Jaja 3</td><td>Jaja 4</td></tr>
|
||||
<tr><td>Jaja 1</td><td>Jaja 2</td><td>Jaja 3</td><td>Jaja 4</td></tr>
|
||||
<tr><td>Jaja 1</td><td>Jaja 2</td><td>Jaja 3</td><td>Jaja 4</td></tr>
|
||||
<tr><td>Jaja 1</td><td>Jaja 2</td><td>Jaja 3</td><td>Jaja 4</td></tr>
|
||||
<tr><td>Jaja 1</td><td>Jaja 2</td><td>Jaja 3</td><td>Jaja 4</td></tr>
|
||||
<tr><td>Jaja 1</td><td>Jaja 2</td><td>Jaja 3</td><td>Jaja 4</td></tr>
|
||||
<tr><td>Jaja 1</td><td>Jaja 2</td><td>Jaja 3</td><td>Jaja 4</td></tr>
|
||||
<tr><td>Jaja 1</td><td>Jaja 2</td><td>Jaja 3</td><td>Jaja 4</td></tr>
|
||||
<tr><td>Jaja 1</td><td>Jaja 2</td><td>Jaja 3</td><td>Jaja 4</td></tr>
|
||||
</tbody>
|
||||
</table>
|
||||
<p>Otro texto xD</p>
|
||||
{list_a}
|
||||
`),
|
||||
footer : (`
|
||||
<table class="footer-box">
|
||||
<tbody>
|
||||
<tr>
|
||||
<td class="page">{page} / {pages}</td>
|
||||
<td class="date">{date}</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
`),
|
||||
// body : (`
|
||||
// <h1>FUNCIONA xD</h1>
|
||||
// <p><a href="https://kyman.k3y.pw" target="_blank" title="KyMAN"><img src="https://kyman.k3y.pw/images/KyMAN.png" /></a></p>
|
||||
// `),
|
||||
// footer : (`<p>Esto es el Footer xD</p>`),
|
||||
css : (`
|
||||
h1{
|
||||
color : #F00;
|
||||
text-align : center;
|
||||
}
|
||||
.body img{
|
||||
width : 50%;
|
||||
height : auto;
|
||||
}
|
||||
table{width : 100%;}
|
||||
.grid_a{padding-top : ` + js_reports.to_pixels(5) + `px;}
|
||||
ol{list-style-type : upper-roman;}
|
||||
ul{list-style-type : circle;}
|
||||
.header-box img{
|
||||
width : auto;
|
||||
height : ` + js_reports.to_pixels(30) + `px;
|
||||
margin-right : 1em;
|
||||
vertical-align : middle;
|
||||
}
|
||||
.header-box .logo{width : 0px;}
|
||||
.header-box{border-collapse : collapse;}
|
||||
.header-box td{padding : 0px;}
|
||||
.header-box .entity{
|
||||
vertical-align : bottom;
|
||||
font-weight : 400;
|
||||
font-size : ` + js_reports.to_pixels(6) + `px;
|
||||
}
|
||||
.header-box .title{
|
||||
vertical-align : top;
|
||||
font-weight : 900;
|
||||
font-size : ` + js_reports.to_pixels(10) + `px;
|
||||
}
|
||||
.entity,h1{font-family : Roboto;}
|
||||
.grid_a thead>tr>:nth-child(1){width : 10%}
|
||||
.grid_a thead>tr>:nth-child(2){width : 40%}
|
||||
`),
|
||||
type : format,
|
||||
margin_bottom : 20,
|
||||
variables : {
|
||||
grid_a : grid_a,
|
||||
list_a : {type : "list", mode : "ordered", start : 12, items : [
|
||||
"cosa 1",
|
||||
"cosa 2",
|
||||
"cosa 3",
|
||||
"...",
|
||||
["jojo", {mode : "unordered", items : [
|
||||
"pasa A",
|
||||
["pasa B", {items : [
|
||||
"otro xD"
|
||||
]}],
|
||||
"pasa C"
|
||||
]}],
|
||||
"juas",
|
||||
"jiji"
|
||||
]}
|
||||
},
|
||||
header_height : 30,
|
||||
footer_height : 10
|
||||
}, pdf => {
|
||||
console.log(pdf);
|
||||
js_reports.download(pdf, "prueba." + format);
|
||||
}));
|
||||
|
||||
</script>
|
||||
|
||||
</head>
|
||||
<body></body>
|
||||
</html>
|
6
Public/wmd.php
Executable file
6
Public/wmd.php
Executable file
@ -0,0 +1,6 @@
|
||||
<?php
|
||||
|
||||
include __DIR__ . "/../../WMarkDown/PHP/include.php";
|
||||
include __DIR__ . "/../PHP/JSReports.Secrets.php";
|
||||
|
||||
$wmd = new WMarkDown(JSReports\Secrets::wmarkdown);
|
26
Public/wmd_scripts.php
Executable file
26
Public/wmd_scripts.php
Executable file
@ -0,0 +1,26 @@
|
||||
<?php
|
||||
|
||||
include __DIR__ . "/../../WMarkDown/PHP/include.php";
|
||||
include __DIR__ . "/../PHP/JSReports.Secrets.php";
|
||||
|
||||
$wmd = new WMarkDown(array_merge([
|
||||
"action" => "update_scripts",
|
||||
"author" => "KyMAN",
|
||||
"project" => "JSReports",
|
||||
"class" => "JSReports",
|
||||
"object" => "jsreports",
|
||||
"url" => "https://jsreports.k3y.pw",
|
||||
"project_author" => "KyMAN",
|
||||
"key_words" => "jsreports,js,report,ecma,pdf,doc,csv,kyman,developt,desarrollo,documentacion,doc",
|
||||
"logo" => "/images/JSReports.png",
|
||||
"language" => "es",
|
||||
"wmd_file" => "/../WMarkDown/HTML/script.w.md",
|
||||
"wmd_file_empty" => "/../WMarkDown/HTML/file.w.md",
|
||||
"ignore_script_paths" => [
|
||||
"/Public/data",
|
||||
"/Public/git_update.php",
|
||||
"/Public/wmd.php",
|
||||
"/Public/wmd_scripts.php"
|
||||
],
|
||||
"only" => "/Public"
|
||||
], JSReports\Secrets::wmarkdown));
|
24
WMD/dev/ECMAScript/index.w.md
Executable file
24
WMD/dev/ECMAScript/index.w.md
Executable file
@ -0,0 +1,24 @@
|
||||
[[post_data {
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422
|
||||
}]]
|
||||
# ECMAScript
|
||||
|
||||
[[header_level 0]]
|
||||
[[include /WMD/dev/Public/ecma/JSReports.ecma.js.w.md]]
|
||||
|
||||
|
||||
|
||||
[[html_data {
|
||||
"title" : "ECMAScript - JSReports",
|
||||
"url" : "https://jsreports.k3y.pw/dev/ECMAScript/index.html",
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422,
|
||||
"key_words" : "jsreports,js,report,ecma,pdf,doc,csv,kyman,developt,desarrollo,documentacion,doc,developt,desarrollo,programación,ecmascript",
|
||||
"description" : "Parte ECMAScript del JSReports.",
|
||||
"project" : "JSReports",
|
||||
"logo" : "/images/JSReports.png",
|
||||
"language" : "es"
|
||||
}]]
|
549
WMD/dev/Public/ecma/JSReports.ecma.js.w.md
Executable file
549
WMD/dev/Public/ecma/JSReports.ecma.js.w.md
Executable file
@ -0,0 +1,549 @@
|
||||
[[post_data {
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422
|
||||
}]]
|
||||
# JSReports.ecma.js
|
||||
|
||||
```txt
|
||||
/Public/ecma/JSReports.ecma.js
|
||||
```
|
||||
|
||||
## [[plain JSReports.event_execute]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.event_execute
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 8278db1e610a100e5d356a52280cc082
|
||||
#key - optional Parámetro key
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.event_add]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.event_add
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 0c176da24fa7ae3cb649495f8e7170d8
|
||||
#key - optional Parámetro key
|
||||
#method - optional Parámetro method
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.event_remove]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.event_remove
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 19d4a9003d7c5d18ecaaea69096d8af0
|
||||
#key - optional Parámetro key
|
||||
#i - optional Parámetro i
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.is_html_item]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.is_html_item
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 9fc6e2286fc35144ae5d31e9f90223a0
|
||||
#item - optional Parámetro item
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.default_value]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.default_value
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash a1841f42c4352bb7f9f7bb87f89ff6fb
|
||||
#_default - optional Parámetro _default
|
||||
#nulls - optional Parámetro nulls
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.settings]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.settings
|
||||
@see JSReports.default_value
|
||||
@see JSReports.settings
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash aca8a9716fee6aef64d6753573aebf61
|
||||
#names - optional Parámetro names
|
||||
#inputs - optional Parámetro inputs
|
||||
#_default - optional Parámetro _default
|
||||
#nulls - optional Parámetro nulls
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.threads_method]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.threads_method
|
||||
@see JSReports.event_execute
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access private
|
||||
@hash bdc0d47954df34f8c7dd34886abb484b
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.threads_start]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.threads_start
|
||||
@see JSReports.settings
|
||||
@see JSReports.threads_method
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 8ddfcc5b5bc311360f29b185dce9cd19
|
||||
#frames_per_second - optional Parámetro frames_per_second
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.threads_stop]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.threads_stop
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash c1b6d79c278d28a090faf96255fa0c34
|
||||
]]
|
||||
|
||||
## [[plain JSReports.threads_add]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.threads_add
|
||||
@see JSReports.event_add
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash a8bcfab6b51e3d71c29dfe4489f1a2ea
|
||||
#method - optional Parámetro method
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.threads_remove]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.threads_remove
|
||||
@see JSReports.event_remove
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 2502fd5b998c2aa8c8ef113766274944
|
||||
#i - optional Parámetro i
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.preload]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.preload
|
||||
@see JSReports.is_html_item
|
||||
@see JSReports.settings
|
||||
@see JSReports.threads_add
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 78825cc3c12f69f2ce9e0dbb365032e3
|
||||
#selector - optional Parámetro selector
|
||||
#callback - optional Parámetro callback
|
||||
]]
|
||||
|
||||
## [[plain JSReports.ready]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.ready
|
||||
@see JSReports.event_execute
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access private
|
||||
@hash 24173da9f3087d1dc7dd6cfb091e1973
|
||||
#position - optional Parámetro position
|
||||
]]
|
||||
|
||||
## [[plain JSReports.start]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.start
|
||||
@see JSReports.threads_start
|
||||
@see JSReports.settings
|
||||
@see JSReports.preload
|
||||
@see JSReports.ready
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 7a9f7395ead121483d8fff795eec1c1f
|
||||
]]
|
||||
|
||||
## [[plain JSReports.on_ready]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.on_ready
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash b10a8f8510b1fdd31af34e4742531d68
|
||||
#method - optional Parámetro method
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.string_variables]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.string_variables
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash baaa8e283a18d68f6e9af7bb5fa4cbbe
|
||||
#string - optional Parámetro string
|
||||
#variables - optional Parámetro variables
|
||||
#_default - optional Parámetro _default
|
||||
]]
|
||||
|
||||
## [[plain JSReports.base64_to_blob]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.base64_to_blob
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash b9ca1772f19dd57db9bedc5678ed79e5
|
||||
#uri - optional Parámetro uri
|
||||
#type - optional Parámetro type
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.hash]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.hash
|
||||
@see JSReports.settings
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 0e8da659a099929c4de6a1f107c44d8c
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.grid_to_html]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.grid_to_html
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 667df7e5df63dd419bf9465b12f221a1
|
||||
#grid - optional Parámetro grid
|
||||
#name - optional Parámetro name
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.list_to_html]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.list_to_html
|
||||
@see JSReports.settings
|
||||
@see JSReports.list_to_html
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash d0310359b0d5fbe909db8f3968c63972
|
||||
#list - optional Parámetro list
|
||||
#name - optional Parámetro name
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.css_to_html]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.css_to_html
|
||||
@see JSReports.hash
|
||||
@see JSReports.preload
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash ca5cbc79e2bf66ca5b2b3fb1d5390cea
|
||||
#html - optional Parámetro html
|
||||
#css - optional Parámetro css
|
||||
#type - optional Parámetro type
|
||||
#body_size - optional Parámetro body_size
|
||||
#dpi - optional Parámetro dpi
|
||||
#callback - optional Parámetro callback
|
||||
]]
|
||||
|
||||
## [[plain JSReports.get_page_size]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.get_page_size
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 0c9acc181031029511c870013794933e
|
||||
#format - optional Parámetro format
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.to_pixels]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.to_pixels
|
||||
@see JSReports.settings
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 834fd27f6c5fad1286ac1d4f2686a685
|
||||
#size - optional Parámetro size
|
||||
#dpi - optional Parámetro dpi
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.create_canas]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.create_canas
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash e590bf71f37824d9ccfad63f9d5d1b18
|
||||
#html - optional Parámetro html
|
||||
#width - optional Parámetro width
|
||||
#height - optional Parámetro height
|
||||
#callback - optional Parámetro callback
|
||||
]]
|
||||
|
||||
## [[plain JSReports.time_format]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.time_format
|
||||
@see JSReports.string_variables
|
||||
@see JSReports.settings
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 204420143766456a0655f90e88bde2a8
|
||||
#date - optional Parámetro date
|
||||
#format - optional Parámetro format
|
||||
]]
|
||||
|
||||
## [[plain JSReports.page_variables]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.page_variables
|
||||
@see JSReports.settings
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access private
|
||||
@hash 0e1b0f139196df893613aac593e29e3c
|
||||
#html - optional Parámetro html
|
||||
#variables - optional Parámetro variables
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.pdf_header_footer_create]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.pdf_header_footer_create
|
||||
@see JSReports.pdf_header_footer_create
|
||||
@see JSReports.page_variables
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access private
|
||||
@hash fc6d493a044a62726024d64c9cdaa4f0
|
||||
#pdf - optional Parámetro pdf
|
||||
#header - optional Parámetro header
|
||||
#footer - optional Parámetro footer
|
||||
#margin - optional Parámetro margin
|
||||
#pages - optional Parámetro pages
|
||||
#callback - optional Parámetro callback
|
||||
#i - optional Parámetro i
|
||||
]]
|
||||
|
||||
## [[plain JSReports.create]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.create
|
||||
@see JSReports.settings
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash d8eec2408d0579c21dfaed249e09d2c9
|
||||
#input - optional Parámetro input
|
||||
#callback - optional Parámetro callback
|
||||
]]
|
||||
|
||||
## [[plain JSReports.get_uri_data]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.get_uri_data
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash f4644a2029a63c4358ff2c669cc04ab8
|
||||
#data - optional Parámetro data
|
||||
#type - optional Parámetro type
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.download]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.download
|
||||
@see JSReports.get_uri_data
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 4f44d8e3a5538fff046fd56976784a58
|
||||
#data - optional Parámetro data
|
||||
#file_name - optional Parámetro file_name
|
||||
]]
|
||||
|
||||
## [[plain JSReports.add_fonts]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.add_fonts
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access public
|
||||
@hash 3e46c209a2c978863975828939679f6c
|
||||
#array - optional Parámetro array
|
||||
#return - - Retorno.
|
||||
]]
|
||||
|
||||
## [[plain JSReports.construct]]
|
||||
|
||||
[[wdoc
|
||||
Método object.
|
||||
@name JSReports.construct
|
||||
@see JSReports.settings
|
||||
@see JSReports.add_fonts
|
||||
@see JSReports.start
|
||||
@lang ECMAScript
|
||||
@author KyMAN
|
||||
@since 20220422
|
||||
@version 20220422
|
||||
@access private
|
||||
@hash 3843a081dceb29470cdbf51afab923a8
|
||||
]]
|
||||
|
||||
[[html_data {
|
||||
"title" : "JSReports.ecma.js - JSReports",
|
||||
"url" : "https://jsreports.k3y.pw/Public/ecma/JSReports.ecma.js.html",
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422,
|
||||
"key_words" : "jsreports,js,report,ecma,pdf,doc,csv,kyman,developt,desarrollo,documentacion,doc,developt,desarrollo,programación,cma",
|
||||
"description" : "JSReports.ecma.js del JSReports.",
|
||||
"project" : "JSReports",
|
||||
"logo" : "/images/JSReports.png",
|
||||
"language" : "es"
|
||||
}]]
|
55
WMD/dev/index.w.md
Executable file
55
WMD/dev/index.w.md
Executable file
@ -0,0 +1,55 @@
|
||||
[[post_data {
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422
|
||||
}]]
|
||||
|
||||
# ECMAScript
|
||||
|
||||
- [/dev/ECMAScript#JSReports-ecma-js-2 /Public/ecma/JSReports.ecma.js]
|
||||
- [/dev/ECMAScript#JSReports-event-execute-2 JSReports.event\_execute]
|
||||
- [/dev/ECMAScript#JSReports-event-add-2 JSReports.event\_add]
|
||||
- [/dev/ECMAScript#JSReports-event-remove-2 JSReports.event\_remove]
|
||||
- [/dev/ECMAScript#JSReports-is-html-item-2 JSReports.is\_html\_item]
|
||||
- [/dev/ECMAScript#JSReports-default-value-2 JSReports.default\_value]
|
||||
- [/dev/ECMAScript#JSReports-settings-2 JSReports.settings]
|
||||
- [/dev/ECMAScript#JSReports-threads-method-2 JSReports.threads\_method]
|
||||
- [/dev/ECMAScript#JSReports-threads-start-2 JSReports.threads\_start]
|
||||
- [/dev/ECMAScript#JSReports-threads-stop-2 JSReports.threads\_stop]
|
||||
- [/dev/ECMAScript#JSReports-threads-add-2 JSReports.threads\_add]
|
||||
- [/dev/ECMAScript#JSReports-threads-remove-2 JSReports.threads\_remove]
|
||||
- [/dev/ECMAScript#JSReports-preload-2 JSReports.preload]
|
||||
- [/dev/ECMAScript#JSReports-ready-2 JSReports.ready]
|
||||
- [/dev/ECMAScript#JSReports-start-2 JSReports.start]
|
||||
- [/dev/ECMAScript#JSReports-on-ready-2 JSReports.on\_ready]
|
||||
- [/dev/ECMAScript#JSReports-string-variables-2 JSReports.string\_variables]
|
||||
- [/dev/ECMAScript#JSReports-base64-to-blob-2 JSReports.base64\_to\_blob]
|
||||
- [/dev/ECMAScript#JSReports-hash-2 JSReports.hash]
|
||||
- [/dev/ECMAScript#JSReports-grid-to-html-2 JSReports.grid\_to\_html]
|
||||
- [/dev/ECMAScript#JSReports-list-to-html-2 JSReports.list\_to\_html]
|
||||
- [/dev/ECMAScript#JSReports-css-to-html-2 JSReports.css\_to\_html]
|
||||
- [/dev/ECMAScript#JSReports-get-page-size-2 JSReports.get\_page\_size]
|
||||
- [/dev/ECMAScript#JSReports-to-pixels-2 JSReports.to\_pixels]
|
||||
- [/dev/ECMAScript#JSReports-create-canas-2 JSReports.create\_canas]
|
||||
- [/dev/ECMAScript#JSReports-time-format-2 JSReports.time\_format]
|
||||
- [/dev/ECMAScript#JSReports-page-variables-2 JSReports.page\_variables]
|
||||
- [/dev/ECMAScript#JSReports-pdf-header-footer-create-2 JSReports.pdf\_header\_footer\_create]
|
||||
- [/dev/ECMAScript#JSReports-create-2 JSReports.create]
|
||||
- [/dev/ECMAScript#JSReports-get-uri-data-2 JSReports.get\_uri\_data]
|
||||
- [/dev/ECMAScript#JSReports-download-2 JSReports.download]
|
||||
- [/dev/ECMAScript#JSReports-add-fonts-2 JSReports.add\_fonts]
|
||||
- [/dev/ECMAScript#JSReports-construct-2 JSReports.construct]
|
||||
|
||||
|
||||
[[html_data {
|
||||
"title" : "Código - JSReports",
|
||||
"url" : "https://jsreports.k3y.pw/dev/index.html",
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422,
|
||||
"key_words" : "jsreports,js,report,ecma,pdf,doc,csv,kyman,developt,desarrollo,documentacion,doc,developt,desarrollo,programación,todo,all",
|
||||
"description" : "Parte Todo del JSReports.",
|
||||
"project" : "JSReports",
|
||||
"logo" : "/images/JSReports.png",
|
||||
"language" : "es"
|
||||
}]]
|
122
WMD/es/bugs.w.md
Executable file
122
WMD/es/bugs.w.md
Executable file
@ -0,0 +1,122 @@
|
||||
[[post_data {
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422
|
||||
}]]
|
||||
# Bugs
|
||||
|
||||
En esta sección se catalogarán todos los Bugs y el estado conforme a si están o no arreglados o si
|
||||
se están tratando.
|
||||
|
||||
## Cabeceras y pies dispares en UDF
|
||||
|
||||
Las cabeceras y pies de página salen en las páginas impares en UDF. El problema recae principalmente
|
||||
en que los etiquetados y marcas de MS no son compatibles con las de UDF, siendo para UDF el
|
||||
'title="header"' para la cabecera y el 'title="footer"' para el pie; mientras que en MS sería el
|
||||
atributo Style "mso-element:header;" para la cabecera y "mso-elemento:footer;" para el pie. Está
|
||||
globalizado, pero el método UDF sólo muestra las cabeceras y los pies en las páginas impares.
|
||||
|
||||
- [ ] Arreglar el fallo para que salgan en todas las páginas.
|
||||
|
||||
Hay una pseudosolución que aportaron en la respuesta del Link que se muestra a continuación se
|
||||
muestra una pseudosolución (Digo pseudo porque no es una cabecera ni pié real, sino que se usa una
|
||||
tabla que contiene ambas cosas la cual repite su THEAD y su TFOOT en todas las páginas) pero al no
|
||||
ser una cabecera y pié reales no lo establecí, pero decir que en caso de extrema necesidad, ésta
|
||||
puede ser aplicada perfectamente.
|
||||
|
||||
https://stackoverflow.com/questions/1360869/how-to-use-html-to-print-header-and-footer-on-every-printed-page-of-a-document#answer-51371081
|
||||
|
||||
## Problemas cabeceras y piés PDF
|
||||
|
||||
El jsPDF no fue diseñado para trabajar en profundidad el HTML de hecho, no es capaz ni de
|
||||
interpretar CSS ni de adjuntar las fuentes de forma autónoma, pero el problema viene a la hora de
|
||||
establecer un elemento HTML pues, aunque establezcas la página donde quieras establecerlo, éste
|
||||
siempre irá a la primera página, y si estableces un margen o posición "top" muy alto, éste
|
||||
desaparece si no es nativo para estar ahí. El HTML se superpondrá a lo que ya hay en el documento y
|
||||
no permite establecer márgenes diferentes a distintos HTML, por lo que el tema de las cabeceras
|
||||
queda totalmente descartado mediante HTML nativo.
|
||||
|
||||
- [X] Conseguir un sistema que permita generar cabeceras y piés de página contra HTML y CSS.
|
||||
- [ ] Probar el sistema de impresión HTML de CSS para establecer una tabla que por página repita su
|
||||
THEAD y su TFOOT, como la trampa para establecer cabeceras que encontré para DOCs.
|
||||
|
||||
> [[! important IMPORTANTE]]: Actualmente, este sistema funciona pero es a partir de la creación de
|
||||
una imagen contra el HTML y CSS dado lo que impide seleccionar texto entre otros problemas. No me
|
||||
preocupan los sistemas que migran de PDF a DOC por los OCR.
|
||||
|
||||
> [[! note NOTA]]: Para arreglar este problema se optó por hacer uso de la dependencia del propio
|
||||
jsPDF: html2canvas, y de ahí se extrae una imagen en URI Base64 que es la que se usa para dichos
|
||||
fines.
|
||||
|
||||
## Problemas con CSS
|
||||
|
||||
En los documentos DOC, la etiqueta STYLE que contiene el CSS, tiene órdenes y sentencias muy
|
||||
específicas que no pueden ser flexibilizadas por lo que hay que hacer una adaptación de la misma
|
||||
para que funcionen.
|
||||
|
||||
- [X] Crear adaptación para que se generen.
|
||||
|
||||
Básicamente se reutilizó el sistema hecho para los PDF.
|
||||
|
||||
## Corregir tamaños IMG
|
||||
|
||||
Las imágenes, en os documentos DOC tienen el problema del valor de atributo "width" y "height" auto,
|
||||
que cogen como valor su ancho o alto, consecutivamente.
|
||||
|
||||
- [X] Conseguir proporcionar las imágenes.
|
||||
|
||||
Para arreglar dicho fallo se hice un análisis del CSS contra las imágenes en su precarga y
|
||||
establecer un tamaño relativo con respecto al formato de página, tamaño de la misma y el tamaño de
|
||||
la imagen.
|
||||
|
||||
## Tamaños de tabla
|
||||
|
||||
En los DOC, las tablas no hacen caso de los atributos de tamaño de CSS, requiriendo de hacer uso del
|
||||
atributo WIDTH.
|
||||
|
||||
Por otro lado, las celdas tampoo hacen caso de su ancho, teniendo que usar la etiqueta COLGROUP y
|
||||
sus subetiquetas COL.
|
||||
|
||||
- [X] Migrar el ancho en CSS al atributo WIDTH de la tabla.
|
||||
- [X] Migrar el ancho de las columnas a los COL.
|
||||
- [-] Corregir la porcentualidad de los COL.
|
||||
|
||||
> [[! important IMPORTANTE]]: Los COL, en los DOC UDF ignora la unidad del atributo y no respeta la
|
||||
proporción de peso, quedando sobre una proporción a 50000. Automáticamente lo tramita desde los DPI
|
||||
en medidas por pixel; y por el tamaño de página en mm, cm, in, etc; así como por los propios
|
||||
porcentajes. Creo que es algo que hay que mejorar, pero que para salir del paso llega.
|
||||
|
||||
## Medidas mm en DOC UDF
|
||||
|
||||
Cuando tratabajamos los márgenes CSS de las cabeceras y los pies de página, éstos se establecen en
|
||||
mm de forma forzada aunque le pongas otra unidad de medida.
|
||||
|
||||
> [[! note NOTA]]: Al ser un atributo CSS especial para MS puede ser que se condicione forzadamente
|
||||
en mm? No hay información a penas acerca de ello.
|
||||
|
||||
- [ ] Arreglar el Bug, o al menos, adaptarlo para que salga en otras unidades establecidas en CSS.
|
||||
|
||||
> [[! note NOTA]]: Actualmente está trabajando en mm, de la misma forma que trabaja esta librería.
|
||||
|
||||
## PDF en Chrome
|
||||
|
||||
Por algún motivo, en Chrome no crea el PDF. Queda como totalmente apagado y sin terminar el proceso.
|
||||
|
||||
- [X] Arreglar el Bug.
|
||||
|
||||
El Bug parece ser que era porque el evento OnLoad del IFRAME que gestiona los html2canvas no existe
|
||||
en Chrome salvo que éste venga con una URL, por lo que se decidió hacer un Timeout para solventar la
|
||||
precarga del objeto.
|
||||
|
||||
[[html_data {
|
||||
"title" : "JSReports - Bugs",
|
||||
"url" : "https://jsreports.k3y.pw/es/bugs.html",
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422,
|
||||
"key_words" : "jsreports,js,report,ecma,pdf,doc,csv,kyman,wmd,wmarkdown,documentación,bugs,errores,errors",
|
||||
"description" : "Bugs del proyecto JSReports.",
|
||||
"project" : "Bugs",
|
||||
"logo" : "https://jsreports.k3y.pw/images/JSReports.png",
|
||||
"language" : "es"
|
||||
}]]
|
38
WMD/es/index.w.md
Executable file
38
WMD/es/index.w.md
Executable file
@ -0,0 +1,38 @@
|
||||
[[post_data {
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422
|
||||
}]]
|
||||
# JSReports
|
||||
|
||||
Este proyecto está orientado a crear Reports (Informes) directamente desde JS cliente desde un
|
||||
navegador. Dichos informes se entiende como resultados de información en texto como PDF, DOC, etc.
|
||||
Así como tablas de datos.
|
||||
|
||||
[[header_level 0]]
|
||||
[[include /WMD/es/project.w.md]]
|
||||
|
||||
[[header_level 0]]
|
||||
[[include /WMD/es/projects.w.md]]
|
||||
|
||||
[[header_level 0]]
|
||||
[[include /WMD/es/notes.w.md]]
|
||||
|
||||
[[header_level 0]]
|
||||
[[include /WMD/es/bugs.w.md]]
|
||||
|
||||
[[header_level 0]]
|
||||
[[include /WMD/es/targets.w.md]]
|
||||
|
||||
[[html_data {
|
||||
"title" : "JSReports - Documentación",
|
||||
"url" : "https://jsreports.k3y.pw/es",
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422,
|
||||
"key_words" : "jsreports,js,report,ecma,pdf,doc,csv,kyman,wmd,wmarkdown,documentación",
|
||||
"description" : "Documentación del proyecto JSReports.",
|
||||
"project" : "Documentación",
|
||||
"logo" : "https://jsreports.k3y.pw/images/JSReports.png",
|
||||
"language" : "es"
|
||||
}]]
|
176
WMD/es/notes.w.md
Executable file
176
WMD/es/notes.w.md
Executable file
@ -0,0 +1,176 @@
|
||||
[[post_data {
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422
|
||||
}]]
|
||||
# Notas
|
||||
|
||||
Notas para no olvidarme del proyecto.
|
||||
|
||||
El proyecto se basa en una librería ECMA/JS la cual se llama JSReports como nombre de clase. Hay que
|
||||
crear un objecto JSReports para poder trabajar con ella. En el caso de PDF depende de las librerías:
|
||||
|
||||
- [https://cdn.k3y.pw/js/html2canvas.min.js]
|
||||
- [https://cdn.k3y.pw/js/jspdf.umd.min.js]
|
||||
- [https://cdn.k3y.pw/js/purify.min.js]
|
||||
|
||||
Para poder empezar a trabajar con esta librería hay que esperar asíncronamente a que termine de
|
||||
cargar mediante un Callback "on_ready"
|
||||
|
||||
```js
|
||||
(js_reports = new JSReports(/* PARAMETROS DE ENTRADA */)).on_ready(() => console.log("Ya terminó de cargar xD"));
|
||||
```
|
||||
|
||||
> [[! note NOTA]]: La librería requiere de un sitio donde poner componentes de forma temporal a modo
|
||||
de caché. No le vale un DocumentFragment. Si no se le establece se pondrá por defecto BODY.
|
||||
|
||||
# PDF y DOC
|
||||
|
||||
El trabajo con esta librería cara los PDF y DOC es exactamente igual. Hay que llamar a un método
|
||||
llamado "create" el cual permite crear este tipo de documentos. La librería se centra en que crees
|
||||
un HTML4 y CSS2, aunque pueden ser adjuntadas cosas de HTML5 y XHTML, así como algunos parámetros
|
||||
CSS3 y customizados cara cualquier a de las dos plataformas. La idea es construir plantillas para
|
||||
cabeceras, pies y cuerpos en HTML y una única hoja de estilos general en CSS, lo que cubriría el 99%
|
||||
del informe, luego hay ciertos parámetros que son necesarios establecer mediante valores.
|
||||
|
||||
Con esta información tenemos como parámetros de entrada un único valor que vendrá siendo un
|
||||
diccionario el cual tiene los siguientes elementos:
|
||||
|
||||
> [[! note NOTA]]: Todas las medidas se toma en mm (Milímetros).
|
||||
|
||||
- **header**: Cabecera HTML.
|
||||
- **body**: Cuerpo HTML.
|
||||
- **footer**: Pié HTML.
|
||||
- **css**: Estilos CSS.
|
||||
- **type**: Extensión que determina si es "doc" o "pdf".
|
||||
- **margin**: Margen general para cualquier lado.
|
||||
- **margin_top**: Margen superior.
|
||||
- **margin_right**: Margen derecho.
|
||||
- **margin_bottom**: Margen inferior.
|
||||
- **margin_left**: Margen izquierdo.
|
||||
- **variables**: Variables para cubrir dentro de los HTML.
|
||||
- **header_height**: Alto de la cabecera.
|
||||
- **footer_height**: Alto del pié.
|
||||
- **margin_header**: Margen de la cabecera.
|
||||
- **margin_footer**: Margen del pié.
|
||||
- **dpi**: DPI para marcar tamaños digitales en PX.
|
||||
- **page_format**: Formato de página (A4, A3, A5, C5, Letter (L), etc.); o tamaño (alto y ancho).
|
||||
|
||||
El formato PDF requiere de embedar las fuentes con las que se vaya a trabajar en formato TTF, que es
|
||||
el formato por defecto cara los OS. Dicho formato requiere de un archivo por estilo (Regular o
|
||||
normal, Light, Bold, Italic, etc). Para embedar fuentes es necesario cubrir la variable "fonts" en
|
||||
el diccionario de parámetros de entrada del objeto y se compone de un Array bidimensional donde el
|
||||
primer nivel es conjunto de fuentes y el segundo se compone de:
|
||||
|
||||
0. Nombre de la fuente.
|
||||
0. Link del estilo.
|
||||
0. Nombre del estilo.
|
||||
|
||||
En ambos casos, las imágenes se embedarán mediante URI Base64, pasando a formar parte del documento.
|
||||
Las imágenes, por defecto, suelen estar protegidas por CORS. Para saltarse dicha restricción es
|
||||
importante hacer uso de un Proxy. Para establecer el Proxy hemos de establecer el parámetro global
|
||||
"proxy" que vendrá siendo una URL contra el Proxy donde la variable String "{url}" determinará donde
|
||||
colocar la URL de la imagen.
|
||||
|
||||
```js
|
||||
js_reports = new JSReports({
|
||||
proxy : "https://proxycors.local/api/DHkwPBhzp78Gz8g3BmG4VFnDgnt5kU9J6XQPjWMGDKwjr6s3f9nV7545B/{url}"
|
||||
})
|
||||
```
|
||||
|
||||
> [[! note NOTA]]: Si el Proxy no retorna las cabeceras del CORS, éste no servirá de nada. Se puede
|
||||
hacer uso del proyecto [https://proxycors.k3y.pw/ ProxyCORS], proyecto en el que está basado el
|
||||
ejemplo también desarrollado por KyMAN. El Git del proyecto es [https://git.k3y.pw/KyMAN/ProxyCORS].
|
||||
|
||||
> [[! important IMPORTANTE]]: El link del ProxyCORS posiblemente no funcione por el hecho de que con
|
||||
dicho Hash podrían usar mi servidor como salto anónimo para saltarse el CORS entre otros fines por
|
||||
lo que el Hash quede deshabilitado.
|
||||
|
||||
También se le pueden agregar componentes especiales al documento como tablas o listas programas
|
||||
directamente como objetos o Arrays a partir de un objeto que determina su tipo y el contenido del
|
||||
mismo. A continuación se titularán los tipos de objetos especiales que hay actualmente.
|
||||
|
||||
## Tablas (Grids)
|
||||
|
||||
Los documentos DOC y PDF permiten la generación de tablas dinámicas a partir de la idea de un Grid,
|
||||
es decir, un objeto que determina la cabecera y los datos y automáticamente, el programa embedará
|
||||
una tabla con dichos datos. La estructura del objeto es la siguiente:
|
||||
|
||||
- **type**: Tipo (puede ser "table" o "grid").
|
||||
- **header** : Array de textos, cada uno será la cabecera de esa columna concreta.
|
||||
- **body**: Cuerpo de la tabla o datos. Array bidimensional con los valores por cada tupla y columna.
|
||||
|
||||
Un ejemplo de una tabla puede ser el siguiente:
|
||||
|
||||
```js
|
||||
const table = {
|
||||
type : "table",
|
||||
header : ["Cabecera 1", "Cabecera 2", "Cabecera 3", "...", "Cabecera N"],
|
||||
body : [
|
||||
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"],
|
||||
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"],
|
||||
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"],
|
||||
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"],
|
||||
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"],
|
||||
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"],
|
||||
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"],
|
||||
["Valor 1", "Valor 2", "Valor 3", "...", "Valor N"]
|
||||
]
|
||||
};
|
||||
```
|
||||
|
||||
## Listas
|
||||
|
||||
Los documentos DOC y PDF permiten la generación de listas dinámicas a partir de un Array el cual
|
||||
puede anidar otros Array para hacer Listas de múltiples niveles. Admiten tantos listas ordenadas
|
||||
como desordenadas, y su estructura es la siguiente:
|
||||
|
||||
- **type**: Tipo (Siempre será "list"),
|
||||
- **mode**: El modo en que se mostrarán los datos. Éste puede ser:
|
||||
- *ol* o *ordered*: Para mostrar los datos con un valor que representa su posición autoincremental.
|
||||
- *ul* o *unordered*: Para mostrar los datos con puntos, guiones o como se establezca por CSS.
|
||||
- **start**: Para los elementos ordenados autoincrementalmente, valor numérico de inicio.
|
||||
- **items**: Array de elementos ordenados. Puede contener objetos que anidan otras listas.
|
||||
|
||||
Un ejemplo de una tabla puede ser el siguiente:
|
||||
|
||||
```js
|
||||
const list = {
|
||||
type : "list",
|
||||
mode : "ordered",
|
||||
start : 12,
|
||||
items : [
|
||||
"cosa 1",
|
||||
"cosa 2",
|
||||
"cosa 3",
|
||||
"...",
|
||||
["jojo", {
|
||||
mode : "unordered",
|
||||
items : [
|
||||
"pasa A",
|
||||
["pasa B", {
|
||||
items : [
|
||||
"otro xD"
|
||||
]
|
||||
}],
|
||||
"pasa C"
|
||||
]
|
||||
}],
|
||||
"juas",
|
||||
"jiji"
|
||||
]
|
||||
};
|
||||
```
|
||||
|
||||
[[html_data {
|
||||
"title" : "JSReports - Notas",
|
||||
"url" : "https://jsreports.k3y.pw/es/notes.html",
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422,
|
||||
"key_words" : "jsreports,js,report,ecma,pdf,doc,csv,kyman,wmd,wmarkdown,documentación,notas",
|
||||
"description" : "Notas del proyecto JSReports.",
|
||||
"project" : "JSReports",
|
||||
"logo" : "https://jsreports.k3y.pw/images/JSReports.png",
|
||||
"language" : "es"
|
||||
}]]
|
29
WMD/es/project.w.md
Executable file
29
WMD/es/project.w.md
Executable file
@ -0,0 +1,29 @@
|
||||
[[post_data {
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422
|
||||
}]]
|
||||
# Proyecto
|
||||
|
||||
El proyecto viene siendo una librería Core que permite, desde un cliente JS (Navegador), junto con
|
||||
sus dependencias, en caso de requerirlo, crear informes en múltiples formatos como PDF y DOC,
|
||||
pasando como formato visual HTML y CSS, así como generación de archivos multiplataforma compatibles
|
||||
con Excel y Calc como es el formato CSV. También se baraja la idea de poder gestionar la descarga de
|
||||
información directa en XML, JSON, etc.
|
||||
|
||||
La librería final es la siguiente:
|
||||
|
||||
https://jsreports.k3y.pw/ecma/JSReports.ecma.js
|
||||
|
||||
[[html_data {
|
||||
"title" : "JSReports - Proyecto",
|
||||
"url" : "https://jsreports.k3y.pw/es/project.html",
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422,
|
||||
"key_words" : "jsreports,js,report,ecma,pdf,doc,csv,kyman,wmd,wmarkdown,documentación,proyecto,descripción",
|
||||
"description" : "Descripción del proyecto JSReports.",
|
||||
"project" : "Proyecto",
|
||||
"logo" : "https://jsreports.k3y.pw/images/JSReports.png",
|
||||
"language" : "es"
|
||||
}]]
|
67
WMD/es/projects.w.md
Executable file
67
WMD/es/projects.w.md
Executable file
@ -0,0 +1,67 @@
|
||||
[[post_data {
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422
|
||||
}]]
|
||||
# Proyectos y dependencias
|
||||
|
||||
Este proyecto depende de una serie de librerías externas las cuales son:
|
||||
|
||||
[[links_group [{
|
||||
"images" : [],
|
||||
"link" : "https://github.com/cure53/DOMPurify",
|
||||
"text" : "DOMPurify"
|
||||
}, {
|
||||
"images" : [""],
|
||||
"link" : "https://html2canvas.hertzen.com/",
|
||||
"text" : "html2canvas"
|
||||
}, {
|
||||
"images" : [
|
||||
"https://parall.ax/parallax-2016/img/svg/jspdf-logo.svg",
|
||||
"https://camo.githubusercontent.com/54ed74d0938e90aa54fc062f91767281c46cfd9964787f1b4a7b898eca9e887e/68747470733a2f2f706172616c6c2e61782f706172616c6c61782d323031362f696d672f7376672f6a737064662d6c6f676f2e737667"
|
||||
],
|
||||
"link" : "https://github.com/parallax/jsPDF",
|
||||
"text" : "jsPDF"
|
||||
}] ]]
|
||||
|
||||
Por otro lado, hay proyectos desarrollados por KyMAN o en los que KyMAN también participó tales
|
||||
como:
|
||||
|
||||
[[links_group [{
|
||||
"images" : ["https://wmarkdown.k3y.pw/images/wmarkdown.png"],
|
||||
"link" : "https://wmarkdown.k3y.pw/",
|
||||
"text" : "WMarkDown"
|
||||
}, {
|
||||
"images" : [],
|
||||
"link" : "https://wdictionaries.k3y.pw/",
|
||||
"text" : "Wdictionaries"
|
||||
}, {
|
||||
"images" : [],
|
||||
"link" : "https://proxycors.k3y.pw/",
|
||||
"text" : "ProxyCORS"
|
||||
}] ]]
|
||||
|
||||
Finalmente, este proyecto es usado en los proyectos:
|
||||
|
||||
[[links_group [{
|
||||
"images" : ["https://anp.k3y.pw/images/AnP.png"],
|
||||
"link" : "https://anp.k3y.pw/",
|
||||
"text" : "AnP"
|
||||
}, {
|
||||
"images" : [],
|
||||
"link" : "https://anprm.k3y.pw/",
|
||||
"text" : "AnPRM"
|
||||
}] ]]
|
||||
|
||||
[[html_data {
|
||||
"title" : "JSReports - Proyectos",
|
||||
"url" : "https://jsreports.k3y.pw/es/projects.html",
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422,
|
||||
"key_words" : "jsreports,js,report,ecma,pdf,doc,csv,kyman,wmd,wmarkdown,documentación,proyectos,dependencias",
|
||||
"description" : "Proyectos y dependencias del proyecto JSReports.",
|
||||
"project" : "Proyectos y dependencias",
|
||||
"logo" : "https://jsreports.k3y.pw/images/JSReports.png",
|
||||
"language" : "es"
|
||||
}]]
|
51
WMD/es/targets.w.md
Executable file
51
WMD/es/targets.w.md
Executable file
@ -0,0 +1,51 @@
|
||||
[[post_data {
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422
|
||||
}]]
|
||||
# Objetivos
|
||||
|
||||
Aquí se pondrán los objetivos del proyecto JSReports.
|
||||
|
||||
- [X] Crear proyecto Git.
|
||||
- [X] Crear base del proyecto.
|
||||
- [X] Crear el JS.
|
||||
- [-] Crear la parte para HTML compacto.
|
||||
- [X] Adjuntador de fuentes.
|
||||
- [X] Meter todo en el CDN y comentarlo.
|
||||
- [X] Añadir cabeceras y pies al PDF.
|
||||
- [X] Posibilidad de múltiples cabeceras y pies.
|
||||
- [X] Corregir sobreescritura de elementos CSS y el múltiple ";".
|
||||
- [X] Montar el cuerpo de los DOC.
|
||||
- [X] Montar cabeceras y pies de página.
|
||||
- [X] Corregir Bug de tamaños de imagen.
|
||||
- [X] Corregir Bug de ancho de tablas.
|
||||
- [X] Corregir Bug de ancho de celdas.
|
||||
- [X] Compatibilizar OpenDocument con MSDocument.
|
||||
- [X] Montar variables de página.
|
||||
- [X] Arreglar Bug de márgenes del Footer y el Header.
|
||||
- [X] Corregir fuentes embedadas de PDF.
|
||||
- /*Hasta aquí es compatible con UDF al 100%.*/
|
||||
- [ ] Montar VM temporal con el Office 365 para probar resultados y corregir Bugs.
|
||||
- *Compatibilizar UDF con MS XML.*
|
||||
- [-] Documentar.
|
||||
- [X] Añadir JSReports al WDictionaries.
|
||||
- [X] Publicar.
|
||||
- [X] Montar CORS.
|
||||
- [X] Subir los archivos de dependencias.
|
||||
- [X] Arreglar el tester HTML.
|
||||
- [X] Elimintar el tester 0 HTML.
|
||||
- [X] Corregir Bug del JSReports en Chrome.
|
||||
|
||||
[[html_data {
|
||||
"title" : "JSReports - Objetivos",
|
||||
"url" : "https://jsreports.k3y.pw/es/targets.html",
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422,
|
||||
"key_words" : "jsreports,js,report,ecma,pdf,doc,csv,kyman,wmd,wmarkdown,documentación,objetivos,targets",
|
||||
"description" : "Objetivos del proyecto JSReports.",
|
||||
"project" : "Objetivos",
|
||||
"logo" : "https://jsreports.k3y.pw/images/JSReports.png",
|
||||
"language" : "es"
|
||||
}]]
|
40
WMD/index.w.md
Executable file
40
WMD/index.w.md
Executable file
@ -0,0 +1,40 @@
|
||||
[[post_data {
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422
|
||||
}]]
|
||||
# JSReports
|
||||
|
||||
Seleccione un idioma para acceder a la documentación del proyecto.
|
||||
|
||||
[[links_group [{
|
||||
"images" : ["https://i.imgur.com/im1o0gc.png"],
|
||||
"link" : "/es/",
|
||||
"text" : "Español",
|
||||
"self" : true
|
||||
}] ]]
|
||||
|
||||
[[header_level 0]]
|
||||
[[include /WMD/es/project.w.md]]
|
||||
|
||||
[[header_level 0]]
|
||||
[[include /WMD/es/projects.w.md]]
|
||||
|
||||
[[header_level 0]]
|
||||
[[include /WMD/es/bugs.w.md]]
|
||||
|
||||
[[header_level 0]]
|
||||
[[include /WMD/es/targets.w.md]]
|
||||
|
||||
[[html_data {
|
||||
"title" : "JSReports - Idioma",
|
||||
"url" : "https://jsreports.k3y.pw/",
|
||||
"author" : "KyMAN",
|
||||
"since" : 20220422,
|
||||
"version" : 20220422,
|
||||
"key_words" : "jsreports,js,report,ecma,pdf,doc,csv,kyman,wmd,wmarkdown,documentación",
|
||||
"description" : "Documentación del proyecto JSReports.",
|
||||
"project" : "JSReports",
|
||||
"logo" : "https://jsreports.k3y.pw/images/JSReports.png",
|
||||
"language" : "es"
|
||||
}]]
|
Loading…
Reference in New Issue
Block a user