Compare commits
33 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
b5290971c1 | ||
|
|
2f1cb6a0a5 | ||
|
|
d813ce0e35 | ||
|
|
22b4fbce8d | ||
|
|
7fe27b8040 | ||
|
|
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 |
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.3-httpd-2.4/bin/php
|
||||||
|
|
||||||
|
Update composer phar file
|
||||||
|
/usr/local/php-7.3-httpd-2.4/bin/php composer.phar selfupdate
|
||||||
|
|
||||||
|
Install something:
|
||||||
|
/usr/local/php-7.3-httpd-2.4/bin/php composer.phar require something/something
|
||||||
|
|
||||||
|
Update all installed:
|
||||||
|
/usr/local/php-7.3-httpd-2.4/bin/php composer.phar update
|
||||||
|
|
||||||
|
Or update only one package:
|
||||||
|
/usr/local/php-7.3-httpd-2.4/bin/php composer.phar something/something
|
||||||
|
|
||||||
|
Install AWS SDK:
|
||||||
|
/usr/local/php-7.3-httpd-2.4/bin/php -d memory_limit=-1 composer.phar require aws/aws-sdk-php
|
||||||
|
|
||||||
|
Install zipStream:
|
||||||
|
/usr/local/php-7.3-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';
|
||||||
@@ -10,8 +10,9 @@ CREATE TABLE edit_access (
|
|||||||
edit_access_id SERIAL PRIMARY KEY,
|
edit_access_id SERIAL PRIMARY KEY,
|
||||||
name VARCHAR 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
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -15,5 +15,3 @@ CREATE TABLE edit_group (
|
|||||||
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);
|
|
||||||
|
|||||||
@@ -16,5 +16,3 @@ CREATE TABLE edit_language (
|
|||||||
enabled SMALLINT NOT NULL DEFAULT 0,
|
enabled SMALLINT NOT NULL DEFAULT 0,
|
||||||
lang_default SMALLINT NOT NULL DEFAULT 0
|
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);
|
|
||||||
|
|||||||
@@ -13,6 +13,4 @@ CREATE TABLE edit_menu_group (
|
|||||||
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);
|
|
||||||
|
|||||||
@@ -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);
|
|
||||||
|
|||||||
@@ -12,9 +12,5 @@ CREATE TABLE edit_scheme (
|
|||||||
name VARCHAR,
|
name VARCHAR,
|
||||||
header_color VARCHAR,
|
header_color VARCHAR,
|
||||||
css_file VARCHAR,
|
css_file VARCHAR,
|
||||||
template VARCHARs
|
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);
|
|
||||||
|
|||||||
@@ -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);
|
|
||||||
|
|||||||
@@ -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();
|
|
||||||
@@ -7,8 +7,8 @@ LOCAL_BASE_DIR="<local folder>";
|
|||||||
LOCAL_DIR=$LOCAL_BASE_DIR"";
|
LOCAL_DIR=$LOCAL_BASE_DIR"";
|
||||||
REMOTE_WEB="<remote folder>";
|
REMOTE_WEB="<remote folder>";
|
||||||
TARGET_HOST_WEB="<user>@<host>";
|
TARGET_HOST_WEB="<user>@<host>";
|
||||||
TMP_DIR=$LOCAL_BASE_DIR"/4dev/";
|
TMP_DIR=$LOCAL_BASE_DIR"/4dev/tmp/";
|
||||||
tmpf_web=$TMP_DIR"tmp.web";
|
tmpf_web=$TMP_DIR"sync.exclude.tmp";
|
||||||
|
|
||||||
# for web (ika)
|
# for web (ika)
|
||||||
rm -f $tmpf_web;
|
rm -f $tmpf_web;
|
||||||
|
|||||||
@@ -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__
|
||||||
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
|
||||||
@@ -139,8 +139,11 @@ $PAGES = $_SESSION["PAGES"];
|
|||||||
|
|
||||||
//$form->debug('menu', $form->printAr($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
|
||||||
@@ -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
@@ -1,12 +1,10 @@
|
|||||||
/*
|
/*********************************************************************
|
||||||
********************************************************************
|
* AUTHOR: Clemens Schwaighofer
|
||||||
* AUTHOR: Clemens Schwaighofer
|
* DATE: 2015/4/24
|
||||||
* DATE: 2015/4/24
|
* DESCRIPTION:
|
||||||
* DESCRIPTION:
|
* debug javascript
|
||||||
* debug javascript
|
* HISTORY:
|
||||||
* HISTORY:
|
**********************************************************************/
|
||||||
********************************************************************
|
|
||||||
*/
|
|
||||||
|
|
||||||
// if debug is set to true, console log messages are printed
|
// if debug is set to true, console log messages are printed
|
||||||
if (!DEBUG) {
|
if (!DEBUG) {
|
||||||
|
|||||||
@@ -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
23
www/layout/admin/default/javascript/fineuploader/s3/LICENSE
Normal file
23
www/layout/admin/default/javascript/fineuploader/s3/LICENSE
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
The MIT License (MIT)
|
||||||
|
|
||||||
|
Copyright (c) 2010-2012, Andrew Valums
|
||||||
|
Copyright (c) 2012-2013, Andrew Valums and Raymond S. Nicholus, III
|
||||||
|
Copyright (c) 2013-present, Widen Enterprises, Inc.
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in all
|
||||||
|
copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
SOFTWARE.
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
../fine-uploader-new.css
|
||||||
BIN
www/layout/admin/default/javascript/fineuploader/s3/continue.gif
Normal file
BIN
www/layout/admin/default/javascript/fineuploader/s3/continue.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 221 B |
1100
www/layout/admin/default/javascript/fineuploader/s3/dnd.js
Normal file
1100
www/layout/admin/default/javascript/fineuploader/s3/dnd.js
Normal file
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
3
www/layout/admin/default/javascript/fineuploader/s3/dnd.min.js
vendored
Normal file
3
www/layout/admin/default/javascript/fineuploader/s3/dnd.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
BIN
www/layout/admin/default/javascript/fineuploader/s3/edit.gif
Normal file
BIN
www/layout/admin/default/javascript/fineuploader/s3/edit.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 150 B |
@@ -0,0 +1,471 @@
|
|||||||
|
/* ---------------------------------------
|
||||||
|
/* Fine Uploader Gallery View Styles
|
||||||
|
/* ---------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
/* Buttons
|
||||||
|
------------------------------------------ */
|
||||||
|
.qq-gallery .qq-btn
|
||||||
|
{
|
||||||
|
float: right;
|
||||||
|
border: none;
|
||||||
|
padding: 0;
|
||||||
|
margin: 0;
|
||||||
|
box-shadow: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Upload Button
|
||||||
|
------------------------------------------ */
|
||||||
|
.qq-gallery .qq-upload-button {
|
||||||
|
display: inline;
|
||||||
|
width: 105px;
|
||||||
|
padding: 7px 10px;
|
||||||
|
float: left;
|
||||||
|
text-align: center;
|
||||||
|
background: #00ABC7;
|
||||||
|
color: #FFFFFF;
|
||||||
|
border-radius: 2px;
|
||||||
|
border: 1px solid #37B7CC;
|
||||||
|
box-shadow: 0 1px 1px rgba(255, 255, 255, 0.37) inset,
|
||||||
|
1px 0 1px rgba(255, 255, 255, 0.07) inset,
|
||||||
|
0 1px 0 rgba(0, 0, 0, 0.36),
|
||||||
|
0 -2px 12px rgba(0, 0, 0, 0.08) inset
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-button-hover {
|
||||||
|
background: #33B6CC;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-button-focus {
|
||||||
|
outline: 1px dotted #000000;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Drop Zone
|
||||||
|
------------------------------------------ */
|
||||||
|
.qq-gallery.qq-uploader {
|
||||||
|
position: relative;
|
||||||
|
min-height: 200px;
|
||||||
|
max-height: 490px;
|
||||||
|
overflow-y: hidden;
|
||||||
|
width: inherit;
|
||||||
|
border-radius: 6px;
|
||||||
|
border: 1px dashed #CCCCCC;
|
||||||
|
background-color: #FAFAFA;
|
||||||
|
padding: 20px;
|
||||||
|
}
|
||||||
|
.qq-gallery.qq-uploader:before {
|
||||||
|
content: attr(qq-drop-area-text) " ";
|
||||||
|
position: absolute;
|
||||||
|
font-size: 200%;
|
||||||
|
left: 0;
|
||||||
|
width: 100%;
|
||||||
|
text-align: center;
|
||||||
|
top: 45%;
|
||||||
|
opacity: 0.25;
|
||||||
|
filter: alpha(opacity=25);
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-drop-area, .qq-upload-extra-drop-area {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
min-height: 30px;
|
||||||
|
z-index: 2;
|
||||||
|
background: #F9F9F9;
|
||||||
|
border-radius: 4px;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-drop-area span {
|
||||||
|
display: block;
|
||||||
|
position: absolute;
|
||||||
|
top: 50%;
|
||||||
|
width: 100%;
|
||||||
|
margin-top: -8px;
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-extra-drop-area {
|
||||||
|
position: relative;
|
||||||
|
margin-top: 50px;
|
||||||
|
font-size: 16px;
|
||||||
|
padding-top: 30px;
|
||||||
|
height: 20px;
|
||||||
|
min-height: 40px;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-drop-area-active {
|
||||||
|
background: #FDFDFD;
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-list {
|
||||||
|
margin: 0;
|
||||||
|
padding: 10px 0 0;
|
||||||
|
list-style: none;
|
||||||
|
max-height: 450px;
|
||||||
|
overflow-y: auto;
|
||||||
|
clear: both;
|
||||||
|
box-shadow: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Uploaded Elements
|
||||||
|
------------------------------------------ */
|
||||||
|
.qq-gallery .qq-upload-list li {
|
||||||
|
display: inline-block;
|
||||||
|
position: relative;
|
||||||
|
max-width: 120px;
|
||||||
|
margin: 0 25px 25px 0;
|
||||||
|
padding: 0;
|
||||||
|
line-height: 16px;
|
||||||
|
font-size: 13px;
|
||||||
|
color: #424242;
|
||||||
|
background-color: #FFFFFF;
|
||||||
|
border-radius: 2px;
|
||||||
|
box-shadow: 0 1px 1px 0 rgba(0, 0, 0, 0.22);
|
||||||
|
vertical-align: top;
|
||||||
|
|
||||||
|
/* to ensure consistent size of tiles - may need to change if qq-max-size attr on preview img changes */
|
||||||
|
height: 186px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery .qq-upload-spinner,
|
||||||
|
.qq-gallery .qq-upload-size,
|
||||||
|
.qq-gallery .qq-upload-retry,
|
||||||
|
.qq-gallery .qq-upload-failed-text,
|
||||||
|
.qq-gallery .qq-upload-delete,
|
||||||
|
.qq-gallery .qq-upload-pause,
|
||||||
|
.qq-gallery .qq-upload-continue {
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-retry:hover,
|
||||||
|
.qq-gallery .qq-upload-delete:hover,
|
||||||
|
.qq-gallery .qq-upload-pause:hover,
|
||||||
|
.qq-gallery .qq-upload-continue:hover {
|
||||||
|
background-color: transparent;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-delete,
|
||||||
|
.qq-gallery .qq-upload-pause,
|
||||||
|
.qq-gallery .qq-upload-continue,
|
||||||
|
.qq-gallery .qq-upload-cancel {
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-delete,
|
||||||
|
.qq-gallery .qq-upload-pause,
|
||||||
|
.qq-gallery .qq-upload-continue {
|
||||||
|
border:none;
|
||||||
|
background: none;
|
||||||
|
color: #00A0BA;
|
||||||
|
font-size: 12px;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
/* to ensure consistent size of tiles - only display status text before auto-retry or after failure */
|
||||||
|
.qq-gallery .qq-upload-status-text {
|
||||||
|
color: #333333;
|
||||||
|
font-size: 12px;
|
||||||
|
padding-left: 3px;
|
||||||
|
padding-top: 2px;
|
||||||
|
width: inherit;
|
||||||
|
display: none;
|
||||||
|
width: 108px;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-fail .qq-upload-status-text {
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
white-space: nowrap;
|
||||||
|
overflow-x: hidden;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-retrying .qq-upload-status-text {
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-retrying .qq-progress-bar-container {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery .qq-upload-cancel {
|
||||||
|
background-color: #525252;
|
||||||
|
color: #F7F7F7;
|
||||||
|
font-weight: bold;
|
||||||
|
font-family: Arial, Helvetica, sans-serif;
|
||||||
|
border-radius: 12px;
|
||||||
|
border: none;
|
||||||
|
height: 22px;
|
||||||
|
width: 22px;
|
||||||
|
padding: 4px;
|
||||||
|
position: absolute;
|
||||||
|
right: -5px;
|
||||||
|
top: -6px;
|
||||||
|
margin: 0;
|
||||||
|
line-height: 17px;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-cancel:hover {
|
||||||
|
background-color: #525252;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-retry {
|
||||||
|
cursor: pointer;
|
||||||
|
position: absolute;
|
||||||
|
top: 30px;
|
||||||
|
left: 50%;
|
||||||
|
margin-left: -31px;
|
||||||
|
box-shadow: 0 1px 1px rgba(255, 255, 255, 0.37) inset,
|
||||||
|
1px 0 1px rgba(255, 255, 255, 0.07) inset,
|
||||||
|
0 4px 4px rgba(0, 0, 0, 0.5),
|
||||||
|
0 -2px 12px rgba(0, 0, 0, 0.08) inset;
|
||||||
|
padding: 3px 4px;
|
||||||
|
border: 1px solid #d2ddc7;
|
||||||
|
border-radius: 2px;
|
||||||
|
color: inherit;
|
||||||
|
background-color: #EBF6E0;
|
||||||
|
z-index: 1;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-retry:hover {
|
||||||
|
background-color: #f7ffec;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery .qq-file-info {
|
||||||
|
padding: 10px 6px 4px;
|
||||||
|
margin-top: -3px;
|
||||||
|
border-radius: 0 0 2px 2px;
|
||||||
|
text-align: left;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery .qq-file-info .qq-file-name {
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery .qq-upload-file {
|
||||||
|
display: block;
|
||||||
|
margin-right: 0;
|
||||||
|
margin-bottom: 3px;
|
||||||
|
width: auto;
|
||||||
|
|
||||||
|
/* to ensure consistent size of tiles - constrain text to single line */
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
white-space: nowrap;
|
||||||
|
overflow-x: hidden;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-spinner {
|
||||||
|
display: inline-block;
|
||||||
|
background: url("loading.gif");
|
||||||
|
position: absolute;
|
||||||
|
left: 50%;
|
||||||
|
margin-left: -7px;
|
||||||
|
top: 53px;
|
||||||
|
width: 15px;
|
||||||
|
height: 15px;
|
||||||
|
vertical-align: text-bottom;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-drop-processing {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-drop-processing-spinner {
|
||||||
|
display: inline-block;
|
||||||
|
background: url("processing.gif");
|
||||||
|
width: 24px;
|
||||||
|
height: 24px;
|
||||||
|
vertical-align: text-bottom;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-failed-text {
|
||||||
|
display: none;
|
||||||
|
font-style: italic;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-failed-icon {
|
||||||
|
display:none;
|
||||||
|
width:15px;
|
||||||
|
height:15px;
|
||||||
|
vertical-align:text-bottom;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-fail .qq-upload-failed-text {
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-retrying .qq-upload-failed-text {
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-list li.qq-upload-success {
|
||||||
|
background-color: #F2F7ED;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-upload-list li.qq-upload-fail {
|
||||||
|
background-color: #F5EDED;
|
||||||
|
box-shadow: 0 0 1px 0 red;
|
||||||
|
border: 0;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-progress-bar {
|
||||||
|
display: block;
|
||||||
|
background: #00abc7;
|
||||||
|
width: 0%;
|
||||||
|
height: 15px;
|
||||||
|
border-radius: 6px;
|
||||||
|
margin-bottom: 3px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery .qq-total-progress-bar {
|
||||||
|
height: 25px;
|
||||||
|
border-radius: 9px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery .qq-total-progress-bar-container {
|
||||||
|
margin-left: 9px;
|
||||||
|
display: inline;
|
||||||
|
float: right;
|
||||||
|
width: 500px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery .qq-upload-size {
|
||||||
|
float: left;
|
||||||
|
font-size: 11px;
|
||||||
|
color: #929292;
|
||||||
|
margin-bottom: 3px;
|
||||||
|
margin-right: 0;
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery INPUT.qq-edit-filename {
|
||||||
|
position: absolute;
|
||||||
|
opacity: 0;
|
||||||
|
filter: alpha(opacity=0);
|
||||||
|
z-index: -1;
|
||||||
|
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery .qq-upload-file.qq-editable {
|
||||||
|
cursor: pointer;
|
||||||
|
margin-right: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery .qq-edit-filename-icon.qq-editable {
|
||||||
|
display: inline-block;
|
||||||
|
cursor: pointer;
|
||||||
|
position: absolute;
|
||||||
|
right: 0;
|
||||||
|
top: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery INPUT.qq-edit-filename.qq-editing {
|
||||||
|
position: static;
|
||||||
|
height: 28px;
|
||||||
|
width: 90px;
|
||||||
|
width: -moz-available;
|
||||||
|
padding: 0 8px;
|
||||||
|
margin-bottom: 3px;
|
||||||
|
border: 1px solid #ccc;
|
||||||
|
border-radius: 2px;
|
||||||
|
font-size: 13px;
|
||||||
|
|
||||||
|
opacity: 1;
|
||||||
|
filter: alpha(opacity=100);
|
||||||
|
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery .qq-edit-filename-icon {
|
||||||
|
display: none;
|
||||||
|
background: url("edit.gif");
|
||||||
|
width: 15px;
|
||||||
|
height: 15px;
|
||||||
|
vertical-align: text-bottom;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-delete-icon {
|
||||||
|
background: url("trash.gif");
|
||||||
|
width: 15px;
|
||||||
|
height: 15px;
|
||||||
|
vertical-align: sub;
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-retry-icon {
|
||||||
|
background: url("retry.gif");
|
||||||
|
width: 15px;
|
||||||
|
height: 15px;
|
||||||
|
vertical-align: sub;
|
||||||
|
display: inline-block;
|
||||||
|
float: none;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-continue-icon {
|
||||||
|
background: url("continue.gif");
|
||||||
|
width: 15px;
|
||||||
|
height: 15px;
|
||||||
|
vertical-align: sub;
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-pause-icon {
|
||||||
|
background: url("pause.gif");
|
||||||
|
width: 15px;
|
||||||
|
height: 15px;
|
||||||
|
vertical-align: sub;
|
||||||
|
display: inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery .qq-hide {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Thumbnail
|
||||||
|
------------------------------------------ */
|
||||||
|
.qq-gallery .qq-in-progress .qq-thumbnail-wrapper {
|
||||||
|
/* makes the spinner on top of the thumbnail more visible */
|
||||||
|
opacity: 0.5;
|
||||||
|
filter: alpha(opacity=50);
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-thumbnail-wrapper {
|
||||||
|
overflow: hidden;
|
||||||
|
position: relative;
|
||||||
|
|
||||||
|
/* to ensure consistent size of tiles - should match qq-max-size attribute value on qq-thumbnail-selector IMG element */
|
||||||
|
height: 120px;
|
||||||
|
width: 120px;
|
||||||
|
}
|
||||||
|
.qq-gallery .qq-thumbnail-selector {
|
||||||
|
border-radius: 2px 2px 0 0;
|
||||||
|
bottom: 0;
|
||||||
|
|
||||||
|
/* we will override this in the :root thumbnail selector (to help center the preview) for everything other than IE8 */
|
||||||
|
top: 0;
|
||||||
|
|
||||||
|
/* center the thumb horizontally in the tile */
|
||||||
|
margin:auto;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* hack to ensure we don't try to center preview in IE8, since -ms-filter doesn't mimic translateY as expected in all cases */
|
||||||
|
:root *> .qq-gallery .qq-thumbnail-selector {
|
||||||
|
/* vertically center preview image on tile */
|
||||||
|
position: relative;
|
||||||
|
top: 50%;
|
||||||
|
transform: translateY(-50%);
|
||||||
|
-moz-transform: translateY(-50%);
|
||||||
|
-ms-transform: translateY(-50%);
|
||||||
|
-webkit-transform: translateY(-50%);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* <dialog> element styles */
|
||||||
|
.qq-gallery.qq-uploader DIALOG {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery.qq-uploader DIALOG[open] {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery.qq-uploader DIALOG {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery.qq-uploader DIALOG[open] {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery.qq-uploader DIALOG .qq-dialog-buttons {
|
||||||
|
text-align: center;
|
||||||
|
padding-top: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery.qq-uploader DIALOG .qq-dialog-buttons BUTTON {
|
||||||
|
margin-left: 5px;
|
||||||
|
margin-right: 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery.qq-uploader DIALOG .qq-dialog-message-selector {
|
||||||
|
padding-bottom: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.qq-gallery .qq-uploader DIALOG::backdrop {
|
||||||
|
background-color: rgba(0, 0, 0, 0.7);
|
||||||
|
}
|
||||||
1
www/layout/admin/default/javascript/fineuploader/s3/fine-uploader-gallery.min.css
vendored
Normal file
1
www/layout/admin/default/javascript/fineuploader/s3/fine-uploader-gallery.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
@@ -0,0 +1 @@
|
|||||||
|
{"version":3,"sources":["_build/fine-uploader-gallery.css"],"names":[],"mappings":"AAOA,oBAEI,MAAO,MACP,OAAQ,KACR,QAAS,EACT,OAAQ,EACR,WAAY,KAKhB,8BACI,QAAS,OACT,MAAO,MACP,QAAS,IAAI,KACb,MAAO,KACP,WAAY,OACZ,WAAY,QACZ,MAAO,KACP,cAAe,IACf,OAAQ,IAAI,MAAM,QAClB,WAAY,EAAE,IAAI,IAAI,sBAA0B,KAAK,CACrD,IAAI,EAAE,IAAI,sBAA0B,KAAK,CACzC,EAAE,IAAI,EAAE,eAAmB,CAC3B,EAAE,KAAK,KAAK,gBAAoB,MAEpC,oCACI,WAAY,QAEhB,oCACI,QAAS,IAAI,OAAO,KAMxB,wBACI,SAAU,SACV,WAAY,MACZ,WAAY,MACZ,WAAY,OACZ,MAAO,QACP,cAAe,IACf,OAAQ,IAAI,OAAO,KACnB,iBAAkB,QAClB,QAAS,KAEb,+BACI,QAAS,wBAAwB,IACjC,SAAU,SACV,UAAW,KACX,KAAM,EACN,MAAO,KACP,WAAY,OACZ,IAAK,IACL,QAAS,IAGb,iCAAkC,2BAC9B,SAAU,SACV,IAAK,EACL,KAAM,EACN,MAAO,KACP,OAAQ,KACR,WAAY,KACZ,QAAS,EACT,WAAY,QACZ,cAAe,IACf,WAAY,OAEhB,sCACI,QAAS,MACT,SAAU,SACV,IAAK,IACL,MAAO,KACP,WAAY,KACZ,UAAW,KAEf,uCACI,SAAU,SACV,WAAY,KACZ,UAAW,KACX,YAAa,KACb,OAAQ,KACR,WAAY,KAEhB,wCACI,WAAY,QACZ,cAAe,IAEnB,4BACI,OAAQ,EACR,QAAS,KAAK,EAAE,EAChB,WAAY,KACZ,WAAY,MACZ,WAAY,KACZ,MAAO,KACP,WAAY,KAMhB,+BACI,QAAS,aACT,SAAU,SACV,UAAW,MACX,OAAQ,EAAE,KAAK,KAAK,EACpB,QAAS,EACT,YAAa,KACb,UAAW,KACX,MAAO,QACP,iBAAkB,KAClB,cAAe,IACf,WAAY,EAAE,IAAI,IAAI,EAAE,gBACxB,eAAgB,IAGhB,OAAQ,MASZ,gCAFA,8BADA,mCAEA,6BAHA,6BADA,4BADA,+BAOI,QAAS,OAKb,sCAFA,oCACA,mCAFA,mCAII,iBAAkB,YAKtB,8BADA,gCAFA,8BACA,6BAGI,OAAQ,QAIZ,gCAFA,8BACA,6BAEI,OAAO,KACP,WAAY,IACZ,MAAO,QACP,UAAW,KACX,QAAS,EAGb,mCACI,MAAO,KACP,UAAW,KACX,aAAc,IACd,YAAa,IACb,MAAO,QACP,QAAS,KACT,MAAO,MAEX,mDACI,cAAe,SACf,YAAa,OACb,WAAY,OACZ,QAAS,MAEb,uDACI,QAAS,aAEb,2DACI,QAAS,KAGb,8BACI,iBAAkB,QAClB,MAAO,QACP,YAAa,IACb,YAAa,KAAK,CAAE,SAAS,CAAE,WAC/B,cAAe,KACf,OAAQ,KACR,OAAQ,KACR,MAAO,KACP,QAAS,IACT,SAAU,SACV,MAAO,KACP,IAAK,KACL,OAAQ,EACR,YAAa,KAEjB,oCACI,iBAAkB,QAEtB,6BACI,OAAQ,QACR,SAAU,SACV,IAAK,KACL,KAAM,IACN,YAAa,MACb,WAAY,EAAE,IAAI,IAAI,sBAA0B,KAAK,CACzC,IAAI,EAAE,IAAI,sBAA0B,KAAK,CACzC,EAAE,IAAI,IAAI,cAAkB,CAC5B,EAAE,KAAK,KAAK,gBAAoB,MAC5C,QAAS,IAAI,IACb,OAAQ,IAAI,MAAM,QAClB,cAAe,IACf,MAAO,QACP,iBAAkB,QAClB,QAAS,EAEb,mCACI,iBAAkB,QAGtB,0BACI,QAAS,KAAK,IAAI,IAClB,WAAY,KACZ,cAAe,EAAE,EAAE,IAAI,IACvB,WAAY,KACZ,SAAU,OAGd,wCACI,SAAU,SAGd,4BACI,QAAS,MACT,aAAc,EACd,cAAe,IACf,MAAO,KAGP,cAAe,SACf,YAAa,OACb,WAAY,OAEhB,+BACI,QAAS,aACT,WAAY,iBACZ,SAAU,SACV,KAAM,IACN,YAAa,KACb,IAAK,KACL,MAAO,KACP,OAAQ,KACR,eAAgB,YAEpB,gCACI,QAAS,MAEb,wCACI,QAAS,aACT,WAAY,oBACZ,MAAO,KACP,OAAQ,KACR,eAAgB,YAEpB,mCACI,QAAS,KACT,WAAY,OACZ,YAAa,IAEjB,mCACI,QAAQ,KACR,MAAM,KACN,OAAO,KACP,eAAe,YAEnB,mDACI,QAAS,OAEb,uDACI,QAAS,OAEb,iDACI,iBAAkB,QAEtB,8CACI,iBAAkB,QAClB,WAAY,EAAE,EAAE,IAAI,EAAE,IACtB,OAAQ,EAEZ,6BACI,QAAS,MACT,WAAY,QACZ,MAAO,EACP,OAAQ,KACR,cAAe,IACf,cAAe,IAGnB,mCACI,OAAQ,KACR,cAAe,IAGnB,6CACI,YAAa,IACb,QAAS,OACT,MAAO,MACP,MAAO,MAGX,4BACI,MAAO,KACP,UAAW,KACX,MAAO,QACP,cAAe,IACf,aAAc,EACd,QAAS,aAGb,mCACI,SAAU,SACV,QAAS,EAET,QAAS,GAIb,wCACI,OAAQ,QACR,aAAc,KAGlB,+CACI,QAAS,aACT,OAAQ,QACR,SAAU,SACV,MAAO,EACP,IAAK,EAGT,8CACI,SAAU,OACV,OAAQ,KACR,MAAO,KACP,MAAO,eACP,QAAS,EAAE,IACX,cAAe,IACf,OAAQ,IAAI,MAAM,KAClB,cAAe,IACf,UAAW,KAEX,QAAS,EAKb,mCACI,QAAS,KACT,WAAY,cACZ,MAAO,KACP,OAAQ,KACR,eAAgB,YAEpB,4BACI,WAAY,eACZ,MAAO,KACP,OAAQ,KACR,eAAgB,IAChB,QAAS,aAEb,2BACI,WAAY,eACZ,MAAO,KACP,OAAQ,KACR,eAAgB,IAChB,QAAS,aACT,MAAO,KAEX,8BACI,WAAY,kBACZ,MAAO,KACP,OAAQ,KACR,eAAgB,IAChB,QAAS,aAEb,2BACI,WAAY,eACZ,MAAO,KACP,OAAQ,KACR,eAAgB,IAChB,QAAS,aAGb,qBACI,QAAS,KAMb,kDACI,4DACA,QAAS,GAGb,kCACI,SAAU,OACV,SAAU,SAGV,OAAQ,MACR,MAAO,MAEX,mCACI,cAAe,IAAI,IAAI,EAAE,EACzB,OAAQ,EAGR,IAAK,EAGL,OAAO,KACP,QAAS,MAIb,2CAEI,SAAU,SACV,IAAK,IACL,UAAW,iBACX,eAAgB,iBAChB,cAAe,iBACf,kBAAmB,iBAIvB,+BACI,QAAS,KAGb,qCACI,QAAS,MAGb,+BACI,QAAS,KAGb,qCACI,QAAS,MAGb,kDACI,WAAY,OACZ,YAAa,KAGjB,yDACI,YAAa,IACb,aAAc,IAGlB,2DACI,eAAgB,KAGpB,0CACI,iBAAkB"}
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user