Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
b3d783bf63 |
@@ -147,4 +147,4 @@ BEGIN
|
|||||||
RETURN NULL;
|
RETURN NULL;
|
||||||
END
|
END
|
||||||
$$
|
$$
|
||||||
LANGUAGE 'plpgsql'
|
LANGUAGE 'plpgsql';
|
||||||
|
|||||||
@@ -64,6 +64,10 @@ print '<div><a href="class_test.backend.php">Class Test: BACKEND ADMIN CLASS</a>
|
|||||||
print '<div><a href="class_test.lang.php">Class Test: LANG/L10n</a></div>';
|
print '<div><a href="class_test.lang.php">Class Test: LANG/L10n</a></div>';
|
||||||
print '<div><a href="class_test.smarty.php">Class Test: SMARTY</a></div>';
|
print '<div><a href="class_test.smarty.php">Class Test: SMARTY</a></div>';
|
||||||
|
|
||||||
|
print "<hr>";
|
||||||
|
// print all _ENV vars set
|
||||||
|
print "<div>READ _ENV ARRAY:</div>";
|
||||||
|
print "<pre>" . print_r(array_map('htmlentities', $_ENV), true) . "</pre>";
|
||||||
// set + check edit access id
|
// set + check edit access id
|
||||||
$edit_access_id = 3;
|
$edit_access_id = 3;
|
||||||
if (is_object($login) && isset($login->acl['unit'])) {
|
if (is_object($login) && isset($login->acl['unit'])) {
|
||||||
|
|||||||
8
www/configs/.env.example
Normal file
8
www/configs/.env.example
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
# Master configs
|
||||||
|
BASE_NAME=
|
||||||
|
G_TITLE=
|
||||||
|
# DB configs
|
||||||
|
DB_NAME_TEST=
|
||||||
|
DB_USER_TEST=
|
||||||
|
DB_PASS_TEST=
|
||||||
|
DB_HOST_TEST=
|
||||||
@@ -13,15 +13,15 @@ declare(strict_types=1);
|
|||||||
// please be VERY carefull only to change the right side
|
// please be VERY carefull only to change the right side
|
||||||
$DB_CONFIG = [
|
$DB_CONFIG = [
|
||||||
'test' => [
|
'test' => [
|
||||||
'db_name' => 'clemens',
|
'db_name' => $_ENV['DB_NAME_TEST'] ?? '',
|
||||||
'db_user' => 'clemens',
|
'db_user' => $_ENV['DB_USER_TEST'] ?? '',
|
||||||
'db_pass' => 'clemens',
|
'db_pass' => $_ENV['DB_PASS_TEST'] ?? '',
|
||||||
'db_host' => 'db.tokyo.tequila.jp',
|
'db_host' => $_ENV['DB_HOST_TEST'] ?? '',
|
||||||
'db_port' => 5432,
|
'db_port' => 5432,
|
||||||
'db_schema' => 'public',
|
'db_schema' => 'public',
|
||||||
'db_type' => 'pgsql',
|
'db_type' => 'pgsql',
|
||||||
'db_encoding' => '',
|
'db_encoding' => '',
|
||||||
'db_ssl' => 'disable' // allow, disable, require, prefer
|
'db_ssl' => 'allow' // allow, disable, require, prefer
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|||||||
@@ -84,7 +84,7 @@ define('DEFAULT_HASH', 'sha256');
|
|||||||
// default acl level
|
// default acl level
|
||||||
define('DEFAULT_ACL_LEVEL', 80);
|
define('DEFAULT_ACL_LEVEL', 80);
|
||||||
// SSL host name
|
// SSL host name
|
||||||
// define('SSL_HOST', 'ssl.host.name');
|
// define('SSL_HOST', $_ENV['SSL_HOST'] ?? '');
|
||||||
// error page strictness, Default is 3
|
// error page strictness, Default is 3
|
||||||
// 1: only show error page as the last mesure if really no mid & aid can be loaded and found at all
|
// 1: only show error page as the last mesure if really no mid & aid can be loaded and found at all
|
||||||
// 2: if template not found, do not search, show error template
|
// 2: if template not found, do not search, show error template
|
||||||
@@ -139,7 +139,8 @@ define('MASTER_TEMPLATE_NAME', 'main_body.tpl');
|
|||||||
/************* OVERALL CONTROL NAMES *************/
|
/************* OVERALL CONTROL NAMES *************/
|
||||||
// BELOW has HAS to be changed
|
// BELOW has HAS to be changed
|
||||||
// base name for all session and log names
|
// base name for all session and log names
|
||||||
define('BASE_NAME', 'CoreLibs');
|
// only alphanumeric characters, strip all others
|
||||||
|
define('BASE_NAME', preg_replace('/[^A-Za-z0-9]/', '', $_ENV['BASE_NAME'] ?? ''));
|
||||||
|
|
||||||
/************* SESSION NAMES *************/
|
/************* SESSION NAMES *************/
|
||||||
// server name HASH
|
// server name HASH
|
||||||
@@ -266,7 +267,7 @@ define('LOGIN_ENABLED', $SITE_CONFIG[HOST_NAME]['login_enabled']);
|
|||||||
define('SHOW_ALL_ERRORS', true);
|
define('SHOW_ALL_ERRORS', true);
|
||||||
|
|
||||||
/************* GENERAL PAGE TITLE ********/
|
/************* GENERAL PAGE TITLE ********/
|
||||||
define('G_TITLE', '<OVERALL FALLBACK PAGE TITLE>');
|
define('G_TITLE', $_ENV['G_TITLE'] ?? '');
|
||||||
|
|
||||||
/************ STYLE SHEETS / JS **********/
|
/************ STYLE SHEETS / JS **********/
|
||||||
define('ADMIN_STYLESHEET', 'edit.css');
|
define('ADMIN_STYLESHEET', 'edit.css');
|
||||||
|
|||||||
@@ -16,6 +16,13 @@ $CONFIG_PATH_PREFIX = '';
|
|||||||
for ($dir_pos = 0, $dir_max = count(explode(DIRECTORY_SEPARATOR, __DIR__)); $dir_pos <= $dir_max; $dir_pos++) {
|
for ($dir_pos = 0, $dir_max = count(explode(DIRECTORY_SEPARATOR, __DIR__)); $dir_pos <= $dir_max; $dir_pos++) {
|
||||||
$CONFIG_PATH_PREFIX .= '..' . DIRECTORY_SEPARATOR;
|
$CONFIG_PATH_PREFIX .= '..' . DIRECTORY_SEPARATOR;
|
||||||
if (file_exists($CONFIG_PATH_PREFIX . CONFIG_PATH . 'config.master.php')) {
|
if (file_exists($CONFIG_PATH_PREFIX . CONFIG_PATH . 'config.master.php')) {
|
||||||
|
// check if there is an read env file, load it
|
||||||
|
if (file_exists($CONFIG_PATH_PREFIX . CONFIG_PATH . 'read_env_file.php')) {
|
||||||
|
require $CONFIG_PATH_PREFIX . CONFIG_PATH . 'read_env_file.php';
|
||||||
|
// load env variables first
|
||||||
|
readEnvFile($CONFIG_PATH_PREFIX . CONFIG_PATH);
|
||||||
|
}
|
||||||
|
// then load master config file that loads all other config files
|
||||||
require $CONFIG_PATH_PREFIX . CONFIG_PATH . 'config.master.php';
|
require $CONFIG_PATH_PREFIX . CONFIG_PATH . 'config.master.php';
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|||||||
84
www/configs/read_env_file.php
Normal file
84
www/configs/read_env_file.php
Normal file
@@ -0,0 +1,84 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* parses .env file
|
||||||
|
*
|
||||||
|
* Rules for .env file
|
||||||
|
* variable is any alphanumeric string followed by = on the same line
|
||||||
|
* content starts with the first non space part
|
||||||
|
* strings can be contained in "
|
||||||
|
* strings MUST be contained in " if they are multiline
|
||||||
|
* if string starts with " it will match until another " is found
|
||||||
|
* anything AFTER " is ignored
|
||||||
|
* if there are two variables with the same name only the first is used
|
||||||
|
* variables are case sensitive
|
||||||
|
*
|
||||||
|
* @param string $path Folder to file, default is __DIR__
|
||||||
|
* @param string $env_file What file to load, default is .env
|
||||||
|
* @return int -1 other error
|
||||||
|
* 0 for success full load
|
||||||
|
* 1 for file loadable, but no data inside
|
||||||
|
* 2 for file not readable
|
||||||
|
* 3 for file not found
|
||||||
|
*/
|
||||||
|
function readEnvFile(string $path = __DIR__, string $env_file = '.env'): int
|
||||||
|
{
|
||||||
|
// default -1;
|
||||||
|
$status = -1;
|
||||||
|
$env_file_target = $path . DIRECTORY_SEPARATOR . $env_file;
|
||||||
|
// this is not a file -> abort
|
||||||
|
if (!is_file($env_file_target)) {
|
||||||
|
$status = 3;
|
||||||
|
return $status;
|
||||||
|
}
|
||||||
|
// cannot open file -> abort
|
||||||
|
if (($fp = fopen($env_file_target, 'r')) === false) {
|
||||||
|
$status = 2;
|
||||||
|
return $status;
|
||||||
|
}
|
||||||
|
// set to readable but not yet any data loaded
|
||||||
|
$status = 1;
|
||||||
|
$block = false;
|
||||||
|
$var = '';
|
||||||
|
while ($line = fgets($fp)) {
|
||||||
|
// main match for variable = value part
|
||||||
|
if (preg_match("/^\s*([\w_]+)\s*=\s*((\"?).*)/", $line, $matches)) {
|
||||||
|
$var = $matches[1];
|
||||||
|
$value = $matches[2];
|
||||||
|
$quotes = $matches[3];
|
||||||
|
// wirte only if env is not set yet, and write only the first time
|
||||||
|
if (empty($_ENV[$var])) {
|
||||||
|
if (!empty($quotes)) {
|
||||||
|
// match greedy for first to last so we move any " if there are
|
||||||
|
if (preg_match('/^"(.*[^\\\])"/U', $value, $matches)) {
|
||||||
|
$value = $matches[1];
|
||||||
|
} else {
|
||||||
|
// this is a multi line
|
||||||
|
$block = true;
|
||||||
|
// first " in string remove
|
||||||
|
// add removed new line back because this is a multi line
|
||||||
|
$value = ltrim($value, '"') . PHP_EOL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// if block is set, we strip line of slashes
|
||||||
|
$_ENV[$var] = $block === true ? stripslashes($value) : $value;
|
||||||
|
// set successful load
|
||||||
|
$status = 0;
|
||||||
|
}
|
||||||
|
} elseif ($block === true) {
|
||||||
|
// read line until there is a unescaped "
|
||||||
|
// this also strips everything after the last "
|
||||||
|
if (preg_match("/(.*[^\\\])\"/", $line, $matches)) {
|
||||||
|
$block = false;
|
||||||
|
// strip ending " and EVERYTHING that follows after that
|
||||||
|
$line = $matches[1];
|
||||||
|
}
|
||||||
|
// strip line of slashes
|
||||||
|
$_ENV[$var] .= stripslashes($line);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fclose($fp);
|
||||||
|
return $status;
|
||||||
|
}
|
||||||
|
|
||||||
|
// __END__
|
||||||
@@ -3,6 +3,8 @@
|
|||||||
|
|
||||||
/* jshint esversion: 6 */
|
/* jshint esversion: 6 */
|
||||||
|
|
||||||
|
/* global i18n */
|
||||||
|
|
||||||
// debug set
|
// debug set
|
||||||
/*var FRONTEND_DEBUG = false;
|
/*var FRONTEND_DEBUG = false;
|
||||||
var DEBUG = true;
|
var DEBUG = true;
|
||||||
@@ -22,7 +24,8 @@ var GL_OB_BASE = 30;
|
|||||||
* @param {String} winName window name
|
* @param {String} winName window name
|
||||||
* @param {Object} features popup features
|
* @param {Object} features popup features
|
||||||
*/
|
*/
|
||||||
function pop(theURL, winName, features) {
|
function pop(theURL, winName, features) // eslint-disable-line no-unused-vars
|
||||||
|
{
|
||||||
winName = window.open(theURL, winName, features);
|
winName = window.open(theURL, winName, features);
|
||||||
winName.focus();
|
winName.focus();
|
||||||
}
|
}
|
||||||
@@ -31,7 +34,8 @@ function pop(theURL, winName, features) {
|
|||||||
* automatically resize a text area based on the amount of lines in it
|
* automatically resize a text area based on the amount of lines in it
|
||||||
* @param {[string} ta_id element id
|
* @param {[string} ta_id element id
|
||||||
*/
|
*/
|
||||||
function expandTA(ta_id) {
|
function expandTA(ta_id) // eslint-disable-line no-unused-vars
|
||||||
|
{
|
||||||
var ta;
|
var ta;
|
||||||
// if a string comes, its a get by id, else use it as an element pass on
|
// if a string comes, its a get by id, else use it as an element pass on
|
||||||
if (!ta_id.length) {
|
if (!ta_id.length) {
|
||||||
@@ -124,7 +128,7 @@ function setCenter(id, left, top)
|
|||||||
* @param {Number} [duration=500] animation time, default 500ms
|
* @param {Number} [duration=500] animation time, default 500ms
|
||||||
* @param {String} [base='body,html'] base element for offset scroll
|
* @param {String} [base='body,html'] base element for offset scroll
|
||||||
*/
|
*/
|
||||||
function goToPos(element, offset = 0, duration = 500, base = 'body,html')
|
function goToPos(element, offset = 0, duration = 500, base = 'body,html') // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
if ($('#' + element).length) {
|
if ($('#' + element).length) {
|
||||||
@@ -190,7 +194,7 @@ if (Number.prototype.round) {
|
|||||||
* @param {Number} x number to be formated
|
* @param {Number} x number to be formated
|
||||||
* @return {String} formatted with , in thousands
|
* @return {String} formatted with , in thousands
|
||||||
*/
|
*/
|
||||||
function numberWithCommas(x)
|
function numberWithCommas(x) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
var parts = x.toString().split('.');
|
var parts = x.toString().split('.');
|
||||||
parts[0] = parts[0].replace(/\B(?=(\d{3})+(?!\d))/g, ',');
|
parts[0] = parts[0].replace(/\B(?=(\d{3})+(?!\d))/g, ',');
|
||||||
@@ -202,7 +206,7 @@ function numberWithCommas(x)
|
|||||||
* @param {String} string any string
|
* @param {String} string any string
|
||||||
* @return {String} string with <br>
|
* @return {String} string with <br>
|
||||||
*/
|
*/
|
||||||
function convertLBtoBR(string)
|
function convertLBtoBR(string) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
return string.replace(/(?:\r\n|\r|\n)/g, '<br>');
|
return string.replace(/(?:\r\n|\r|\n)/g, '<br>');
|
||||||
}
|
}
|
||||||
@@ -255,7 +259,7 @@ if (!String.prototype.unescapeHTML) {
|
|||||||
* returns current timestamp (unix timestamp)
|
* returns current timestamp (unix timestamp)
|
||||||
* @return {Number} timestamp (in milliseconds)
|
* @return {Number} timestamp (in milliseconds)
|
||||||
*/
|
*/
|
||||||
function getTimestamp()
|
function getTimestamp() // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
var date = new Date();
|
var date = new Date();
|
||||||
return date.getTime();
|
return date.getTime();
|
||||||
@@ -278,7 +282,7 @@ function dec2hex(dec)
|
|||||||
* @param {Number} len length of unique id string
|
* @param {Number} len length of unique id string
|
||||||
* @return {String} random string in length of len
|
* @return {String} random string in length of len
|
||||||
*/
|
*/
|
||||||
function generateId(len)
|
function generateId(len) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
var arr = new Uint8Array((len || 40) / 2);
|
var arr = new Uint8Array((len || 40) / 2);
|
||||||
(window.crypto || window.msCrypto).getRandomValues(arr);
|
(window.crypto || window.msCrypto).getRandomValues(arr);
|
||||||
@@ -291,7 +295,7 @@ function generateId(len)
|
|||||||
* after many runs it will create duplicates
|
* after many runs it will create duplicates
|
||||||
* @return {String} not true random string
|
* @return {String} not true random string
|
||||||
*/
|
*/
|
||||||
function randomIdF()
|
function randomIdF() // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
return Math.random().toString(36).substring(2);
|
return Math.random().toString(36).substring(2);
|
||||||
}
|
}
|
||||||
@@ -301,7 +305,7 @@ function randomIdF()
|
|||||||
* @param {string} name Name of function to check if exists
|
* @param {string} name Name of function to check if exists
|
||||||
* @return {Boolean} true/false
|
* @return {Boolean} true/false
|
||||||
*/
|
*/
|
||||||
function isFunction(name)
|
function isFunction(name) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
if (typeof window[name] !== 'undefined' &&
|
if (typeof window[name] !== 'undefined' &&
|
||||||
typeof window[name] === 'function') {
|
typeof window[name] === 'function') {
|
||||||
@@ -320,7 +324,7 @@ function isFunction(name)
|
|||||||
* hidden next are all the arguments
|
* hidden next are all the arguments
|
||||||
* @return {mixed} Return values from functon
|
* @return {mixed} Return values from functon
|
||||||
*/
|
*/
|
||||||
function executeFunctionByName(functionName, context /*, args */)
|
function executeFunctionByName(functionName, context /*, args */) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
var args = Array.prototype.slice.call(arguments, 2);
|
var args = Array.prototype.slice.call(arguments, 2);
|
||||||
var namespaces = functionName.split('.');
|
var namespaces = functionName.split('.');
|
||||||
@@ -362,7 +366,7 @@ function getObjectCount(object)
|
|||||||
*/
|
*/
|
||||||
function keyInObject(key, object)
|
function keyInObject(key, object)
|
||||||
{
|
{
|
||||||
return (Object.prototype.hasOwnProperty.call(object, key)) ? true : false;
|
return Object.prototype.hasOwnProperty.call(object, key) ? true : false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -371,7 +375,7 @@ function keyInObject(key, object)
|
|||||||
* @param {Mixed} value any value (String, Number, etc)
|
* @param {Mixed} value any value (String, Number, etc)
|
||||||
* @return {String} the key found for the first matching value
|
* @return {String} the key found for the first matching value
|
||||||
*/
|
*/
|
||||||
function getKeyByValue(object, value)
|
function getKeyByValue(object, value) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
return Object.keys(object).find(key => object[key] === value);
|
return Object.keys(object).find(key => object[key] === value);
|
||||||
// return Object.keys(object).find(function (key) {
|
// return Object.keys(object).find(function (key) {
|
||||||
@@ -385,9 +389,9 @@ function getKeyByValue(object, value)
|
|||||||
* @param {Mixed} value any value (String, Number, etc)
|
* @param {Mixed} value any value (String, Number, etc)
|
||||||
* @return {Boolean} true on value found, false on not found
|
* @return {Boolean} true on value found, false on not found
|
||||||
*/
|
*/
|
||||||
function valueInObject(object, value)
|
function valueInObject(object, value) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
return (Object.keys(object).find(key => object[key] === value)) ? true : false;
|
return Object.keys(object).find(key => object[key] === value) ? true : false;
|
||||||
// return Object.keys(object).find(function (key) {
|
// return Object.keys(object).find(function (key) {
|
||||||
// return object[key] === value;
|
// return object[key] === value;
|
||||||
// }) ? true : false;
|
// }) ? true : false;
|
||||||
@@ -434,7 +438,7 @@ function exists(id)
|
|||||||
* @param {Number} bytes bytes in int
|
* @param {Number} bytes bytes in int
|
||||||
* @return {String} string in GB/MB/KB
|
* @return {String} string in GB/MB/KB
|
||||||
*/
|
*/
|
||||||
function formatBytes(bytes)
|
function formatBytes(bytes) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
var i = -1;
|
var i = -1;
|
||||||
do {
|
do {
|
||||||
@@ -450,7 +454,7 @@ function formatBytes(bytes)
|
|||||||
* @param {Number} bytes bytes in int
|
* @param {Number} bytes bytes in int
|
||||||
* @return {String} string in GB/MB/KB
|
* @return {String} string in GB/MB/KB
|
||||||
*/
|
*/
|
||||||
function formatBytesLong(bytes)
|
function formatBytesLong(bytes) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
var i = Math.floor(Math.log(bytes) / Math.log(1024));
|
var i = Math.floor(Math.log(bytes) / Math.log(1024));
|
||||||
var sizes = ['B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'];
|
var sizes = ['B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'];
|
||||||
@@ -462,7 +466,7 @@ function formatBytesLong(bytes)
|
|||||||
* @param {String|Number} bytes Any string with B/K/M/etc
|
* @param {String|Number} bytes Any string with B/K/M/etc
|
||||||
* @return {String|Number} A byte number, or original string as is
|
* @return {String|Number} A byte number, or original string as is
|
||||||
*/
|
*/
|
||||||
function stringByteFormat(bytes)
|
function stringByteFormat(bytes) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
// if anything not string return
|
// if anything not string return
|
||||||
if (!(typeof bytes === 'string' || bytes instanceof String)) {
|
if (!(typeof bytes === 'string' || bytes instanceof String)) {
|
||||||
@@ -537,7 +541,7 @@ function errorCatch(err)
|
|||||||
* default empty. for console.log
|
* default empty. for console.log
|
||||||
* @param {Boolean} [overlay=true] override the auto hide/show over the overlay div block
|
* @param {Boolean} [overlay=true] override the auto hide/show over the overlay div block
|
||||||
*/
|
*/
|
||||||
function actionIndicator(loc, overlay = true)
|
function actionIndicator(loc, overlay = true) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
if ($('#indicator').is(':visible')) {
|
if ($('#indicator').is(':visible')) {
|
||||||
actionIndicatorHide(loc, overlay);
|
actionIndicatorHide(loc, overlay);
|
||||||
@@ -614,7 +618,7 @@ function overlayBoxHide()
|
|||||||
/**
|
/**
|
||||||
* position the overlay block box and shows it
|
* position the overlay block box and shows it
|
||||||
*/
|
*/
|
||||||
function setOverlayBox()
|
function setOverlayBox() // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
if (!$('#overlayBox').is(':visible')) {
|
if (!$('#overlayBox').is(':visible')) {
|
||||||
$('#overlayBox').show();
|
$('#overlayBox').show();
|
||||||
@@ -624,7 +628,7 @@ function setOverlayBox()
|
|||||||
/**
|
/**
|
||||||
* opposite of set, always hides overlay box
|
* opposite of set, always hides overlay box
|
||||||
*/
|
*/
|
||||||
function hideOverlayBox()
|
function hideOverlayBox() // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
if ($('#overlayBox').is(':visible')) {
|
if ($('#overlayBox').is(':visible')) {
|
||||||
$('#overlayBox').hide();
|
$('#overlayBox').hide();
|
||||||
@@ -634,7 +638,7 @@ function hideOverlayBox()
|
|||||||
/**
|
/**
|
||||||
* the abort call, clears the action box and hides it and the overlay box
|
* the abort call, clears the action box and hides it and the overlay box
|
||||||
*/
|
*/
|
||||||
function ClearCall()
|
function ClearCall() // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
$('#actionBox').html('');
|
$('#actionBox').html('');
|
||||||
$('#actionBox').hide();
|
$('#actionBox').hide();
|
||||||
@@ -655,7 +659,7 @@ function ClearCall()
|
|||||||
* - indicator is page centered
|
* - indicator is page centered
|
||||||
* @param {String} loc ID string, only used for console log
|
* @param {String} loc ID string, only used for console log
|
||||||
*/
|
*/
|
||||||
function showActionIndicator(loc)
|
function showActionIndicator(loc) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
// console.log('Indicator: SHOW [%s]', loc);
|
// console.log('Indicator: SHOW [%s]', loc);
|
||||||
// check if indicator element exists
|
// check if indicator element exists
|
||||||
@@ -693,7 +697,7 @@ function showActionIndicator(loc)
|
|||||||
* is set to this value
|
* is set to this value
|
||||||
* @param {String} loc ID string, only used for console log
|
* @param {String} loc ID string, only used for console log
|
||||||
*/
|
*/
|
||||||
function hideActionIndicator(loc)
|
function hideActionIndicator(loc) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
// console.log('Indicator: HIDE [%s]', loc);
|
// console.log('Indicator: HIDE [%s]', loc);
|
||||||
// check if indicator is visible
|
// check if indicator is visible
|
||||||
@@ -733,7 +737,7 @@ function checkOverlayExists()
|
|||||||
* if visible, add +1 to the GL_OB_S variable and
|
* if visible, add +1 to the GL_OB_S variable and
|
||||||
* up zIndex by this value
|
* up zIndex by this value
|
||||||
*/
|
*/
|
||||||
function showOverlayBoxLayers(el_id)
|
function showOverlayBoxLayers(el_id) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
// console.log('SHOW overlaybox: %s', GL_OB_S);
|
// console.log('SHOW overlaybox: %s', GL_OB_S);
|
||||||
// if overlay box is not visible show and set zIndex to 0
|
// if overlay box is not visible show and set zIndex to 0
|
||||||
@@ -790,7 +794,7 @@ function hideOverlayBoxLayers(el_id)
|
|||||||
/**
|
/**
|
||||||
* only for single action box
|
* only for single action box
|
||||||
*/
|
*/
|
||||||
function clearCallActionBox()
|
function clearCallActionBox() // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
$('#actionBox').html('');
|
$('#actionBox').html('');
|
||||||
$('#actionBox').hide();
|
$('#actionBox').hide();
|
||||||
@@ -873,7 +877,7 @@ function aelx(base, ...attach)
|
|||||||
* @param {Array} attach array of objects to attach
|
* @param {Array} attach array of objects to attach
|
||||||
* @return {Object} "none", technically there is no return needed, global attach
|
* @return {Object} "none", technically there is no return needed, global attach
|
||||||
*/
|
*/
|
||||||
function aelxar(base, attach)
|
function aelxar(base, attach) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
for (var i = 0; i < attach.length; i ++) {
|
for (var i = 0; i < attach.length; i ++) {
|
||||||
// base.sub.push(Object.assign({}, attach[i]));
|
// base.sub.push(Object.assign({}, attach[i]));
|
||||||
@@ -887,7 +891,7 @@ function aelxar(base, attach)
|
|||||||
* @param {Object} base cel created element
|
* @param {Object} base cel created element
|
||||||
* @return {Object} returns reset base element
|
* @return {Object} returns reset base element
|
||||||
*/
|
*/
|
||||||
function rel(base)
|
function rel(base) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
base.sub = [];
|
base.sub = [];
|
||||||
return base;
|
return base;
|
||||||
@@ -931,7 +935,7 @@ function acssel(_element, css)
|
|||||||
* @param {String} acss style to add (name)
|
* @param {String} acss style to add (name)
|
||||||
* @return {Object} returns full element
|
* @return {Object} returns full element
|
||||||
*/
|
*/
|
||||||
function scssel(_element, rcss, acss)
|
function scssel(_element, rcss, acss) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
rcssel(_element, rcss);
|
rcssel(_element, rcss);
|
||||||
acssel(_element, acss);
|
acssel(_element, acss);
|
||||||
@@ -1009,7 +1013,7 @@ function phfo(tree)
|
|||||||
* @param {Array} list Array of cel created objects
|
* @param {Array} list Array of cel created objects
|
||||||
* @return {String} HTML String
|
* @return {String} HTML String
|
||||||
*/
|
*/
|
||||||
function phfa(list)
|
function phfa(list) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
var content = [];
|
var content = [];
|
||||||
for (var i = 0; i < list.length; i ++) {
|
for (var i = 0; i < list.length; i ++) {
|
||||||
@@ -1035,7 +1039,7 @@ function phfa(list)
|
|||||||
* 'values' all others are ignored
|
* 'values' all others are ignored
|
||||||
* @return {String} html with build options block
|
* @return {String} html with build options block
|
||||||
*/
|
*/
|
||||||
function html_options(name, data, selected = '', options_only = false, return_string = false, sort = '')
|
function html_options(name, data, selected = '', options_only = false, return_string = false, sort = '') // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
// wrapper to new call
|
// wrapper to new call
|
||||||
return html_options_block(name, data, selected, false, options_only, return_string, sort);
|
return html_options_block(name, data, selected, false, options_only, return_string, sort);
|
||||||
@@ -1141,7 +1145,7 @@ function html_options_block(name, data, selected = '', multiple = 0, options_onl
|
|||||||
* @param {String} [sort=''] if empty as is, else allowed 'keys', 'values'
|
* @param {String} [sort=''] if empty as is, else allowed 'keys', 'values'
|
||||||
* all others are ignored
|
* all others are ignored
|
||||||
*/
|
*/
|
||||||
function html_options_refill(name, data, sort = '')
|
function html_options_refill(name, data, sort = '') // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
var element_option;
|
var element_option;
|
||||||
var option_selected;
|
var option_selected;
|
||||||
@@ -1188,7 +1192,8 @@ function html_options_refill(name, data, sort = '')
|
|||||||
* or empty for none
|
* or empty for none
|
||||||
* @return {Object|String} parameter entry list
|
* @return {Object|String} parameter entry list
|
||||||
*/
|
*/
|
||||||
function parseQueryString(query = '', return_key = '') {
|
function parseQueryString(query = '', return_key = '') // eslint-disable-line no-unused-vars
|
||||||
|
{
|
||||||
if (!query) {
|
if (!query) {
|
||||||
query = window.location.search.substring(1);
|
query = window.location.search.substring(1);
|
||||||
}
|
}
|
||||||
@@ -1198,6 +1203,10 @@ function parseQueryString(query = '', return_key = '') {
|
|||||||
var pair = vars[i].split('=');
|
var pair = vars[i].split('=');
|
||||||
var key = decodeURIComponent(pair[0]);
|
var key = decodeURIComponent(pair[0]);
|
||||||
var value = decodeURIComponent(pair[1]);
|
var value = decodeURIComponent(pair[1]);
|
||||||
|
// skip over run if there is nothing
|
||||||
|
if (!key || value === 'undefined') {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
// If first entry with this name
|
// If first entry with this name
|
||||||
if (typeof query_string[key] === 'undefined') {
|
if (typeof query_string[key] === 'undefined') {
|
||||||
query_string[key] = decodeURIComponent(value);
|
query_string[key] = decodeURIComponent(value);
|
||||||
@@ -1222,26 +1231,59 @@ function parseQueryString(query = '', return_key = '') {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* searchs the current url for a parameter
|
* searches query parameters for entry and returns data either as string or array
|
||||||
* @param {String} key uid key to get data for
|
* if no search is given the whole parameters are returned as an object
|
||||||
* @return {String} value for the key or '' for not found
|
* if a parameter is set several times it will be returned as an array
|
||||||
|
* if search parameter set and nothing found and empty string is returned
|
||||||
|
* if no parametes exist and no serach is set and empty object is returned
|
||||||
|
* @param {String} [search=''] if set searches for this entry, if empty
|
||||||
|
* all parameters are returned
|
||||||
|
* @param {String} [query=''] different query string to parse, if not
|
||||||
|
* set (default) the current window href is used
|
||||||
|
* @param {Bool} [single=false] if set to true then only the first found
|
||||||
|
* will be returned
|
||||||
|
* @return {Object|Array|String} if search is empty, object, if search is set
|
||||||
|
* and only one entry, then string, else array
|
||||||
|
* unless single is true
|
||||||
*/
|
*/
|
||||||
function getQueryStringParam(key)
|
function getQueryStringParam(search = '', query = '', single = false) // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
var url = new URL(window.location.href);
|
if (!query) {
|
||||||
var param = url.searchParams.get(key);
|
query = window.location.href;
|
||||||
if (param) {
|
|
||||||
return param;
|
|
||||||
} else {
|
|
||||||
return '';
|
|
||||||
}
|
}
|
||||||
|
const url = new URL(query);
|
||||||
|
let param = '';
|
||||||
|
if (search) {
|
||||||
|
let _params = url.searchParams.getAll(search);
|
||||||
|
if (_params.length == 1 || single === true) {
|
||||||
|
param = _params[0];
|
||||||
|
} else if (_params.length > 1) {
|
||||||
|
param = _params;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// will be object, so declare it one
|
||||||
|
param = {};
|
||||||
|
// loop over paramenters
|
||||||
|
for (const [key] of url.searchParams.entries()) {
|
||||||
|
// check if not yet set
|
||||||
|
if (typeof param[key] === 'undefined') {
|
||||||
|
// get the parameters multiple
|
||||||
|
let _params = url.searchParams.getAll(key);
|
||||||
|
// if 1 set as string, else attach array as is
|
||||||
|
param[key] = _params.length < 2 || single === true ?
|
||||||
|
_params[0] :
|
||||||
|
_params;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return param;
|
||||||
}
|
}
|
||||||
|
|
||||||
// *** MASTER logout call
|
// *** MASTER logout call
|
||||||
/**
|
/**
|
||||||
* submits basic data for form logout
|
* submits basic data for form logout
|
||||||
*/
|
*/
|
||||||
function loginLogout()
|
function loginLogout() // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
const form = document.createElement('form');
|
const form = document.createElement('form');
|
||||||
form.method = 'post';
|
form.method = 'post';
|
||||||
@@ -1261,7 +1303,7 @@ function loginLogout()
|
|||||||
* if not set mainHeader is assumed
|
* if not set mainHeader is assumed
|
||||||
* this is the target div for the "loginRow"
|
* this is the target div for the "loginRow"
|
||||||
*/
|
*/
|
||||||
function createLoginRow(login_string, header_id = 'mainHeader')
|
function createLoginRow(login_string, header_id = 'mainHeader') // eslint-disable-line no-unused-vars
|
||||||
{
|
{
|
||||||
// if header does not exist, we do nothing
|
// if header does not exist, we do nothing
|
||||||
if (exists(header_id)) {
|
if (exists(header_id)) {
|
||||||
@@ -1295,7 +1337,8 @@ function createLoginRow(login_string, header_id = 'mainHeader')
|
|||||||
* if not set mainHeader is assumed
|
* if not set mainHeader is assumed
|
||||||
* this is the target div for the "menuRow"
|
* this is the target div for the "menuRow"
|
||||||
*/
|
*/
|
||||||
function createNavMenu(nav_menu, header_id = 'mainHeader') {
|
function createNavMenu(nav_menu, header_id = 'mainHeader') // eslint-disable-line no-unused-vars
|
||||||
|
{
|
||||||
// must be an object
|
// must be an object
|
||||||
if (isObject(nav_menu) && getObjectCount(nav_menu) > 1) {
|
if (isObject(nav_menu) && getObjectCount(nav_menu) > 1) {
|
||||||
// do we have more than one entry, if not, do not show (single page)
|
// do we have more than one entry, if not, do not show (single page)
|
||||||
|
|||||||
@@ -722,7 +722,8 @@ class IO extends \CoreLibs\Basic
|
|||||||
$this->__dbError();
|
$this->__dbError();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
// if we do have an insert, check if there is no RETURNING pk_id, add it if I can get the PK id
|
// if we do have an insert, check if there is no RETURNING pk_id,
|
||||||
|
// add it if I can get the PK id
|
||||||
if ($this->__checkQueryForInsert($this->query, true)) {
|
if ($this->__checkQueryForInsert($this->query, true)) {
|
||||||
$this->pk_name = $pk_name;
|
$this->pk_name = $pk_name;
|
||||||
if ($this->pk_name != 'NULL') {
|
if ($this->pk_name != 'NULL') {
|
||||||
|
|||||||
Reference in New Issue
Block a user