Compare commits
33 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
be03bc96cb | ||
|
|
4f73a88a8b | ||
|
|
b2019226da | ||
|
|
754c2edbd2 | ||
|
|
98e16e6143 | ||
|
|
005584e2ed | ||
|
|
7e34c5321d | ||
|
|
9d918f3b43 | ||
|
|
433b21ab6f | ||
|
|
826b5fdfd6 | ||
|
|
a923f07fc7 | ||
|
|
736415e939 | ||
|
|
2e8712d935 | ||
|
|
c6a15506c5 | ||
|
|
b2f5d439d5 | ||
|
|
071395bfe5 | ||
|
|
03ff1862c1 | ||
|
|
71ab3e27bd | ||
|
|
a190148125 | ||
|
|
fa5350baa2 | ||
|
|
4d70f8a017 | ||
|
|
d5476b4269 | ||
|
|
bddc196e25 | ||
|
|
e3d1679f86 | ||
|
|
34f33772d0 | ||
|
|
bfe3fdcff4 | ||
|
|
1feb7bf574 | ||
|
|
272a5ad202 | ||
|
|
8a86145307 | ||
|
|
1afc0eb982 | ||
|
|
a7e7539911 | ||
|
|
6e3f017960 | ||
|
|
80715e5ef1 |
21
4dev/composer/install.txt
Normal file
21
4dev/composer/install.txt
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
Install composer:
|
||||||
|
curl -sS https://getcomposer.org/installer | /usr/local/php-7.2-httpd-2.4/bin/php
|
||||||
|
|
||||||
|
Update composer phar file
|
||||||
|
/usr/local/php-7.2-httpd-2.4/bin/php composer.phar selfupdate
|
||||||
|
|
||||||
|
Install something:
|
||||||
|
/usr/local/php-7.2-httpd-2.4/bin/php composer.phar require something/something
|
||||||
|
|
||||||
|
Update all installed:
|
||||||
|
/usr/local/php-7.2-httpd-2.4/bin/php composer.phar update
|
||||||
|
|
||||||
|
Or update only one package:
|
||||||
|
/usr/local/php-7.2-httpd-2.4/bin/php composer.phar something/something
|
||||||
|
|
||||||
|
Install AWS SDK:
|
||||||
|
/usr/local/php-7.2-httpd-2.4/bin/php -d memory_limit=-1 composer.phar require aws/aws-sdk-php
|
||||||
|
|
||||||
|
Install zipStream:
|
||||||
|
/usr/local/php-7.2-httpd-2.4/bin/php composer.phar require maennchen/zipstream-php
|
||||||
|
|
||||||
@@ -1,5 +1,7 @@
|
|||||||
# functions
|
# functions
|
||||||
function/update_function.sql
|
function/update_function.sql
|
||||||
|
function/random_string.sql
|
||||||
|
function/edit_set_access_uid.sql
|
||||||
# generic tables
|
# generic tables
|
||||||
table/edit_temp_files.sql
|
table/edit_temp_files.sql
|
||||||
table/edit_generic.sql
|
table/edit_generic.sql
|
||||||
@@ -18,9 +20,11 @@ table/edit_user.sql
|
|||||||
table/edit_log.sql
|
table/edit_log.sql
|
||||||
table/edit_access.sql
|
table/edit_access.sql
|
||||||
table/edit_access_user.sql
|
table/edit_access_user.sql
|
||||||
|
table/edit_access_data.sql
|
||||||
# all triggers (after all tables have been created)
|
# all triggers (after all tables have been created)
|
||||||
trigger/trg_edit_access_right.sql
|
trigger/trg_edit_access_right.sql
|
||||||
trigger/trg_edit_access.sql
|
trigger/trg_edit_access.sql
|
||||||
|
trigger/trg_edit_access_data.sql
|
||||||
trigger/trg_edit_access_user.sql
|
trigger/trg_edit_access_user.sql
|
||||||
trigger/trg_edit_generic.sql
|
trigger/trg_edit_generic.sql
|
||||||
trigger/trg_edit_group.sql
|
trigger/trg_edit_group.sql
|
||||||
@@ -33,3 +37,6 @@ trigger/trg_edit_scheme.sql
|
|||||||
trigger/trg_edit_user.sql
|
trigger/trg_edit_user.sql
|
||||||
trigger/trg_edit_visible_group.sql
|
trigger/trg_edit_visible_group.sql
|
||||||
trigger/trg_edit_menu_group.sql
|
trigger/trg_edit_menu_group.sql
|
||||||
|
trigger/trg_set_edit_access_uid.sql
|
||||||
|
# insert data
|
||||||
|
data/edit_tables.sql
|
||||||
|
|||||||
147
4dev/database/data/edit_tables.sql
Executable file
147
4dev/database/data/edit_tables.sql
Executable file
@@ -0,0 +1,147 @@
|
|||||||
|
-- edit tables insert data in order
|
||||||
|
|
||||||
|
-- edit visible group
|
||||||
|
DELETE FROM edit_visible_group;
|
||||||
|
INSERT INTO edit_visible_group (name, flag) VALUES ('Main Menu', 'main');
|
||||||
|
INSERT INTO edit_visible_group (name, flag) VALUES ('Data popup Menu', 'datapopup');
|
||||||
|
|
||||||
|
-- edit menu group
|
||||||
|
DELETE FROM edit_menu_group;
|
||||||
|
INSERT INTO edit_menu_group (name, flag, order_number) VALUES ('Admin Menu', 'admin', 1);
|
||||||
|
INSERT INTO edit_menu_group (name, flag, order_number) VALUES ('Admin Data Popup Menu', 'AdminDataPopup', 2);
|
||||||
|
|
||||||
|
-- edit page
|
||||||
|
DELETE FROM edit_page;
|
||||||
|
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_pages.php', 'Edit Pages', 1, 1, 1);
|
||||||
|
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_users.php', 'Edit Users', 2, 1, 1);
|
||||||
|
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_languages.php', 'Edit Languages', 3, 1, 1);
|
||||||
|
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_schemes.php', 'Edit Schemes', 4, 1, 1);
|
||||||
|
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_groups.php', 'Edit Groups', 5, 1, 1);
|
||||||
|
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_visible_group.php', 'Edit Visible Groups', 6, 1, 1);
|
||||||
|
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_menu_group.php', 'Edit Menu Groups', 7, 1, 1);
|
||||||
|
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_access.php', 'Edit Access', 8, 1, 1);
|
||||||
|
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_order.php', 'Edit Order', 9, 1, 0);
|
||||||
|
|
||||||
|
-- edit visible group
|
||||||
|
DELETE FROM edit_page_visible_group;
|
||||||
|
INSERT INTO edit_page_visible_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Pages'), (SELECT edit_visible_group_id FROM edit_visible_group WHERE flag = 'main'));
|
||||||
|
INSERT INTO edit_page_visible_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Users'), (SELECT edit_visible_group_id FROM edit_visible_group WHERE flag = 'main'));
|
||||||
|
INSERT INTO edit_page_visible_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Languages'), (SELECT edit_visible_group_id FROM edit_visible_group WHERE flag = 'main'));
|
||||||
|
INSERT INTO edit_page_visible_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Schemes'), (SELECT edit_visible_group_id FROM edit_visible_group WHERE flag = 'main'));
|
||||||
|
INSERT INTO edit_page_visible_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Groups'), (SELECT edit_visible_group_id FROM edit_visible_group WHERE flag = 'main'));
|
||||||
|
INSERT INTO edit_page_visible_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Visible Groups'), (SELECT edit_visible_group_id FROM edit_visible_group WHERE flag = 'main'));
|
||||||
|
INSERT INTO edit_page_visible_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Menu Groups'), (SELECT edit_visible_group_id FROM edit_visible_group WHERE flag = 'main'));
|
||||||
|
INSERT INTO edit_page_visible_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Access'), (SELECT edit_visible_group_id FROM edit_visible_group WHERE flag = 'main'));
|
||||||
|
-- INSERT INTO edit_page_visible_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Order'), (SELECT edit_visible_group_id FROM edit_visible_group WHERE flag = 'main'));
|
||||||
|
|
||||||
|
-- edit page menu group
|
||||||
|
DELETE FROM edit_page_menu_group;
|
||||||
|
INSERT INTO edit_page_menu_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Pages'), (SELECT edit_menu_group_id FROM edit_menu_group WHERE flag = 'admin'));
|
||||||
|
INSERT INTO edit_page_menu_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Users'), (SELECT edit_menu_group_id FROM edit_menu_group WHERE flag = 'admin'));
|
||||||
|
INSERT INTO edit_page_menu_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Languages'), (SELECT edit_menu_group_id FROM edit_menu_group WHERE flag = 'admin'));
|
||||||
|
INSERT INTO edit_page_menu_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Schemes'), (SELECT edit_menu_group_id FROM edit_menu_group WHERE flag = 'admin'));
|
||||||
|
INSERT INTO edit_page_menu_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Groups'), (SELECT edit_menu_group_id FROM edit_menu_group WHERE flag = 'admin'));
|
||||||
|
INSERT INTO edit_page_menu_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Visible Groups'), (SELECT edit_menu_group_id FROM edit_menu_group WHERE flag = 'admin'));
|
||||||
|
INSERT INTO edit_page_menu_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Menu Groups'), (SELECT edit_menu_group_id FROM edit_menu_group WHERE flag = 'admin'));
|
||||||
|
INSERT INTO edit_page_menu_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Access'), (SELECT edit_menu_group_id FROM edit_menu_group WHERE flag = 'admin'));
|
||||||
|
-- INSERT INTO edit_page_menu_group VALUES ((SELECT edit_page_id FROM edit_page WHERE name = 'Edit Order'), (SELECT edit_menu_group_id FROM edit_menu_group WHERE flag = 'admin'));
|
||||||
|
|
||||||
|
|
||||||
|
-- edit access right
|
||||||
|
DELETE FROM edit_access_right;
|
||||||
|
INSERT INTO edit_access_right (name, level, type) VALUES ('Default', -1, 'default');
|
||||||
|
INSERT INTO edit_access_right (name, level, type) VALUES ('No Access', 0, 'none');
|
||||||
|
INSERT INTO edit_access_right (name, level, type) VALUES ('Read', 20, 'read');
|
||||||
|
INSERT INTO edit_access_right (name, level, type) VALUES ('Translator', 30, 'mod_trans');
|
||||||
|
INSERT INTO edit_access_right (name, level, type) VALUES ('Modify', 40, 'mod');
|
||||||
|
INSERT INTO edit_access_right (name, level, type) VALUES ('Create/Write', 60, 'write');
|
||||||
|
INSERT INTO edit_access_right (name, level, type) VALUES ('Delete', 80, 'del');
|
||||||
|
INSERT INTO edit_access_right (name, level, type) VALUES ('Site Admin', 90, 'siteadmin');
|
||||||
|
INSERT INTO edit_access_right (name, level, type) VALUES ('Admin', 100, 'admin');
|
||||||
|
|
||||||
|
-- edit scheme
|
||||||
|
DELETE FROM edit_scheme;
|
||||||
|
INSERT INTO edit_scheme (name, header_color, enabled) VALUES ('Default Scheme', 'E0E2FF', 1);
|
||||||
|
INSERT INTO edit_scheme (name, header_color, enabled) VALUES ('Admin', 'CC7E7E', 1);
|
||||||
|
INSERT INTO edit_scheme (name, header_color, enabled) VALUES ('Visitor', 'B0C4B3', 1);
|
||||||
|
INSERT INTO edit_scheme (name, header_color, enabled) VALUES ('User', '1E789E', 1);
|
||||||
|
|
||||||
|
-- edit language
|
||||||
|
DELETE FROM edit_language;
|
||||||
|
INSERT INTO edit_language (short_name, long_name, iso_name, order_number, enabled, lang_default) VALUES ('en', 'English', 'UTF-8', 1, 1, 1);
|
||||||
|
INSERT INTO edit_language (short_name, long_name, iso_name, order_number, enabled, lang_default) VALUES ('ja', 'Japanese', 'UTF-8', 2, 1, 0);
|
||||||
|
|
||||||
|
-- edit group
|
||||||
|
DELETE FROM edit_group;
|
||||||
|
INSERT INTO edit_group (name, enabled, edit_scheme_id, edit_access_right_id) VALUES ('Admin', 1, (SELECT edit_scheme_id FROM edit_scheme WHERE name = 'Admin'), (SELECT edit_access_right_id FROM edit_access_right WHERE type = 'admin'));
|
||||||
|
INSERT INTO edit_group (name, enabled, edit_scheme_id, edit_access_right_id) VALUES ('User', 1, (SELECT edit_scheme_id FROM edit_scheme WHERE name = 'User'), (SELECT edit_access_right_id FROM edit_access_right WHERE type = 'write'));
|
||||||
|
|
||||||
|
-- edit page access
|
||||||
|
DELETE FROM edit_page_access;
|
||||||
|
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1,
|
||||||
|
(SELECT edit_group_id FROM edit_group WHERE name = 'Admin'),
|
||||||
|
(SELECT edit_page_id FROM edit_page WHERE name = 'Edit Pages'),
|
||||||
|
(SELECT edit_access_right_id FROM edit_access_right WHERE type = 'admin')
|
||||||
|
);
|
||||||
|
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1,
|
||||||
|
(SELECT edit_group_id FROM edit_group WHERE name = 'Admin'),
|
||||||
|
(SELECT edit_page_id FROM edit_page WHERE name = 'Edit Users'),
|
||||||
|
(SELECT edit_access_right_id FROM edit_access_right WHERE type = 'admin')
|
||||||
|
);
|
||||||
|
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1,
|
||||||
|
(SELECT edit_group_id FROM edit_group WHERE name = 'Admin'),
|
||||||
|
(SELECT edit_page_id FROM edit_page WHERE name = 'Edit Languages'),
|
||||||
|
(SELECT edit_access_right_id FROM edit_access_right WHERE type = 'admin')
|
||||||
|
);
|
||||||
|
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1,
|
||||||
|
(SELECT edit_group_id FROM edit_group WHERE name = 'Admin'),
|
||||||
|
(SELECT edit_page_id FROM edit_page WHERE name = 'Edit Schemes'),
|
||||||
|
(SELECT edit_access_right_id FROM edit_access_right WHERE type = 'admin')
|
||||||
|
);
|
||||||
|
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1,
|
||||||
|
(SELECT edit_group_id FROM edit_group WHERE name = 'Admin'),
|
||||||
|
(SELECT edit_page_id FROM edit_page WHERE name = 'Edit Groups'),
|
||||||
|
(SELECT edit_access_right_id FROM edit_access_right WHERE type = 'admin')
|
||||||
|
);
|
||||||
|
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1,
|
||||||
|
(SELECT edit_group_id FROM edit_group WHERE name = 'Admin'),
|
||||||
|
(SELECT edit_page_id FROM edit_page WHERE name = 'Edit Visible Groups'),
|
||||||
|
(SELECT edit_access_right_id FROM edit_access_right WHERE type = 'admin')
|
||||||
|
);
|
||||||
|
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1,
|
||||||
|
(SELECT edit_group_id FROM edit_group WHERE name = 'Admin'),
|
||||||
|
(SELECT edit_page_id FROM edit_page WHERE name = 'Edit Menu Groups'),
|
||||||
|
(SELECT edit_access_right_id FROM edit_access_right WHERE type = 'admin')
|
||||||
|
);
|
||||||
|
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1,
|
||||||
|
(SELECT edit_group_id FROM edit_group WHERE name = 'Admin'),
|
||||||
|
(SELECT edit_page_id FROM edit_page WHERE name = 'Edit Access'),
|
||||||
|
(SELECT edit_access_right_id FROM edit_access_right WHERE type = 'admin')
|
||||||
|
);
|
||||||
|
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1,
|
||||||
|
(SELECT edit_group_id FROM edit_group WHERE name = 'Admin'),
|
||||||
|
(SELECT edit_page_id FROM edit_page WHERE name = 'Edit Order'),
|
||||||
|
(SELECT edit_access_right_id FROM edit_access_right WHERE type = 'admin')
|
||||||
|
);
|
||||||
|
|
||||||
|
-- edit user
|
||||||
|
-- inserts admin user so basic users can be created
|
||||||
|
DELETE FROM edit_user;
|
||||||
|
INSERT INTO edit_user (username, password, enabled, debug, db_debug, email, protected, admin, edit_language_id, edit_group_id, edit_scheme_id, edit_access_right_id) VALUES ('admin', 'admin', 1, 1, 1, '', 1, 1,
|
||||||
|
(SELECT edit_language_id FROM edit_language WHERE short_name = 'en'),
|
||||||
|
(SELECT edit_group_id FROM edit_group WHERE name = 'Admin'),
|
||||||
|
(SELECT edit_scheme_id FROM edit_scheme WHERE name = 'Admin'),
|
||||||
|
(SELECT edit_access_right_id FROM edit_access_right WHERE type = 'admin')
|
||||||
|
);
|
||||||
|
|
||||||
|
-- edit access
|
||||||
|
DELETE FROM edit_access;
|
||||||
|
INSERT INTO edit_access (name, enabled, protected) VALUES ('Admin Access', 1, 1);
|
||||||
|
|
||||||
|
-- edit access user
|
||||||
|
DELETE FROM edit_access_user;
|
||||||
|
INSERT INTO edit_access_user (edit_default, enabled, edit_access_id, edit_user_id, edit_access_right_id) VALUES (1, 1,
|
||||||
|
(SELECT edit_access_id FROM edit_access WHERE uid = 'AdminAccess'),
|
||||||
|
(SELECT edit_user_id FROM edit_user WHERE username = 'admin'),
|
||||||
|
(SELECT edit_access_right_id FROM edit_access_right WHERE type = 'admin')
|
||||||
|
);
|
||||||
59
4dev/database/function/edit_log_partition_insert.sql
Normal file
59
4dev/database/function/edit_log_partition_insert.sql
Normal file
@@ -0,0 +1,59 @@
|
|||||||
|
CREATE OR REPLACE FUNCTION edit_log_insert_trigger ()
|
||||||
|
RETURNS TRIGGER AS
|
||||||
|
$$
|
||||||
|
DECLARE
|
||||||
|
start_date DATE := '2010-01-01';
|
||||||
|
end_date DATE;
|
||||||
|
timeformat TEXT := 'YYYY';
|
||||||
|
selector TEXT := 'year';
|
||||||
|
_interval INTERVAL;
|
||||||
|
table_name TEXT;
|
||||||
|
BEGIN
|
||||||
|
-- get year and month from edit_log date so we can build the target edit_log table
|
||||||
|
|
||||||
|
-- move interval
|
||||||
|
_interval := '1 ' || selector;
|
||||||
|
-- current table name
|
||||||
|
table_name := 'edit_log_' || to_char(NEW.event_date, timeformat);
|
||||||
|
|
||||||
|
-- we are in valid start time area
|
||||||
|
IF (NEW.event_date >= start_date) THEN
|
||||||
|
BEGIN
|
||||||
|
EXECUTE 'INSERT INTO ' || quote_ident(table_name) || ' SELECT ($1).*' USING NEW;
|
||||||
|
-- if insert failed because of missing table, create new below
|
||||||
|
EXCEPTION
|
||||||
|
WHEN undefined_table THEN
|
||||||
|
-- another block, so in case the creation fails here too
|
||||||
|
BEGIN
|
||||||
|
-- create new talbe here + all indexes
|
||||||
|
start_date := date_trunc(selector, NEW.event_date);
|
||||||
|
end_date := date_trunc(selector, NEW.event_date + _interval);
|
||||||
|
-- creat table
|
||||||
|
EXECUTE 'CREATE TABLE IF NOT EXISTS ' || quote_ident(table_name) || ' ( CHECK ( event_date >= ' || quote_literal(start_date) || ' AND event_date < ' || quote_literal(end_date) || ' ) ) INHERITS (edit_log)';
|
||||||
|
-- create all indexes and triggers
|
||||||
|
EXECUTE 'ALTER TABLE ' || quote_ident(table_name) || ' ADD PRIMARY KEY (edit_log_id)';
|
||||||
|
-- FK constraints
|
||||||
|
EXECUTE 'ALTER TABLE ' || quote_ident(table_name) || ' ADD CONSTRAINT fk_' || quote_ident(table_name) || '_euid_fkey FOREIGN KEY (euid) REFERENCES edit_user (edit_user_id) MATCH FULL ON UPDATE CASCADE ON DELETE CASCADE';
|
||||||
|
-- generic trigger
|
||||||
|
EXECUTE 'CREATE TRIGGER trg_' || quote_ident(table_name) || ' BEFORE INSERT OR UPDATE ON ' || quote_ident(table_name) || ' FOR EACH ROW EXECUTE PROCEDURE set_edit_generic()';
|
||||||
|
|
||||||
|
-- insert try again
|
||||||
|
EXECUTE 'INSERT INTO ' || quote_ident(table_name) || ' SELECT ($1).*' USING NEW;
|
||||||
|
EXCEPTION
|
||||||
|
WHEN OTHERS THEN
|
||||||
|
-- if this faled, throw it into the overflow table (so we don't loose anything)
|
||||||
|
INSERT INTO edit_log_overflow VALUES (NEW.*);
|
||||||
|
END;
|
||||||
|
-- other errors, insert into overlow
|
||||||
|
WHEN OTHERS THEN
|
||||||
|
-- if this faled, throw it into the overflow table (so we don't loose anything)
|
||||||
|
INSERT INTO edit_log_overflow VALUES (NEW.*);
|
||||||
|
END;
|
||||||
|
ELSE
|
||||||
|
-- if outside valid date, insert into overflow
|
||||||
|
INSERT INTO edit_log_overflow VALUES (NEW.*);
|
||||||
|
END IF;
|
||||||
|
RETURN NULL;
|
||||||
|
END
|
||||||
|
$$
|
||||||
|
LANGUAGE 'plpgsql'
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
-- add uid add for edit_access table
|
-- add uid add for edit_access table
|
||||||
|
|
||||||
CREATE OR REPLACE FUNCTION set_edit_access_uid() RETURNS TRIGGER AS
|
CREATE OR REPLACE FUNCTION set_edit_access_uid() RETURNS TRIGGER AS
|
||||||
$$
|
$$
|
||||||
DECLARE
|
DECLARE
|
||||||
myrec RECORD;
|
myrec RECORD;
|
||||||
|
|||||||
18
4dev/database/function/random_string.sql
Executable file
18
4dev/database/function/random_string.sql
Executable file
@@ -0,0 +1,18 @@
|
|||||||
|
-- create random string with length X
|
||||||
|
|
||||||
|
CREATE FUNCTION random_string(randomLength int)
|
||||||
|
RETURNS text AS $$
|
||||||
|
SELECT array_to_string(
|
||||||
|
ARRAY(
|
||||||
|
SELECT substring(
|
||||||
|
'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789',
|
||||||
|
trunc(random() * 62)::int + 1,
|
||||||
|
1
|
||||||
|
)
|
||||||
|
FROM generate_series(1, randomLength) AS gs(x)
|
||||||
|
),
|
||||||
|
''
|
||||||
|
)
|
||||||
|
$$ LANGUAGE SQL
|
||||||
|
RETURNS NULL ON NULL INPUT
|
||||||
|
VOLATILE; -- LEAKPROOF;
|
||||||
15
4dev/database/function/set_edit_generic.sql
Normal file
15
4dev/database/function/set_edit_generic.sql
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
-- adds the created or updated date tags
|
||||||
|
|
||||||
|
CREATE OR REPLACE FUNCTION set_edit_generic() RETURNS TRIGGER AS '
|
||||||
|
DECLARE
|
||||||
|
random_length INT = 12; -- that should be long enough
|
||||||
|
BEGIN
|
||||||
|
IF TG_OP = ''INSERT'' THEN
|
||||||
|
NEW.date_created := ''now'';
|
||||||
|
NEW.cuid := random_string(random_length);
|
||||||
|
ELSIF TG_OP = ''UPDATE'' THEN
|
||||||
|
NEW.date_updated := ''now'';
|
||||||
|
END IF;
|
||||||
|
RETURN NEW;
|
||||||
|
END;
|
||||||
|
' LANGUAGE 'plpgsql';
|
||||||
12
4dev/database/function/set_uid.sql
Executable file
12
4dev/database/function/set_uid.sql
Executable file
@@ -0,0 +1,12 @@
|
|||||||
|
-- adds the created or updated date tags
|
||||||
|
|
||||||
|
CREATE OR REPLACE FUNCTION set_uid() RETURNS TRIGGER AS '
|
||||||
|
DECLARE
|
||||||
|
random_length INT = 12; -- that should be long enough
|
||||||
|
BEGIN
|
||||||
|
IF TG_OP = ''INSERT'' THEN
|
||||||
|
NEW.uid := random_string(random_length);
|
||||||
|
END IF;
|
||||||
|
RETURN NEW;
|
||||||
|
END;
|
||||||
|
' LANGUAGE 'plpgsql';
|
||||||
@@ -8,10 +8,11 @@
|
|||||||
-- DROP TABLE edit_access;
|
-- DROP TABLE edit_access;
|
||||||
CREATE TABLE edit_access (
|
CREATE TABLE edit_access (
|
||||||
edit_access_id SERIAL PRIMARY KEY,
|
edit_access_id SERIAL PRIMARY KEY,
|
||||||
name VARCHAR(255) UNIQUE,
|
name VARCHAR UNIQUE,
|
||||||
description VARCHAR,
|
description VARCHAR,
|
||||||
COLOR VARCHAR
|
color VARCHAR,
|
||||||
|
uid VARCHAR,
|
||||||
|
enabled SMALLINT NOT NULL DEFAULT 0,
|
||||||
|
protected INT,
|
||||||
|
deleted SMALLINT DEFAULT 0
|
||||||
) INHERITS (edit_generic) WITHOUT OIDS;
|
) INHERITS (edit_generic) WITHOUT OIDS;
|
||||||
|
|
||||||
DELETE FROM edit_access;
|
|
||||||
INSERT INTO edit_access (name) VALUES ('Admin Access');
|
|
||||||
|
|||||||
@@ -14,14 +14,3 @@ CREATE TABLE edit_access_right (
|
|||||||
type VARCHAR,
|
type VARCHAR,
|
||||||
UNIQUE (level,type)
|
UNIQUE (level,type)
|
||||||
) INHERITS (edit_generic) WITHOUT OIDS;
|
) INHERITS (edit_generic) WITHOUT OIDS;
|
||||||
|
|
||||||
DELETE FROM edit_access_right;
|
|
||||||
INSERT INTO edit_access_right (name, level, type) VALUES ('Default', -1, 'default');
|
|
||||||
INSERT INTO edit_access_right (name, level, type) VALUES ('No Access', 0, 'none');
|
|
||||||
INSERT INTO edit_access_right (name, level, type) VALUES ('Read', 20, 'read');
|
|
||||||
INSERT INTO edit_access_right (name, level, type) VALUES ('Translator', 30, 'mod_trans');
|
|
||||||
INSERT INTO edit_access_right (name, level, type) VALUES ('Modify', 40, 'mod');
|
|
||||||
INSERT INTO edit_access_right (name, level, type) VALUES ('Create/Write', 60, 'write');
|
|
||||||
INSERT INTO edit_access_right (name, level, type) VALUES ('Delete', 80, 'del');
|
|
||||||
INSERT INTO edit_access_right (name, level, type) VALUES ('Site Admin', 90, 'siteadmin');
|
|
||||||
INSERT INTO edit_access_right (name, level, type) VALUES ('Admin', 100, 'admin');
|
|
||||||
|
|||||||
@@ -17,6 +17,3 @@ CREATE TABLE edit_access_user (
|
|||||||
FOREIGN KEY (edit_user_id) REFERENCES edit_user (edit_user_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
FOREIGN KEY (edit_user_id) REFERENCES edit_user (edit_user_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
FOREIGN KEY (edit_access_right_id) REFERENCES edit_access_right (edit_access_right_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE
|
FOREIGN KEY (edit_access_right_id) REFERENCES edit_access_right (edit_access_right_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
) INHERITS (edit_generic) WITHOUT OIDS;
|
) INHERITS (edit_generic) WITHOUT OIDS;
|
||||||
|
|
||||||
DELETE FROM edit_access_user;
|
|
||||||
INSERT INTO edit_access_user (edit_default, edit_access_id, edit_user_id, edit_access_right_id) VALUES (1, 1, 1, 8);
|
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
|
|
||||||
-- DROP TABLE edit_generic;
|
-- DROP TABLE edit_generic;
|
||||||
CREATE TABLE edit_generic (
|
CREATE TABLE edit_generic (
|
||||||
eg_status INT,
|
cuid VARCHAR,
|
||||||
date_created TIMESTAMP WITHOUT TIME ZONE DEFAULT clock_timestamp(),
|
date_created TIMESTAMP WITHOUT TIME ZONE DEFAULT clock_timestamp(),
|
||||||
date_updated TIMESTAMP WITHOUT TIME ZONE
|
date_updated TIMESTAMP WITHOUT TIME ZONE
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -8,12 +8,10 @@
|
|||||||
-- DROP TABLE edit_group;
|
-- DROP TABLE edit_group;
|
||||||
CREATE TABLE edit_group (
|
CREATE TABLE edit_group (
|
||||||
edit_group_id SERIAL PRIMARY KEY,
|
edit_group_id SERIAL PRIMARY KEY,
|
||||||
name VARCHAR(50),
|
name VARCHAR,
|
||||||
enabled SMALLINT NOT NULL DEFAULT 0,
|
enabled SMALLINT NOT NULL DEFAULT 0,
|
||||||
edit_scheme_id INT,
|
edit_scheme_id INT,
|
||||||
edit_access_right_id INT NOT NULL,
|
edit_access_right_id INT NOT NULL,
|
||||||
FOREIGN KEY (edit_scheme_id) REFERENCES edit_scheme (edit_scheme_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
FOREIGN KEY (edit_scheme_id) REFERENCES edit_scheme (edit_scheme_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
FOREIGN KEY (edit_access_right_id) REFERENCES edit_access_right (edit_access_right_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE
|
FOREIGN KEY (edit_access_right_id) REFERENCES edit_access_right (edit_access_right_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
) INHERITS (edit_generic) WITHOUT OIDS;
|
) INHERITS (edit_generic) WITHOUT OIDS;
|
||||||
|
|
||||||
INSERT INTO edit_group (name, enabled, edit_scheme_id, edit_access_right_id) VALUES ('Admin', 1, 2, 8);
|
|
||||||
|
|||||||
@@ -9,12 +9,10 @@
|
|||||||
-- DROP TABLE edit_language;
|
-- DROP TABLE edit_language;
|
||||||
CREATE TABLE edit_language (
|
CREATE TABLE edit_language (
|
||||||
edit_language_id SERIAL PRIMARY KEY,
|
edit_language_id SERIAL PRIMARY KEY,
|
||||||
short_name VARCHAR(2),
|
short_name VARCHAR,
|
||||||
long_name VARCHAR(70),
|
long_name VARCHAR,
|
||||||
iso_name VARCHAR(12),
|
iso_name VARCHAR,
|
||||||
order_number INT,
|
order_number INT,
|
||||||
enabled SMALLINT NOT NULL DEFAULT 0,
|
enabled SMALLINT NOT NULL DEFAULT 0,
|
||||||
lang_default SMALLINT NOT NULL DEFAULT 0 UNIQUE
|
lang_default SMALLINT NOT NULL DEFAULT 0
|
||||||
) INHERITS (edit_generic) WITHOUT OIDS;
|
) INHERITS (edit_generic) WITHOUT OIDS;
|
||||||
|
|
||||||
INSERT INTO edit_language (short_name, long_name, iso_name, order_number, enabled, lang_default) VALUES ('en', 'English', 'UTF-8', 1, 1, 1);
|
|
||||||
|
|||||||
@@ -8,11 +8,9 @@
|
|||||||
-- DROP TABLE edit_menu_group;
|
-- DROP TABLE edit_menu_group;
|
||||||
CREATE TABLE edit_menu_group (
|
CREATE TABLE edit_menu_group (
|
||||||
edit_menu_group_id SERIAL PRIMARY KEY,
|
edit_menu_group_id SERIAL PRIMARY KEY,
|
||||||
name VARCHAR(255),
|
name VARCHAR,
|
||||||
flag VARCHAR(50),
|
flag VARCHAR,
|
||||||
order_number INT NOT NULL
|
order_number INT NOT NULL
|
||||||
) INHERITS (edit_generic) WITHOUT OIDS;
|
) INHERITS (edit_generic) WITHOUT OIDS;
|
||||||
|
|
||||||
DELETE FROM edit_menu_group;
|
|
||||||
INSERT INTO edit_menu_group (name, flag, order_number) VALUES ('Admin Menu', 'admin', 1);
|
|
||||||
INSERT INTO edit_menu_group (name, flag, order_number) VALUES ('Admin Data Popup Menu', 'AdminDataPopup', 2);
|
|
||||||
|
|||||||
@@ -8,8 +8,8 @@
|
|||||||
-- DROP TABLE edit_page;
|
-- DROP TABLE edit_page;
|
||||||
CREATE TABLE edit_page (
|
CREATE TABLE edit_page (
|
||||||
edit_page_id SERIAL PRIMARY KEY,
|
edit_page_id SERIAL PRIMARY KEY,
|
||||||
filename VARCHAR(70),
|
filename VARCHAR,
|
||||||
name VARCHAR(255) UNIQUE,
|
name VARCHAR UNIQUE,
|
||||||
order_number INT NOT NULL,
|
order_number INT NOT NULL,
|
||||||
online SMALLINT NOT NULL DEFAULT 0,
|
online SMALLINT NOT NULL DEFAULT 0,
|
||||||
menu SMALLINT NOT NULL DEFAULT 0,
|
menu SMALLINT NOT NULL DEFAULT 0,
|
||||||
@@ -17,14 +17,3 @@ CREATE TABLE edit_page (
|
|||||||
popup_x SMALLINT,
|
popup_x SMALLINT,
|
||||||
popup_y SMALLINT
|
popup_y SMALLINT
|
||||||
) INHERITS (edit_generic) WITHOUT OIDS;
|
) INHERITS (edit_generic) WITHOUT OIDS;
|
||||||
|
|
||||||
DELETE FROM edit_page;
|
|
||||||
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_pages.php', 'Edit Pages', 1, 1, 1);
|
|
||||||
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_users.php', 'Edit Users', 2, 1, 1);
|
|
||||||
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_languages.php', 'Edit Languages', 3, 1, 1);
|
|
||||||
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_schemes.php', 'Edit Schemes', 4, 1, 1);
|
|
||||||
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_groups.php', 'Edit Groups', 5, 1, 1);
|
|
||||||
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_visible_group.php', 'Edit Visible Groups', 6, 1, 1);
|
|
||||||
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_menu_group.php', 'Edit Menu Groups', 7, 1, 1);
|
|
||||||
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_access.php', 'Edit Access', 8, 1, 1);
|
|
||||||
INSERT INTO edit_page (filename, name, order_number, online, menu) VALUES ('edit_order.php', 'Edit Order', 9, 1, 0);
|
|
||||||
|
|||||||
@@ -17,12 +17,4 @@ CREATE TABLE edit_page_access (
|
|||||||
FOREIGN KEY (edit_access_right_id) REFERENCES edit_access_right (edit_access_right_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE
|
FOREIGN KEY (edit_access_right_id) REFERENCES edit_access_right (edit_access_right_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
) INHERITS (edit_generic) WITHOUT OIDS;
|
) INHERITS (edit_generic) WITHOUT OIDS;
|
||||||
|
|
||||||
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1, 1, 1, 8);
|
|
||||||
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1, 1, 2, 8);
|
|
||||||
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1, 1, 3, 8);
|
|
||||||
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1, 1, 4, 8);
|
|
||||||
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1, 1, 5, 8);
|
|
||||||
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1, 1, 6, 8);
|
|
||||||
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1, 1, 7, 8);
|
|
||||||
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1, 1, 8, 8);
|
|
||||||
INSERT INTO edit_page_access (enabled, edit_group_id, edit_page_id, edit_access_right_id) VALUES (1, 1, 9, 8);
|
|
||||||
|
|||||||
@@ -12,12 +12,3 @@ CREATE TABLE edit_page_menu_group (
|
|||||||
FOREIGN KEY (edit_page_id) REFERENCES edit_page (edit_page_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
FOREIGN KEY (edit_page_id) REFERENCES edit_page (edit_page_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
FOREIGN KEY (edit_menu_group_id) REFERENCES edit_menu_group (edit_menu_group_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE
|
FOREIGN KEY (edit_menu_group_id) REFERENCES edit_menu_group (edit_menu_group_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
);
|
);
|
||||||
|
|
||||||
DELETE FROM edit_page_menu_group;
|
|
||||||
INSERT INTO edit_page_menu_group VALUES (1, 1);
|
|
||||||
INSERT INTO edit_page_menu_group VALUES (2, 1);
|
|
||||||
INSERT INTO edit_page_menu_group VALUES (3, 1);
|
|
||||||
INSERT INTO edit_page_menu_group VALUES (4, 1);
|
|
||||||
INSERT INTO edit_page_menu_group VALUES (5, 1);
|
|
||||||
INSERT INTO edit_page_menu_group VALUES (6, 1);
|
|
||||||
INSERT INTO edit_page_menu_group VALUES (7, 1);
|
|
||||||
|
|||||||
@@ -12,12 +12,3 @@ CREATE TABLE edit_page_visible_group (
|
|||||||
FOREIGN KEY (edit_page_id) REFERENCES edit_page (edit_page_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
FOREIGN KEY (edit_page_id) REFERENCES edit_page (edit_page_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
FOREIGN KEY (edit_visible_group_id) REFERENCES edit_visible_group (edit_visible_group_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE
|
FOREIGN KEY (edit_visible_group_id) REFERENCES edit_visible_group (edit_visible_group_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
);
|
);
|
||||||
|
|
||||||
DELETE FROM edit_page_visible_group;
|
|
||||||
INSERT INTO edit_page_visible_group VALUES (1, 1);
|
|
||||||
INSERT INTO edit_page_visible_group VALUES (2, 1);
|
|
||||||
INSERT INTO edit_page_visible_group VALUES (3, 1);
|
|
||||||
INSERT INTO edit_page_visible_group VALUES (4, 1);
|
|
||||||
INSERT INTO edit_page_visible_group VALUES (5, 1);
|
|
||||||
INSERT INTO edit_page_visible_group VALUES (6, 1);
|
|
||||||
INSERT INTO edit_page_visible_group VALUES (7, 1);
|
|
||||||
|
|||||||
@@ -8,8 +8,8 @@
|
|||||||
-- DROP TABLE edit_query_string;
|
-- DROP TABLE edit_query_string;
|
||||||
CREATE TABLE edit_query_string (
|
CREATE TABLE edit_query_string (
|
||||||
edit_query_string_id SERIAL PRIMARY KEY,
|
edit_query_string_id SERIAL PRIMARY KEY,
|
||||||
name VARCHAR(255),
|
name VARCHAR,
|
||||||
value VARCHAR(255),
|
value VARCHAR,
|
||||||
enabled SMALLINT NOT NULL DEFAULT 0,
|
enabled SMALLINT NOT NULL DEFAULT 0,
|
||||||
dynamic SMALLINT NOT NULL DEFAULT 0,
|
dynamic SMALLINT NOT NULL DEFAULT 0,
|
||||||
edit_page_id INT NOT NULL,
|
edit_page_id INT NOT NULL,
|
||||||
|
|||||||
@@ -9,12 +9,8 @@
|
|||||||
CREATE TABLE edit_scheme (
|
CREATE TABLE edit_scheme (
|
||||||
edit_scheme_id SERIAL PRIMARY KEY,
|
edit_scheme_id SERIAL PRIMARY KEY,
|
||||||
enabled SMALLINT NOT NULL DEFAULT 0,
|
enabled SMALLINT NOT NULL DEFAULT 0,
|
||||||
name VARCHAR(50),
|
name VARCHAR,
|
||||||
header_color VARCHAR(7),
|
header_color VARCHAR,
|
||||||
css_file VARCHAR(50),
|
css_file VARCHAR,
|
||||||
template VARCHAR(50)
|
template VARCHAR
|
||||||
) INHERITS (edit_generic) WITHOUT OIDS;
|
) INHERITS (edit_generic) WITHOUT OIDS;
|
||||||
|
|
||||||
INSERT INTO edit_scheme (name, header_color, enabled) VALUES ('Default Scheme', '#E0E2FF', 1);
|
|
||||||
INSERT INTO edit_scheme (name, header_color, enabled) VALUES ('Admin', '#CC7E7E', 1);
|
|
||||||
INSERT INTO edit_scheme (name, header_color, enabled) VALUES ('Visitor', '#B0C4B3', 1);
|
|
||||||
|
|||||||
@@ -7,5 +7,5 @@
|
|||||||
|
|
||||||
-- DROP TABLE temp_files;
|
-- DROP TABLE temp_files;
|
||||||
CREATE TABLE temp_files (
|
CREATE TABLE temp_files (
|
||||||
filename VARCHAR(250)
|
filename VARCHAR
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -8,8 +8,13 @@
|
|||||||
-- DROP TABLE edit_user;
|
-- DROP TABLE edit_user;
|
||||||
CREATE TABLE edit_user (
|
CREATE TABLE edit_user (
|
||||||
edit_user_id SERIAL PRIMARY KEY,
|
edit_user_id SERIAL PRIMARY KEY,
|
||||||
|
connect_edit_user_id INT, -- possible reference to other user
|
||||||
username VARCHAR UNIQUE,
|
username VARCHAR UNIQUE,
|
||||||
password VARCHAR,
|
password VARCHAR,
|
||||||
|
first_name VARCHAR,
|
||||||
|
last_name VARCHAR,
|
||||||
|
first_name_furigana VARCHAR,
|
||||||
|
last_name_furigana VARCHAR,
|
||||||
enabled SMALLINT NOT NULL DEFAULT 0,
|
enabled SMALLINT NOT NULL DEFAULT 0,
|
||||||
debug SMALLINT NOT NULL DEFAULT 0,
|
debug SMALLINT NOT NULL DEFAULT 0,
|
||||||
db_debug SMALLINT NOT NULL DEFAULT 0,
|
db_debug SMALLINT NOT NULL DEFAULT 0,
|
||||||
@@ -21,18 +26,15 @@ CREATE TABLE edit_user (
|
|||||||
edit_scheme_id INT,
|
edit_scheme_id INT,
|
||||||
edit_access_right_id INT NOT NULL,
|
edit_access_right_id INT NOT NULL,
|
||||||
login_error_count INT,
|
login_error_count INT,
|
||||||
login_error_date_last TIMESTAMP WTIHOUT TIME ZONE,
|
login_error_date_last TIMESTAMP WITHOUT TIME ZONE,
|
||||||
login_error_date_first TIMESTAMP WTIHOUT TIME ZONE,
|
login_error_date_first TIMESTAMP WITHOUT TIME ZONE,
|
||||||
strict SMALLINT DEFAULT 0,
|
strict SMALLINT DEFAULT 0,
|
||||||
locked SMALLINT DEFAULT 0,
|
locked SMALLINT DEFAULT 0,
|
||||||
password_change_date TIMESTAMP WITHOUT TIME ZONE, -- only when password is first set or changed
|
password_change_date TIMESTAMP WITHOUT TIME ZONE, -- only when password is first set or changed
|
||||||
password_change_interval INTERVAL, -- null if no change is needed, or d/m/y time interval
|
password_change_interval INTERVAL, -- null if no change is needed, or d/m/y time interval
|
||||||
|
FOREIGN KEY (connect_edit_user_id) REFERENCES edit_user (edit_user_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
FOREIGN KEY (edit_language_id) REFERENCES edit_language (edit_language_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
FOREIGN KEY (edit_language_id) REFERENCES edit_language (edit_language_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
FOREIGN KEY (edit_group_id) REFERENCES edit_group (edit_group_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
FOREIGN KEY (edit_group_id) REFERENCES edit_group (edit_group_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
FOREIGN KEY (edit_scheme_id) REFERENCES edit_scheme (edit_scheme_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
FOREIGN KEY (edit_scheme_id) REFERENCES edit_scheme (edit_scheme_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
FOREIGN KEY (edit_access_right_id) REFERENCES edit_access_right (edit_access_right_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE
|
FOREIGN KEY (edit_access_right_id) REFERENCES edit_access_right (edit_access_right_id) MATCH FULL ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
) INHERITS (edit_generic) WITHOUT OIDS;
|
) INHERITS (edit_generic) WITHOUT OIDS;
|
||||||
|
|
||||||
-- inserts admin user so basic users can be created
|
|
||||||
DELETE FROM edit_user;
|
|
||||||
INSERT INTO edit_user (username, password, enabled, debug, db_debug, email, protected, admin, edit_language_id, edit_group_id, edit_scheme_id, edit_access_right_id) VALUES ('admin', 'admin', 1, 1, 1, '', 1, 1, 1, 1, 2, 8);
|
|
||||||
|
|||||||
@@ -8,8 +8,8 @@
|
|||||||
-- DROP TABLE edit_visible_group;
|
-- DROP TABLE edit_visible_group;
|
||||||
CREATE TABLE edit_visible_group (
|
CREATE TABLE edit_visible_group (
|
||||||
edit_visible_group_id SERIAL PRIMARY KEY,
|
edit_visible_group_id SERIAL PRIMARY KEY,
|
||||||
name VARCHAR(255),
|
name VARCHAR,
|
||||||
flag VARCHAR(50)
|
flag VARCHAR
|
||||||
) INHERITS (edit_generic) WITHOUT OIDS;
|
) INHERITS (edit_generic) WITHOUT OIDS;
|
||||||
|
|
||||||
DELETE FROM edit_visible_group;
|
DELETE FROM edit_visible_group;
|
||||||
|
|||||||
@@ -1,4 +1,9 @@
|
|||||||
-- DROP TRIGGER trg_edit_access ON edit_access;
|
DROP TRIGGER trg_edit_access ON edit_access;
|
||||||
CREATE TRIGGER trg_edit_access
|
CREATE TRIGGER trg_edit_access
|
||||||
BEFORE INSERT OR UPDATE ON edit_access
|
BEFORE INSERT OR UPDATE ON edit_access
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_generic();
|
||||||
|
|
||||||
|
DROP TRIGGER trg_set_edit_access_uid ON edit_access;
|
||||||
|
CREATE TRIGGER trg_set_edit_access_uid
|
||||||
|
BEFORE INSERT OR UPDATE ON edit_access
|
||||||
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_access_uid();
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
-- DROP TRIGGER trg_edit_access_data ON edit_access_data;
|
DROP TRIGGER trg_edit_access_data ON edit_access_data;
|
||||||
CREATE TRIGGER trg_edit_access_data
|
CREATE TRIGGER trg_edit_access_data
|
||||||
BEFORE INSERT OR UPDATE ON edit_access_data
|
BEFORE INSERT OR UPDATE ON edit_access_data
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_generic();
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
-- DROP TRIGGER trg_edit_access_right ON edit_access_right;
|
DROP TRIGGER trg_edit_access_right ON edit_access_right;
|
||||||
CREATE TRIGGER trg_edit_access_right
|
CREATE TRIGGER trg_edit_access_right
|
||||||
BEFORE INSERT OR UPDATE ON edit_access_right
|
BEFORE INSERT OR UPDATE ON edit_access_right
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_generic();
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
-- DROP TRIGGER trg_edit_access_user ON edit_access_user;
|
DROP TRIGGER trg_edit_access_user ON edit_access_user;
|
||||||
CREATE TRIGGER trg_edit_access_user
|
CREATE TRIGGER trg_edit_access_user
|
||||||
BEFORE INSERT OR UPDATE ON edit_access_user
|
BEFORE INSERT OR UPDATE ON edit_access_user
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_generic();
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
-- DROP TRIGGER trg_edit_group ON edit_group;
|
DROP TRIGGER trg_edit_group ON edit_group;
|
||||||
CREATE TRIGGER trg_edit_group
|
CREATE TRIGGER trg_edit_group
|
||||||
BEFORE INSERT OR UPDATE ON edit_group
|
BEFORE INSERT OR UPDATE ON edit_group
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_generic();
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
-- DROP TRIGGER trg_edit_language ON edit_language;
|
DROP TRIGGER trg_edit_language ON edit_language;
|
||||||
CREATE TRIGGER trg_edit_language
|
CREATE TRIGGER trg_edit_language
|
||||||
BEFORE INSERT OR UPDATE ON edit_language
|
BEFORE INSERT OR UPDATE ON edit_language
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_generic();
|
||||||
|
|||||||
@@ -1,4 +1,9 @@
|
|||||||
-- DROP TRIGGER trg_edit_log ON edit_log;
|
DROP TRIGGER trg_edit_log ON edit_log;
|
||||||
CREATE TRIGGER trg_edit_log
|
CREATE TRIGGER trg_edit_log
|
||||||
BEFORE INSERT OR UPDATE ON edit_log
|
BEFORE INSERT OR UPDATE ON edit_log
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_generic();
|
||||||
|
|
||||||
|
DROP TRIGGER trg_edit_log_insert_partition ON edit_log;
|
||||||
|
CREATE TRIGGER trg_edit_log_insert_partition
|
||||||
|
BEFORE INSERT OR UPDATE ON edit_log
|
||||||
|
FOR EACH ROW EXECUTE PROCEDURE edit_log_insert_trigger();
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
-- DROP TRIGGER trg_edit_visible_group ON edit_visible_group;
|
DROP TRIGGER trg_edit_menu_group ON edit_menu_group;
|
||||||
CREATE TRIGGER trg_edit_menu_group
|
CREATE TRIGGER trg_edit_menu_group
|
||||||
BEFORE INSERT OR UPDATE ON edit_menu_group
|
BEFORE INSERT OR UPDATE ON edit_menu_group
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_generic();
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
-- DROP TRIGGER trg_edit_page ON edit_page;
|
DROP TRIGGER trg_edit_page ON edit_page;
|
||||||
CREATE TRIGGER trg_edit_page
|
CREATE TRIGGER trg_edit_page
|
||||||
BEFORE INSERT OR UPDATE ON edit_page
|
BEFORE INSERT OR UPDATE ON edit_page
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_generic();
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
-- DROP TRIGGER trg_edit_page_access ON edit_page_access;
|
DROP TRIGGER trg_edit_page_access ON edit_page_access;
|
||||||
CREATE TRIGGER trg_edit_page_access
|
CREATE TRIGGER trg_edit_page_access
|
||||||
BEFORE INSERT OR UPDATE ON edit_page_access
|
BEFORE INSERT OR UPDATE ON edit_page_access
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_generic();
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
-- DROP TRIGGER trg_edit_query_string ON edit_query_string;
|
DROP TRIGGER trg_edit_query_string ON edit_query_string;
|
||||||
CREATE TRIGGER trg_edit_query_string
|
CREATE TRIGGER trg_edit_query_string
|
||||||
BEFORE INSERT OR UPDATE ON edit_query_string
|
BEFORE INSERT OR UPDATE ON edit_query_string
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_generic();
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
-- DROP TRIGGER trg_edit_scheme ON edit_scheme;
|
DROP TRIGGER trg_edit_scheme ON edit_scheme;
|
||||||
CREATE TRIGGER trg_edit_scheme
|
CREATE TRIGGER trg_edit_scheme
|
||||||
BEFORE INSERT OR UPDATE ON edit_scheme
|
BEFORE INSERT OR UPDATE ON edit_scheme
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_generic();
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
-- DROP TRIGGER trg_edit_user ON edit_user;
|
DROP TRIGGER trg_edit_user ON edit_user;
|
||||||
CREATE TRIGGER trg_edit_user
|
CREATE TRIGGER trg_edit_user
|
||||||
BEFORE INSERT OR UPDATE ON edit_user
|
BEFORE INSERT OR UPDATE ON edit_user
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_generic();
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
-- DROP TRIGGER trg_edit_visible_group ON edit_visible_group;
|
DROP TRIGGER trg_edit_visible_group ON edit_visible_group;
|
||||||
CREATE TRIGGER trg_edit_visible_group
|
CREATE TRIGGER trg_edit_visible_group
|
||||||
BEFORE INSERT OR UPDATE ON edit_visible_group
|
BEFORE INSERT OR UPDATE ON edit_visible_group
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_generic();
|
FOR EACH ROW EXECUTE PROCEDURE set_edit_generic();
|
||||||
|
|||||||
@@ -1,4 +0,0 @@
|
|||||||
-- DROP TRIGGER trg_set_edit_access_uid ON edit_access;
|
|
||||||
CREATE TRIGGER trg_set_edit_access_uid
|
|
||||||
BEFORE INSERT OR UPDATE ON edit_access
|
|
||||||
FOR EACH ROW EXECUTE PROCEDURE set_edit_access_uid();
|
|
||||||
@@ -18,7 +18,9 @@ The active branch, which is the namespace branch
|
|||||||
|
|
||||||
### legacy
|
### legacy
|
||||||
|
|
||||||
The old non namepsace format layout. This will only get bug fixes and no new development
|
The old non namepsace format layout.
|
||||||
|
This is fully deprecated and will no longer be maintaned.
|
||||||
|
last tested PHP 5.6 and PHP 7.0
|
||||||
|
|
||||||
### namespace
|
### namespace
|
||||||
|
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
php_value xdebug.profiler_output_dir /home/developer/html/adidas/20081208_catalogue/4dev/xdebug/
|
# all .inc files are denied access from outside
|
||||||
php_value xdebug.profiler_output_name timestamp
|
<Files "*.inc">
|
||||||
php_value xdebug.profiler_enable 0
|
Require all denied
|
||||||
|
</Files>
|
||||||
|
|||||||
@@ -14,7 +14,8 @@ ob_start();
|
|||||||
// basic class test file
|
// basic class test file
|
||||||
define('USE_DATABASE', true);
|
define('USE_DATABASE', true);
|
||||||
// sample config
|
// sample config
|
||||||
require("config.inc");
|
// require("config.inc");
|
||||||
|
require 'config.php';
|
||||||
// set session name
|
// set session name
|
||||||
if (!defined('SET_SESSION_NAME')) {
|
if (!defined('SET_SESSION_NAME')) {
|
||||||
DEFINE('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
DEFINE('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
||||||
@@ -31,7 +32,7 @@ ob_end_flush();
|
|||||||
|
|
||||||
// set + check edit access id
|
// set + check edit access id
|
||||||
$edit_access_id = 3;
|
$edit_access_id = 3;
|
||||||
if (array_key_exists('unit', $login->acl)) {
|
if (isset($login) && is_object($login) && isset($login->acl['unit'])) {
|
||||||
print "ACL UNIT: ".print_r(array_keys($login->acl['unit']), 1)."<br>";
|
print "ACL UNIT: ".print_r(array_keys($login->acl['unit']), 1)."<br>";
|
||||||
print "ACCESS CHECK: ".$login->loginCheckEditAccess($edit_access_id)."<br>";
|
print "ACCESS CHECK: ".$login->loginCheckEditAccess($edit_access_id)."<br>";
|
||||||
if ($login->loginCheckEditAccess($edit_access_id)) {
|
if ($login->loginCheckEditAccess($edit_access_id)) {
|
||||||
@@ -67,14 +68,16 @@ print "CALLER BACKTRACE: ".$basic->getCallerMethod()."<br>";
|
|||||||
$basic->debug('SOME MARK', 'Some error output');
|
$basic->debug('SOME MARK', 'Some error output');
|
||||||
|
|
||||||
print "EDIT ACCESS ID: ".$basic->edit_access_id."<br>";
|
print "EDIT ACCESS ID: ".$basic->edit_access_id."<br>";
|
||||||
// print "ACL: <br>".$basic->print_ar($login->acl)."<br>";
|
if (isset($login)) {
|
||||||
$basic->debug('ACL', "ACL: ".$basic->printAr($login->acl));
|
// print "ACL: <br>".$basic->print_ar($login->acl)."<br>";
|
||||||
// print "DEFAULT ACL: <br>".$basic->print_ar($login->default_acl_list)."<br>";
|
$basic->debug('ACL', "ACL: ".$basic->printAr($login->acl));
|
||||||
// print "DEFAULT ACL: <br>".$basic->print_ar($login->default_acl_list)."<br>";
|
// print "DEFAULT ACL: <br>".$basic->print_ar($login->default_acl_list)."<br>";
|
||||||
// $result = array_flip(array_filter(array_flip($login->default_acl_list), function ($key) { if (is_numeric($key)) return $key; }));
|
// print "DEFAULT ACL: <br>".$basic->print_ar($login->default_acl_list)."<br>";
|
||||||
// print "DEFAULT ACL: <br>".$basic->print_ar($result)."<br>";
|
// $result = array_flip(array_filter(array_flip($login->default_acl_list), function ($key) { if (is_numeric($key)) return $key; }));
|
||||||
// DEPRICATED CALL
|
// print "DEFAULT ACL: <br>".$basic->print_ar($result)."<br>";
|
||||||
// $basic->adbSetACL($login->acl);
|
// DEPRICATED CALL
|
||||||
|
// $basic->adbSetACL($login->acl);
|
||||||
|
}
|
||||||
|
|
||||||
// DB client encoding
|
// DB client encoding
|
||||||
print "DB Client encoding: ".$basic->dbGetEncoding()."<br>";
|
print "DB Client encoding: ".$basic->dbGetEncoding()."<br>";
|
||||||
@@ -97,6 +100,9 @@ print "DIRECT MULTIPLE INSERT STATUS: $status | PRIMARY KEYS: ".print_r($basic->
|
|||||||
// no returning, but not needed ;
|
// no returning, but not needed ;
|
||||||
$status = $basic->dbExec("INSERT INTO foo (test) VALUES ('FOO; TEST ".time()."');");
|
$status = $basic->dbExec("INSERT INTO foo (test) VALUES ('FOO; TEST ".time()."');");
|
||||||
print "DIRECT INSERT STATUS: $status | PRIMARY KEY: ".$basic->insert_id." | PRIMARY KEY EXT: ".print_r($basic->insert_id_ext, 1)."<br>";
|
print "DIRECT INSERT STATUS: $status | PRIMARY KEY: ".$basic->insert_id." | PRIMARY KEY EXT: ".print_r($basic->insert_id_ext, 1)."<br>";
|
||||||
|
// UPDATE WITH RETURNING
|
||||||
|
$status = $basic->dbExec("UPDATE foo SET test = 'SOMETHING DIFFERENT' WHERE foo_id = 3688452 RETURNING test");
|
||||||
|
print "UPDATE STATUS: $status | RETURNING EXT: ".print_r($basic->insert_id_ext, 1)."<br>";
|
||||||
|
|
||||||
# db write class test
|
# db write class test
|
||||||
$table = 'foo';
|
$table = 'foo';
|
||||||
@@ -161,14 +167,14 @@ print "DB Version bigger than $to_db_version: ".$basic->dbCompareVersion('>='.$t
|
|||||||
print "DB Version bigger $to_db_version: ".$basic->dbCompareVersion('>'.$to_db_version)."<br>";
|
print "DB Version bigger $to_db_version: ".$basic->dbCompareVersion('>'.$to_db_version)."<br>";
|
||||||
|
|
||||||
/* $q = "SELECT FOO FRO BAR";
|
/* $q = "SELECT FOO FRO BAR";
|
||||||
// $q = "Select * from foo";
|
// $q = "Select * from foo";
|
||||||
$foo = $basic->dbExecAsync($q);
|
$foo = $basic->dbExecAsync($q);
|
||||||
print "[ERR] Query: ".$q."<br>";
|
print "[ERR] Query: ".$q."<br>";
|
||||||
print "[ERR] RESOURCE: $foo<br>";
|
print "[ERR] RESOURCE: $foo<br>";
|
||||||
while (($ret = $basic->dbCheckAsync()) === true)
|
while (($ret = $basic->dbCheckAsync()) === true)
|
||||||
{
|
{
|
||||||
print "[ERR]: $ret<br>";
|
print "[ERR]: $ret<br>";
|
||||||
// sleep(5);
|
sleep(5);
|
||||||
} */
|
} */
|
||||||
|
|
||||||
// search path check
|
// search path check
|
||||||
@@ -202,8 +208,11 @@ $date_1 = '2017/1/5';
|
|||||||
$date_2 = '2017-01-05';
|
$date_2 = '2017-01-05';
|
||||||
print "COMPARE DATE: ".$basic->compareDate($date_1, $date_2)."<br>";
|
print "COMPARE DATE: ".$basic->compareDate($date_1, $date_2)."<br>";
|
||||||
|
|
||||||
|
|
||||||
|
// array re
|
||||||
|
|
||||||
// print error messages
|
// print error messages
|
||||||
print $login->printErrorMsg();
|
// print $login->printErrorMsg();
|
||||||
print $basic->printErrorMsg();
|
print $basic->printErrorMsg();
|
||||||
|
|
||||||
print "</body></html>";
|
print "</body></html>";
|
||||||
|
|||||||
@@ -1 +0,0 @@
|
|||||||
../configs/config.inc
|
|
||||||
1
www/admin/config.php
Symbolic link
1
www/admin/config.php
Symbolic link
@@ -0,0 +1 @@
|
|||||||
|
../configs/config.php
|
||||||
@@ -1 +1 @@
|
|||||||
edit_base.inc
|
../includes/edit_base.inc
|
||||||
@@ -1 +1 @@
|
|||||||
edit_base.inc
|
../includes/edit_base.inc
|
||||||
@@ -1 +1 @@
|
|||||||
edit_base.inc
|
../includes/edit_base.inc
|
||||||
@@ -1 +1 @@
|
|||||||
edit_base.inc
|
../includes/edit_base.inc
|
||||||
@@ -16,7 +16,7 @@ $DB_DEBUG = 1;
|
|||||||
extract($_GET, EXTR_SKIP);
|
extract($_GET, EXTR_SKIP);
|
||||||
extract($_POST, EXTR_SKIP);
|
extract($_POST, EXTR_SKIP);
|
||||||
|
|
||||||
include("config.inc");
|
require 'config.php';
|
||||||
// set session name
|
// set session name
|
||||||
define('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
define('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
||||||
// overrride debug flags
|
// overrride debug flags
|
||||||
@@ -71,6 +71,9 @@ if (defined('LAYOUT')) {
|
|||||||
// there are the POSITION stored, that should CHANGE there order (up/down)
|
// there are the POSITION stored, that should CHANGE there order (up/down)
|
||||||
// $row_data_id ... has ALL ids from the sorting part
|
// $row_data_id ... has ALL ids from the sorting part
|
||||||
// $row_data_order ... has ALL order positions from the soirting part
|
// $row_data_order ... has ALL order positions from the soirting part
|
||||||
|
if (!is_array($position)) {
|
||||||
|
$position = array ();
|
||||||
|
}
|
||||||
if (count($position)) {
|
if (count($position)) {
|
||||||
$original_id = $row_data_id;
|
$original_id = $row_data_id;
|
||||||
|
|
||||||
@@ -146,9 +149,12 @@ if ($error) {
|
|||||||
$DATA['form_error_msg'] = $messages;
|
$DATA['form_error_msg'] = $messages;
|
||||||
|
|
||||||
// all the row data
|
// all the row data
|
||||||
$options_id = array();
|
$options_id = array ();
|
||||||
$options_name = array();
|
$options_name = array ();
|
||||||
$options_selected = array();
|
$options_selected = array ();
|
||||||
|
if (!is_array($row_data)) {
|
||||||
|
$row_data = array ();
|
||||||
|
}
|
||||||
for ($i = 0; $i < count($row_data); $i ++) {
|
for ($i = 0; $i < count($row_data); $i ++) {
|
||||||
$options_id[] = $i;
|
$options_id[] = $i;
|
||||||
$options_name[] = $row_data[$i]["name"];
|
$options_name[] = $row_data[$i]["name"];
|
||||||
@@ -165,8 +171,8 @@ $DATA['options_name'] = $options_name;
|
|||||||
$DATA['options_selected'] = $options_selected;
|
$DATA['options_selected'] = $options_selected;
|
||||||
|
|
||||||
// hidden list for the data (id, order number)
|
// hidden list for the data (id, order number)
|
||||||
$row_data_id = array();
|
$row_data_id = array ();
|
||||||
$row_data_order = array();
|
$row_data_order = array ();
|
||||||
for ($i = 0; $i < count($row_data); $i++) {
|
for ($i = 0; $i < count($row_data); $i++) {
|
||||||
$row_data_id[] = $row_data[$i]["id"];
|
$row_data_id[] = $row_data[$i]["id"];
|
||||||
$row_data_order[] = $row_data[$i]["order"];
|
$row_data_order[] = $row_data[$i]["order"];
|
||||||
@@ -184,7 +190,7 @@ $DEBUG_DATA['DEBUG'] = $DEBUG_TMPL;
|
|||||||
// create main data array
|
// create main data array
|
||||||
$CONTENT_DATA = array_merge($HEADER, $DATA, $DEBUG_DATA);
|
$CONTENT_DATA = array_merge($HEADER, $DATA, $DEBUG_DATA);
|
||||||
// data is 1:1 mapping (all vars, values, etc)
|
// data is 1:1 mapping (all vars, values, etc)
|
||||||
while (list($key, $value) = each($CONTENT_DATA)) {
|
foreach ($CONTENT_DATA as $key => $value) {
|
||||||
$smarty->assign($key, $value);
|
$smarty->assign($key, $value);
|
||||||
}
|
}
|
||||||
$smarty->display('edit_order.tpl');
|
$smarty->display('edit_order.tpl');
|
||||||
@@ -192,5 +198,4 @@ $smarty->display('edit_order.tpl');
|
|||||||
echo $login->printErrorMsg();
|
echo $login->printErrorMsg();
|
||||||
echo $db->printErrorMsg();
|
echo $db->printErrorMsg();
|
||||||
|
|
||||||
# __END__
|
// __END__
|
||||||
|
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
edit_base.inc
|
../includes/edit_base.inc
|
||||||
@@ -1 +1 @@
|
|||||||
edit_base.inc
|
../includes/edit_base.inc
|
||||||
@@ -1 +1 @@
|
|||||||
edit_base.inc
|
../includes/edit_base.inc
|
||||||
@@ -1 +1 @@
|
|||||||
edit_base.inc
|
../includes/edit_base.inc
|
||||||
@@ -10,7 +10,7 @@ if ($DEBUG_ALL) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// sample config
|
// sample config
|
||||||
require("config.inc");
|
require 'config.php';
|
||||||
echo "FILE: ".BASE.LIB."Error.Handling.inc<br>";
|
echo "FILE: ".BASE.LIB."Error.Handling.inc<br>";
|
||||||
require(BASE.LIB."Error.Handling.inc");
|
require(BASE.LIB."Error.Handling.inc");
|
||||||
|
|
||||||
|
|||||||
@@ -1,480 +0,0 @@
|
|||||||
<?php
|
|
||||||
/********************************************************************
|
|
||||||
* AUTHOR: Clemens Schwaighofer
|
|
||||||
* CREATED: 2005/07/13
|
|
||||||
* SHORT DESCRIPTION:
|
|
||||||
* Create categories for CMS
|
|
||||||
* HISTORY:
|
|
||||||
* 2005/08/19 (cs) changed the mime type get from the _FILE to mime get fkt
|
|
||||||
*********************************************************************/
|
|
||||||
|
|
||||||
// DEBUG vars here
|
|
||||||
$DEBUG_ALL = 1;
|
|
||||||
$DB_DEBUG = 1;
|
|
||||||
$DEBUG_TMPL = 1;
|
|
||||||
|
|
||||||
//------------------------------ header
|
|
||||||
require("header.inc");
|
|
||||||
$MASTER_TEMPLATE_NAME = 'cms_popup.tpl';
|
|
||||||
$TEMPLATE_NAME = 'cms_files.tpl';
|
|
||||||
$PAGE_WIDTH = 750;
|
|
||||||
require("set_paths.inc");
|
|
||||||
//------------------------------ header
|
|
||||||
|
|
||||||
//------------------------------ processing data start
|
|
||||||
$form_name = $_GET['form'];
|
|
||||||
$value_name = $_GET['name'];
|
|
||||||
$data_id = $_GET['id'];
|
|
||||||
$show_type = $_GET['type']; // P (pic), F (flash), V (video), D (document: word), A (document: pdf), B (binary); , separated string
|
|
||||||
|
|
||||||
// default view is list
|
|
||||||
if (!$view && !$data_id) {
|
|
||||||
$view = 'list';
|
|
||||||
} elseif (!$view && $data_id) {
|
|
||||||
$view = 'list';
|
|
||||||
}
|
|
||||||
// default is online
|
|
||||||
if (!isset($online)) {
|
|
||||||
$online = 't';
|
|
||||||
}
|
|
||||||
// if not set, it is a fresh load
|
|
||||||
if (!$show_amount) {
|
|
||||||
$fresh_load = 1;
|
|
||||||
}
|
|
||||||
// the next two are for page view
|
|
||||||
if (!$start_row) {
|
|
||||||
$start_row = 0;
|
|
||||||
}
|
|
||||||
if (!$show_amount) {
|
|
||||||
$show_amount = 12;
|
|
||||||
}
|
|
||||||
if (!$show_type) {
|
|
||||||
$show_type = 'P';
|
|
||||||
}
|
|
||||||
|
|
||||||
// set edit access array
|
|
||||||
$edit_access_ids = array_keys($cms->user_unit);
|
|
||||||
|
|
||||||
// yes no list (online)
|
|
||||||
$yesno_list['f'] = 'No';
|
|
||||||
$yesno_list['t'] = 'Yes';
|
|
||||||
// order list
|
|
||||||
$sort_order_list['date_created'] = 'ID / Insert time'; // default
|
|
||||||
$sort_order_list['file_name'] = 'File Name';
|
|
||||||
$sort_order_list['file_size'] = 'File Size';
|
|
||||||
$sort_order_list['mime_type'] = 'Mime Type';
|
|
||||||
$sort_order_list['name_en'] = 'Alt Name English';
|
|
||||||
$sort_order_list['name_ja'] = 'Alt Name Japanese';
|
|
||||||
$sort_order_list['date_updated'] = 'Updated';
|
|
||||||
if (!$sort_order) {
|
|
||||||
$sort_order = 'date_created';
|
|
||||||
}
|
|
||||||
$sort_direction_list['ASC'] = 'Normal';
|
|
||||||
$sort_direction_list['DESC'] = 'Reverse';
|
|
||||||
if (!$sort_direction) {
|
|
||||||
$sort_direction = 'ASC';
|
|
||||||
}
|
|
||||||
// set if we need to write to any of the set live queues
|
|
||||||
// a) on page save with set_live
|
|
||||||
// b) global page with live_queue
|
|
||||||
// set via QUEUE variable
|
|
||||||
|
|
||||||
// create 0 entries for: templates, menu, data_group?
|
|
||||||
if ($cms->action == 'new' && $cms->action_yes == 'true') {
|
|
||||||
unset($file_uid);
|
|
||||||
unset($file_id);
|
|
||||||
unset($file_type);
|
|
||||||
$new_okay = 1;
|
|
||||||
}
|
|
||||||
// file type: P picture, M mouse over picutre, F flash, V video, B binary
|
|
||||||
if ($cms->action == 'save') {
|
|
||||||
if (!$file_type) {
|
|
||||||
$file_type = 'B';
|
|
||||||
}
|
|
||||||
$file_ok = false;
|
|
||||||
if (!$_FILES['file_up']['name'] && !$file_uid) {
|
|
||||||
$cms->messages[] = array('msg' => 'No file name given', 'class' => 'error');
|
|
||||||
$error = 1;
|
|
||||||
}
|
|
||||||
if (!$_FILES['file_up']['name'] && $file_uid) {
|
|
||||||
$file_ok = true;
|
|
||||||
}
|
|
||||||
// echo "FILE TYPE: ".$_FILES['file_up']['type']."<br>";
|
|
||||||
foreach (split(',', $show_type) as $_show_type) {
|
|
||||||
// check if the uploaded filename matches to the given type
|
|
||||||
if ($_FILES['file_up']['name'] && preg_match("/jpeg|png|gif/", $_FILES['file_up']['type']) && preg_match("/P/", $show_type)) {
|
|
||||||
$file_ok = true;
|
|
||||||
}
|
|
||||||
if ($_FILES['file_up']['name'] && preg_match("/swf/", $_FILES['file_up']['type']) && preg_match("/F/", $show_type)) {
|
|
||||||
$file_ok = true;
|
|
||||||
}
|
|
||||||
if ($_FILES['file_up']['name'] && preg_match("/video/", $_FILES['file_up']['type']) && preg_match("/V/", $show_type)) {
|
|
||||||
$file_ok = true;
|
|
||||||
}
|
|
||||||
if ($_FILES['file_up']['name'] && preg_match("/msword|vnd.oasis.opendocument.text/", $_FILES['file_up']['type']) && preg_match("/D/", $show_type)) {
|
|
||||||
$file_ok = true;
|
|
||||||
}
|
|
||||||
if ($_FILES['file_up']['name'] && preg_match("/pdf/", $_FILES['file_up']['type']) && preg_match("/A/", $show_type)) {
|
|
||||||
$file_ok = true;
|
|
||||||
}
|
|
||||||
if ($_FILES['file_up']['name'] && preg_match("/B/", $show_type)) {
|
|
||||||
$file_ok = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// write out error messages according to show type
|
|
||||||
if (!$file_ok) {
|
|
||||||
if (preg_match("/P/", $show_type)) {
|
|
||||||
$cms->messages[] = array('msg' => 'File is not a JPEG/PNG/GIF file', 'class' => 'error');
|
|
||||||
$error = 1;
|
|
||||||
}
|
|
||||||
if (preg_match("/F/", $show_type)) {
|
|
||||||
$cms->messages[] = array('msg' => 'File is not a Flash File', 'class' => 'error');
|
|
||||||
$error = 1;
|
|
||||||
}
|
|
||||||
if (preg_match("/V/", $show_type)) {
|
|
||||||
$cms->messages[] = array('msg' => 'File is not a Video', 'class' => 'error');
|
|
||||||
$error = 1;
|
|
||||||
}
|
|
||||||
if (preg_match("/D/", $show_type)) {
|
|
||||||
$cms->messages[] = array('msg' => 'File is not a DOC/ODT file', 'class' => 'error');
|
|
||||||
$error = 1;
|
|
||||||
}
|
|
||||||
if (preg_match("/A/", $show_type)) {
|
|
||||||
$cms->messages[] = array('msg' => 'File is not a PDF file', 'class' => 'error');
|
|
||||||
$error = 1;
|
|
||||||
}
|
|
||||||
if (preg_match("/B/", $show_type)) {
|
|
||||||
$cms->messages[] = array('msg' => 'No valid file was given', 'class' => 'error');
|
|
||||||
$error = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// binary: all okay
|
|
||||||
// if no error, save data
|
|
||||||
if (!$error) {
|
|
||||||
if ($_FILES['file_up']['name']) {
|
|
||||||
$mime_type = $_FILES['file_up']['type'];
|
|
||||||
$file_size = $_FILES['file_up']['size'];
|
|
||||||
$file_name = $_FILES['file_up']['name'];
|
|
||||||
// get picture size
|
|
||||||
list($width, $height) = getimagesize($_FILES['file_up']['tmp_name']);
|
|
||||||
$cms->debug('upload', "Width: $width X Height: $height");
|
|
||||||
// set the file type and the target folder
|
|
||||||
if (preg_match("/jpeg|png|gif/", $mime_type)) {
|
|
||||||
$file_type = 'P';
|
|
||||||
} elseif (preg_match("/swf/", $mime_type)) {
|
|
||||||
$file_type = 'F';
|
|
||||||
} elseif (preg_match("/video/", $mime_type)) {
|
|
||||||
$file_type = 'V';
|
|
||||||
} elseif (preg_match("/msword|vnd.oasis.opendocument.text/", $mime_type)) {
|
|
||||||
$file_type = 'D';
|
|
||||||
} elseif (preg_match("/pdf/", $mime_type)) {
|
|
||||||
$file_type = 'A';
|
|
||||||
} elseif ($mime_type) {
|
|
||||||
$file_type = 'B';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// if we have an id -> updated
|
|
||||||
if ($file_uid) {
|
|
||||||
$q = "UPDATE file SET";
|
|
||||||
$q_set = " name_en = '".addslashes($name_en)."', name_ja = '".addslashes($name_ja)."', file_name = '".addslashes($file_name)."', online = '".$online."' ";
|
|
||||||
if ($_FILES['file_up']['name']) {
|
|
||||||
$q_set .= ", type = '".$file_type."', mime_type = '$mime_type', file_size = $file_size, size_x = $width, size_y = $height ";
|
|
||||||
}
|
|
||||||
$q .= $q_set."WHERE file_uid = '".$file_uid."'";
|
|
||||||
$cms->db_exec($q);
|
|
||||||
if (QUEUE == 'live_queue') {
|
|
||||||
$sql_action = 'UPDATE';
|
|
||||||
$sql_data = $q_set;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// insert new data
|
|
||||||
$file_uid = md5(uniqid(rand(), true));
|
|
||||||
$q = "INSERT INTO file (name_en, name_ja, file_name, online, mime_type, file_size, size_x, size_y, file_uid, type) VALUES (";
|
|
||||||
$q .= "'".addslashes($name_en)."', '".addslashes($name_ja)."', '".addslashes($file_name)."', '".$online."', '".$mime_type."', ";
|
|
||||||
$q .= "$file_size, ".(($width) ? $width : 'NULL').", ".(($height) ? $height : 'NULL').", '".$file_uid."', '".$file_type."')";
|
|
||||||
$cms->db_exec($q);
|
|
||||||
$file_id = $cms->insert_id;
|
|
||||||
// if queue
|
|
||||||
if (QUEUE == 'live_queue') {
|
|
||||||
$sql_data = $q;
|
|
||||||
$sql_action = 'INSERT';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$size_x = $width;
|
|
||||||
$size_y = $height;
|
|
||||||
$file = DEV_SCHEMA."_".$file_uid;
|
|
||||||
// now upload the file
|
|
||||||
if ($_FILES['file_up']['name']) {
|
|
||||||
$upload_file = BASE.MEDIA.$cms->data_path[$file_type].$file;
|
|
||||||
// wipe out any old tmp data for this new upload
|
|
||||||
if (is_array(glob(BASE.TMP."thumb_".$file."*"))) {
|
|
||||||
foreach (glob(BASE.TMP."thumb_".$file."*") as $filename) {
|
|
||||||
@unlink($filename);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
# copy file to correct path
|
|
||||||
$error = move_uploaded_file($_FILES['file_up']['tmp_name'], $upload_file);
|
|
||||||
|
|
||||||
$cms->debug('file_upload', "UP: $upload_file");
|
|
||||||
$cms->debug('file_upload', "Orig: ".$cms->printAr($_FILES['file_up']));
|
|
||||||
|
|
||||||
// because I get bogus error info from move_uploaded_file ...
|
|
||||||
$error = 0;
|
|
||||||
if ($error) {
|
|
||||||
$cms->debug('file_upload', "ERROR: $error | INI FSize: ".ini_get("upload_max_filesize"));
|
|
||||||
$cms->messages[] = array('msg' => 'File upload failed', 'class' => 'error');
|
|
||||||
$q = "DELETE FROM file WHERE file_uid = '".$file_uid."'";
|
|
||||||
$cms->db_exec($q);
|
|
||||||
unset($file_id);
|
|
||||||
unset($file_uid);
|
|
||||||
$view = 'list';
|
|
||||||
} else {
|
|
||||||
$cms->messages[] = array('msg' => 'File upload successful', 'class' => 'warning');
|
|
||||||
// $view = 'list';
|
|
||||||
}
|
|
||||||
} // if file upload
|
|
||||||
// create thumbs + file size
|
|
||||||
$picture = $cms->cache_pictures.$cms->adbCreateThumbnail($file, 400, 280, $file_type, '', $cms->cache_pictures_root);
|
|
||||||
$picture_small = $cms->cache_pictures.$cms->adbCreateThumbnail($file, 80, 60, $file_type, '', $cms->cache_pictures_root);
|
|
||||||
$file_size = $cms->adbByteStringFormat($file_size);
|
|
||||||
// for live queue this is here needed
|
|
||||||
if (QUEUE == 'live_queue') {
|
|
||||||
$q = "INSERT INTO ".GLOBAL_DB_SCHEMA.".live_queue (queue_key, key_value, key_name, type, target, data, group_key, action";
|
|
||||||
if ($_FILES['file_up']['name']) {
|
|
||||||
$q .= ", file";
|
|
||||||
}
|
|
||||||
$q .= ") VALUES ('".$cms->queue_name."', '".$file_uid."', 'file_uid', '".$sql_action."', 'file', '".$cms->db_escape_string($sql_data)."', '".$cms->queue_key."', '".$cms->action."'";
|
|
||||||
if ($_FILES['file_up']['name']) {
|
|
||||||
$q .= ", '".BASE.MEDIA.$cms->data_path[$file_type].$file."#".BASE.MEDIA.$cms->data_path[$file_type].PUBLIC_SCHEMA."_".$file_uid."'";
|
|
||||||
}
|
|
||||||
$q .= ")";
|
|
||||||
$cms->db_exec($q);
|
|
||||||
}
|
|
||||||
} // if not error
|
|
||||||
}
|
|
||||||
if ($cms->action == 'delete' && $cms->action_yes == 'true') {
|
|
||||||
$file_uid = $cms->action_id;
|
|
||||||
$q = "SELECT type FROM file WHERE file_uid = '".$file_uid."'";
|
|
||||||
list ($file_type) = $cms->db_return_row($q);
|
|
||||||
// get the file type for the file path
|
|
||||||
$q = "DELETE FROM file WHERE file_uid = '".$file_uid."'";
|
|
||||||
$cms->db_exec($q);
|
|
||||||
if (QUEUE == 'set_live') {
|
|
||||||
$q = "INSERT INTO ".GLOBAL_DB_SCHEMA.".set_live (table_name, pkid, delete_flag) VALUES ('".$cms->page_name."', ".$file_uid.", 't')";
|
|
||||||
$cms->db_exec($q);
|
|
||||||
}
|
|
||||||
if (QUEUE == 'live_queue') {
|
|
||||||
$q = "INSERT INTO ".GLOBAL_DB_SCHEMA.".live_queue (queue_key, key_value, key_name, type, target, data, group_key, action, file) VALUES (";
|
|
||||||
$q .= "'".$cms->queue_name."', '".$file_uid."', 'file_uid', 'DELETE', 'file', '', '".$cms->queue_key."', '".$cms->action."', '".
|
|
||||||
$q .= BASE.MEDIA.$cms->data_path[$file_type].PUBLIC_SCHEMA."_".$file_uid."')";
|
|
||||||
}
|
|
||||||
@unlink(BASE.MEDIA.$cms->data_path[$file_type].DEV_SCHEMA."_".$file_uid);
|
|
||||||
// wipe out any old cache data for this new upload
|
|
||||||
if (is_array(glob($cms->cache_pictures."thumb_".TEST_SCHEMA."_".$file_uid."*"))) {
|
|
||||||
foreach (glob($cms->cache_pictures."thumb_".TEST_SCHEMA."_".$file_uid."*") as $filename) {
|
|
||||||
@unlink($filename);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
unset($file_uid);
|
|
||||||
unset($file_id);
|
|
||||||
$delete_done = 1;
|
|
||||||
$view = 'list';
|
|
||||||
}
|
|
||||||
if ($cms->action == 'load') {
|
|
||||||
$file_uid = $cms->action_id;
|
|
||||||
// load the data
|
|
||||||
$q = "SELECT file_id, name_en, name_ja, file_name, online, mime_type, file_size, size_x, size_y, type FROM file WHERE file_uid = '".$file_uid."'";
|
|
||||||
list($file_id, $name_en, $name_ja, $file_name, $online, $mime_type, $file_size, $size_x, $size_y, $file_type) = $cms->db_return_row($q);
|
|
||||||
// create thumbnail for edit view
|
|
||||||
$file = DEV_SCHEMA."_".$file_uid;
|
|
||||||
// thumbnails are only valid for pictures
|
|
||||||
$picture = $cms->cache_pictures.$cms->adbCreateThumbnail($file, 400, 280, $file_type, '', $cms->cache_pictures_root);
|
|
||||||
$picture_small = $cms->cache_pictures.$cms->adbCreateThumbnail($file, 80, 60, $file_type, '', $cms->cache_pictures_root);
|
|
||||||
$file_size = $cms->adbByteStringFormat($file_size);
|
|
||||||
// view to edit
|
|
||||||
$view = 'edit';
|
|
||||||
}
|
|
||||||
if ($cms->action == 'add_new') {
|
|
||||||
$view = 'edit';
|
|
||||||
}
|
|
||||||
if ($cms->action == 'view_files' && $cms->action_yes == 'true') {
|
|
||||||
$view = 'list';
|
|
||||||
}
|
|
||||||
// set delete live
|
|
||||||
if ($cms->action_flag == 'set_live' && $cms->action = 'set_delete') {
|
|
||||||
$q = "SELECT file_uid, pkid, type FROM ".LOGIN_DB_SCHEMA.".set_live sl, file f WHERE sl.pkid = f.file_uid table_name = '".$cms->page_name."' AND delete_flag = 't'";
|
|
||||||
while ($res = $cms->db_return($q)) {
|
|
||||||
$q_del = "DELETE FROM ".PUBLIC_SCHEMA.".file WHERE file_uid = '".$res['pkid'].'"';
|
|
||||||
$cms->db_exec($q_del);
|
|
||||||
@unlink(BASE.MEDIA.$cms->data_path[$res['type']].PUBLIC_SCHEMA."_".$res['file_uid']);
|
|
||||||
// wipe out any old cache data for this new upload
|
|
||||||
if (is_array(glob($cms->cache_pictures."thumb_".LIVE_SCHEMA."_".$file_uid."*"))) {
|
|
||||||
foreach (glob($cms->cache_pictures."thumb_".LIVE_SCHEMA."_".$file_uid."*") as $filename) {
|
|
||||||
@unlink($filename);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$q = "DELETE FROM ".LOGIN_DB_SCHEMA.".set_live WHERE table_name = '".$cms->page_name."' AND delete_flag = 't'";
|
|
||||||
$cms->db_exec($q);
|
|
||||||
}
|
|
||||||
if (DEV_SCHEMA != PUBLIC_SCHEMA) {
|
|
||||||
// read out possible deleted, to add "delete from live"
|
|
||||||
$q = "SELECT pkid FROM ".LOGIN_DB_SCHEMA.".set_live WHERE table_name = '".$cms->page_name."' AND delete_flag = 't'";
|
|
||||||
if ($cms->access_rights['base_acl'] < 90) {
|
|
||||||
$q .= "AND edit_access_id IN (".join(',', $edit_access_ids).") ";
|
|
||||||
}
|
|
||||||
while ($res = $cms->db_return($q, 3)) {
|
|
||||||
$cms->DATA['set_delete'][]['pkid'] = $res['pkid'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// get th max entries
|
|
||||||
$q = "SELECT COUNT(file_uid) FROM file ";
|
|
||||||
$q_search_where = "WHERE ";
|
|
||||||
// only for current edit_access id, unless it is an admin user, then he can see all of them
|
|
||||||
if ($cms->access_rights['base_acl'] < 90) {
|
|
||||||
$q_search_where .= "edit_access_id IN (".join(',', $edit_access_ids).") AND ";
|
|
||||||
}
|
|
||||||
$q_search_where .= "type in ('".str_replace(',', "','", $show_type)."') ";
|
|
||||||
if ($search_what) {
|
|
||||||
$q_search_where .= "AND LOWER(name_en) LIKE '%".addslashes(strtolower($search_what))."%' OR name_ja LIKE '%".addslashes($search_what)."%' OR LOWER(file_name) LIKE '%".addslashes(strtolower($search_what))."%' ";
|
|
||||||
}
|
|
||||||
$q .= $q_search_where;
|
|
||||||
// get selection from show_type
|
|
||||||
list ($file_count) = $cms->db_return_row($q);
|
|
||||||
|
|
||||||
if ($cms->action == 'browse') {
|
|
||||||
// browse in the list of data
|
|
||||||
switch ($cms->action_id) {
|
|
||||||
case "<<<<":
|
|
||||||
$start_row = 0;
|
|
||||||
break;
|
|
||||||
case "<":
|
|
||||||
$start_row -= $show_amount;
|
|
||||||
break;
|
|
||||||
case ">":
|
|
||||||
$start_row += $show_amount;
|
|
||||||
break;
|
|
||||||
case ">>>>":
|
|
||||||
$start_row = $file_count - $show_amount;
|
|
||||||
break;
|
|
||||||
case "gopage":
|
|
||||||
// for page is page -1, so page 1 start from 0, etc
|
|
||||||
$start_row = ((($cms->action_value - 1) > 0) ? ($cms->action_value - 1) * $show_amount : 0);
|
|
||||||
$current_page = $cms->action_value;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// check overflow
|
|
||||||
if ($start_row < 0) {
|
|
||||||
$start_row = 0;
|
|
||||||
}
|
|
||||||
if ($start_row > $file_count) {
|
|
||||||
$start_row = $file_count - $show_amount;
|
|
||||||
}
|
|
||||||
|
|
||||||
// if we have a "fresh_load"
|
|
||||||
if ($fresh_load) {
|
|
||||||
$count = 1;
|
|
||||||
$q = "SELECT file_uid FROM file ";
|
|
||||||
if ($q_search_where) {
|
|
||||||
$q .= $q_search_where;
|
|
||||||
}
|
|
||||||
$q .= "ORDER BY ".$sort_order." ".$sort_direction." ";
|
|
||||||
while ($res = $cms->db_return($q)) {
|
|
||||||
// if data_id is set and not file_id, go to the page where the current highlight is, but only if this is a "virgin" load of the page
|
|
||||||
if ($data_id && ($data_id == $res['file_uid'])) {
|
|
||||||
$current_page = floor(($count / $show_amount));
|
|
||||||
$start_row = $current_page * $show_amount;
|
|
||||||
$current_page ++;
|
|
||||||
}
|
|
||||||
$count ++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// page forward/back buttons settings
|
|
||||||
if ($start_row > 0) {
|
|
||||||
$cms->DATA['show_back'] = 1;
|
|
||||||
}
|
|
||||||
$cms->DATA['page_number'] = ceil($start_row / $show_amount) + 1;
|
|
||||||
$cms->DATA['page_count'] = ceil($file_count / $show_amount);
|
|
||||||
if ($cms->DATA['page_count'] > 2 && !$current_page) {
|
|
||||||
$current_page = 1;
|
|
||||||
}
|
|
||||||
if (($start_row + $show_amount) < $file_count) {
|
|
||||||
$cms->DATA['show_forward'] = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
$q = "SELECT file_id, name_en, name_ja, file_name, online, mime_type, file_size, size_x, size_y, file_uid, type FROM file ";
|
|
||||||
// if search what, search in name_en, name_ja, file_name for the string
|
|
||||||
if ($q_search_where) {
|
|
||||||
$q .= $q_search_where;
|
|
||||||
}
|
|
||||||
$q .= "ORDER BY ".$sort_order." ".$sort_direction." ";
|
|
||||||
$q .= "LIMIT ".$show_amount." OFFSET ".$start_row;
|
|
||||||
while ($res = $cms->db_return($q)) {
|
|
||||||
$data_files[] = array (
|
|
||||||
'id' => $res['file_id'],
|
|
||||||
'name_en' => $res['name_en'],
|
|
||||||
'name_ja' => $res['name_ja'],
|
|
||||||
'file_name' => $res['file_name'],
|
|
||||||
'online' => $res['online'],
|
|
||||||
'mime_type' => $res['mime_type'],
|
|
||||||
'file_size' => $cms->adbByteStringFormat($res['file_size']),
|
|
||||||
'size_x' => $res['size_x'],
|
|
||||||
'size_y' => $res['size_y'],
|
|
||||||
'file_uid' => $res['file_uid'],
|
|
||||||
'file_type' => $res['type'],
|
|
||||||
'picture' => $cms->cache_pictures.$cms->adbCreateThumbnail(DEV_SCHEMA.'_'.$res['file_uid'], 80, 60, $res['type'], '', $cms->cache_pictures_root)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
$cms->DATA['show_type'] = $show_type;
|
|
||||||
$cms->DATA['data_files'] = $data_files;
|
|
||||||
$cms->DATA['view'] = $view;
|
|
||||||
$cms->DATA['images_path'] = MEDIA.$cms->data_path[$file_type];
|
|
||||||
// get vars for position (only when)
|
|
||||||
$cms->DATA['form_name'] = $form_name;
|
|
||||||
$cms->DATA['value_name'] = $value_name;
|
|
||||||
$cms->DATA['file_id'] = $file_id;
|
|
||||||
$cms->DATA['file_uid'] = $file_uid;
|
|
||||||
|
|
||||||
// write back all the other vars
|
|
||||||
if (!($delete_done || $new_okay)) {
|
|
||||||
// data name
|
|
||||||
$cms->DATA['file_name'] = $file_name;
|
|
||||||
$cms->DATA['name_en'] = $name_en;
|
|
||||||
$cms->DATA['name_ja'] = $name_ja;
|
|
||||||
$cms->DATA['mime_type'] = $mime_type;
|
|
||||||
$cms->DATA['file_size'] = $file_size;
|
|
||||||
$cms->DATA['size_x'] = $size_x;
|
|
||||||
$cms->DATA['size_y'] = $size_y;
|
|
||||||
$cms->DATA['online'] = $online;
|
|
||||||
$cms->DATA['picture'] = $picture;
|
|
||||||
$cms->DATA['picture_small'] = $picture_small;
|
|
||||||
$cms->DATA['file_type'] = $file_type;
|
|
||||||
}
|
|
||||||
$cms->DATA['sort_order_list'] = $sort_order_list;
|
|
||||||
$cms->DATA['sort_order'] = $sort_order;
|
|
||||||
$cms->DATA['sort_direction_list'] = $sort_direction_list;
|
|
||||||
$cms->DATA['sort_direction'] = $sort_direction;
|
|
||||||
$cms->DATA['search_what'] = $search_what;
|
|
||||||
$cms->DATA['current_page'] = $current_page;
|
|
||||||
$cms->DATA['yesno_list'] = $yesno_list;
|
|
||||||
$cms->DATA['start_row'] = $start_row;
|
|
||||||
$cms->DATA['show_amount'] = $show_amount;
|
|
||||||
if ($data_id) {
|
|
||||||
$cms->DATA['data_id'] = $data_id;
|
|
||||||
}
|
|
||||||
$cms->DATA['top'] = 0;
|
|
||||||
$cms->DATA['left'] = 0;
|
|
||||||
|
|
||||||
//------------------------------ processing data end
|
|
||||||
|
|
||||||
//------------------------------ smarty start
|
|
||||||
require("smarty.inc");
|
|
||||||
//------------------------------ smarty end
|
|
||||||
|
|
||||||
//------------------------------ footer
|
|
||||||
require("footer.inc");
|
|
||||||
//------------------------------ footer
|
|
||||||
@@ -1,51 +0,0 @@
|
|||||||
<?
|
|
||||||
/********************************************************************
|
|
||||||
* AUTHOR: Clemens Schwaighofer
|
|
||||||
* CREATED: 2005/07/19
|
|
||||||
* SHORT DESCRIPTION:
|
|
||||||
* preset date variables
|
|
||||||
* HISTORY:
|
|
||||||
*********************************************************************/
|
|
||||||
|
|
||||||
$day_short[1] = "Mon";
|
|
||||||
$day_short[2] = "Tue";
|
|
||||||
$day_short[3] = "Wed";
|
|
||||||
$day_short[4] = "Thu";
|
|
||||||
$day_short[5] = "Fri";
|
|
||||||
$day_short[6] = "Sat";
|
|
||||||
$day_short[7] = "Sun";
|
|
||||||
|
|
||||||
$day_long[1] = "Monday";
|
|
||||||
$day_long[2] = "Tuesday";
|
|
||||||
$day_long[3] = "Wednesday";
|
|
||||||
$day_long[4] = "Thursday";
|
|
||||||
$day_long[5] = "Friday";
|
|
||||||
$day_long[6] = "Saturday";
|
|
||||||
$day_long[7] = "Sunday";
|
|
||||||
|
|
||||||
// monate
|
|
||||||
$month_long[1] = "January";
|
|
||||||
$month_long[2] = "February";
|
|
||||||
$month_long[3] = "March";
|
|
||||||
$month_long[4] = "April";
|
|
||||||
$month_long[5] = "May";
|
|
||||||
$month_long[6] = "June";
|
|
||||||
$month_long[7] = "July";
|
|
||||||
$month_long[8] = "August";
|
|
||||||
$month_long[9] = "September";
|
|
||||||
$month_long[10] = "October";
|
|
||||||
$month_long[11] = "November";
|
|
||||||
$month_long[12] = "December";
|
|
||||||
|
|
||||||
$month_short[1] = "Jan";
|
|
||||||
$month_short[2] = "Feb";
|
|
||||||
$month_short[3] = "Mar";
|
|
||||||
$month_short[4] = "Apr";
|
|
||||||
$month_short[5] = "May";
|
|
||||||
$month_short[6] = "Jun";
|
|
||||||
$month_short[7] = "Jul";
|
|
||||||
$month_short[8] = "Aug";
|
|
||||||
$month_short[9] = "Sep";
|
|
||||||
$month_short[10] = "Oct";
|
|
||||||
$month_short[11] = "Nov";
|
|
||||||
$month_short[12] = "Dec";
|
|
||||||
17
www/admin/l10n_test.php
Executable file
17
www/admin/l10n_test.php
Executable file
@@ -0,0 +1,17 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
// debug for L10n issues in php 7.3
|
||||||
|
|
||||||
|
// namespace test
|
||||||
|
ob_start();
|
||||||
|
|
||||||
|
$lang = 'en_utf8';
|
||||||
|
|
||||||
|
// admin class tests
|
||||||
|
require 'config.php';
|
||||||
|
$l = new CoreLibs\Language\L10n($lang);
|
||||||
|
|
||||||
|
echo "OK<br>";
|
||||||
|
|
||||||
|
ob_end_flush();
|
||||||
|
// __END__
|
||||||
@@ -11,7 +11,7 @@ $DB_DEBUG = 1;
|
|||||||
ob_start();
|
ob_start();
|
||||||
|
|
||||||
// admin class tests
|
// admin class tests
|
||||||
require 'config.inc' ;
|
require 'config.php';
|
||||||
DEFINE('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
DEFINE('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
||||||
|
|
||||||
echo "DIR: ".DIR."<br>ROOT: ".ROOT."<br>BASE: ".BASE."<br>";
|
echo "DIR: ".DIR."<br>ROOT: ".ROOT."<br>BASE: ".BASE."<br>";
|
||||||
|
|||||||
46
www/admin/qq_file_upload_ajax.php
Executable file
46
www/admin/qq_file_upload_ajax.php
Executable file
@@ -0,0 +1,46 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$DEBUG_ALL = 1;
|
||||||
|
$ECHO_ALL = 0;
|
||||||
|
$PRINT_ALL = 1;
|
||||||
|
|
||||||
|
// load the Basic && qq file uploader here
|
||||||
|
require 'config.php';
|
||||||
|
// class load
|
||||||
|
$base = new CoreLibs\Basic();
|
||||||
|
$base->debug('AJAX UPLOAD', 'START Backend');
|
||||||
|
// set max upload size
|
||||||
|
$MAX_UPLOAD_SIZE = $base->StringByteFormat(ini_get('upload_max_filesize'));
|
||||||
|
|
||||||
|
// test for qqFileUploader (AJAX side)
|
||||||
|
$allowedExtensions = array ('csv', 'zip', 'jpg', 'pdf', 'bz2');
|
||||||
|
$sizeLimit = $MAX_UPLOAD_SIZE; // as set in php ini
|
||||||
|
$base->debug('AJAX UPLOAD', 'Size: '.$sizeLimit.', Memory Limit: '.ini_get('memory_limit'));
|
||||||
|
$uploader = new CoreLibs\Upload\qqFileUploader($allowedExtensions, $sizeLimit);
|
||||||
|
// either in post or get
|
||||||
|
$_action= $_POST['action'] ? $_POST['action'] : $_GET['action'];
|
||||||
|
$_task_uid = $_POST['task_uid'] ? $_POST['task_uid'] : $_GET['task_uid'];
|
||||||
|
$get_post['start'] = microtime(true);
|
||||||
|
$base->debug('AJAX UPLOAD', 'Action: '.$_action.', Task UID: '.$_task_uid.' => '.$base->dateStringFormat($get_post['start']));
|
||||||
|
|
||||||
|
$upload_path = ROOT.MEDIA.UPLOADS;
|
||||||
|
$get_post['result'] = $uploader->handleUpload($upload_path, false);
|
||||||
|
$base->debug('AJAX UPLOAD', 'Memory peak: '.$base->ByteStringFormat(memory_get_usage()).' | '.$base->ByteStringFormat(memory_get_peak_usage()));
|
||||||
|
|
||||||
|
// set file name
|
||||||
|
$get_post['filename'] = $uploader->uploadFileName;
|
||||||
|
$get_post['type'] = $uploader->uploadFileExt;
|
||||||
|
$get_post['filesize'] = filesize($uploader->uploadFileName);
|
||||||
|
$get_post['filesize_formated'] = $base->ByteStringFormat($get_post['filesize']);
|
||||||
|
$get_post['end'] = microtime(true);
|
||||||
|
$get_post['time'] = $get_post['end'] - $get_post['start'];
|
||||||
|
|
||||||
|
$base->debug('AJAX RESULT', $base->printAr($get_post));
|
||||||
|
// return data
|
||||||
|
$output = htmlspecialchars(json_encode($get_post), ENT_NOQUOTES);
|
||||||
|
// $base->debug('AJAX JSON', $output);
|
||||||
|
print $output;
|
||||||
|
|
||||||
|
$base->printErrorMsg();
|
||||||
|
|
||||||
|
// __END__
|
||||||
225
www/admin/qq_file_upload_front.php
Executable file
225
www/admin/qq_file_upload_front.php
Executable file
@@ -0,0 +1,225 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$DEBUG_ALL = 1;
|
||||||
|
$ECHO_ALL = 0;
|
||||||
|
$PRINT_ALL = 1;
|
||||||
|
|
||||||
|
// test file for qqFileUploader (HTML side)
|
||||||
|
// load the Basic class here
|
||||||
|
require 'config.php';
|
||||||
|
$base = new CoreLibs\Basic();
|
||||||
|
// set max upload size
|
||||||
|
$MAX_UPLOAD_SIZE = $base->StringByteFormat(ini_get('upload_max_filesize'));
|
||||||
|
$base->debug('UPLOADED FRONT', 'With max size: '.$MAX_UPLOAD_SIZE);
|
||||||
|
|
||||||
|
// very basic template output with super basic div for two file upload
|
||||||
|
?>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>File upload AJAX</title>
|
||||||
|
<link rel="stylesheet" href="https://www.w3schools.com/w3css/4/w3.css">
|
||||||
|
<style type="text/css">
|
||||||
|
.normal {
|
||||||
|
width: 25%;
|
||||||
|
}
|
||||||
|
.flx-s {
|
||||||
|
align-content: stretch;
|
||||||
|
display: flex;
|
||||||
|
flex: 1 100%;
|
||||||
|
}
|
||||||
|
.uploadError {
|
||||||
|
font-weight: bold;
|
||||||
|
color: red;
|
||||||
|
}
|
||||||
|
.uploadCancel {
|
||||||
|
font-weight: bold;
|
||||||
|
color: orange;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-file-upload-button {
|
||||||
|
border: 1px solid #999999;
|
||||||
|
border-radius: 2px 2px 2px 2px;
|
||||||
|
box-shadow: 0 10px rgba(255, 255, 255, 0.3) inset, 0 10px rgba(255, 255, 255, 0.2) inset, 0 10px 2px rgba(255, 255, 255, 0.25) inset, 0 -1px 2px rgba(0, 0, 0, 0.3) inset;
|
||||||
|
text-align: center;
|
||||||
|
padding: 3px 5px 3px;
|
||||||
|
background-color: #cacaca;
|
||||||
|
margin: 2px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-file-upload-button:hover {
|
||||||
|
box-shadow: 0 10px 2px rgba(107, 107, 107, 0.2) inset, 0 12px rgba(107, 107, 107, 0.05) inset, 0 12px 2px rgba(107, 107, 107, 0.1) inset, 0 -1px 2px rgba(255, 255, 255, 0.3) inset;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-file-upload-button:active {
|
||||||
|
border: 1px solid red;
|
||||||
|
background-color: rgba(80, 80, 80, 0.5);
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-upload-cancel {
|
||||||
|
border: 1px solid red;
|
||||||
|
border-radius: 2px;
|
||||||
|
text-align: center;
|
||||||
|
padding: 3px 5px 3px;
|
||||||
|
background-color: #eb652d;
|
||||||
|
margin: 2px;
|
||||||
|
}
|
||||||
|
.qq-upload-cancel:hover {
|
||||||
|
background-color: #eb8686;
|
||||||
|
}
|
||||||
|
.qq-upload-cancel:active {
|
||||||
|
border: 1px solid black;
|
||||||
|
background-color: #eb2d2d;
|
||||||
|
}
|
||||||
|
|
||||||
|
.progressBarOutside {
|
||||||
|
background-color: #f1f1f1;
|
||||||
|
color: black;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.progressBarInside {
|
||||||
|
background-color: #1e9e84;
|
||||||
|
border-radius: 4px;
|
||||||
|
padding: 0.01em;
|
||||||
|
text-align: center;
|
||||||
|
font-size: 0.8em;
|
||||||
|
}
|
||||||
|
|
||||||
|
</style>
|
||||||
|
<script src="layout/default/javascript/prototype.js" type="text/javascript"></script>
|
||||||
|
<script src="layout/default/javascript/file-uploader/fileuploader.js" type="text/javascript"></script>
|
||||||
|
<script type="text/javascript">
|
||||||
|
function formatBytes(bytes)
|
||||||
|
{
|
||||||
|
var i = -1;
|
||||||
|
do {
|
||||||
|
bytes = bytes / 1024;
|
||||||
|
i++;
|
||||||
|
} while (bytes > 99);
|
||||||
|
|
||||||
|
// return Math.max(bytes, 0.1).toFixed(1) + ['kB', 'MB', 'GB', 'TB', 'PB', 'EB'][i];
|
||||||
|
return parseFloat(Math.round(bytes * Math.pow(10, 2)) / Math.pow(10, 2)) + ['kB', 'MB', 'GB', 'TB', 'PB', 'EB'][i];
|
||||||
|
}
|
||||||
|
var MAX_UPLOAD_SIZE = <?=$MAX_UPLOAD_SIZE;?>;
|
||||||
|
// function to add an AJAX uploadeder to the set
|
||||||
|
function createUploaderSin(divName, divNumber) {
|
||||||
|
divID = divName + '_' + divNumber;
|
||||||
|
console.log('Div: %s, Number: %s => ID: %s', divName, divNumber, divID);
|
||||||
|
$(divID + '_Cancel').hide();
|
||||||
|
var uploader = new qq.FileUploaderBasic({
|
||||||
|
// element: document.getElementById(divID),
|
||||||
|
element: $(divID),
|
||||||
|
cancel: $(divID + '_Cancel'),
|
||||||
|
action: 'qq_file_upload_ajax.php',
|
||||||
|
multiple: false,
|
||||||
|
button: $(divID),
|
||||||
|
allowedExtensions: ['csv', 'zip', 'jpg', 'pdf', 'bz2'],
|
||||||
|
sizeLimit: MAX_UPLOAD_SIZE, // size set from php ini
|
||||||
|
name: divID,
|
||||||
|
params: {
|
||||||
|
'file_pos': divNumber, // we need to add here ID or something
|
||||||
|
'action': 'upload',
|
||||||
|
'task_uid': divNumber // -> test for some internal uid
|
||||||
|
},
|
||||||
|
onSubmit: function(id, filename, target) {
|
||||||
|
console.log('File upload: "%s", ID: "%s" => "%s"', filename, id, target);
|
||||||
|
// remove any assigned error classes and flags
|
||||||
|
if ($(target + '_ProgressText').hasClassName('uploadError') || $(target + '_ProgressText').hasClassName('uploadCancel')) {
|
||||||
|
$(target + '_ProgressText').className = '';
|
||||||
|
$(target + '_Error').value = 0;
|
||||||
|
}
|
||||||
|
$(target + '_ProgressText').innerHTML = 'Start uploading file: ' + filename;
|
||||||
|
$(target + '_Cancel').show();
|
||||||
|
// disabled stuff here
|
||||||
|
},
|
||||||
|
onProgress: function(id, filename, loaded, total, target) {
|
||||||
|
console.log('Progress for file: "%s", ID: "%s", loaded: "%s", total: "%s" => "%s"', id, filename, loaded, total, target);
|
||||||
|
var percent = Math.round((loaded / total) * 100);
|
||||||
|
$(target + '_ProgressBar').innerHTML = percent + '%';
|
||||||
|
$(target + '_ProgressBar').style.width = percent + '%';
|
||||||
|
$(target + '_ProgressText').innerHTML = 'Uploading: ' + filename + ', ' + formatBytes(loaded) + '/' + formatBytes(total);
|
||||||
|
},
|
||||||
|
onComplete: function(id, filename, responseJSON, target) {
|
||||||
|
console.log('File upload for file "%s", id "%s" done with status "%s" => "%s", And success: %s', filename, id, responseJSON, target, responseJSON.result.success);
|
||||||
|
if (responseJSON.result.success) {
|
||||||
|
$(target + '_ProgressBar').innerHTML = '100%';
|
||||||
|
$(target + '_ProgressBar').style.width = '100%';
|
||||||
|
$(target + '_ProgressText').innerHTML = 'Uploaded: ' + filename + ' (' + responseJSON.filesize_formated + ')';
|
||||||
|
// also write hidden vars for this (file name, etc)
|
||||||
|
// for that we replace the divName part from the target and get just the pos number ?
|
||||||
|
// $(target + 'Name').value = filename;
|
||||||
|
// $(target + 'NameUpload').value = responseJSON.filename;
|
||||||
|
// $(target + 'Type').value = responseJSON.type;
|
||||||
|
// $(target + 'Size').value = responseJSON.filesize;
|
||||||
|
} else {
|
||||||
|
// set the error class
|
||||||
|
$(target + '_ProgressText').className = 'uploadError';
|
||||||
|
// flag error
|
||||||
|
$(target + '_Error').value = 1;
|
||||||
|
// and write the error
|
||||||
|
$(target + '_ProgressText').innerHTML = 'UPLOAD FAILED FOR FILE: ' + filename;
|
||||||
|
}
|
||||||
|
// renable stuff here
|
||||||
|
$(target + '_Cancel').hide();
|
||||||
|
},
|
||||||
|
onCancel: function (id, filename, target) {
|
||||||
|
// cancel upload
|
||||||
|
console.log('File upload cancled for file "%s", id "%s"', filename, id);
|
||||||
|
// upload cancel
|
||||||
|
$(target + '_ProgressText').className = 'uploadCancel';
|
||||||
|
$(target + '_Error').value = 1;
|
||||||
|
$(target + '_ProgressText').innerHTML = 'UPLOAD CANCELED FOR FILE: ' + filename;
|
||||||
|
$(target + '_Cancel').hide();
|
||||||
|
},
|
||||||
|
/*showMessage: function(message) {
|
||||||
|
console.log('MESSAGE: %s', message);
|
||||||
|
}, */
|
||||||
|
debug: true
|
||||||
|
});
|
||||||
|
// console.log('INIT Nr %s => cnt: %s', divNumber, uploader);
|
||||||
|
return uploader;
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<div id="masterGroup">
|
||||||
|
<div>File upload via AJAX (MAX SIZE: <?=$base->byteStringFormat($MAX_UPLOAD_SIZE);?>)</div>
|
||||||
|
<div class="flx-s">
|
||||||
|
<div id="Uploader_3WD7MAFmjAux_dlvvu13tezNj_XeSO0Ovauli0_MF5tISORiay7" class="normal qq-file-upload-button" style="width: 20%">Upload File</div>
|
||||||
|
<div style="width: 5%">
|
||||||
|
<div id="Uploader_3WD7MAFmjAux_dlvvu13tezNj_XeSO0Ovauli0_MF5tISORiay7_Cancel" class="qq-upload-cancel">X</div>
|
||||||
|
</div>
|
||||||
|
<div style="width: 75%; padding: 5px;">
|
||||||
|
<div id="Uploader_3WD7MAFmjAux_dlvvu13tezNj_XeSO0Ovauli0_MF5tISORiay7_ProgressText"></div>
|
||||||
|
<div class="progressBarOutside">
|
||||||
|
<div class="progressBarInside" id="Uploader_3WD7MAFmjAux_dlvvu13tezNj_XeSO0Ovauli0_MF5tISORiay7_ProgressBar" style="width: 0%">0%</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<input type="hidden" name="Uploader_3WD7MAFmjAux_dlvvu13tezNj_XeSO0Ovauli0_MF5tISORiay7_Error" id="Uploader_3WD7MAFmjAux_dlvvu13tezNj_XeSO0Ovauli0_MF5tISORiay7_Error" value="">
|
||||||
|
</div>
|
||||||
|
<div class="flx-s">
|
||||||
|
<div id="Uploader_3WD7MAFmjAux_dlvvu13tezNj_XeSO0Ovauli0_Ww9iWKrl3Xou" class="normal qq-file-upload-button" style="width: 20%">Upload File</div>
|
||||||
|
<div style="width: 5%">
|
||||||
|
<div id="Uploader_3WD7MAFmjAux_dlvvu13tezNj_XeSO0Ovauli0_Ww9iWKrl3Xou_Cancel" class="qq-upload-cancel">X</div>
|
||||||
|
</div>
|
||||||
|
<div style="width: 75%; padding: 5px;">
|
||||||
|
<div id="Uploader_3WD7MAFmjAux_dlvvu13tezNj_XeSO0Ovauli0_Ww9iWKrl3Xou_ProgressText"></div>
|
||||||
|
<div class="progressBarOutside">
|
||||||
|
<div class="progressBarInside" id="Uploader_3WD7MAFmjAux_dlvvu13tezNj_XeSO0Ovauli0_Ww9iWKrl3Xou_ProgressBar" style="width: 0%">0%</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<input type="hidden" name="Uploader_3WD7MAFmjAux_dlvvu13tezNj_XeSO0Ovauli0_Ww9iWKrl3Xou_Error" id="Uploader_3WD7MAFmjAux_dlvvu13tezNj_XeSO0Ovauli0_Ww9iWKrl3Xou_Error" value="">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
|
<script type="text/javascript">
|
||||||
|
// attach uploader to div areas
|
||||||
|
createUploaderSin('Uploader', '3WD7MAFmjAux_dlvvu13tezNj_XeSO0Ovauli0_MF5tISORiay7');
|
||||||
|
createUploaderSin('Uploader', '3WD7MAFmjAux_dlvvu13tezNj_XeSO0Ovauli0_Ww9iWKrl3Xou');
|
||||||
|
</script>
|
||||||
|
<?php
|
||||||
|
$base->printErrorMsg();
|
||||||
|
|
||||||
|
// __END__
|
||||||
29
www/admin/smarty_test.php
Normal file → Executable file
29
www/admin/smarty_test.php
Normal file → Executable file
@@ -7,14 +7,35 @@ $DB_DEBUG = 1;
|
|||||||
$LOG_PER_RUN = 1;
|
$LOG_PER_RUN = 1;
|
||||||
|
|
||||||
define('USE_DATABASE', true);
|
define('USE_DATABASE', true);
|
||||||
require("header.inc");
|
define('USE_HEADER', true);
|
||||||
|
require 'config.php';
|
||||||
|
require BASE.INCLUDES.'admin_header.inc';
|
||||||
$MASTER_TEMPLATE_NAME = 'main_body.tpl';
|
$MASTER_TEMPLATE_NAME = 'main_body.tpl';
|
||||||
$TEMPLATE_NAME = 'smarty_test.tpl';
|
$TEMPLATE_NAME = 'smarty_test.tpl';
|
||||||
$PAGE_WIDTH = 750;
|
$PAGE_WIDTH = 750;
|
||||||
require("set_paths.inc");
|
require BASE.INCLUDES.'admin_set_paths.inc';
|
||||||
|
|
||||||
// smarty test
|
// smarty test
|
||||||
$cms->DATA['SMARTY_TEST'] = 'Test Data';
|
$cms->DATA['SMARTY_TEST'] = 'Test Data';
|
||||||
|
|
||||||
require("smarty.inc");
|
// drop down test with optgroups
|
||||||
require("footer.inc");
|
$options = array (
|
||||||
|
'' => '選択してください',
|
||||||
|
'4/25(木)' => array (
|
||||||
|
'4/25(木) 11:00-11:50' => '4/25(木) 11:00-11:50',
|
||||||
|
'4/25(木) 12:20-13:00' => '4/25(木) 12:20-13:00'
|
||||||
|
),
|
||||||
|
'4/26(金)' => array (
|
||||||
|
'4/26(金) 11:00-11:50' => '4/26(金) 11:00-11:50',
|
||||||
|
'4/26(金) 12:20-13:00' => '4/26(金) 12:20-13:00'
|
||||||
|
),
|
||||||
|
'4/27(土)' => array (
|
||||||
|
'4/27(土) 11:00-11:50' => '4/27(土) 11:00-11:50',
|
||||||
|
'4/27(土) 12:20-13:00' => '4/27(土) 12:20-13:00'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$cms->DATA['drop_down_test'] = $options;
|
||||||
|
|
||||||
|
require BASE.INCLUDES.'admin_smarty.inc';
|
||||||
|
require BASE.INCLUDES.'admin_footer.inc';
|
||||||
|
|||||||
106
www/admin/various_class_test.php
Executable file
106
www/admin/various_class_test.php
Executable file
@@ -0,0 +1,106 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
$DEBUG_ALL_OVERRIDE = 0; // set to 1 to debug on live/remote server locations
|
||||||
|
$DEBUG_ALL = 1;
|
||||||
|
$PRINT_ALL = 1;
|
||||||
|
$DB_DEBUG = 1;
|
||||||
|
|
||||||
|
// admin class tests
|
||||||
|
// require 'config.inc';
|
||||||
|
require 'config.php';
|
||||||
|
DEFINE('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
||||||
|
$base = new CoreLibs\Basic();
|
||||||
|
|
||||||
|
print "THIS HOST: ".HOST_NAME.", with PROTOCOL: ".HOST_PROTOCOL." is running SSL: ".HOST_SSL."<br>";
|
||||||
|
print "DIR: ".DIR."<br>";
|
||||||
|
print "BASE: ".BASE."<br>";
|
||||||
|
print "ROOT: ".ROOT."<br>";
|
||||||
|
print "HOST: ".$HOST_NAME." => DB HOST: ".$DB_HOST[$HOST_NAME]." => ".MAIN_DB."<br>";
|
||||||
|
|
||||||
|
$text = 'I am some text
|
||||||
|
with some
|
||||||
|
line breaks
|
||||||
|
in there. Theis
|
||||||
|
is sucky';
|
||||||
|
|
||||||
|
print "LB remove: ".$base->removeLB($text)."<br>";
|
||||||
|
print "LB remove: ".$base->removeLB($text, '##BR##')."<br>";
|
||||||
|
|
||||||
|
// $test = array (
|
||||||
|
// 'A' => array (
|
||||||
|
// 'B' => array (),
|
||||||
|
// 'C' => array (
|
||||||
|
// 'D' => array (),
|
||||||
|
// 'E' => array (
|
||||||
|
// 'F' => array ()
|
||||||
|
// )
|
||||||
|
// )
|
||||||
|
// ),
|
||||||
|
// '1' => array (),
|
||||||
|
// '2' => array (),
|
||||||
|
// '3' => array (
|
||||||
|
// 'G' => array ()
|
||||||
|
// )
|
||||||
|
// );
|
||||||
|
|
||||||
|
$base->debug('ARRAY', $base->printAr($test));
|
||||||
|
|
||||||
|
function rec($pre, $cur, $node = array ())
|
||||||
|
{
|
||||||
|
if (!is_array($node)) {
|
||||||
|
$node = array ();
|
||||||
|
}
|
||||||
|
print "<div style='color: green;'>#### PRE: ".$pre.", CUR: ".$cur.", N-c: ".count($node)." [".join('|', array_keys($node))."]</div>";
|
||||||
|
if (!$pre) {
|
||||||
|
print "** <span style='color: red;'>NEW</span><br>";
|
||||||
|
$node[$cur] = array ();
|
||||||
|
} else {
|
||||||
|
if (array_key_exists($pre, $node)) {
|
||||||
|
print "+ <span style='color: orange;'>KEY FOUND:</span> ".$pre.", add: ".$cur."<br>";
|
||||||
|
$node[$pre][$cur] = array ();
|
||||||
|
} else {
|
||||||
|
print "- NOT FOUND: loop<br>";
|
||||||
|
foreach ($node as $_pre => $_cur) {
|
||||||
|
print "> TRY: ".$_pre." => ".count($_cur)." [".join('|', array_keys($_cur))."]<br>";
|
||||||
|
if (count($_cur) > 0) {
|
||||||
|
$node[$_pre] = rec($pre, $cur, $_cur);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $node;
|
||||||
|
}
|
||||||
|
|
||||||
|
function flattenArrayKey(array $array, array $return = array ())
|
||||||
|
{
|
||||||
|
foreach ($array as $key => $sub) {
|
||||||
|
$return[] = $key;
|
||||||
|
if (count($sub) > 0) {
|
||||||
|
$return = flattenArrayKey($sub, $return);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// core
|
||||||
|
$test = rec('', 'A', $test);
|
||||||
|
$test = rec('', '1', $test);
|
||||||
|
$test = rec('', '2', $test);
|
||||||
|
$test = rec('', '3', $test);
|
||||||
|
$test = rec('3', 'G', $test);
|
||||||
|
$test = rec('A', 'B', $test);
|
||||||
|
$test = rec('A', 'C', $test);
|
||||||
|
$test = rec('C', 'D', $test);
|
||||||
|
$test = rec('C', 'E', $test);
|
||||||
|
$test = rec('E', 'F', $test);
|
||||||
|
// new
|
||||||
|
$test = rec('C', 'U', $test);
|
||||||
|
$test = rec('F', 'U', $test);
|
||||||
|
$test = rec('', 'Al', $test);
|
||||||
|
$test = rec('B', 'B1', $test);
|
||||||
|
$base->debug('REC', $base->printAr($test));
|
||||||
|
print "FLATTEN: ".$base->printAr(flattenArrayKey($test))."<br>";
|
||||||
|
|
||||||
|
print $base->printErrorMsg();
|
||||||
|
|
||||||
|
// __END__
|
||||||
BIN
www/composer.phar
Executable file
BIN
www/composer.phar
Executable file
Binary file not shown.
25
www/configs/config.db.inc
Executable file
25
www/configs/config.db.inc
Executable file
@@ -0,0 +1,25 @@
|
|||||||
|
<?php
|
||||||
|
/********************************************************************
|
||||||
|
* AUTHOR: Clemens Schwaighofer
|
||||||
|
* CREATED: 2018/10/11
|
||||||
|
* SHORT DESCRIPTION:
|
||||||
|
* configuration file for database settings
|
||||||
|
* HISTORY:
|
||||||
|
*********************************************************************/
|
||||||
|
|
||||||
|
// please be VERY carefull only to change the right side
|
||||||
|
$DB_CONFIG = array (
|
||||||
|
'test' => array (
|
||||||
|
'db_name' => 'gullevek',
|
||||||
|
'db_user' => 'gullevek',
|
||||||
|
'db_pass' => 'gullevek',
|
||||||
|
'db_host' => 'db.tokyo.tequila.jp',
|
||||||
|
'db_port' => '5432',
|
||||||
|
'db_schema' => 'public',
|
||||||
|
'db_type' => 'pgsql',
|
||||||
|
'db_encoding' => '',
|
||||||
|
'db_ssl' => 'disable' // allow, disable, require, prefer
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
// __END__
|
||||||
33
www/configs/config.host.inc
Executable file
33
www/configs/config.host.inc
Executable file
@@ -0,0 +1,33 @@
|
|||||||
|
<?php
|
||||||
|
/********************************************************************
|
||||||
|
* AUTHOR: Clemens Schwaighofer
|
||||||
|
* CREATED: 2018/10/11
|
||||||
|
* SHORT DESCRIPTION:
|
||||||
|
* configuration file for core host settings
|
||||||
|
* - DB access name (array group from config.db)
|
||||||
|
* - location (test/stage/live)
|
||||||
|
* - debug flag (true/false)
|
||||||
|
* - DB path (eg PUBLIC_SCHEMA)
|
||||||
|
* - stie lang
|
||||||
|
* HISTORY:
|
||||||
|
*********************************************************************/
|
||||||
|
|
||||||
|
// each host has a different db_host
|
||||||
|
// development host
|
||||||
|
$DB_HOST['soba.tokyo.tequila.jp'] = 'test';
|
||||||
|
// target host (live)
|
||||||
|
// $DB_TARGET_HOST['soba'] = '<DB ID>';
|
||||||
|
// url redirect database
|
||||||
|
// $DB_URL_REDIRECT_HOST['soba'] = '<DB ID>';
|
||||||
|
// location flagging
|
||||||
|
// test/dev/live
|
||||||
|
$LOCATION['soba.tokyo.tequila.jp'] = 'test';
|
||||||
|
// show DEBUG override
|
||||||
|
// true/false
|
||||||
|
$DEBUG_FLAG['soba.tokyo.tequila.jp'] = true;
|
||||||
|
// set postgresql paths (schemas)
|
||||||
|
$DB_PATH['soba.tokyo.tequila.jp'] = PUBLIC_SCHEMA;
|
||||||
|
// site language
|
||||||
|
$SITE_LANG['soba.tokyo.tequila.jp'] = 'en_utf8';
|
||||||
|
|
||||||
|
// __END__
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
<?
|
<?
|
||||||
/********************************************************************
|
/********************************************************************
|
||||||
* AUTHOR: Clemens "Gullevek" Schwaighofer (www.gullevek.org)
|
* AUTHOR: Clemens Schwaighofer
|
||||||
* CREATED: 2003/06/10
|
* CREATED: 2003/06/10
|
||||||
* SHORT DESCRIPTION:
|
* SHORT DESCRIPTION:
|
||||||
* configuration file
|
* configuration file
|
||||||
@@ -9,16 +9,16 @@
|
|||||||
|
|
||||||
/************* SESSION NAMES *************/
|
/************* SESSION NAMES *************/
|
||||||
// backend
|
// backend
|
||||||
DEFINE('EDIT_SESSION_NAME', "<ADMIN SESSION NAME>");
|
DEFINE('EDIT_SESSION_NAME', '<ADMIN SESSION NAME>');
|
||||||
// frontend
|
// frontend
|
||||||
DEFINE('SESSION_NAME', "<SESSION NAME>");
|
DEFINE('SESSION_NAME', '<SESSION NAME>');
|
||||||
// set the session name
|
// set the session name
|
||||||
define('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
define('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
||||||
|
|
||||||
/************* LANGUAGE / ENCODING *******/
|
/************* LANGUAGE / ENCODING *******/
|
||||||
DEFINE('DEFAULT_LANG', "en_utf8");
|
DEFINE('DEFAULT_LANG', 'en_utf8');
|
||||||
// default web page encoding setting
|
// default web page encoding setting
|
||||||
DEFINE('DEFAULT_ENCODING', "UTF-8");
|
DEFINE('DEFAULT_ENCODING', 'UTF-8');
|
||||||
|
|
||||||
/************* PATHS *********************/
|
/************* PATHS *********************/
|
||||||
// directory seperator
|
// directory seperator
|
||||||
@@ -40,51 +40,51 @@ DEFINE('INCLUDES', 'includes'.DS);
|
|||||||
// layout base path
|
// layout base path
|
||||||
DEFINE('LAYOUT', 'layout'.DS);
|
DEFINE('LAYOUT', 'layout'.DS);
|
||||||
// pic-root (compatible to CMS)
|
// pic-root (compatible to CMS)
|
||||||
DEFINE('PICTURES', "images".DS);
|
DEFINE('PICTURES', 'images'.DS);
|
||||||
// images
|
// images
|
||||||
DEFINE('IMAGES', "images".DS);
|
DEFINE('IMAGES', 'images'.DS);
|
||||||
// icons (below the images/ folder)
|
// icons (below the images/ folder)
|
||||||
DEFINE('ICONS', 'icons'.DS);
|
DEFINE('ICONS', 'icons'.DS);
|
||||||
// media
|
// media
|
||||||
DEFINE('MEDIA', "media".DS);
|
DEFINE('MEDIA', 'media'.DS);
|
||||||
// flash-root (below media)
|
// flash-root (below media)
|
||||||
DEFINE('FLASH', "flash".DS);
|
DEFINE('FLASH', 'flash'.DS);
|
||||||
// uploads (anything to keep)
|
// uploads (anything to keep)
|
||||||
DEFINE('UPLOADS', "uploads".DS);
|
DEFINE('UPLOADS', 'uploads'.DS);
|
||||||
// files (binaries) (below media)
|
// files (binaries) (below media)
|
||||||
DEFINE('BINARIES', "binaries".DS);
|
DEFINE('BINARIES', 'binaries'.DS);
|
||||||
// files (videos) (below media)
|
// files (videos) (below media)
|
||||||
DEFINE('VIDEOS', "videos".DS);
|
DEFINE('VIDEOS', 'videos'.DS);
|
||||||
// files (documents) (below media)
|
// files (documents) (below media)
|
||||||
DEFINE('DOCUMENTS', "documents".DS);
|
DEFINE('DOCUMENTS', 'documents'.DS);
|
||||||
// files (pdfs) (below media)
|
// files (pdfs) (below media)
|
||||||
DEFINE('PDFS', "documents".DS);
|
DEFINE('PDFS', 'documents'.DS);
|
||||||
// CSV
|
// CSV
|
||||||
DEFINE('CSV', 'csv'.DS);
|
DEFINE('CSV', 'csv'.DS);
|
||||||
// css
|
// css
|
||||||
DEFINE('CSS', "css".DS);
|
DEFINE('CSS', 'css'.DS);
|
||||||
// js
|
// js
|
||||||
DEFINE('JS', "javascript".DS);
|
DEFINE('JS', 'javascript'.DS);
|
||||||
// table arrays
|
// table arrays
|
||||||
DEFINE('TABLE_ARRAYS', "table_arrays".DS);
|
DEFINE('TABLE_ARRAYS', 'table_arrays'.DS);
|
||||||
// smarty libs path
|
// smarty libs path
|
||||||
DEFINE('SMARTY', "Smarty".DS);
|
DEFINE('SMARTY', 'Smarty'.DS);
|
||||||
// po langs
|
// po langs
|
||||||
DEFINE('LANG', "lang".DS);
|
DEFINE('LANG', 'lang'.DS);
|
||||||
// cache path
|
// cache path
|
||||||
DEFINE('CACHE', "cache".DS);
|
DEFINE('CACHE', 'cache'.DS);
|
||||||
// temp path
|
// temp path
|
||||||
DEFINE('TMP', "tmp".DS);
|
DEFINE('TMP', 'tmp'.DS);
|
||||||
// log files
|
// log files
|
||||||
DEFINE('LOG', 'log'.DS);
|
DEFINE('LOG', 'log'.DS);
|
||||||
// compiled template folder
|
// compiled template folder
|
||||||
DEFINE('TEMPLATES_C', 'templates_c'.DS);
|
DEFINE('TEMPLATES_C', 'templates_c'.DS);
|
||||||
// template base
|
// template base
|
||||||
DEFINE('TEMPLATES', "templates".DS);
|
DEFINE('TEMPLATES', 'templates'.DS);
|
||||||
// frontend template dir', only for admin
|
// frontend template dir', only for admin
|
||||||
DEFINE('TEMPLATES_FRONTEND', "templates_frontend".DS);
|
DEFINE('TEMPLATES_FRONTEND', 'templates_frontend'.DS);
|
||||||
// default template
|
// default template
|
||||||
DEFINE('DEFAULT_TEMPLATE', "default".DS);
|
DEFINE('DEFAULT_TEMPLATE', 'default'.DS);
|
||||||
// default template file
|
// default template file
|
||||||
DEFINE('DEFAULT_TEMPLATE_FILE', 'default.tpl');
|
DEFINE('DEFAULT_TEMPLATE_FILE', 'default.tpl');
|
||||||
|
|
||||||
@@ -102,14 +102,14 @@ DEFINE('DEFAULT_ACL_SEND', 70);
|
|||||||
DEFINE('DEFAULT_ACL_DEL', 80);
|
DEFINE('DEFAULT_ACL_DEL', 80);
|
||||||
DEFINE('DEFAULT_ACL_ADMIN', 100); */
|
DEFINE('DEFAULT_ACL_ADMIN', 100); */
|
||||||
// SSL host name
|
// SSL host name
|
||||||
// DEFINE('SSL_HOST', "ssl.host.name");
|
// DEFINE('SSL_HOST', 'ssl.host.name');
|
||||||
// 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
|
||||||
// 3: if default template is not found, show error template, do not fall back to default tree
|
// 3: if default template is not found, show error template, do not fall back to default tree
|
||||||
// 4: very strict, even on normal fixable errors through error
|
// 4: very strict, even on normal fixable errors through error
|
||||||
// DEFINE('ERROR_STRICT', 3);
|
// DEFINE('ERROR_STRICT', 3);
|
||||||
// allow page caching in general, set to "FALSE" if you do debugging or development!
|
// allow page caching in general, set to 'FALSE' if you do debugging or development!
|
||||||
// DEFINE('ALLOW_SMARTY_CACHE', FALSE);
|
// DEFINE('ALLOW_SMARTY_CACHE', FALSE);
|
||||||
// cache life time, in seconds, default here is 2 days (172800s)
|
// cache life time, in seconds, default here is 2 days (172800s)
|
||||||
// -1 is never expire cache
|
// -1 is never expire cache
|
||||||
@@ -134,6 +134,11 @@ DEFINE('PAGE_WIDTH', 800);
|
|||||||
// the default template name
|
// the default template name
|
||||||
DEFINE('MASTER_TEMPLATE_NAME', 'main_body.tpl');
|
DEFINE('MASTER_TEMPLATE_NAME', 'main_body.tpl');
|
||||||
|
|
||||||
|
// below two can be defined here, but they should be
|
||||||
|
// defined in either the header file or the file itself
|
||||||
|
/************* LOGGING *******************/
|
||||||
|
// DEFINE('LOG_FILE_ID', '');
|
||||||
|
|
||||||
/************* QUEUE TABLE *************/
|
/************* QUEUE TABLE *************/
|
||||||
// if we have a dev/live system
|
// if we have a dev/live system
|
||||||
// set_live is a per page/per item
|
// set_live is a per page/per item
|
||||||
@@ -151,32 +156,32 @@ DEFINE('LIVE_SCHEMA', 'public');
|
|||||||
/************* DB ACCESS *****************/
|
/************* DB ACCESS *****************/
|
||||||
// please be VERY carefull only to change the right side
|
// please be VERY carefull only to change the right side
|
||||||
$DB_CONFIG = array (
|
$DB_CONFIG = array (
|
||||||
"<db id>" => array (
|
'<db id>' => array (
|
||||||
"db_name" => "<database>",
|
'db_name' => '<database>',
|
||||||
"db_user" => "<user>",
|
'db_user' => '<user>',
|
||||||
"db_pass" => "<password>",
|
'db_pass' => '<password>',
|
||||||
"db_host" => "<host>",
|
'db_host' => '<host>',
|
||||||
"db_port" => "5432",
|
'db_port' => '5432',
|
||||||
"db_schema" => "public", // if not set, uses public
|
'db_schema' => 'public', // if not set, uses public
|
||||||
"db_type" => "pgsql",
|
'db_type' => 'pgsql',
|
||||||
"db_encoding" => '',
|
'db_encoding' => '',
|
||||||
"db_ssl" => 'disable' // allow, disable, require, prefer
|
'db_ssl' => 'disable' // allow, disable, require, prefer
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
// File and Folder paths
|
// File and Folder paths
|
||||||
// ID is TARGET (first array element)
|
// ID is TARGET (first array element)
|
||||||
// $PATHS["test"]["csv_path"] = "";
|
// $PATHS['test']['csv_path'] = '';
|
||||||
// $PATHS["test"]["perl_bin"] = "";
|
// $PATHS['test']['perl_bin'] = '';
|
||||||
// $PATHS["test"]["redirect_url"] = "";
|
// $PATHS['test']['redirect_url'] = '';
|
||||||
|
|
||||||
// each host has a different db_host
|
// each host has a different db_host
|
||||||
// development host
|
// development host
|
||||||
$DB_HOST['<host>'] = "<db id>";
|
$DB_HOST['<host>'] = '<db id>';
|
||||||
// target host (live)
|
// target host (live)
|
||||||
// $DB_TARGET_HOST['<host>'] = "<DB ID>";
|
// $DB_TARGET_HOST['<host>'] = '<DB ID>';
|
||||||
// url redirect database
|
// url redirect database
|
||||||
// $DB_URL_REDIRECT_HOST['<host>'] = "<DB ID>";
|
// $DB_URL_REDIRECT_HOST['<host>'] = '<DB ID>';
|
||||||
// location flagging
|
// location flagging
|
||||||
// test/dev/live
|
// test/dev/live
|
||||||
$LOCATION['<host>'] = '<test|live|remote|etc>';
|
$LOCATION['<host>'] = '<test|live|remote|etc>';
|
||||||
@@ -192,9 +197,9 @@ $USE_DATABASE = defined('USE_DATABASE') ? USE_DATABASE : true;
|
|||||||
// live frontend pages
|
// live frontend pages
|
||||||
// ** missing live domains **
|
// ** missing live domains **
|
||||||
// get the name without the port
|
// get the name without the port
|
||||||
list($HOST_NAME, $PORT) = array_pad(explode(":", $_SERVER['HTTP_HOST'], 2), 2, null);
|
list($HOST_NAME) = array_pad(explode(':', $_SERVER['HTTP_HOST'], 2), 2, null);
|
||||||
if (!$DB_HOST[$HOST_NAME] && $USE_DATABASE) {
|
if (!$DB_HOST[$HOST_NAME] && $USE_DATABASE) {
|
||||||
echo "No matching DB config found. Contact Admin<br>";
|
echo 'No matching DB config found. Contact Admin<br>';
|
||||||
exit -1;
|
exit -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -221,11 +226,11 @@ DEFINE('SHOW_ALL_ERRORS', false); // show all errors if debug_all & show_error_h
|
|||||||
$G_TITLE = '<OVERALL PAGE TITLE>';
|
$G_TITLE = '<OVERALL PAGE TITLE>';
|
||||||
|
|
||||||
/************ STYLE SHEETS / JS **********/
|
/************ STYLE SHEETS / JS **********/
|
||||||
$EDIT_STYLESHEET = "edit.css";
|
$EDIT_STYLESHEET = 'edit.css';
|
||||||
$EDIT_JAVASCRIPT = "edit.js";
|
$EDIT_JAVASCRIPT = 'edit.js';
|
||||||
|
|
||||||
$STYLESHEET = "frontend.css";
|
$STYLESHEET = 'frontend.css';
|
||||||
$JAVASCRIPT = "frontend.js";
|
$JAVASCRIPT = 'frontend.js';
|
||||||
|
|
||||||
/************* CONVERT *******************/
|
/************* CONVERT *******************/
|
||||||
$paths = array (
|
$paths = array (
|
||||||
@@ -235,14 +240,14 @@ $paths = array (
|
|||||||
);
|
);
|
||||||
// find convert
|
// find convert
|
||||||
foreach ($paths as $path) {
|
foreach ($paths as $path) {
|
||||||
if (file_exists($path."/convert") && is_file($path."/convert")) {
|
if (file_exists($path.DS.'convert') && is_file($path.DS.'convert')) {
|
||||||
// image magick convert location
|
// image magick convert location
|
||||||
DEFINE('CONVERT', $path."/convert");
|
DEFINE('CONVERT', $path.DS.'convert');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// turn off debug if debug flag is OFF
|
// turn off debug if debug flag is OFF
|
||||||
if (DEBUG == false) {
|
if (defined('DEBUG') && DEBUG == false) {
|
||||||
$ECHO_ALL = 0;
|
$ECHO_ALL = 0;
|
||||||
$DEBUG_ALL = 0;
|
$DEBUG_ALL = 0;
|
||||||
$PRINT_ALL = 0;
|
$PRINT_ALL = 0;
|
||||||
@@ -255,3 +260,5 @@ if (DEBUG == false) {
|
|||||||
|
|
||||||
// read auto loader
|
// read auto loader
|
||||||
require BASE.LIB.'autoloader.php';
|
require BASE.LIB.'autoloader.php';
|
||||||
|
|
||||||
|
# __END__
|
||||||
|
|||||||
25
www/configs/config.php
Executable file
25
www/configs/config.php
Executable file
@@ -0,0 +1,25 @@
|
|||||||
|
<?php
|
||||||
|
/********************************************************************
|
||||||
|
* AUTHOR: Clemens Schwaighofer
|
||||||
|
* CREATED: 2018/10/11
|
||||||
|
* SHORT DESCRIPTION:
|
||||||
|
* pre config included -> includes master config
|
||||||
|
* HISTORY:
|
||||||
|
*********************************************************************/
|
||||||
|
|
||||||
|
define('CONFIG_PATH', 'configs'.DIRECTORY_SEPARATOR);
|
||||||
|
// config path prefix search, start with 0, got down each level __DIR__ has, if nothing found -> bail
|
||||||
|
$CONFIG_PATH_PREFIX = '';
|
||||||
|
for ($dir_pos = 0, $dir_max = count(explode('/', __DIR__)); $dir_pos <= $dir_max; $dir_pos ++) {
|
||||||
|
$CONFIG_PATH_PREFIX .= '..'.DIRECTORY_SEPARATOR;
|
||||||
|
if (file_exists($CONFIG_PATH_PREFIX.CONFIG_PATH.'config.inc')) {
|
||||||
|
require $CONFIG_PATH_PREFIX.CONFIG_PATH.'config.inc';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// fail if no base DS is not set
|
||||||
|
if (!defined('DS')) {
|
||||||
|
exit('Base config unloadable');
|
||||||
|
}
|
||||||
|
|
||||||
|
// __END__
|
||||||
@@ -1,259 +0,0 @@
|
|||||||
<?php
|
|
||||||
/********************************************************************
|
|
||||||
* AUTHOR: Clemens Schwaighofer
|
|
||||||
* CREATED: 2003/06/10
|
|
||||||
* SHORT DESCRIPTION:
|
|
||||||
* configuration file
|
|
||||||
* HISTORY:
|
|
||||||
*********************************************************************/
|
|
||||||
|
|
||||||
/************* SESSION NAMES *************/
|
|
||||||
// backend
|
|
||||||
DEFINE('EDIT_SESSION_NAME', "<ADMIN SESSION NAME>");
|
|
||||||
// frontend
|
|
||||||
DEFINE('SESSION_NAME', "<SESSION NAME>");
|
|
||||||
// set the session name
|
|
||||||
define('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
|
||||||
|
|
||||||
/************* LANGUAGE / ENCODING *******/
|
|
||||||
DEFINE('DEFAULT_LANG', "en_utf8");
|
|
||||||
// default web page encoding setting
|
|
||||||
DEFINE('DEFAULT_ENCODING', "UTF-8");
|
|
||||||
|
|
||||||
/************* PATHS *********************/
|
|
||||||
// directory seperator
|
|
||||||
DEFINE('DS', DIRECTORY_SEPARATOR);
|
|
||||||
// ** NEW/BETTER DIR DECLARATIONS **
|
|
||||||
// path to original file (if symlink)
|
|
||||||
DEFINE('DIR', __DIR__.DS);
|
|
||||||
// base dir root folder level
|
|
||||||
DEFINE('BASE', str_replace('configs', '', __DIR__));
|
|
||||||
|
|
||||||
// ** OLD DIR DECLARATIONS **
|
|
||||||
// path to document root of file called
|
|
||||||
DEFINE('ROOT', getcwd().DS);
|
|
||||||
// libs path
|
|
||||||
DEFINE('LIB', 'lib'.DS);
|
|
||||||
DEFINE('LIBS', 'lib'.DS);
|
|
||||||
// includes (strings, arrays for static, etc)
|
|
||||||
DEFINE('INCLUDES', 'includes'.DS);
|
|
||||||
// layout base path
|
|
||||||
DEFINE('LAYOUT', 'layout'.DS);
|
|
||||||
// pic-root (compatible to CMS)
|
|
||||||
DEFINE('PICTURES', "images".DS);
|
|
||||||
// images
|
|
||||||
DEFINE('IMAGES', "images".DS);
|
|
||||||
// icons (below the images/ folder)
|
|
||||||
DEFINE('ICONS', 'icons'.DS);
|
|
||||||
// media
|
|
||||||
DEFINE('MEDIA', "media".DS);
|
|
||||||
// flash-root (below media)
|
|
||||||
DEFINE('FLASH', "flash".DS);
|
|
||||||
// uploads (anything to keep)
|
|
||||||
DEFINE('UPLOADS', "uploads".DS);
|
|
||||||
// files (binaries) (below media)
|
|
||||||
DEFINE('BINARIES', "binaries".DS);
|
|
||||||
// files (videos) (below media)
|
|
||||||
DEFINE('VIDEOS', "videos".DS);
|
|
||||||
// files (documents) (below media)
|
|
||||||
DEFINE('DOCUMENTS', "documents".DS);
|
|
||||||
// files (pdfs) (below media)
|
|
||||||
DEFINE('PDFS', "documents".DS);
|
|
||||||
// CSV
|
|
||||||
DEFINE('CSV', 'csv'.DS);
|
|
||||||
// css
|
|
||||||
DEFINE('CSS', "css".DS);
|
|
||||||
// js
|
|
||||||
DEFINE('JS', "javascript".DS);
|
|
||||||
// table arrays
|
|
||||||
DEFINE('TABLE_ARRAYS', "table_arrays".DS);
|
|
||||||
// smarty libs path
|
|
||||||
DEFINE('SMARTY', "Smarty".DS);
|
|
||||||
// po langs
|
|
||||||
DEFINE('LANG', "lang".DS);
|
|
||||||
// cache path
|
|
||||||
DEFINE('CACHE', "cache".DS);
|
|
||||||
// temp path
|
|
||||||
DEFINE('TMP', "tmp".DS);
|
|
||||||
// log files
|
|
||||||
DEFINE('LOG', 'log'.DS);
|
|
||||||
// compiled template folder
|
|
||||||
DEFINE('TEMPLATES_C', 'templates_c'.DS);
|
|
||||||
// template base
|
|
||||||
DEFINE('TEMPLATES', "templates".DS);
|
|
||||||
// frontend template dir', only for admin
|
|
||||||
DEFINE('TEMPLATES_FRONTEND', "templates_frontend".DS);
|
|
||||||
// default template
|
|
||||||
DEFINE('DEFAULT_TEMPLATE', "default".DS);
|
|
||||||
// default template file
|
|
||||||
DEFINE('DEFAULT_TEMPLATE_FILE', 'default.tpl');
|
|
||||||
|
|
||||||
/************* HASH / ACL DEFAULT / ERROR SETTINGS / SMARTY *************/
|
|
||||||
// default hash type
|
|
||||||
DEFINE('DEFAULT_HASH', 'sha256');
|
|
||||||
// default acl level
|
|
||||||
DEFINE('DEFAULT_ACL_LEVEL', 80);
|
|
||||||
// default levels for certain actions
|
|
||||||
/* DEFINE('DEFAULT_ACL_READ', 20);
|
|
||||||
DEFINE('DEFAULT_ACL_CONFIRM', 35);
|
|
||||||
DEFINE('DEFAULT_ACL_MOD', 40);
|
|
||||||
DEFINE('DEFAULT_ACL_WRITE', 60);
|
|
||||||
DEFINE('DEFAULT_ACL_SEND', 70);
|
|
||||||
DEFINE('DEFAULT_ACL_DEL', 80);
|
|
||||||
DEFINE('DEFAULT_ACL_ADMIN', 100); */
|
|
||||||
// SSL host name
|
|
||||||
// DEFINE('SSL_HOST', "ssl.host.name");
|
|
||||||
// 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
|
|
||||||
// 2: if template not found, do not search, show error template
|
|
||||||
// 3: if default template is not found, show error template, do not fall back to default tree
|
|
||||||
// 4: very strict, even on normal fixable errors through error
|
|
||||||
// DEFINE('ERROR_STRICT', 3);
|
|
||||||
// allow page caching in general, set to "FALSE" if you do debugging or development!
|
|
||||||
// DEFINE('ALLOW_SMARTY_CACHE', FALSE);
|
|
||||||
// cache life time, in seconds, default here is 2 days (172800s)
|
|
||||||
// -1 is never expire cache
|
|
||||||
// DEFINE('SMARTY_CACHE_LIFETIME', -1);
|
|
||||||
|
|
||||||
/************* LOGOUT ********************/
|
|
||||||
// logout target
|
|
||||||
DEFINE('LOGOUT_TARGET', '');
|
|
||||||
// password change allowed
|
|
||||||
DEFINE('PASSWORD_CHANGE', false);
|
|
||||||
|
|
||||||
/************* AJAX / ACCESS *************/
|
|
||||||
// ajax request type
|
|
||||||
DEFINE('AJAX_REQUEST_TYPE', 'POST');
|
|
||||||
// what AJAX type to use
|
|
||||||
DEFINE('USE_PROTOTYPE', true);
|
|
||||||
DEFINE('USE_SCRIPTACULOUS', false);
|
|
||||||
DEFINE('USE_JQUERY', false);
|
|
||||||
|
|
||||||
/************* LAYOUT WIDTHS *************/
|
|
||||||
DEFINE('PAGE_WIDTH', 800);
|
|
||||||
// the default template name
|
|
||||||
DEFINE('MASTER_TEMPLATE_NAME', 'main_body.tpl');
|
|
||||||
|
|
||||||
/************* QUEUE TABLE *************/
|
|
||||||
// if we have a dev/live system
|
|
||||||
// set_live is a per page/per item
|
|
||||||
// live_queue is a global queue system
|
|
||||||
// DEFINE('QUEUE', 'live_queue');
|
|
||||||
|
|
||||||
/************* DB PATHS (PostgreSQL) *****************/
|
|
||||||
// schema names, can also be defined per <DB INFO>
|
|
||||||
DEFINE('PUBLIC_SCHEMA', 'public');
|
|
||||||
DEFINE('DEV_SCHEMA', 'public');
|
|
||||||
DEFINE('TEST_SCHEMA', 'public');
|
|
||||||
DEFINE('LIVE_SCHEMA', 'public');
|
|
||||||
|
|
||||||
// non constant part
|
|
||||||
/************* DB ACCESS *****************/
|
|
||||||
// please be VERY carefull only to change the right side
|
|
||||||
$DB_CONFIG = array (
|
|
||||||
"<DB ID>" => array (
|
|
||||||
"db_name" => "<DB NAME>",
|
|
||||||
"db_user" => "<DB USER>",
|
|
||||||
"db_pass" => "<DB PASSWORD>",
|
|
||||||
"db_host" => "<DB HOST>",
|
|
||||||
"db_port" => "5432",
|
|
||||||
"db_schema" => "<DB SCHEMA>", // if not set, uses public
|
|
||||||
"db_type" => "pgsql",
|
|
||||||
"db_encoding" => '',
|
|
||||||
"db_ssl" => 'disable' // allow, disable, require, prefer
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
// File and Folder paths
|
|
||||||
// ID is TARGET (first array element)
|
|
||||||
// $PATHS["test"]["csv_path"] = "";
|
|
||||||
// $PATHS["test"]["perl_bin"] = "";
|
|
||||||
// $PATHS["test"]["redirect_url"] = "";
|
|
||||||
|
|
||||||
// each host has a different db_host
|
|
||||||
// development host
|
|
||||||
$DB_HOST['<HOST NAME>'] = "<DB ID>";
|
|
||||||
// target host (live)
|
|
||||||
// $DB_TARGET_HOST['<HOST NAME>'] = "<DB ID>";
|
|
||||||
// url redirect database
|
|
||||||
// $DB_URL_REDIRECT_HOST['<HOST NAME>'] = "<DB ID>";
|
|
||||||
// location flagging
|
|
||||||
// test/dev/live
|
|
||||||
$LOCATION['<HOST NAME>'] = '<test|live|remote|etc>';
|
|
||||||
// show DEBUG override
|
|
||||||
// true/false
|
|
||||||
$DEBUG_FLAG['<HOST NAME>'] = true;
|
|
||||||
// set postgresql paths (schemas)
|
|
||||||
$DB_PATH['<HOST NAME>'] = PUBLIC_SCHEMA;
|
|
||||||
|
|
||||||
// set the USE_DATABASE var, if there is nothing set, we assume TRUE
|
|
||||||
$USE_DATABASE = defined('USE_DATABASE') ? USE_DATABASE : true;
|
|
||||||
|
|
||||||
// live frontend pages
|
|
||||||
// ** missing live domains **
|
|
||||||
// get the name without the port
|
|
||||||
list($HOST_NAME, $PORT) = array_pad(explode(":", $_SERVER['HTTP_HOST'], 2), 2, null);
|
|
||||||
if (!$DB_HOST[$HOST_NAME] && $USE_DATABASE) {
|
|
||||||
echo "No matching DB config found. Contact Admin<br>";
|
|
||||||
exit -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
// define the static names
|
|
||||||
DEFINE('LOGIN_DB', $DB_HOST[$HOST_NAME]);
|
|
||||||
DEFINE('MAIN_DB', $DB_HOST[$HOST_NAME]);
|
|
||||||
DEFINE('DB_SCHEMA', $DB_PATH[$HOST_NAME]);
|
|
||||||
// DEFINE('TARGET_DB', $DB_TARGET_HOST[$HOST_NAME]);
|
|
||||||
// DEFINE('URL_REDIRECT_DB', $DB_URL_REDIRECT_HOST[$HOST_NAME]);
|
|
||||||
// next three if top is not set
|
|
||||||
// DEFINE('DEV_SCHEMA', $DB_CONFIG[MAIN_DB]['db_schema']);
|
|
||||||
// DEFINE('TEST_SCHEMA', $DB_CONFIG[MAIN_DB]['db_schema']);
|
|
||||||
// DEFINE('PUBLIC_SCHEMA', $DB_CONFIG[TARGET_DB]['db_schema']);
|
|
||||||
DEFINE('LOGIN_DB_SCHEMA', 'public'); // where the edit* tables are
|
|
||||||
DEFINE('GLOBAL_DB_SCHEMA', 'public'); // where global tables are that are used by all schemas (eg queue tables for online, etc)
|
|
||||||
DEFINE('TARGET', $LOCATION[$HOST_NAME]);
|
|
||||||
// DEFINE('CSV_PATH', $PATHS[TARGET]['csv_path']);
|
|
||||||
// DEFINE('EXPORT_SCRIPT', $PATHS[TARGET]['perl_bin']);
|
|
||||||
// DEFINE('REDIRECT_URL', $PATHS[TARGET]['redirect_url']);
|
|
||||||
DEFINE('DEBUG', $DEBUG_FLAG[$HOST_NAME]);
|
|
||||||
DEFINE('SHOW_ALL_ERRORS', false); // show all errors if debug_all & show_error_handling are enabled
|
|
||||||
|
|
||||||
/************* GENERAL PAGE TITLE ********/
|
|
||||||
$G_TITLE = '<OVERALL PAGE TITLE>';
|
|
||||||
|
|
||||||
/************ STYLE SHEETS / JS **********/
|
|
||||||
$EDIT_STYLESHEET = "edit.css";
|
|
||||||
$EDIT_JAVASCRIPT = "edit.js";
|
|
||||||
|
|
||||||
$STYLESHEET = "frontend.css";
|
|
||||||
$JAVASCRIPT = "frontend.js";
|
|
||||||
|
|
||||||
/************* CONVERT *******************/
|
|
||||||
$paths = array (
|
|
||||||
'/bin',
|
|
||||||
'/usr/bin',
|
|
||||||
'/usr/local/bin'
|
|
||||||
);
|
|
||||||
// find convert
|
|
||||||
foreach ($paths as $path) {
|
|
||||||
if (file_exists($path."/convert") && is_file($path."/convert")) {
|
|
||||||
// image magick convert location
|
|
||||||
DEFINE('CONVERT', $path."/convert");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// turn off debug if debug flag is OFF
|
|
||||||
if (DEBUG == false) {
|
|
||||||
$ECHO_ALL = 0;
|
|
||||||
$DEBUG_ALL = 0;
|
|
||||||
$PRINT_ALL = 0;
|
|
||||||
$DB_DEBUG = 0;
|
|
||||||
$ENABLE_ERROR_HANDLING = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// any other global definitons here
|
|
||||||
// DEFINE('SOME_ID', <SOME VALUE>);
|
|
||||||
|
|
||||||
// read auto loader
|
|
||||||
require BASE.LIB.'autoloader.php';
|
|
||||||
|
|
||||||
# __END__
|
|
||||||
61
www/includes/Date.Vars.inc
Normal file
61
www/includes/Date.Vars.inc
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
<?php
|
||||||
|
/********************************************************************
|
||||||
|
* AUTHOR: Clemens Schwaighofer
|
||||||
|
* CREATED: 2005/07/19
|
||||||
|
* SHORT DESCRIPTION:
|
||||||
|
* preset date variables
|
||||||
|
* HISTORY:
|
||||||
|
*********************************************************************/
|
||||||
|
|
||||||
|
$day_short = array (
|
||||||
|
1 => 'Mon',
|
||||||
|
2 => 'Tue',
|
||||||
|
3 => 'Wed',
|
||||||
|
4 => 'Thu',
|
||||||
|
5 => 'Fri',
|
||||||
|
6 => 'Sat',
|
||||||
|
7 => 'Sun'
|
||||||
|
);
|
||||||
|
|
||||||
|
$day_long = array (
|
||||||
|
1 => 'Monday',
|
||||||
|
2 => 'Tuesday',
|
||||||
|
3 => 'Wednesday',
|
||||||
|
4 => 'Thursday',
|
||||||
|
5 => 'Friday',
|
||||||
|
6 => 'Saturday',
|
||||||
|
7 => 'Sunday'
|
||||||
|
);
|
||||||
|
|
||||||
|
// months
|
||||||
|
$month_long = array (
|
||||||
|
1 => 'January',
|
||||||
|
2 => 'February',
|
||||||
|
3 => 'March',
|
||||||
|
4 => 'April',
|
||||||
|
5 => 'May',
|
||||||
|
6 => 'June',
|
||||||
|
7 => 'July',
|
||||||
|
8 => 'August',
|
||||||
|
9 => 'September',
|
||||||
|
10 => 'October',
|
||||||
|
11 => 'November',
|
||||||
|
12 => 'December'
|
||||||
|
);
|
||||||
|
|
||||||
|
$month_short = array (
|
||||||
|
1 => 'Jan',
|
||||||
|
2 => 'Feb',
|
||||||
|
3 => 'Mar',
|
||||||
|
4 => 'Apr',
|
||||||
|
5 => 'May',
|
||||||
|
6 => 'Jun',
|
||||||
|
7 => 'Jul',
|
||||||
|
8 => 'Aug',
|
||||||
|
9 => 'Sep',
|
||||||
|
10 => 'Oct',
|
||||||
|
11 => 'Nov',
|
||||||
|
12 => 'Dec'
|
||||||
|
);
|
||||||
|
|
||||||
|
// __END__
|
||||||
@@ -10,3 +10,5 @@
|
|||||||
// print debug messages
|
// print debug messages
|
||||||
echo $login->printErrorMsg();
|
echo $login->printErrorMsg();
|
||||||
echo $cms->printErrorMsg();
|
echo $cms->printErrorMsg();
|
||||||
|
|
||||||
|
// __END__
|
||||||
@@ -10,7 +10,7 @@
|
|||||||
//------------------------------ variable init start
|
//------------------------------ variable init start
|
||||||
// for dev test we set full error reporting; writes everything, except E_ERROR into logs/php_error-<day>.log
|
// for dev test we set full error reporting; writes everything, except E_ERROR into logs/php_error-<day>.log
|
||||||
if ($DEBUG_ALL && $ENABLE_ERROR_HANDLING) {
|
if ($DEBUG_ALL && $ENABLE_ERROR_HANDLING) {
|
||||||
include("libs/Error.Handling.inc");
|
include(BASE.LIBS."Error.Handling.inc");
|
||||||
}
|
}
|
||||||
// predefine vars
|
// predefine vars
|
||||||
$lang = '';
|
$lang = '';
|
||||||
@@ -22,7 +22,6 @@ extract($_POST, EXTR_SKIP);
|
|||||||
//------------------------------ library include start
|
//------------------------------ library include start
|
||||||
// set output to quiet for load of classes & session settings
|
// set output to quiet for load of classes & session settings
|
||||||
ob_start();
|
ob_start();
|
||||||
require("config.inc");
|
|
||||||
//------------------------------ library include end
|
//------------------------------ library include end
|
||||||
|
|
||||||
//------------------------------ basic variable settings start
|
//------------------------------ basic variable settings start
|
||||||
@@ -95,3 +94,5 @@ if ((TARGET == 'live' || TARGET == 'remote') && !$DEBUG_ALL_OVERRIDE) {
|
|||||||
$cms->print_output_all = 0;
|
$cms->print_output_all = 0;
|
||||||
}
|
}
|
||||||
$cms->DATA['JS_DEBUG'] = DEBUG;
|
$cms->DATA['JS_DEBUG'] = DEBUG;
|
||||||
|
|
||||||
|
// __END__
|
||||||
@@ -32,7 +32,7 @@ if ($_SESSION['DEFAULT_CHARSET']) {
|
|||||||
if ($_SESSION['DEFAULT_LANG']) {
|
if ($_SESSION['DEFAULT_LANG']) {
|
||||||
$lang = $_SESSION['DEFAULT_LANG'];
|
$lang = $_SESSION['DEFAULT_LANG'];
|
||||||
} elseif (!$lang) {
|
} elseif (!$lang) {
|
||||||
$lang = DEFAULT_LANG;
|
$lang = defined('SITE_LANG') ? SITE_LANG : DEFAULT_LANG;
|
||||||
}
|
}
|
||||||
// create the char lang encoding
|
// create the char lang encoding
|
||||||
$lang_short = substr($lang, 0, 2);
|
$lang_short = substr($lang, 0, 2);
|
||||||
@@ -55,13 +55,16 @@ $cms->CSS_SPECIAL_TEMPLATE_NAME = @$CSS_NAME;
|
|||||||
$cms->JS_SPECIAL_TEMPLATE_NAME = @$JS_NAME;
|
$cms->JS_SPECIAL_TEMPLATE_NAME = @$JS_NAME;
|
||||||
|
|
||||||
// set basic template path (tmp)
|
// set basic template path (tmp)
|
||||||
$smarty->setTemplateDir(LAYOUT.$TEMPLATE_DIR.TEMPLATES);
|
$cms->template_path = LAYOUT.$TEMPLATE_DIR.TEMPLATES;
|
||||||
$cms->lang_dir = LAYOUT.$TEMPLATE_DIR.LANG;
|
if ($smarty) {
|
||||||
$cms->includes = LAYOUT.$TEMPLATE_DIR.INCLUDES;
|
$smarty->setTemplateDir($cms->template_path);
|
||||||
|
}
|
||||||
|
$cms->lang_dir = LAYOUT.$TEMPLATE_DIR.LANG; // no outside
|
||||||
|
$cms->includes = BASE.INCLUDES; // no longer in templates, only global
|
||||||
$cms->javascript = LAYOUT.$TEMPLATE_DIR.JS;
|
$cms->javascript = LAYOUT.$TEMPLATE_DIR.JS;
|
||||||
$cms->css = LAYOUT.$TEMPLATE_DIR.CSS;
|
$cms->css = LAYOUT.$TEMPLATE_DIR.CSS;
|
||||||
$cms->pictures = LAYOUT.$TEMPLATE_DIR.IMAGES;
|
$cms->pictures = LAYOUT.$TEMPLATE_DIR.IMAGES;
|
||||||
$cms->cache_pictures = LAYOUT.$TEMPLATE_DIR.CACHE.IMAGES;
|
$cms->cache_pictures = LAYOUT.$TEMPLATE_DIR.CACHE;
|
||||||
$cms->cache_pictures_root = ROOT.$cms->cache_pictures;
|
$cms->cache_pictures_root = ROOT.$cms->cache_pictures;
|
||||||
if (!is_dir($cms->cache_pictures_root)) {
|
if (!is_dir($cms->cache_pictures_root)) {
|
||||||
mkdir($cms->cache_pictures_root);
|
mkdir($cms->cache_pictures_root);
|
||||||
@@ -80,20 +83,13 @@ if (!file_exists(ROOT.$smarty->getTemplateDir()[0].DS.MASTER_TEMPLATE_NAME)) {
|
|||||||
$smarty->setTemplateDir(LAYOUT.DEFAULT_TEMPLATE.TEMPLATES);
|
$smarty->setTemplateDir(LAYOUT.DEFAULT_TEMPLATE.TEMPLATES);
|
||||||
$template_set = DEFAULT_TEMPLATE;
|
$template_set = DEFAULT_TEMPLATE;
|
||||||
}
|
}
|
||||||
// loop to check if dir exists
|
|
||||||
// check if file exists, if not reset to default path
|
|
||||||
|
|
||||||
// check if the javascript folder exists in the template path, if not fall back to default
|
|
||||||
if (!is_dir($cms->javascript)) {
|
|
||||||
$cms->javascript = LAYOUT.DEFAULT_TEMPLATE.JS;
|
|
||||||
}
|
|
||||||
// check if lang_dir folder exists in the template path, if not fall back to default
|
// check if lang_dir folder exists in the template path, if not fall back to default
|
||||||
if (!is_dir($cms->lang_dir)) {
|
if (!is_dir($cms->lang_dir)) {
|
||||||
$cms->lang_dir = LAYOUT.DEFAULT_TEMPLATE.LANG;
|
$cms->lang_dir = LAYOUT.DEFAULT_TEMPLATE.LANG;
|
||||||
}
|
}
|
||||||
// check if include folder exists in the template path, if not fall back to default
|
// check if the javascript folder exists in the template path, if not fall back to default
|
||||||
if (!is_dir($cms->includes)) {
|
if (!is_dir($cms->javascript)) {
|
||||||
$cms->includes = LAYOUT.DEFAULT_TEMPLATE.INCLUDES;
|
$cms->javascript = LAYOUT.DEFAULT_TEMPLATE.JS;
|
||||||
}
|
}
|
||||||
// check if css folder exists in the template path, if not fall back to default
|
// check if css folder exists in the template path, if not fall back to default
|
||||||
if (!is_dir($cms->css)) {
|
if (!is_dir($cms->css)) {
|
||||||
@@ -103,19 +99,49 @@ if (!is_dir($cms->pictures)) {
|
|||||||
$cms->pictures = LAYOUT.DEFAULT_TEMPLATE.PICTURES;
|
$cms->pictures = LAYOUT.DEFAULT_TEMPLATE.PICTURES;
|
||||||
}
|
}
|
||||||
if (!is_dir($cms->cache_pictures)) {
|
if (!is_dir($cms->cache_pictures)) {
|
||||||
$cms->cache_pictures = LAYOUT.DEFAULT_TEMPLATE.CACHE.IMAGES;
|
$cms->cache_pictures = LAYOUT.DEFAULT_TEMPLATE.CACHE;
|
||||||
|
$cms->cache_pictures_root = ROOT.$cms->cache_pictures;
|
||||||
}
|
}
|
||||||
|
|
||||||
// if the template_dir is != DEFAULT_TEMPLATE, then try to make a lang switch
|
// if the template_dir is != DEFAULT_TEMPLATE, then try to make a lang switch
|
||||||
// if the default lang is not like the lang given, switch lang
|
// if the default lang is not like the lang given, switch lang
|
||||||
if (false === strstr(LAYOUT.DEFAULT_TEMPLATE.LANG, $cms->lang_dir) || strcasecmp(DEFAULT_LANG, $lang)) {
|
if (false === strstr(LAYOUT.DEFAULT_TEMPLATE.LANG, $cms->lang_dir) ||
|
||||||
$cms->debug('LANG', 'Orig: '.LAYOUT.DEFAULT_TEMPLATE.LANG.', New: '.$cms->lang_dir.' | Orig Lang: '.DEFAULT_LANG.', New Lang: '.$lang);
|
strcasecmp(defined('SITE_LANG') ? SITE_LANG : DEFAULT_LANG, $lang)
|
||||||
|
) {
|
||||||
|
$cms->debug('LANG', 'Orig: '.LAYOUT.DEFAULT_TEMPLATE.LANG.', New: '.$cms->lang_dir.' | Orig Lang: '.(defined('SITE_LANG') ? SITE_LANG : DEFAULT_LANG).', New Lang: '.$lang);
|
||||||
$cms->l->l10nReloadMOfile($lang, $cms->lang_dir);
|
$cms->l->l10nReloadMOfile($lang, $cms->lang_dir);
|
||||||
$smarty->l10n->l10nReloadMOfile($lang, $cms->lang_dir);
|
// if we have login class
|
||||||
|
if ($login) {
|
||||||
|
$login->l->l10nReloadMOfile($lang, $cms->lang_dir);
|
||||||
|
}
|
||||||
|
// if we have smarty template class
|
||||||
|
if ($smarty) {
|
||||||
|
$smarty->l10n->l10nReloadMOfile($lang, $cms->lang_dir);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// javascrip translate data as template for auto translate
|
||||||
|
if (!$TEMPLATE_TRANSLATE) {
|
||||||
|
$cms->debug('LANG', 'Load lang: '.$lang.', for page file jsTranslate_'.$lang.'.tpl');
|
||||||
|
$TEMPLATE_TRANSLATE = 'jsTranslate_'.$lang.'.tpl';
|
||||||
|
} else {
|
||||||
|
// we assume we have some fixed set
|
||||||
|
// we must add _<$lang>
|
||||||
|
// if .tpl, put before .tpl
|
||||||
|
// if not .tpl, add _<$lang>.tpl
|
||||||
|
if (strpos($TEMPLATE_TRANSLATE, '.tpl')) {
|
||||||
|
$TEMPLATE_TRANSLATE = str_replace('.tpl', '_'.$lang.'.tpl', $TEMPLATE_TRANSLATE);
|
||||||
|
} else {
|
||||||
|
$TEMPLATE_TRANSLATE .= '_'.$lang.'.tpl';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// if we can't find it, dump it
|
||||||
|
if (!file_exists($smarty->getTemplateDir()[0].DS.$TEMPLATE_TRANSLATE)) {
|
||||||
|
unset($TEMPLATE_TRANSLATE);
|
||||||
}
|
}
|
||||||
|
|
||||||
// $cms->debug("LANGUAGE", "L: $lang | ".$cms->lang_dir." | MO File: ".$cms->l->mofile);
|
// $cms->debug("LANGUAGE", "L: $lang | ".$cms->lang_dir." | MO File: ".$cms->l->mofile);
|
||||||
$cms->debug("LANGUAGE", "SL: ".$_SESSION['DEFAULT_CHARSET']." | ".$_SESSION['LANG']." | ".$_SESSION['DEFAULT_LANG']);
|
$cms->debug("LANGUAGE", "SL: ".$_SESSION['DEFAULT_CHARSET']." | ".$_SESSION['LANG']." | ".$_SESSION['DEFAULT_LANG']);
|
||||||
$cms->debug("TEMPLATE", "P: ".$smarty->getTemplateDir()[0]);
|
$cms->debug("TEMPLATE", "P: ".$smarty->getTemplateDir()[0]);
|
||||||
|
|
||||||
# __END__
|
// __END__
|
||||||
@@ -101,4 +101,4 @@ if (is_dir(BASE.CACHE)) {
|
|||||||
}
|
}
|
||||||
$smarty->display($MASTER_TEMPLATE_NAME, $TEMPLATE.$lang, $TEMPLATE.$lang);
|
$smarty->display($MASTER_TEMPLATE_NAME, $TEMPLATE.$lang, $TEMPLATE.$lang);
|
||||||
|
|
||||||
# __END__
|
// __END__
|
||||||
@@ -22,12 +22,12 @@ $DB_DEBUG = 1;
|
|||||||
|
|
||||||
extract($_POST, EXTR_SKIP);
|
extract($_POST, EXTR_SKIP);
|
||||||
|
|
||||||
$table_width = 750;
|
$table_width = '100%';
|
||||||
// this is for certain CMS modules that set a relative path
|
// this is for certain CMS modules that set a relative path
|
||||||
define(REL_PATH, '');
|
define('REL_PATH', '');
|
||||||
|
|
||||||
ob_start();
|
ob_start();
|
||||||
include("config.inc");
|
require 'config.php';
|
||||||
// set session name here
|
// set session name here
|
||||||
define('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
define('SET_SESSION_NAME', EDIT_SESSION_NAME);
|
||||||
// overrride debug flags
|
// overrride debug flags
|
||||||
@@ -137,10 +137,13 @@ $DATA['GROUP_NAME'] = $_SESSION["GROUP_NAME"];
|
|||||||
$DATA['GROUP_LEVEL'] = $_SESSION["GROUP_LEVEL"];
|
$DATA['GROUP_LEVEL'] = $_SESSION["GROUP_LEVEL"];
|
||||||
$PAGES = $_SESSION["PAGES"];
|
$PAGES = $_SESSION["PAGES"];
|
||||||
|
|
||||||
//$form->debug('menu', $form->print_ar($PAGES));
|
//$form->debug('menu', $form->printAr($PAGES));
|
||||||
|
|
||||||
// baue nav aus $PAGES ...
|
// build nav from $PAGES ...
|
||||||
for ($i = 0; $i < count($PAGES); $i ++) {
|
if (!is_array($PAGES)) {
|
||||||
|
$PAGES = array ();
|
||||||
|
}
|
||||||
|
for ($i = 0, $i_max = count($PAGES); $i < $i_max; $i ++) {
|
||||||
if ($PAGES[$i]["menu"] && $PAGES[$i]["online"]) {
|
if ($PAGES[$i]["menu"] && $PAGES[$i]["online"]) {
|
||||||
$menuarray[] = $PAGES[$i];
|
$menuarray[] = $PAGES[$i];
|
||||||
}
|
}
|
||||||
@@ -204,6 +207,7 @@ if ($form->yes) {
|
|||||||
$elements[] = $form->formCreateElement("login_error_date_last");
|
$elements[] = $form->formCreateElement("login_error_date_last");
|
||||||
$elements[] = $form->formCreateElement("login_error_date_first");
|
$elements[] = $form->formCreateElement("login_error_date_first");
|
||||||
$elements[] = $form->formCreateElement("enabled");
|
$elements[] = $form->formCreateElement("enabled");
|
||||||
|
$elements[] = $form->formCreateElement("protected");
|
||||||
$elements[] = $form->formCreateElement("username");
|
$elements[] = $form->formCreateElement("username");
|
||||||
$elements[] = $form->formCreateElement("password");
|
$elements[] = $form->formCreateElement("password");
|
||||||
$elements[] = $form->formCreateElement("password_change_interval");
|
$elements[] = $form->formCreateElement("password_change_interval");
|
||||||
@@ -283,6 +287,8 @@ if ($form->yes) {
|
|||||||
break;
|
break;
|
||||||
case "edit_access":
|
case "edit_access":
|
||||||
$elements[] = $form->formCreateElement("name");
|
$elements[] = $form->formCreateElement("name");
|
||||||
|
$elements[] = $form->formCreateElement("enabled");
|
||||||
|
$elements[] = $form->formCreateElement("protected");
|
||||||
$elements[] = $form->formCreateElement("color");
|
$elements[] = $form->formCreateElement("color");
|
||||||
$elements[] = $form->formCreateElement("description");
|
$elements[] = $form->formCreateElement("description");
|
||||||
// add name/value list here
|
// add name/value list here
|
||||||
@@ -292,7 +298,7 @@ if ($form->yes) {
|
|||||||
print "[No valid page definition given]";
|
print "[No valid page definition given]";
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// $form->debug('edit', "Elements: <pre>".$form->print_ar($elements));
|
// $form->debug('edit', "Elements: <pre>".$form->printAr($elements));
|
||||||
$DATA['elements'] = $elements;
|
$DATA['elements'] = $elements;
|
||||||
$DATA['hidden'] = $form->formCreateHiddenFields();
|
$DATA['hidden'] = $form->formCreateHiddenFields();
|
||||||
$DATA['save_delete'] = $form->formCreateSaveDelete();
|
$DATA['save_delete'] = $form->formCreateSaveDelete();
|
||||||
@@ -304,7 +310,7 @@ $DEBUG_DATA['DEBUG'] = $DEBUG_TMPL;
|
|||||||
// create main data array
|
// create main data array
|
||||||
$CONTENT_DATA = array_merge($HEADER, $DATA, $DEBUG_DATA);
|
$CONTENT_DATA = array_merge($HEADER, $DATA, $DEBUG_DATA);
|
||||||
// data is 1:1 mapping (all vars, values, etc)
|
// data is 1:1 mapping (all vars, values, etc)
|
||||||
while (list($key, $value) = each($CONTENT_DATA)) {
|
foreach ($CONTENT_DATA as $key => $value) {
|
||||||
$smarty->assign($key, $value);
|
$smarty->assign($key, $value);
|
||||||
}
|
}
|
||||||
if (is_dir(BASE.TEMPLATES_C)) {
|
if (is_dir(BASE.TEMPLATES_C)) {
|
||||||
@@ -319,4 +325,4 @@ $smarty->display('edit_body.tpl');
|
|||||||
echo $login->printErrorMsg();
|
echo $login->printErrorMsg();
|
||||||
echo $form->printErrorMsg();
|
echo $form->printErrorMsg();
|
||||||
|
|
||||||
# __END__
|
// __END__
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
$edit_access = array (
|
$edit_access = array (
|
||||||
"table_array" => array (
|
"table_array" => array (
|
||||||
"edit_access_id" => array (
|
"edit_access_id" => array (
|
||||||
@@ -28,6 +29,26 @@ $edit_access = array (
|
|||||||
"error_check" => "custom",
|
"error_check" => "custom",
|
||||||
"error_regex" => "/[\dA-Fa-f]{6}/",
|
"error_regex" => "/[\dA-Fa-f]{6}/",
|
||||||
"error_example" => "F6A544"
|
"error_example" => "F6A544"
|
||||||
|
),
|
||||||
|
"enabled" => array (
|
||||||
|
"value" => $GLOBALS["enabled"],
|
||||||
|
"output_name" => "Enabled",
|
||||||
|
"type" => "binary",
|
||||||
|
"int" => 1, // OR "bool" => 1
|
||||||
|
"element_list" => array (
|
||||||
|
"1" => "Yes",
|
||||||
|
"0" => "No"
|
||||||
|
)
|
||||||
|
),
|
||||||
|
"protected" => array (
|
||||||
|
"value" => $GLOBALS["protected"],
|
||||||
|
"output_name" => "Protected",
|
||||||
|
"type" => "binary",
|
||||||
|
"int" => 1,
|
||||||
|
"element_list" => array (
|
||||||
|
"1" => "Yes",
|
||||||
|
"0" => "No"
|
||||||
|
)
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
"table_name" => "edit_access",
|
"table_name" => "edit_access",
|
||||||
@@ -75,4 +96,4 @@ $edit_access = array (
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
# __END__
|
// __END__
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
$edit_groups = array (
|
$edit_groups = array (
|
||||||
"table_array" => array (
|
"table_array" => array (
|
||||||
"edit_group_id" => array (
|
"edit_group_id" => array (
|
||||||
@@ -98,4 +99,4 @@ $edit_groups = array (
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
# __END__
|
// __END__
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
$edit_languages=array (
|
$edit_languages=array (
|
||||||
"table_array" => array (
|
"table_array" => array (
|
||||||
"edit_language_id" => array (
|
"edit_language_id" => array (
|
||||||
@@ -71,4 +72,4 @@ $edit_languages=array (
|
|||||||
"table_name" => "edit_language"
|
"table_name" => "edit_language"
|
||||||
);
|
);
|
||||||
|
|
||||||
# __END__
|
// __END__
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
$edit_menu_group = array (
|
$edit_menu_group = array (
|
||||||
"table_array" => array (
|
"table_array" => array (
|
||||||
"edit_menu_group_id" => array (
|
"edit_menu_group_id" => array (
|
||||||
@@ -36,4 +37,4 @@ $edit_menu_group = array (
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
# __END__
|
// __END__
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
$edit_pages = array (
|
$edit_pages = array (
|
||||||
"table_array" => array (
|
"table_array" => array (
|
||||||
"edit_page_id" => array (
|
"edit_page_id" => array (
|
||||||
@@ -176,4 +177,4 @@ $edit_pages = array (
|
|||||||
) // element list
|
) // element list
|
||||||
);
|
);
|
||||||
|
|
||||||
# __END__
|
// __END__
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
$edit_schemes = array (
|
$edit_schemes = array (
|
||||||
"table_array" => array (
|
"table_array" => array (
|
||||||
"edit_scheme_id" => array (
|
"edit_scheme_id" => array (
|
||||||
@@ -53,4 +54,4 @@ $edit_schemes = array (
|
|||||||
)
|
)
|
||||||
); // main array
|
); // main array
|
||||||
|
|
||||||
# __END__
|
// __END__
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
$edit_users = array (
|
$edit_users = array (
|
||||||
"table_array" => array (
|
"table_array" => array (
|
||||||
"edit_user_id" => array (
|
"edit_user_id" => array (
|
||||||
@@ -29,6 +30,7 @@ $edit_users = array (
|
|||||||
)
|
)
|
||||||
),
|
),
|
||||||
// password date when first insert and password is set, needs special field with connection to password
|
// password date when first insert and password is set, needs special field with connection to password
|
||||||
|
// password reset force interval, if set, user needs to reset password after X time period
|
||||||
'password_change_interval' => array (
|
'password_change_interval' => array (
|
||||||
'value' => $GLOBALS['password_change_interval'],
|
'value' => $GLOBALS['password_change_interval'],
|
||||||
'output_name' => 'Password change interval',
|
'output_name' => 'Password change interval',
|
||||||
@@ -38,7 +40,6 @@ $edit_users = array (
|
|||||||
'size' => 5, // make it 5 chars long
|
'size' => 5, // make it 5 chars long
|
||||||
'length' => 5
|
'length' => 5
|
||||||
),
|
),
|
||||||
// password reset force interval, if set, user needs to reset password after X time period
|
|
||||||
"enabled" => array (
|
"enabled" => array (
|
||||||
"value" => $GLOBALS["enabled"],
|
"value" => $GLOBALS["enabled"],
|
||||||
"output_name" => "Enabled",
|
"output_name" => "Enabled",
|
||||||
@@ -163,10 +164,15 @@ $edit_users = array (
|
|||||||
"type" => "view",
|
"type" => "view",
|
||||||
"empty" => "-"
|
"empty" => "-"
|
||||||
),
|
),
|
||||||
// planned delete lock flag
|
|
||||||
"protected" => array (
|
"protected" => array (
|
||||||
"value" => $GLOBALS["protected"],
|
"value" => $GLOBALS["protected"],
|
||||||
"int" => 1
|
"output_name" => "Protected",
|
||||||
|
"type" => "binary",
|
||||||
|
"int" => 1,
|
||||||
|
"element_list" => array (
|
||||||
|
"1" => "Yes",
|
||||||
|
"0" => "No"
|
||||||
|
)
|
||||||
)
|
)
|
||||||
),
|
),
|
||||||
"load_query" => "SELECT edit_user_id, username, enabled, debug, db_debug, strict, locked, login_error_count FROM edit_user ORDER BY username",
|
"load_query" => "SELECT edit_user_id, username, enabled, debug, db_debug, strict, locked, login_error_count FROM edit_user ORDER BY username",
|
||||||
@@ -252,4 +258,4 @@ $edit_users = array (
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
# __END__
|
// __END__
|
||||||
@@ -1,4 +1,5 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
$edit_visible_group = array (
|
$edit_visible_group = array (
|
||||||
"table_array" => array (
|
"table_array" => array (
|
||||||
"edit_visible_group_id" => array (
|
"edit_visible_group_id" => array (
|
||||||
@@ -29,4 +30,4 @@ $edit_visible_group = array (
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
# __END__
|
// __END__
|
||||||
0
www/layout/admin/default/cache/index.php
vendored
Normal file
0
www/layout/admin/default/cache/index.php
vendored
Normal file
@@ -367,6 +367,30 @@ input[type="text"]:focus, textarea:focus, select:focus {
|
|||||||
font-size: 8px;
|
font-size: 8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* NEW VERSION with CSS key frame animation */
|
||||||
|
.progress {
|
||||||
|
width: 100px;
|
||||||
|
height: 100px;
|
||||||
|
background: rgba(255, 255, 255, 0.6);
|
||||||
|
border: 20px solid rgba(255, 255, 255 ,0.25);
|
||||||
|
border-left-color: rgba(3, 155, 229 ,1);
|
||||||
|
border-top-color: rgba(3, 155, 229 ,1);
|
||||||
|
border-radius: 50%;
|
||||||
|
display: inline-block;
|
||||||
|
animation: rotate 600ms infinite linear;
|
||||||
|
/* align */
|
||||||
|
left: 0;
|
||||||
|
top: 0;
|
||||||
|
position: absolute;
|
||||||
|
z-index: 100;
|
||||||
|
}
|
||||||
|
/* Animation for above progress */
|
||||||
|
@keyframes rotate {
|
||||||
|
to {
|
||||||
|
transform: rotate(1turn)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* ***************************** ADMIN EDIT INTERFACE COLORS ********************************* */
|
/* ***************************** ADMIN EDIT INTERFACE COLORS ********************************* */
|
||||||
/* set all colors here and not in the config file */
|
/* set all colors here and not in the config file */
|
||||||
/* for edit interface */
|
/* for edit interface */
|
||||||
|
|||||||
88
www/layout/admin/default/css/file-uploader/fileuploader.css
Normal file
88
www/layout/admin/default/css/file-uploader/fileuploader.css
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
.qq-uploader {
|
||||||
|
position: relative;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-upload-button {
|
||||||
|
display: block; /* or inline-block */
|
||||||
|
width: 105px;
|
||||||
|
padding: 7px 0;
|
||||||
|
text-align: center;
|
||||||
|
background: #880000;
|
||||||
|
border-bottom: 1px solid #ddd;
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
.qq-upload-button-hover {
|
||||||
|
background: #cc0000;
|
||||||
|
}
|
||||||
|
.qq-upload-button-focus {
|
||||||
|
outline: 1px dotted black;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-upload-drop-area {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
min-height: 70px;
|
||||||
|
z-index: 2;
|
||||||
|
background: #FF9797;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.qq-upload-drop-area span {
|
||||||
|
display: block;
|
||||||
|
position: absolute;
|
||||||
|
top: 50%;
|
||||||
|
width: 100%;
|
||||||
|
margin-top: -8px;
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
.qq-upload-drop-area-active {
|
||||||
|
background:
|
||||||
|
#FF7171;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-upload-list {
|
||||||
|
margin:
|
||||||
|
15px 35px;
|
||||||
|
padding: 0;
|
||||||
|
list-style: disc;
|
||||||
|
}
|
||||||
|
.qq-upload-list li {
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
line-height: 15px;
|
||||||
|
font-size: 12px;
|
||||||
|
}
|
||||||
|
.qq-upload-file, .qq-upload-spinner, .qq-upload-size, .qq-upload-cancel, .qq-upload-failed-text {
|
||||||
|
margin-right: 7px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-upload-file {
|
||||||
|
}
|
||||||
|
.qq-upload-spinner {
|
||||||
|
display: inline-block;
|
||||||
|
/*background: url("loading.gif");*/
|
||||||
|
width: 15px;
|
||||||
|
height: 15px;
|
||||||
|
vertical-align: text-bottom;
|
||||||
|
/* non gif css rotate */
|
||||||
|
background: rgba(255, 255, 255, 0.6);
|
||||||
|
border: 2px solid rgba(255, 255, 255, 0.25);
|
||||||
|
border-left-color: rgba(102, 102, 102 ,1);
|
||||||
|
border-right-color: rgba(102, 102, 102 ,1);
|
||||||
|
border-radius: 50%;
|
||||||
|
animation: rotate 600ms infinite linear;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-upload-size, .qq-upload-cancel {
|
||||||
|
font-size: 11px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-upload-failed-text {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.qq-upload-fail .qq-upload-failed-text {
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
0
www/layout/admin/default/css/index.php
Normal file
0
www/layout/admin/default/css/index.php
Normal file
0
www/layout/admin/default/images/index.php
Normal file
0
www/layout/admin/default/images/index.php
Normal file
0
www/layout/admin/default/index.php
Normal file
0
www/layout/admin/default/index.php
Normal file
@@ -2,6 +2,8 @@
|
|||||||
code is taken and adapted from dokuwiki
|
code is taken and adapted from dokuwiki
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* jshint esversion: 6 */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Some browser detection
|
* Some browser detection
|
||||||
*/
|
*/
|
||||||
@@ -15,20 +17,28 @@ if (clientPC.indexOf('opera') != -1) {
|
|||||||
var is_opera_preseven = (window.opera && !document.childNodes);
|
var is_opera_preseven = (window.opera && !document.childNodes);
|
||||||
var is_opera_seven = (window.opera && document.childNodes);
|
var is_opera_seven = (window.opera && document.childNodes);
|
||||||
}
|
}
|
||||||
|
// debug set
|
||||||
|
var FRONTEND_DEBUG = false;
|
||||||
|
var DEBUG = true;
|
||||||
|
if (!DEBUG) {
|
||||||
|
$($H(window.console)).each(function(w) {
|
||||||
|
window.console[w.key] = function() {};
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: pop
|
||||||
|
// PARAMS: url, window name, features
|
||||||
|
// RETURN: none
|
||||||
|
// DESC : opens a popup window with winNAme and given features (string)
|
||||||
function pop(theURL, winName, features) {
|
function pop(theURL, winName, features) {
|
||||||
winName = window.open(theURL, winName, features);
|
winName = window.open(theURL, winName, features);
|
||||||
winName.focus();
|
winName.focus();
|
||||||
}
|
}
|
||||||
|
|
||||||
function emd_check_checkbox() {
|
// METHOD: expandTA
|
||||||
for (i = 0; i < document.manage_emails.length; i ++) {
|
// PARAMS: id
|
||||||
if (document.manage_emails.elements[i].checked == false && document.manage_emails.elements[i].type == 'checkbox') {
|
// RETURN: none
|
||||||
document.manage_emails.elements[i].checked = true;
|
// DESC : automatically resize a text area based on the amount of lines in it
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function expandTA(ta_id) {
|
function expandTA(ta_id) {
|
||||||
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
|
||||||
@@ -48,11 +58,13 @@ function expandTA(ta_id) {
|
|||||||
}
|
}
|
||||||
ta.rows = numNewRows + theRows.length;
|
ta.rows = numNewRows + theRows.length;
|
||||||
}
|
}
|
||||||
|
|
||||||
// METHOD: ShowHideMenu
|
// METHOD: ShowHideMenu
|
||||||
// PARAMS: status -> show or hide
|
// PARAMS: status -> show or hide
|
||||||
// id -> id to work on
|
// id -> id to work on
|
||||||
// RETURN: none
|
// RETURN: none
|
||||||
// DESC: shows or hides the menu
|
// DESC: shows or hides the menu
|
||||||
|
// this is used in some old menu templates
|
||||||
function ShowHideMenu(status, id)
|
function ShowHideMenu(status, id)
|
||||||
{
|
{
|
||||||
if (status == 'show') {
|
if (status == 'show') {
|
||||||
@@ -68,18 +80,7 @@ function ShowHideMenu(status, id)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function ShowHideDiv(id)
|
// used in old templates
|
||||||
{
|
|
||||||
element = document.getElementById(id);
|
|
||||||
if (element.className == 'visible' || !element.className) {
|
|
||||||
element.className = 'hidden';
|
|
||||||
} else {
|
|
||||||
element.className = 'visible';
|
|
||||||
}
|
|
||||||
|
|
||||||
// alert('E: ' + element.className + ' -- ' + element.style.visibility);
|
|
||||||
}
|
|
||||||
|
|
||||||
// move element action
|
// move element action
|
||||||
function mv(id, direction)
|
function mv(id, direction)
|
||||||
{
|
{
|
||||||
@@ -105,10 +106,39 @@ function le(id)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// METHOD: sh
|
||||||
|
// PARAMS: id -> element to hide
|
||||||
|
// showText -> text for the element if shown
|
||||||
|
// hideText -> text for the element if hidden
|
||||||
|
// RETURN: returns true if hidden, or false if not
|
||||||
|
// DESC : hides an element, additional writes 1 (show) or 0 (hide) into <id>Flag field
|
||||||
|
// this needs scriptacolous installed for BlindUp/BlindDown
|
||||||
|
function sh(id, showText, hideText)
|
||||||
|
{
|
||||||
|
flag = id + 'Flag';
|
||||||
|
btn = id + 'Btn';
|
||||||
|
// get status from element (hidden or visible)
|
||||||
|
divStatus = $(id).visible();
|
||||||
|
//console.log('Set flag %s for element %s', divStatus, id);
|
||||||
|
if (divStatus) {
|
||||||
|
// hide the element
|
||||||
|
Effect.BlindUp(id, {duration:0.3});
|
||||||
|
$(flag).value = 0;
|
||||||
|
$(btn).innerHTML = showText;
|
||||||
|
} else if (!divStatus) {
|
||||||
|
// show the element
|
||||||
|
Effect.BlindDown(id, {duration:0.3});
|
||||||
|
$(flag).value = 1;
|
||||||
|
$(btn).innerHTML = hideText;
|
||||||
|
}
|
||||||
|
// return current button status
|
||||||
|
return divStatus;
|
||||||
|
}
|
||||||
|
|
||||||
// METHOD: getWindowSize
|
// METHOD: getWindowSize
|
||||||
// PARAMS: none
|
// PARAMS: none
|
||||||
// RETURN: array with width/height
|
// RETURN: array with width/height
|
||||||
// DESC: wrapper to get the real window size for the current browser window
|
// DESC : wrapper to get the real window size for the current browser window
|
||||||
function getWindowSize()
|
function getWindowSize()
|
||||||
{
|
{
|
||||||
var width, height;
|
var width, height;
|
||||||
@@ -123,7 +153,7 @@ function getWindowSize()
|
|||||||
// METHOD: getScrollOffset
|
// METHOD: getScrollOffset
|
||||||
// PARAMS: none
|
// PARAMS: none
|
||||||
// RETURN: array with x/y px
|
// RETURN: array with x/y px
|
||||||
// DESC: wrapper to get the correct scroll offset
|
// DESC : wrapper to get the correct scroll offset
|
||||||
function getScrollOffset()
|
function getScrollOffset()
|
||||||
{
|
{
|
||||||
var left, top;
|
var left, top;
|
||||||
@@ -138,7 +168,7 @@ function getScrollOffset()
|
|||||||
// METHOD: setCenter
|
// METHOD: setCenter
|
||||||
// PARAMS: id to set center
|
// PARAMS: id to set center
|
||||||
// RETURN: none
|
// RETURN: none
|
||||||
// DESC: centers div to current window size middle
|
// DESC : centers div to current window size middle
|
||||||
function setCenter(id, left, top)
|
function setCenter(id, left, top)
|
||||||
{
|
{
|
||||||
// get size of id
|
// get size of id
|
||||||
@@ -164,38 +194,146 @@ function setCenter(id, left, top)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// METHOD sh
|
// METHOD: goToPos()
|
||||||
// PARAMS: id -> element to hide
|
// PARAMS: element, offset (default 0)
|
||||||
// showText -> text for the element if shown
|
// RETURN: none
|
||||||
// hideText -> text for the element if hidden
|
// DESC: goes to an element id position
|
||||||
// RETURN: returns true if hidden, or false if not
|
function goToPos(element, offset = 0)
|
||||||
// DESC: hides an element, additional writes 1 (show) or 0 (hide) into <id>Flag field
|
|
||||||
function sh(id, showText, hideText)
|
|
||||||
{
|
{
|
||||||
flag = id + 'Flag';
|
try {
|
||||||
btn = id + 'Btn';
|
if ($(element))
|
||||||
// get status from element (hidden or visible)
|
{
|
||||||
divStatus = $(id).visible();
|
// get the element pos
|
||||||
//console.log('Set flag %s for element %s', divStatus, id);
|
var pos = $(element).cumulativeOffset();
|
||||||
if (divStatus) {
|
// if not top element and no offset given, set auto offset for top element
|
||||||
// hide the element
|
// also compensate by -40 for some offset calc issue and not have it too much to the header
|
||||||
Effect.BlindUp(id, {duration:0.3});
|
if (pos.top != 0 && offset == 0) {
|
||||||
$(flag).value = 0;
|
offset = ($(GL_main_content_div).style.paddingTop.replace('px', '') * -1) - 40;
|
||||||
$(btn).innerHTML = showText;
|
}
|
||||||
} else if (!divStatus) {
|
//console.log('Scroll to: %s, Offset: %s [%s], PT: %s', element, offset, $('pbsMainContent').style.paddingTop.replace('px', ''), pos.top);
|
||||||
// show the element
|
window.scrollTo(pos.left, pos.top + offset);
|
||||||
Effect.BlindDown(id, {duration:0.3});
|
}
|
||||||
$(flag).value = 1;
|
} catch (err) {
|
||||||
$(btn).innerHTML = hideText;
|
errorCatch(err);
|
||||||
}
|
}
|
||||||
// return current button status
|
|
||||||
return divStatus;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// METHOD: __
|
||||||
|
// PARAMS: text
|
||||||
|
// RETURN: translated text (based on PHP selected language)
|
||||||
|
// DESC : uses the i18n array created in the translation template, that is filled from gettext in PHP (Smarty)
|
||||||
|
function __(string)
|
||||||
|
{
|
||||||
|
if (typeof i18n !== 'undefined' && isObject(i18n) && i18n[string]) {
|
||||||
|
return i18n[string];
|
||||||
|
} else {
|
||||||
|
return string;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: string.format
|
||||||
|
// PARAMS: any, for string format
|
||||||
|
// RETURN: formatted string
|
||||||
|
// DESC : simple sprintf formater for replace
|
||||||
|
// "{0} is cool, {1} is not".format("Alpha", "Beta");
|
||||||
|
// First, checks if it isn't implemented yet.
|
||||||
|
if (!String.prototype.format) {
|
||||||
|
String.prototype.format = function()
|
||||||
|
{
|
||||||
|
var args = arguments;
|
||||||
|
return this.replace(/{(\d+)}/g, function(match, number)
|
||||||
|
{
|
||||||
|
return typeof args[number] != 'undefined' ?
|
||||||
|
args[number] :
|
||||||
|
match
|
||||||
|
;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: numberWithCommas
|
||||||
|
// PARAMS: number
|
||||||
|
// RETURN: formatted with , in thousands
|
||||||
|
// DESC : formats flat number 123456 to 123,456
|
||||||
|
const numberWithCommas = (x) => {
|
||||||
|
var parts = x.toString().split(".");
|
||||||
|
parts[0] = parts[0].replace(/\B(?=(\d{3})+(?!\d))/g, ",");
|
||||||
|
return parts.join(".");
|
||||||
|
};
|
||||||
|
|
||||||
|
// METHOD:
|
||||||
|
// PARAMS: string
|
||||||
|
// RETURN: string with <br>
|
||||||
|
// DESC : converts line breaks to br
|
||||||
|
function convertLBtoBR(string)
|
||||||
|
{
|
||||||
|
return string.replace(/(?:\r\n|\r|\n)/g, '<br>');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!String.prototype.escapeHTML) {
|
||||||
|
String.prototype.escapeHTML = function() {
|
||||||
|
return this.replace(/[&<>"'\/]/g, function (s) {
|
||||||
|
var entityMap = {
|
||||||
|
"&": "&",
|
||||||
|
"<": "<",
|
||||||
|
">": ">",
|
||||||
|
'"': '"',
|
||||||
|
"'": ''',
|
||||||
|
"/": '/'
|
||||||
|
};
|
||||||
|
|
||||||
|
return entityMap[s];
|
||||||
|
});
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!String.prototype.unescapeHTML) {
|
||||||
|
String.prototype.unescapeHTML = function() {
|
||||||
|
return this.replace(/&[#\w]+;/g, function (s) {
|
||||||
|
var entityMap = {
|
||||||
|
"&": "&",
|
||||||
|
"<": "<",
|
||||||
|
">": ">",
|
||||||
|
'"': '"',
|
||||||
|
''': "'",
|
||||||
|
'/': "/"
|
||||||
|
};
|
||||||
|
|
||||||
|
return entityMap[s];
|
||||||
|
});
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: getTimestamp
|
||||||
|
// PARAMS: none
|
||||||
|
// RETURN: timestamp (in milliseconds)
|
||||||
|
// DESC : returns current timestamp (unix timestamp)
|
||||||
|
function getTimestamp()
|
||||||
|
{
|
||||||
|
let date = new Date();
|
||||||
|
return date.getTime();
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: isObject
|
||||||
|
// PARAMS: possible object
|
||||||
|
// RETURN: true/false if it is an object or not
|
||||||
|
function isObject(val) {
|
||||||
|
if (val === null) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return ((typeof val === 'function') || (typeof val === 'object'));
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: exists
|
||||||
|
// PARAMS: uid
|
||||||
|
// RETURN: true/false
|
||||||
|
// DESC : checks if a DOM element actually exists
|
||||||
|
const exists = (id) => $(id) ? true : false;
|
||||||
|
|
||||||
// METHOD: formatBytes
|
// METHOD: formatBytes
|
||||||
// PARAMS: bytes in int
|
// PARAMS: bytes in int
|
||||||
// RETURN: string in GB/MB/KB
|
// RETURN: string in GB/MB/KB
|
||||||
// DESC: converts a int number into bytes with prefix in two decimals precision
|
// DESC : converts a int number into bytes with prefix in two decimals precision
|
||||||
// currently precision is fixed, if dynamic needs check for max/min precision
|
// currently precision is fixed, if dynamic needs check for max/min precision
|
||||||
function formatBytes(bytes)
|
function formatBytes(bytes)
|
||||||
{
|
{
|
||||||
@@ -207,3 +345,441 @@ function formatBytes(bytes)
|
|||||||
|
|
||||||
return parseFloat(Math.round(bytes * Math.pow(10, 2)) / Math.pow(10, 2)) + ['kB', 'MB', 'GB', 'TB', 'PB', 'EB'][i];
|
return parseFloat(Math.round(bytes * Math.pow(10, 2)) / Math.pow(10, 2)) + ['kB', 'MB', 'GB', 'TB', 'PB', 'EB'][i];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// METHOD: goToPos()
|
||||||
|
// PARAMS: element, offset (default 0)
|
||||||
|
// RETURN: none
|
||||||
|
// DESC : goes to an element id position
|
||||||
|
function goToPos(element, offset = 0)
|
||||||
|
{
|
||||||
|
try {
|
||||||
|
if ($(element))
|
||||||
|
{
|
||||||
|
// get the element pos
|
||||||
|
var pos = $(element).cumulativeOffset();
|
||||||
|
// if not top element and no offset given, set auto offset for top element
|
||||||
|
// also compensate by -40 for some offset calc issue and not have it too much to the header
|
||||||
|
if (pos.top != 0 && offset == 0) {
|
||||||
|
offset = ($(GL_main_content_div).style.paddingTop.replace('px', '') * -1) - 40;
|
||||||
|
}
|
||||||
|
//console.log('Scroll to: %s, Offset: %s [%s], PT: %s', element, offset, $('pbsMainContent').style.paddingTop.replace('px', ''), pos.top);
|
||||||
|
window.scrollTo(pos.left, pos.top + offset);
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
errorCatch(err);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: errorCatch
|
||||||
|
// PARAMS: err (error from try/catch
|
||||||
|
// RETURN: none
|
||||||
|
// DESC : prints out error messages based on data available from the browser
|
||||||
|
function errorCatch(err)
|
||||||
|
{
|
||||||
|
// for FF & Chrome
|
||||||
|
if (err.stack) {
|
||||||
|
// only FF
|
||||||
|
if (err.lineNumber) {
|
||||||
|
console.log('ERROR[%s:%s] %s', err.name, err.lineNumber, err.message);
|
||||||
|
} else if (err.line) {
|
||||||
|
// only Safari
|
||||||
|
console.log('ERROR[%s:%s] %s', err.name, err.line, err.message);
|
||||||
|
} else {
|
||||||
|
console.log('ERROR[%s] %s', err.name, err.message);
|
||||||
|
}
|
||||||
|
// stack trace
|
||||||
|
console.log('ERROR[stack] %s', err.stack);
|
||||||
|
} else if (err.number) {
|
||||||
|
// IE
|
||||||
|
console.log('ERROR[%s:%s] %s', err.name, err.number, err.message);
|
||||||
|
console.log('ERROR[description] %s', err.description);
|
||||||
|
} else {
|
||||||
|
// the rest
|
||||||
|
console.log('ERROR[%s] %s', err.name, err.message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: actionIndicator
|
||||||
|
// PARAMS: none
|
||||||
|
// RETURN: none
|
||||||
|
// DESC : show or hide the "do" overlay
|
||||||
|
function actionIndicator(loc = '')
|
||||||
|
{
|
||||||
|
if ($('overlayBox').visible()) {
|
||||||
|
actionIndicatorHide(loc);
|
||||||
|
} else {
|
||||||
|
actionIndicatorShow(loc);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: actionIndicatorShow/actionIndicatorHide
|
||||||
|
// PARAMS: loc for console log info
|
||||||
|
// RETURN: none
|
||||||
|
// DESC : explicit show/hide for action Indicator
|
||||||
|
// instead of automatically show or hide, do
|
||||||
|
// on command
|
||||||
|
function actionIndicatorShow(loc = '')
|
||||||
|
{
|
||||||
|
console.log('Indicator: SHOW [%s]', loc);
|
||||||
|
$('indicator').addClassName('progress');
|
||||||
|
setCenter('indicator', true, true);
|
||||||
|
$('indicator').show();
|
||||||
|
overlayBoxShow();
|
||||||
|
}
|
||||||
|
function actionIndicatorHide(loc = '')
|
||||||
|
{
|
||||||
|
console.log('Indicator: HIDE [%s]', loc);
|
||||||
|
$('indicator').hide();
|
||||||
|
$('indicator').removeClassName('progress');
|
||||||
|
overlayBoxHide();
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: overlayBoxView
|
||||||
|
// PARAMS: none
|
||||||
|
// RETURN: none
|
||||||
|
// DESC : shows or hides the overlay box
|
||||||
|
function overlayBoxShow()
|
||||||
|
{
|
||||||
|
// check if overlay box exists and if yes set the z-index to 100
|
||||||
|
if ($('overlayBox').visible()) {
|
||||||
|
$('overlayBox').style.zIndex = "100";
|
||||||
|
} else {
|
||||||
|
$('overlayBox').show();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function overlayBoxHide()
|
||||||
|
{
|
||||||
|
// if the overlay box z-index is 100, do no hide, but set to 98
|
||||||
|
if ($('overlayBox').style.zIndex == 100) {
|
||||||
|
$('overlayBox').style.zIndex = "98";
|
||||||
|
} else {
|
||||||
|
$('overlayBox').hide();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: setOverlayBox
|
||||||
|
// PARAMS: none
|
||||||
|
// RETURN: none
|
||||||
|
// DESC : position the overlay block box and shows it
|
||||||
|
function setOverlayBox()
|
||||||
|
{
|
||||||
|
var viewport = document.viewport.getDimensions();
|
||||||
|
$('overlayBox').setStyle ({
|
||||||
|
width: '100%',
|
||||||
|
height: '100%'
|
||||||
|
});
|
||||||
|
$('overlayBox').show();
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: ClearCall
|
||||||
|
// PARAMS: none
|
||||||
|
// RETURN: none
|
||||||
|
// DESC : the abort call, clears the action box and hides it and the overlay box
|
||||||
|
function ClearCall()
|
||||||
|
{
|
||||||
|
$('actionBox').innerHTML = '';
|
||||||
|
$('actionBox').hide();
|
||||||
|
$('overlayBox').hide();
|
||||||
|
}
|
||||||
|
|
||||||
|
// *** DOM MANAGEMENT FUNCTIONS
|
||||||
|
// METHOD: cel [create element]
|
||||||
|
// PARAMS: tag: must set tag (div, span, etc)
|
||||||
|
// id: optional set for id, if input, select will be used for name
|
||||||
|
// content: text content inside, is skipped if sub elements exist
|
||||||
|
// css: array for css tags
|
||||||
|
// options: anything else (value, placeholder, OnClick, style)
|
||||||
|
// RETURN: object
|
||||||
|
// DESC : creates object for DOM element creation flow
|
||||||
|
const cel = (tag, id = '', content = '', css = [], options = {}) =>
|
||||||
|
_element = {
|
||||||
|
tag: tag,
|
||||||
|
id: id,
|
||||||
|
name: options.name, // override name if set [name gets ignored in tree build anyway]
|
||||||
|
content: content,
|
||||||
|
css: css,
|
||||||
|
options: options,
|
||||||
|
sub: []
|
||||||
|
};
|
||||||
|
|
||||||
|
// METHOD: ael [attach element]
|
||||||
|
// PARAMS: base: object where to attach/search
|
||||||
|
// attach: the object to be attached
|
||||||
|
// id: optional id, if given search in base for this id and attach there
|
||||||
|
// RETURN: "none", technically there is no return needed
|
||||||
|
// DESC : attach a cel created object to another to create a basic DOM tree
|
||||||
|
function ael(base, attach, id = '')
|
||||||
|
{
|
||||||
|
if (id) {
|
||||||
|
// base id match already
|
||||||
|
if (base.id == id) {
|
||||||
|
base.sub.push(Object.assign({}, attach));
|
||||||
|
} else {
|
||||||
|
// sub check
|
||||||
|
if (base.sub.length > 0) {
|
||||||
|
base.sub.each(function(t) {
|
||||||
|
// recursive call to sub element
|
||||||
|
ael(t, attach, id);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
base.sub.push(Object.assign({}, attach));
|
||||||
|
}
|
||||||
|
return base;
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: aelx [attach n elements]
|
||||||
|
// PARAMS: base: object to where we attach the elements
|
||||||
|
// attach 1..n: attach directly to the base element those attachments
|
||||||
|
// RETURN: "none", technically there is no return needed
|
||||||
|
// DESC : directly attach n elements to one master base element
|
||||||
|
// this type does not support attach with optional id
|
||||||
|
function aelx(base, ...attach)
|
||||||
|
{
|
||||||
|
attach.each(function(t) {
|
||||||
|
base.sub.push(Object.assign({}, t));
|
||||||
|
});
|
||||||
|
return base;
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: rel [reset element]
|
||||||
|
// PARAMS: cel created element
|
||||||
|
// RETURN: "none", is self change, but returns base.sub
|
||||||
|
// DESC : resets the sub elements of the base element given
|
||||||
|
const rel = (base) => base.sub = [];
|
||||||
|
|
||||||
|
// METHOD: rcssel [remove a css from the element]
|
||||||
|
// PARAMS: element, style sheet to remove
|
||||||
|
// RETURN: "none", in place because of reference
|
||||||
|
// DESC : searches and removes style from css array
|
||||||
|
function rcssel(_element, css)
|
||||||
|
{
|
||||||
|
let css_index = _element.css.indexOf(css);
|
||||||
|
if (css_index > -1) {
|
||||||
|
_element.css.splice(css_index, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: acssel [add css element]
|
||||||
|
// PARAMS: element, style sheet to add
|
||||||
|
// RETURN: "none", in place add because of reference
|
||||||
|
// DESC : adds a new style sheet to the element given
|
||||||
|
function acssel(_element, css)
|
||||||
|
{
|
||||||
|
let css_index = _element.css.indexOf(css);
|
||||||
|
if (css_index == -1) {
|
||||||
|
_element.css.push(css);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: scssel
|
||||||
|
// PARAMS: element, style to remove, style to add
|
||||||
|
// RETURN: "none", in place add because of reference
|
||||||
|
// DESC : removes one css and adds another
|
||||||
|
// is a wrapper around rcssel/acssel
|
||||||
|
function scssel(_element, rcss, acss)
|
||||||
|
{
|
||||||
|
rcssel(_element, rcss);
|
||||||
|
acssel(_element, acss);
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: phfo [produce html from object]
|
||||||
|
// PARAMS: object tree with dom element declarations
|
||||||
|
// RETURN: HTML string that can be used as innerHTML
|
||||||
|
// DESC : parses the object tree created with cel/ael
|
||||||
|
// and converts it into an HTML string that can
|
||||||
|
// be inserted into the page
|
||||||
|
function phfo(tree)
|
||||||
|
{
|
||||||
|
// holds the elements
|
||||||
|
let content = [];
|
||||||
|
// main part line
|
||||||
|
let line = '<' + tree.tag;
|
||||||
|
// first id, if set
|
||||||
|
if (tree.id) {
|
||||||
|
line += ' id="' + tree.id + '"';
|
||||||
|
// if anything input (input, textarea, select then add name too)
|
||||||
|
if (['input', 'textarea', 'select'].includes(tree.tag)) {
|
||||||
|
line += ' name="' + (tree.name ? tree.name : tree.id) + '"';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// second CSS
|
||||||
|
if (tree.css.length > 0) {
|
||||||
|
line += ' class="';
|
||||||
|
tree.css.each(function(t) {
|
||||||
|
line += t + ' ';
|
||||||
|
});
|
||||||
|
// strip last space
|
||||||
|
line = line.slice(0, -1);
|
||||||
|
line += '"';
|
||||||
|
}
|
||||||
|
// options is anything key = "data"
|
||||||
|
if (tree.options) {
|
||||||
|
// ignores id, name, class as key
|
||||||
|
for (const [key, item] of Object.entries(tree.options)) {
|
||||||
|
if (!['id', 'name', 'class'].includes(key)) {
|
||||||
|
line += ' ' + key + '="' + item + '"';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// finish open tag
|
||||||
|
line += '>';
|
||||||
|
// push finished line
|
||||||
|
content.push(line);
|
||||||
|
// dive into sub tree to attach sub nodes
|
||||||
|
// NOTES: we can have content (text) AND sub nodes at the same level
|
||||||
|
// CONTENT (TEXT) takes preference over SUB NODE in order
|
||||||
|
if (tree.sub.length > 0) {
|
||||||
|
if (tree.content) {
|
||||||
|
content.push(tree.content);
|
||||||
|
}
|
||||||
|
tree.sub.each(function(t) {
|
||||||
|
content.push(phfo(t));
|
||||||
|
});
|
||||||
|
} else if (tree.content) {
|
||||||
|
content.push(tree.content);
|
||||||
|
}
|
||||||
|
// if not input close
|
||||||
|
if (tree.tag != 'input') {
|
||||||
|
content.push('</' + tree.tag + '>');
|
||||||
|
}
|
||||||
|
// combine to string
|
||||||
|
return content.join('');
|
||||||
|
}
|
||||||
|
// *** DOM MANAGEMENT FUNCTIONS
|
||||||
|
|
||||||
|
// BLOCK: html wrappers for quickly creating html data blocks
|
||||||
|
// METHOD: html_options
|
||||||
|
// PARAMS: name/id, array for the options, selected item uid
|
||||||
|
// options_only [def false] if this is true, it will not print the select part
|
||||||
|
// return_string [def false]: return as string and not as element
|
||||||
|
// sort [def '']: if empty as is, else allowed 'keys', 'values' all others are ignored
|
||||||
|
// RETURN: html with build options block
|
||||||
|
// DESC : creates an select/options drop down block.
|
||||||
|
// the array needs to be key -> value format. key is for the option id and value is for the data output
|
||||||
|
function html_options(name, data, selected = '', options_only = false, return_string = false, sort = '')
|
||||||
|
{
|
||||||
|
let content = [];
|
||||||
|
let element_select;
|
||||||
|
let element_option;
|
||||||
|
let data_list = []; // for sorted output
|
||||||
|
// set outside select, gets stripped on return if options only is true
|
||||||
|
element_select = cel('select', name);
|
||||||
|
// console.log('Call for %s, options: %s', name, options_only);
|
||||||
|
if (sort == 'keys') {
|
||||||
|
data_list = Object.keys(data).sort();
|
||||||
|
} else if (sort == 'values') {
|
||||||
|
data_list = Object.keys(data).sort((a, b) => ('' + data[a]).localeCompare(data[b]));
|
||||||
|
} else {
|
||||||
|
data_list = Object.keys(data);
|
||||||
|
}
|
||||||
|
// console.log('ORDER: %s', data_list);
|
||||||
|
// use the previously sorted list
|
||||||
|
// for (const [key, value] of Object.entries(data)) {
|
||||||
|
for (const key of data_list) {
|
||||||
|
let value = data[key];
|
||||||
|
console.log('create [%s] options: key: %s, value: %s', name, key, value);
|
||||||
|
// basic options init
|
||||||
|
let options = {
|
||||||
|
'label': value,
|
||||||
|
'value': key
|
||||||
|
};
|
||||||
|
// add selected if matching
|
||||||
|
if (selected == key) {
|
||||||
|
options.selected = '';
|
||||||
|
}
|
||||||
|
// create the element option
|
||||||
|
element_option = cel('option', '', value, '', options);
|
||||||
|
// attach it to the select element
|
||||||
|
ael(element_select, element_option);
|
||||||
|
}
|
||||||
|
// if with select part, convert to text
|
||||||
|
if (!options_only) {
|
||||||
|
if (return_string) {
|
||||||
|
content.push(phfo(element_select));
|
||||||
|
return content.join('');
|
||||||
|
} else {
|
||||||
|
return element_select;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// strip select part
|
||||||
|
if (return_string) {
|
||||||
|
element_select.sub.each(function(t) {
|
||||||
|
content.push(phfo(t));
|
||||||
|
});
|
||||||
|
return content.join('');
|
||||||
|
} else {
|
||||||
|
return element_select.sub;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: html_options_refill
|
||||||
|
// PARAMS: name/id, array of options, sort = ''
|
||||||
|
// sort [def '']: if empty as is, else allowed 'keys', 'values' all others are ignored
|
||||||
|
// RETURN: none
|
||||||
|
// DESC : refills a select box with options and keeps the selected
|
||||||
|
function html_options_refill(name, data, sort = '')
|
||||||
|
{
|
||||||
|
let element_option;
|
||||||
|
let option_selected;
|
||||||
|
let data_list = []; // for sorted output
|
||||||
|
// skip if not exists
|
||||||
|
if ($(name)) {
|
||||||
|
// console.log('Call for %s, options: %s', name, options_only);
|
||||||
|
if (sort == 'keys') {
|
||||||
|
data_list = Object.keys(data).sort();
|
||||||
|
} else if (sort == 'values') {
|
||||||
|
data_list = Object.keys(data).sort((a, b) => ('' + data[a]).localeCompare(data[b]));
|
||||||
|
} else {
|
||||||
|
data_list = Object.keys(data);
|
||||||
|
}
|
||||||
|
// first read in existing ones from the options and get the selected one
|
||||||
|
[].forEach.call(document.querySelectorAll('#' + name + ' :checked'), function(elm) {
|
||||||
|
option_selected = elm.value;
|
||||||
|
});
|
||||||
|
$(name).innerHTML = '';
|
||||||
|
for (const key of data_list) {
|
||||||
|
let value = data[key];
|
||||||
|
// console.log('add [%s] options: key: %s, value: %s', name, key, value);
|
||||||
|
element_option = document.createElement('option');
|
||||||
|
element_option.label = value;
|
||||||
|
element_option.value = key;
|
||||||
|
element_option.innerHTML = value;
|
||||||
|
$(name).appendChild(element_option);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// METHOD: initDatepickr
|
||||||
|
// PARAMS: initial date ID (#)
|
||||||
|
// RETURN: true on ok, false on failure
|
||||||
|
// DESC : inits date pickr which translations for dates (week/month)
|
||||||
|
function initDatepickr(init_date)
|
||||||
|
{
|
||||||
|
if ($(init_date)) {
|
||||||
|
datepickr('#' + init_date); // we need to add this so we have it initialized before we can actually change the definitions
|
||||||
|
// dates in japanese
|
||||||
|
datepickr.prototype.l10n.months.shorthand = [__('Jan'), __('Feb'), __('Mar'), __('Apr'), __('May'), __('Jun'), __('Jul'), __('Aug'), __('Sep'), __('Oct'), __('Nov'), __('Dec')];
|
||||||
|
datepickr.prototype.l10n.months.longhand = [__('January'), __('February'), __('March'), __('April'), __('May'), __('June'), __('July'), __('August'), __('September'), __('October'), __('November'), __('December')];
|
||||||
|
datepickr.prototype.l10n.weekdays.shorthand = [__('Mon'), __('Tue'), __('Wed'), __('Thu'), __('Fri'), __('Sat'), __('Sun')];
|
||||||
|
datepickr.prototype.l10n.weekdays.longhand = [__('Monday'), __('Tuesday'), __('Wednesday'), __('Thursday'), __('Friday'), __('Saturday'), __('Sunday')];
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// *** MASTER logout call
|
||||||
|
// METHOD: loginLogout
|
||||||
|
// PARAMS: none
|
||||||
|
// RETURN: none
|
||||||
|
// DESC : submits basic data for form logout
|
||||||
|
function loginLogout()
|
||||||
|
{
|
||||||
|
$('login_logout').value = 'Logout';
|
||||||
|
$(form_name).submit();
|
||||||
|
}
|
||||||
|
|
||||||
|
/* END */
|
||||||
|
|||||||
1313
www/layout/admin/default/javascript/file-uploader/fileuploader.js
Normal file
1313
www/layout/admin/default/javascript/file-uploader/fileuploader.js
Normal file
File diff suppressed because it is too large
Load Diff
0
www/layout/admin/default/javascript/index.php
Normal file
0
www/layout/admin/default/javascript/index.php
Normal file
@@ -1,4 +1,4 @@
|
|||||||
/* Prototype JavaScript framework, version 1.7.2
|
/* Prototype JavaScript framework, version 1.7.3
|
||||||
* (c) 2005-2010 Sam Stephenson
|
* (c) 2005-2010 Sam Stephenson
|
||||||
*
|
*
|
||||||
* Prototype is freely distributable under the terms of an MIT-style license.
|
* Prototype is freely distributable under the terms of an MIT-style license.
|
||||||
@@ -8,7 +8,7 @@
|
|||||||
|
|
||||||
var Prototype = {
|
var Prototype = {
|
||||||
|
|
||||||
Version: '1.7.2',
|
Version: '1.7.3',
|
||||||
|
|
||||||
Browser: (function(){
|
Browser: (function(){
|
||||||
var ua = navigator.userAgent;
|
var ua = navigator.userAgent;
|
||||||
@@ -621,7 +621,7 @@ Object.extend(String.prototype, (function() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function stripTags() {
|
function stripTags() {
|
||||||
return this.replace(/<\w+(\s+("[^"]*"|'[^']*'|[^>])+)?>|<\/\w+>/gi, '');
|
return this.replace(/<\w+(\s+("[^"]*"|'[^']*'|[^>])+)?(\/)?>|<\/\w+>/gi, '');
|
||||||
}
|
}
|
||||||
|
|
||||||
function stripScripts() {
|
function stripScripts() {
|
||||||
@@ -734,7 +734,7 @@ Object.extend(String.prototype, (function() {
|
|||||||
|
|
||||||
function evalJSON(sanitize) {
|
function evalJSON(sanitize) {
|
||||||
var json = this.unfilterJSON(),
|
var json = this.unfilterJSON(),
|
||||||
cx = /[\u0000\u00ad\u0600-\u0604\u070f\u17b4\u17b5\u200c-\u200f\u2028-\u202f\u2060-\u206f\ufeff\ufff0-\uffff]/g;
|
cx = /[\u00ad\u0600-\u0604\u070f\u17b4\u17b5\u200c-\u200f\u2028-\u202f\u2060-\u206f\ufeff\ufff0-\uffff\u0000]/g;
|
||||||
if (cx.test(json)) {
|
if (cx.test(json)) {
|
||||||
json = json.replace(cx, function (a) {
|
json = json.replace(cx, function (a) {
|
||||||
return '\\u' + ('0000' + a.charCodeAt(0).toString(16)).slice(-4);
|
return '\\u' + ('0000' + a.charCodeAt(0).toString(16)).slice(-4);
|
||||||
@@ -1332,10 +1332,9 @@ Array.from = $A;
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (arrayProto.some) {
|
if (arrayProto.some) {
|
||||||
var some = wrapNative(Array.prototype.some);
|
some = wrapNative(Array.prototype.some);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function every(iterator) {
|
function every(iterator) {
|
||||||
if (this == null) throw new TypeError();
|
if (this == null) throw new TypeError();
|
||||||
iterator = iterator || Prototype.K;
|
iterator = iterator || Prototype.K;
|
||||||
@@ -1352,22 +1351,16 @@ Array.from = $A;
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (arrayProto.every) {
|
if (arrayProto.every) {
|
||||||
var every = wrapNative(Array.prototype.every);
|
every = wrapNative(Array.prototype.every);
|
||||||
}
|
}
|
||||||
|
|
||||||
var _reduce = arrayProto.reduce;
|
|
||||||
function inject(memo, iterator) {
|
|
||||||
iterator = iterator || Prototype.K;
|
|
||||||
var context = arguments[2];
|
|
||||||
return _reduce.call(this, iterator.bind(context), memo);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!arrayProto.reduce) {
|
|
||||||
var inject = Enumerable.inject;
|
|
||||||
}
|
|
||||||
|
|
||||||
Object.extend(arrayProto, Enumerable);
|
Object.extend(arrayProto, Enumerable);
|
||||||
|
|
||||||
|
if (arrayProto.entries === Enumerable.entries) {
|
||||||
|
delete arrayProto.entries;
|
||||||
|
}
|
||||||
|
|
||||||
if (!arrayProto._reverse)
|
if (!arrayProto._reverse)
|
||||||
arrayProto._reverse = arrayProto.reverse;
|
arrayProto._reverse = arrayProto.reverse;
|
||||||
|
|
||||||
@@ -1383,7 +1376,6 @@ Array.from = $A;
|
|||||||
any: some,
|
any: some,
|
||||||
every: every,
|
every: every,
|
||||||
all: every,
|
all: every,
|
||||||
inject: inject,
|
|
||||||
|
|
||||||
clear: clear,
|
clear: clear,
|
||||||
first: first,
|
first: first,
|
||||||
@@ -2146,12 +2138,12 @@ Ajax.PeriodicalUpdater = Class.create(Ajax.Base, {
|
|||||||
|
|
||||||
|
|
||||||
function visible(element) {
|
function visible(element) {
|
||||||
return $(element).style.display !== 'none';
|
return $(element).getStyle('display') !== 'none';
|
||||||
}
|
}
|
||||||
|
|
||||||
function toggle(element, bool) {
|
function toggle(element, bool) {
|
||||||
element = $(element);
|
element = $(element);
|
||||||
if (Object.isUndefined(bool))
|
if (typeof bool !== 'boolean')
|
||||||
bool = !Element.visible(element);
|
bool = !Element.visible(element);
|
||||||
Element[bool ? 'show' : 'hide'](element);
|
Element[bool ? 'show' : 'hide'](element);
|
||||||
|
|
||||||
@@ -2683,6 +2675,7 @@ Ajax.PeriodicalUpdater = Class.create(Ajax.Base, {
|
|||||||
|
|
||||||
function descendantOf_DOM(element, ancestor) {
|
function descendantOf_DOM(element, ancestor) {
|
||||||
element = $(element), ancestor = $(ancestor);
|
element = $(element), ancestor = $(ancestor);
|
||||||
|
if (!element || !ancestor) return false;
|
||||||
while (element = element.parentNode)
|
while (element = element.parentNode)
|
||||||
if (element === ancestor) return true;
|
if (element === ancestor) return true;
|
||||||
return false;
|
return false;
|
||||||
@@ -2690,12 +2683,14 @@ Ajax.PeriodicalUpdater = Class.create(Ajax.Base, {
|
|||||||
|
|
||||||
function descendantOf_contains(element, ancestor) {
|
function descendantOf_contains(element, ancestor) {
|
||||||
element = $(element), ancestor = $(ancestor);
|
element = $(element), ancestor = $(ancestor);
|
||||||
|
if (!element || !ancestor) return false;
|
||||||
if (!ancestor.contains) return descendantOf_DOM(element, ancestor);
|
if (!ancestor.contains) return descendantOf_DOM(element, ancestor);
|
||||||
return ancestor.contains(element) && ancestor !== element;
|
return ancestor.contains(element) && ancestor !== element;
|
||||||
}
|
}
|
||||||
|
|
||||||
function descendantOf_compareDocumentPosition(element, ancestor) {
|
function descendantOf_compareDocumentPosition(element, ancestor) {
|
||||||
element = $(element), ancestor = $(ancestor);
|
element = $(element), ancestor = $(ancestor);
|
||||||
|
if (!element || !ancestor) return false;
|
||||||
return (element.compareDocumentPosition(ancestor) & 8) === 8;
|
return (element.compareDocumentPosition(ancestor) & 8) === 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2800,8 +2795,10 @@ Ajax.PeriodicalUpdater = Class.create(Ajax.Base, {
|
|||||||
for (var attr in attributes) {
|
for (var attr in attributes) {
|
||||||
name = table.names[attr] || attr;
|
name = table.names[attr] || attr;
|
||||||
value = attributes[attr];
|
value = attributes[attr];
|
||||||
if (table.values[attr])
|
if (table.values[attr]) {
|
||||||
name = table.values[attr](element, value) || name;
|
value = table.values[attr](element, value);
|
||||||
|
if (Object.isUndefined(value)) continue;
|
||||||
|
}
|
||||||
if (value === false || value === null)
|
if (value === false || value === null)
|
||||||
element.removeAttribute(name);
|
element.removeAttribute(name);
|
||||||
else if (value === true)
|
else if (value === true)
|
||||||
@@ -2979,7 +2976,9 @@ Ajax.PeriodicalUpdater = Class.create(Ajax.Base, {
|
|||||||
|
|
||||||
values: {
|
values: {
|
||||||
checked: function(element, value) {
|
checked: function(element, value) {
|
||||||
element.checked = !!value;
|
value = !!value;
|
||||||
|
element.checked = value;
|
||||||
|
return value ? 'checked' : null;
|
||||||
},
|
},
|
||||||
|
|
||||||
style: function(element, value) {
|
style: function(element, value) {
|
||||||
@@ -3124,8 +3123,11 @@ Ajax.PeriodicalUpdater = Class.create(Ajax.Base, {
|
|||||||
value = element.currentStyle[style];
|
value = element.currentStyle[style];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (style === 'opacity' && !STANDARD_CSS_OPACITY_SUPPORTED)
|
if (style === 'opacity') {
|
||||||
return getOpacity_IE(element);
|
if (!STANDARD_CSS_OPACITY_SUPPORTED)
|
||||||
|
return getOpacity_IE(element);
|
||||||
|
else return value ? parseFloat(value) : 1.0;
|
||||||
|
}
|
||||||
|
|
||||||
if (value === 'auto') {
|
if (value === 'auto') {
|
||||||
if ((style === 'width' || style === 'height') && Element.visible(element))
|
if ((style === 'width' || style === 'height') && Element.visible(element))
|
||||||
@@ -3177,7 +3179,7 @@ Ajax.PeriodicalUpdater = Class.create(Ajax.Base, {
|
|||||||
if (value < 0.00001) value = 0;
|
if (value < 0.00001) value = 0;
|
||||||
|
|
||||||
style.filter = stripAlphaFromFilter_IE(filter) +
|
style.filter = stripAlphaFromFilter_IE(filter) +
|
||||||
'alpha(opacity=' + (value * 100) + ')';
|
' alpha(opacity=' + (value * 100) + ')';
|
||||||
|
|
||||||
return element;
|
return element;
|
||||||
}
|
}
|
||||||
@@ -3193,7 +3195,7 @@ Ajax.PeriodicalUpdater = Class.create(Ajax.Base, {
|
|||||||
|
|
||||||
var filter = Element.getStyle(element, 'filter');
|
var filter = Element.getStyle(element, 'filter');
|
||||||
if (filter.length === 0) return 1.0;
|
if (filter.length === 0) return 1.0;
|
||||||
var match = (filter || '').match(/alpha\(opacity=(.*)\)/);
|
var match = (filter || '').match(/alpha\(opacity=(.*)\)/i);
|
||||||
if (match && match[1]) return parseFloat(match[1]) / 100;
|
if (match && match[1]) return parseFloat(match[1]) / 100;
|
||||||
return 1.0;
|
return 1.0;
|
||||||
}
|
}
|
||||||
@@ -3519,7 +3521,7 @@ Ajax.PeriodicalUpdater = Class.create(Ajax.Base, {
|
|||||||
return boxWidth - bl - br - pl - pr;
|
return boxWidth - bl - br - pl - pr;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ('currentStyle' in document.documentElement) {
|
if (!Object.isUndefined(document.documentElement.currentStyle) && !Prototype.Browser.Opera) {
|
||||||
getRawStyle = getRawStyle_IE;
|
getRawStyle = getRawStyle_IE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -4047,15 +4049,19 @@ Ajax.PeriodicalUpdater = Class.create(Ajax.Base, {
|
|||||||
function getOffsetParent(element) {
|
function getOffsetParent(element) {
|
||||||
element = $(element);
|
element = $(element);
|
||||||
|
|
||||||
|
function selfOrBody(element) {
|
||||||
|
return isHtml(element) ? $(document.body) : $(element);
|
||||||
|
}
|
||||||
|
|
||||||
if (isDocument(element) || isDetached(element) || isBody(element) || isHtml(element))
|
if (isDocument(element) || isDetached(element) || isBody(element) || isHtml(element))
|
||||||
return $(document.body);
|
return $(document.body);
|
||||||
|
|
||||||
var isInline = (Element.getStyle(element, 'display') === 'inline');
|
var isInline = (Element.getStyle(element, 'display') === 'inline');
|
||||||
if (!isInline && element.offsetParent) return $(element.offsetParent);
|
if (!isInline && element.offsetParent) return selfOrBody(element.offsetParent);
|
||||||
|
|
||||||
while ((element = element.parentNode) && element !== document.body) {
|
while ((element = element.parentNode) && element !== document.body) {
|
||||||
if (Element.getStyle(element, 'position') !== 'static') {
|
if (Element.getStyle(element, 'position') !== 'static') {
|
||||||
return isHtml(element) ? $(document.body) : $(element);
|
return selfOrBody(element);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -4093,8 +4099,8 @@ Ajax.PeriodicalUpdater = Class.create(Ajax.Base, {
|
|||||||
}
|
}
|
||||||
} while (element);
|
} while (element);
|
||||||
|
|
||||||
valueL -= layout.get('margin-top');
|
valueL -= layout.get('margin-left');
|
||||||
valueT -= layout.get('margin-left');
|
valueT -= layout.get('margin-top');
|
||||||
|
|
||||||
return new Element.Offset(valueL, valueT);
|
return new Element.Offset(valueL, valueT);
|
||||||
}
|
}
|
||||||
@@ -4265,6 +4271,8 @@ Ajax.PeriodicalUpdater = Class.create(Ajax.Base, {
|
|||||||
offsetLeft: 0
|
offsetLeft: 0
|
||||||
}, options || {});
|
}, options || {});
|
||||||
|
|
||||||
|
var docEl = document.documentElement;
|
||||||
|
|
||||||
source = $(source);
|
source = $(source);
|
||||||
element = $(element);
|
element = $(element);
|
||||||
var p, delta, layout, styles = {};
|
var p, delta, layout, styles = {};
|
||||||
@@ -4278,19 +4286,41 @@ Ajax.PeriodicalUpdater = Class.create(Ajax.Base, {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function pageScrollXY() {
|
||||||
|
var x = 0, y = 0;
|
||||||
|
if (Object.isNumber(window.pageXOffset)) {
|
||||||
|
x = window.pageXOffset;
|
||||||
|
y = window.pageYOffset;
|
||||||
|
} else if (document.body && (document.body.scrollLeft || document.body.scrollTop)) {
|
||||||
|
x = document.body.scrollLeft;
|
||||||
|
y = document.body.scrollTop;
|
||||||
|
} else if (docEl && (docEl.scrollLeft || docEl.scrollTop)) {
|
||||||
|
x = docEl.scrollLeft;
|
||||||
|
y = docEl.scrollTop;
|
||||||
|
}
|
||||||
|
return { x: x, y: y };
|
||||||
|
}
|
||||||
|
|
||||||
|
var pageXY = pageScrollXY();
|
||||||
|
|
||||||
|
|
||||||
if (options.setWidth || options.setHeight) {
|
if (options.setWidth || options.setHeight) {
|
||||||
layout = Element.getLayout(source);
|
layout = Element.getLayout(source);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (options.setLeft)
|
if (options.setLeft)
|
||||||
styles.left = (p[0] - delta[0] + options.offsetLeft) + 'px';
|
styles.left = (p[0] + pageXY.x - delta[0] + options.offsetLeft) + 'px';
|
||||||
if (options.setTop)
|
if (options.setTop)
|
||||||
styles.top = (p[1] - delta[1] + options.offsetTop) + 'px';
|
styles.top = (p[1] + pageXY.y - delta[1] + options.offsetTop) + 'px';
|
||||||
|
|
||||||
if (options.setWidth)
|
var currentLayout = element.getLayout();
|
||||||
styles.width = layout.get('border-box-width') + 'px';
|
|
||||||
if (options.setHeight)
|
if (options.setWidth) {
|
||||||
styles.height = layout.get('border-box-height') + 'px';
|
styles.width = layout.get('width') + 'px';
|
||||||
|
}
|
||||||
|
if (options.setHeight) {
|
||||||
|
styles.height = layout.get('height') + 'px';
|
||||||
|
}
|
||||||
|
|
||||||
return Element.setStyle(element, styles);
|
return Element.setStyle(element, styles);
|
||||||
}
|
}
|
||||||
@@ -4488,15 +4518,29 @@ Prototype.Selector = (function() {
|
|||||||
};
|
};
|
||||||
})();
|
})();
|
||||||
Prototype._original_property = window.Sizzle;
|
Prototype._original_property = window.Sizzle;
|
||||||
|
|
||||||
|
;(function () {
|
||||||
|
function fakeDefine(fn) {
|
||||||
|
Prototype._actual_sizzle = fn();
|
||||||
|
}
|
||||||
|
fakeDefine.amd = true;
|
||||||
|
|
||||||
|
if (typeof define !== 'undefined' && define.amd) {
|
||||||
|
Prototype._original_define = define;
|
||||||
|
Prototype._actual_sizzle = null;
|
||||||
|
window.define = fakeDefine;
|
||||||
|
}
|
||||||
|
})();
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Sizzle CSS Selector Engine v@VERSION
|
* Sizzle CSS Selector Engine v1.10.18
|
||||||
* http://sizzlejs.com/
|
* http://sizzlejs.com/
|
||||||
*
|
*
|
||||||
* Copyright 2013 jQuery Foundation, Inc. and other contributors
|
* Copyright 2013 jQuery Foundation, Inc. and other contributors
|
||||||
* Released under the MIT license
|
* Released under the MIT license
|
||||||
* http://jquery.org/license
|
* http://jquery.org/license
|
||||||
*
|
*
|
||||||
* Date: @DATE
|
* Date: 2014-02-05
|
||||||
*/
|
*/
|
||||||
(function( window ) {
|
(function( window ) {
|
||||||
|
|
||||||
@@ -6229,6 +6273,22 @@ if ( typeof define === "function" && define.amd ) {
|
|||||||
|
|
||||||
})( window );
|
})( window );
|
||||||
|
|
||||||
|
;(function() {
|
||||||
|
if (typeof Sizzle !== 'undefined') {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof define !== 'undefined' && define.amd) {
|
||||||
|
window.Sizzle = Prototype._actual_sizzle;
|
||||||
|
window.define = Prototype._original_define;
|
||||||
|
delete Prototype._actual_sizzle;
|
||||||
|
delete Prototype._original_define;
|
||||||
|
} else if (typeof module !== 'undefined' && module.exports) {
|
||||||
|
window.Sizzle = module.exports;
|
||||||
|
module.exports = {};
|
||||||
|
}
|
||||||
|
})();
|
||||||
|
|
||||||
;(function(engine) {
|
;(function(engine) {
|
||||||
var extendElements = Prototype.Selector.extendElements;
|
var extendElements = Prototype.Selector.extendElements;
|
||||||
|
|
||||||
@@ -6870,7 +6930,7 @@ Form.EventObserver = Class.create(Abstract.EventObserver, {
|
|||||||
|
|
||||||
Event._isCustomEvent = isCustomEvent;
|
Event._isCustomEvent = isCustomEvent;
|
||||||
|
|
||||||
function getRegistryForElement(element, uid) {
|
function getOrCreateRegistryFor(element, uid) {
|
||||||
var CACHE = GLOBAL.Event.cache;
|
var CACHE = GLOBAL.Event.cache;
|
||||||
if (Object.isUndefined(uid))
|
if (Object.isUndefined(uid))
|
||||||
uid = getUniqueElementID(element);
|
uid = getUniqueElementID(element);
|
||||||
@@ -6886,7 +6946,7 @@ Form.EventObserver = Class.create(Abstract.EventObserver, {
|
|||||||
|
|
||||||
|
|
||||||
function register(element, eventName, handler) {
|
function register(element, eventName, handler) {
|
||||||
var registry = getRegistryForElement(element);
|
var registry = getOrCreateRegistryFor(element);
|
||||||
if (!registry[eventName]) registry[eventName] = [];
|
if (!registry[eventName]) registry[eventName] = [];
|
||||||
var entries = registry[eventName];
|
var entries = registry[eventName];
|
||||||
|
|
||||||
@@ -6906,9 +6966,8 @@ Form.EventObserver = Class.create(Abstract.EventObserver, {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function unregister(element, eventName, handler) {
|
function unregister(element, eventName, handler) {
|
||||||
var registry = getRegistryForElement(element);
|
var registry = getOrCreateRegistryFor(element);
|
||||||
var entries = registry[eventName];
|
var entries = registry[eventName] || [];
|
||||||
if (!entries) return;
|
|
||||||
|
|
||||||
var i = entries.length, entry;
|
var i = entries.length, entry;
|
||||||
while (i--) {
|
while (i--) {
|
||||||
@@ -6918,10 +6977,16 @@ Form.EventObserver = Class.create(Abstract.EventObserver, {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!entry) return;
|
if (entry) {
|
||||||
|
var index = entries.indexOf(entry);
|
||||||
|
entries.splice(index, 1);
|
||||||
|
}
|
||||||
|
|
||||||
var index = entries.indexOf(entry);
|
if (entries.length === 0) {
|
||||||
entries.splice(index, 1);
|
delete registry[eventName];
|
||||||
|
if (Object.keys(registry).length === 1 && ('element' in registry))
|
||||||
|
destroyRegistryForElement(element);
|
||||||
|
}
|
||||||
|
|
||||||
return entry;
|
return entry;
|
||||||
}
|
}
|
||||||
@@ -7020,14 +7085,24 @@ Form.EventObserver = Class.create(Abstract.EventObserver, {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function stopObservingEventName(element, eventName) {
|
function stopObservingEventName(element, eventName) {
|
||||||
var registry = getRegistryForElement(element);
|
var registry = getOrCreateRegistryFor(element);
|
||||||
var entries = registry[eventName];
|
var entries = registry[eventName];
|
||||||
if (!entries) return;
|
if (entries) {
|
||||||
delete registry[eventName];
|
delete registry[eventName];
|
||||||
|
}
|
||||||
|
|
||||||
|
entries = entries || [];
|
||||||
|
|
||||||
var i = entries.length;
|
var i = entries.length;
|
||||||
while (i--)
|
while (i--)
|
||||||
removeEvent(element, eventName, entries[i].responder);
|
removeEvent(element, eventName, entries[i].responder);
|
||||||
|
|
||||||
|
for (var name in registry) {
|
||||||
|
if (name === 'element') continue;
|
||||||
|
return; // There is another registered event
|
||||||
|
}
|
||||||
|
|
||||||
|
destroyRegistryForElement(element);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -7194,7 +7269,8 @@ Form.EventObserver = Class.create(Abstract.EventObserver, {
|
|||||||
|
|
||||||
function createResponderForCustomEvent(uid, eventName, handler) {
|
function createResponderForCustomEvent(uid, eventName, handler) {
|
||||||
return function(event) {
|
return function(event) {
|
||||||
var element = Event.cache[uid].element;
|
var cache = Event.cache[uid];
|
||||||
|
var element = cache && cache.element;
|
||||||
|
|
||||||
if (Object.isUndefined(event.eventName))
|
if (Object.isUndefined(event.eventName))
|
||||||
return false;
|
return false;
|
||||||
@@ -7283,7 +7359,9 @@ Hash.toQueryString = Object.toQueryString;
|
|||||||
|
|
||||||
var Toggle = { display: Element.toggle };
|
var Toggle = { display: Element.toggle };
|
||||||
|
|
||||||
Element.Methods.childOf = Element.Methods.descendantOf;
|
Element.addMethods({
|
||||||
|
childOf: Element.Methods.descendantOf
|
||||||
|
});
|
||||||
|
|
||||||
var Insertion = {
|
var Insertion = {
|
||||||
Before: function(element, content) {
|
Before: function(element, content) {
|
||||||
@@ -1 +1 @@
|
|||||||
prototype-1.7.2.0.js
|
prototype-1.7.3.0.js
|
||||||
@@ -79,7 +79,7 @@
|
|||||||
<!-- TOP MENU END //-->
|
<!-- TOP MENU END //-->
|
||||||
<tr>
|
<tr>
|
||||||
<td width="{$table_width}" class="edit_bgcolor">
|
<td width="{$table_width}" class="edit_bgcolor">
|
||||||
<form method="post" name="edit_form">
|
<form method="post" name="edit_form" style="margin-block-end: 0em;">
|
||||||
<table width="100%" border="0" cellpadding="2" cellspacing="1">
|
<table width="100%" border="0" cellpadding="2" cellspacing="1">
|
||||||
<!-- LOAD START //-->
|
<!-- LOAD START //-->
|
||||||
{include file="edit_load.tpl"}
|
{include file="edit_load.tpl"}
|
||||||
|
|||||||
5
www/layout/admin/default/templates/smarty_test.tpl
Normal file → Executable file
5
www/layout/admin/default/templates/smarty_test.tpl
Normal file → Executable file
@@ -1,3 +1,8 @@
|
|||||||
<div>
|
<div>
|
||||||
{$SMARTY_TEST}
|
{$SMARTY_TEST}
|
||||||
</div>
|
</div>
|
||||||
|
<div>
|
||||||
|
<select id="drop_down_test" name="drop_down_test">
|
||||||
|
{html_options options=$drop_down_test selected=$drop_down_test_selected}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
|||||||
0
www/layout/admin/index.php
Normal file
0
www/layout/admin/index.php
Normal file
0
www/layout/frontend/default/cache/index.php
vendored
Normal file
0
www/layout/frontend/default/cache/index.php
vendored
Normal file
@@ -3,3 +3,27 @@
|
|||||||
color: #a4a4a4;
|
color: #a4a4a4;
|
||||||
font-size: 8px;
|
font-size: 8px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* NEW VERSION with CSS key frame animation */
|
||||||
|
.progress {
|
||||||
|
width: 100px;
|
||||||
|
height: 100px;
|
||||||
|
background: rgba(255, 255, 255, 0.6);
|
||||||
|
border: 20px solid rgba(255, 255, 255 ,0.25);
|
||||||
|
border-left-color: rgba(3, 155, 229 ,1);
|
||||||
|
border-top-color: rgba(3, 155, 229 ,1);
|
||||||
|
border-radius: 50%;
|
||||||
|
display: inline-block;
|
||||||
|
animation: rotate 600ms infinite linear;
|
||||||
|
/* align */
|
||||||
|
left: 0;
|
||||||
|
top: 0;
|
||||||
|
position: absolute;
|
||||||
|
z-index: 100;
|
||||||
|
}
|
||||||
|
/* Animation for above progress */
|
||||||
|
@keyframes rotate {
|
||||||
|
to {
|
||||||
|
transform: rotate(1turn)
|
||||||
|
}
|
||||||
|
}
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user