Your commit message
This commit is contained in:
parent
aac7f7ed1b
commit
f9bc85d5f8
|
@ -0,0 +1,3 @@
|
|||
{
|
||||
"presets": ["@babel/preset-env"]
|
||||
}
|
|
@ -0,0 +1,32 @@
|
|||
{
|
||||
"env": {
|
||||
"browser": true,
|
||||
"jquery": true
|
||||
},
|
||||
"parser": "@babel/eslint-parser",
|
||||
"parserOptions": {
|
||||
"ecmaVersion": 2020,
|
||||
"sourceType": "module"
|
||||
},
|
||||
"plugins": [
|
||||
"prettier"
|
||||
],
|
||||
"extends": [
|
||||
"eslint:recommended",
|
||||
"prettier"
|
||||
],
|
||||
"rules": {
|
||||
"prettier/prettier": "error",
|
||||
"no-undef": "off",
|
||||
"no-unused-vars": "off"
|
||||
},
|
||||
"globals": {
|
||||
"$": "readonly",
|
||||
"jQuery": "readonly",
|
||||
"document": "readonly",
|
||||
"window": "readonly",
|
||||
"console": "readonly"
|
||||
}
|
||||
|
||||
}
|
||||
|
|
@ -1,100 +1,66 @@
|
|||
#!/bin/sh
|
||||
. "$(dirname "$0")/_/husky.sh"
|
||||
# Run JS/CSS checks
|
||||
.husky/pre-commit-js-css
|
||||
if [ $? -ne 0 ]; then
|
||||
echo "JS/CSS checks failed"
|
||||
exit 1
|
||||
fi
|
||||
# Get the list of staged PHP files
|
||||
STAGED_FILES=$(git diff --cached --name-only --diff-filter=ACM | grep '\.php$')
|
||||
|
||||
# If there are no staged PHP files, exit
|
||||
if [ -z "$STAGED_FILES" ]; then
|
||||
echo "No PHP files staged for commit."
|
||||
exit 0
|
||||
fi
|
||||
|
||||
# Function to display errors
|
||||
display_errors() {
|
||||
local errors="$1"
|
||||
echo "Errors detected:"
|
||||
echo "---------------------------------------"
|
||||
echo "$errors"
|
||||
echo "$errors" | while IFS='|' read -r file line error; do
|
||||
printf "%-60s | %-10s | %s\n" "$file" "$line" "$error"
|
||||
done
|
||||
echo "---------------------------------------"
|
||||
}
|
||||
|
||||
# Get the list of staged files
|
||||
STAGED_FILES=$(git diff --cached --name-only --diff-filter=ACM | grep -E '\.(php|js|css|jsx|ts|tsx)$')
|
||||
|
||||
# If there are no staged files, exit
|
||||
if [ -z "$STAGED_FILES" ]; then
|
||||
echo "No files staged for commit."
|
||||
exit 0
|
||||
fi
|
||||
|
||||
# Initialize error flags
|
||||
ESLINT_ERRORS=""
|
||||
PHP_ERRORS=0
|
||||
|
||||
# Function to run ESLint and Prettier on JavaScript files
|
||||
run_js_tools() {
|
||||
local files="$1"
|
||||
if [ -n "$files" ]; then
|
||||
echo "Running ESLint..."
|
||||
for FILE in $files; do
|
||||
ESLINT_OUTPUT=$(npx eslint "$FILE" 2>&1)
|
||||
if [ $? -ne 0 ]; then
|
||||
display_errors "$ESLINT_OUTPUT"
|
||||
ESLINT_ERRORS=1
|
||||
fi
|
||||
done
|
||||
|
||||
echo "Running Prettier..."
|
||||
for FILE in $files; do
|
||||
npx prettier --write "$FILE"
|
||||
done
|
||||
fi
|
||||
}
|
||||
|
||||
# Function to run PHP tools
|
||||
run_php_tools() {
|
||||
local files="$1"
|
||||
if [ -n "$files" ]; then
|
||||
echo "Checking PHP syntax errors..."
|
||||
SYNTAX_ERRORS=0
|
||||
for FILE in $files; do
|
||||
# Run PHP lint to check for syntax errors
|
||||
SYNTAX_ERRORS=0
|
||||
echo "Checking PHP syntax errors..."
|
||||
for FILE in $STAGED_FILES; do
|
||||
php -l "$FILE"
|
||||
if [ $? -ne 0 ]; then
|
||||
SYNTAX_ERRORS=1
|
||||
fi
|
||||
done
|
||||
done
|
||||
|
||||
if [ $SYNTAX_ERRORS -ne 0 ]; then
|
||||
PHP_ERRORS=1
|
||||
echo "Syntax errors detected in PHP files."
|
||||
fi
|
||||
if [ $SYNTAX_ERRORS -ne 0 ]; then
|
||||
echo "Syntax errors detected. Please fix them before committing."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "Running PHPCBF..."
|
||||
for FILE in $files; do
|
||||
# Run PHPCBF to auto-fix issues
|
||||
echo "Running PHPCBF..."
|
||||
for FILE in $STAGED_FILES; do
|
||||
/home/aissel/.config/composer/vendor/bin/phpcbf --standard=/var/www/html/google_forms/phpcs.xml "$FILE" || true
|
||||
done
|
||||
done
|
||||
|
||||
echo "Running PHP CS Fixer..."
|
||||
for FILE in $files; do
|
||||
# Run PHP CS Fixer to auto-fix issues
|
||||
echo "Running PHP CS Fixer..."
|
||||
for FILE in $STAGED_FILES; do
|
||||
/home/aissel/.config/composer/vendor/bin/php-cs-fixer fix "$FILE"
|
||||
done
|
||||
done
|
||||
|
||||
echo "Running PHPCS..."
|
||||
for FILE in $files; do
|
||||
PHPCS_OUTPUT=$(/home/aissel/.config/composer/vendor/bin/phpcs --standard=/var/www/html/google_forms/phpcs.xml "$FILE" 2>&1)
|
||||
if [ $? -ne 0 ]; then
|
||||
display_errors "$PHPCS_OUTPUT"
|
||||
PHP_ERRORS=1
|
||||
fi
|
||||
done
|
||||
fi
|
||||
}
|
||||
|
||||
# Run tools based on file types
|
||||
run_js_tools "$(echo "$STAGED_FILES" | grep -E '\.(js|jsx|ts|tsx)$')"
|
||||
run_php_tools "$(echo "$STAGED_FILES" | grep '\.php$')"
|
||||
# Re-run PHPCS to check for unresolved coding standard violations
|
||||
echo "Running PHPCS..."
|
||||
echo "$STAGED_FILES" | xargs -n 1 /home/aissel/.config/composer/vendor/bin/phpcs --standard=/var/www/html/google_forms/phpcs.xml
|
||||
|
||||
# Add the fixed files back to the staging area
|
||||
for FILE in $STAGED_FILES; do
|
||||
git add "$FILE"
|
||||
done
|
||||
|
||||
# Exit with error code if there were any errors
|
||||
if [ $PHP_ERRORS -ne 0 ] || [ $ESLINT_ERRORS -eq 1 ]; then
|
||||
echo "Pre-commit checks failed. Please fix the errors before committing."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "Pre-commit checks completed."
|
||||
|
|
|
@ -0,0 +1,48 @@
|
|||
#!/bin/sh
|
||||
. "$(dirname "$0")/_/husky.sh"
|
||||
|
||||
# Get the list of staged JS/CSS files
|
||||
STAGED_FILES=$(git diff --cached --name-only --diff-filter=ACM | grep -E '\.(js|jsx|ts|tsx|css|scss)$')
|
||||
|
||||
# If there are no staged JS/CSS files, exit
|
||||
if [ -z "$STAGED_FILES" ]; then
|
||||
echo "No JS/CSS files staged for commit."
|
||||
exit 0
|
||||
fi
|
||||
|
||||
# Function to display errors
|
||||
display_errors() {
|
||||
local errors="$1"
|
||||
echo "Errors detected:"
|
||||
echo "---------------------------------------"
|
||||
echo "$errors"
|
||||
echo "---------------------------------------"
|
||||
}
|
||||
# Run Prettier
|
||||
echo "Running Prettier..."
|
||||
for FILE in $STAGED_FILES; do
|
||||
npx prettier --write "$FILE"
|
||||
done
|
||||
|
||||
# Run ESLint
|
||||
echo "Running ESLint..."
|
||||
ESLINT_ERRORS=0
|
||||
for FILE in $STAGED_FILES; do
|
||||
ESLINT_OUTPUT=$(npx eslint "$FILE" 2>&1)
|
||||
if [ $? -ne 0 ]; then
|
||||
display_errors "$ESLINT_OUTPUT"
|
||||
ESLINT_ERRORS=1
|
||||
fi
|
||||
done
|
||||
|
||||
if [ $ESLINT_ERRORS -ne 0 ]; then
|
||||
echo "ESLint errors detected. Please fix them before committing."
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Add the fixed files back to the staging area
|
||||
for FILE in $STAGED_FILES; do
|
||||
git add "$FILE"
|
||||
done
|
||||
|
||||
echo "JS/CSS pre-commit checks completed."
|
File diff suppressed because one or more lines are too long
|
@ -0,0 +1,22 @@
|
|||
# Ignore node_modules directory
|
||||
node_modules/
|
||||
|
||||
# Ignore build directory
|
||||
build/
|
||||
|
||||
# Ignore all minified JavaScript files
|
||||
*.min.js
|
||||
|
||||
|
||||
# Ignore specific files
|
||||
public/vendor/jquery.js
|
||||
public/vendor/bootstrap.js
|
||||
|
||||
# Ignore all files in a specific directory
|
||||
src/vendor/
|
||||
|
||||
# Ignore specific file
|
||||
path/to/specific/file.js
|
||||
|
||||
# Ignore all JavaScript files in a specific directory
|
||||
src/vendor/*.js
|
|
@ -0,0 +1,15 @@
|
|||
{
|
||||
"trailingComma": "es5",
|
||||
"tabWidth": 2,
|
||||
"semi": false,
|
||||
"singleQuote": true,
|
||||
"jsxSingleQuote": true,
|
||||
"bracketSpacing": true,
|
||||
"parser": "babel-ts",
|
||||
"requirePragma": false,
|
||||
"insertPragma": false,
|
||||
"proseWrap": "preserve",
|
||||
"htmlWhitespaceSensitivity": "css",
|
||||
"endOfLine": "lf",
|
||||
"embeddedLanguageFormatting": "off"
|
||||
}
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
/*
|
||||
| -------------------------------------------------------------------
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -102,7 +103,7 @@ $config['charset'] = 'UTF-8';
|
|||
| setting this variable to TRUE (boolean). See the user guide for details.
|
||||
|
|
||||
*/
|
||||
$config['enable_hooks'] = FALSE;
|
||||
$config['enable_hooks'] = false;
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -138,7 +139,7 @@ $config['subclass_prefix'] = 'MY_';
|
|||
| Note: This will NOT disable or override the CodeIgniter-specific
|
||||
| autoloading (application/config/autoload.php)
|
||||
*/
|
||||
$config['composer_autoload'] = FALSE;
|
||||
$config['composer_autoload'] = false;
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -184,7 +185,7 @@ $config['permitted_uri_chars'] = 'a-z 0-9~%.:_\-';
|
|||
| use segment based URLs.
|
||||
|
|
||||
*/
|
||||
$config['enable_query_strings'] = FALSE;
|
||||
$config['enable_query_strings'] = false;
|
||||
$config['controller_trigger'] = 'c';
|
||||
$config['function_trigger'] = 'm';
|
||||
$config['directory_trigger'] = 'd';
|
||||
|
@ -201,7 +202,7 @@ $config['directory_trigger'] = 'd';
|
|||
| for backwards compatibility purposes!
|
||||
|
|
||||
*/
|
||||
$config['allow_get_array'] = TRUE;
|
||||
$config['allow_get_array'] = true;
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -313,7 +314,7 @@ $config['cache_path'] = '';
|
|||
| of query parameters.
|
||||
|
|
||||
*/
|
||||
$config['cache_query_string'] = FALSE;
|
||||
$config['cache_query_string'] = false;
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -387,10 +388,10 @@ $config['sess_driver'] = 'files';
|
|||
$config['sess_cookie_name'] = 'ci_session';
|
||||
$config['sess_samesite'] = 'Lax';
|
||||
$config['sess_expiration'] = 7200;
|
||||
$config['sess_save_path'] = NULL;
|
||||
$config['sess_match_ip'] = FALSE;
|
||||
$config['sess_save_path'] = null;
|
||||
$config['sess_match_ip'] = false;
|
||||
$config['sess_time_to_update'] = 300;
|
||||
$config['sess_regenerate_destroy'] = FALSE;
|
||||
$config['sess_regenerate_destroy'] = false;
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -411,8 +412,8 @@ $config['sess_regenerate_destroy'] = FALSE;
|
|||
$config['cookie_prefix'] = '';
|
||||
$config['cookie_domain'] = '';
|
||||
$config['cookie_path'] = '/';
|
||||
$config['cookie_secure'] = FALSE;
|
||||
$config['cookie_httponly'] = FALSE;
|
||||
$config['cookie_secure'] = false;
|
||||
$config['cookie_httponly'] = false;
|
||||
$config['cookie_samesite'] = 'Lax';
|
||||
|
||||
/*
|
||||
|
@ -427,7 +428,7 @@ $config['cookie_samesite'] = 'Lax';
|
|||
| for backwards compatibility purposes!
|
||||
|
|
||||
*/
|
||||
$config['standardize_newlines'] = FALSE;
|
||||
$config['standardize_newlines'] = false;
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -441,7 +442,7 @@ $config['standardize_newlines'] = FALSE;
|
|||
| for backwards compatibility purposes!
|
||||
|
|
||||
*/
|
||||
$config['global_xss_filtering'] = FALSE;
|
||||
$config['global_xss_filtering'] = false;
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -457,11 +458,11 @@ $config['global_xss_filtering'] = FALSE;
|
|||
| 'csrf_regenerate' = Regenerate token on every submission
|
||||
| 'csrf_exclude_uris' = Array of URIs which ignore CSRF checks
|
||||
*/
|
||||
$config['csrf_protection'] = FALSE;
|
||||
$config['csrf_protection'] = false;
|
||||
$config['csrf_token_name'] = 'csrf_test_name';
|
||||
$config['csrf_cookie_name'] = 'csrf_cookie_name';
|
||||
$config['csrf_expire'] = 7200;
|
||||
$config['csrf_regenerate'] = TRUE;
|
||||
$config['csrf_regenerate'] = true;
|
||||
$config['csrf_exclude_uris'] = array();
|
||||
|
||||
/*
|
||||
|
@ -484,7 +485,7 @@ $config['csrf_exclude_uris'] = array();
|
|||
| by the output class. Do not 'echo' any values with compression enabled.
|
||||
|
|
||||
*/
|
||||
$config['compress_output'] = FALSE;
|
||||
$config['compress_output'] = false;
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -511,7 +512,7 @@ $config['time_reference'] = 'local';
|
|||
| Note: You need to have eval() enabled for this to work.
|
||||
|
|
||||
*/
|
||||
$config['rewrite_short_tags'] = FALSE;
|
||||
$config['rewrite_short_tags'] = false;
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -11,7 +12,7 @@ defined('BASEPATH') OR exit('No direct script access allowed');
|
|||
| of this setting
|
||||
|
|
||||
*/
|
||||
defined('SHOW_DEBUG_BACKTRACE') OR define('SHOW_DEBUG_BACKTRACE', TRUE);
|
||||
defined('SHOW_DEBUG_BACKTRACE') or define('SHOW_DEBUG_BACKTRACE', true);
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -26,10 +27,10 @@ defined('SHOW_DEBUG_BACKTRACE') OR define('SHOW_DEBUG_BACKTRACE', TRUE);
|
|||
| always be used to set the mode correctly.
|
||||
|
|
||||
*/
|
||||
defined('FILE_READ_MODE') OR define('FILE_READ_MODE', 0644);
|
||||
defined('FILE_WRITE_MODE') OR define('FILE_WRITE_MODE', 0666);
|
||||
defined('DIR_READ_MODE') OR define('DIR_READ_MODE', 0755);
|
||||
defined('DIR_WRITE_MODE') OR define('DIR_WRITE_MODE', 0755);
|
||||
defined('FILE_READ_MODE') or define('FILE_READ_MODE', 0644);
|
||||
defined('FILE_WRITE_MODE') or define('FILE_WRITE_MODE', 0666);
|
||||
defined('DIR_READ_MODE') or define('DIR_READ_MODE', 0755);
|
||||
defined('DIR_WRITE_MODE') or define('DIR_WRITE_MODE', 0755);
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -39,14 +40,14 @@ defined('DIR_WRITE_MODE') OR define('DIR_WRITE_MODE', 0755);
|
|||
| These modes are used when working with fopen()/popen()
|
||||
|
|
||||
*/
|
||||
defined('FOPEN_READ') OR define('FOPEN_READ', 'rb');
|
||||
defined('FOPEN_READ_WRITE') OR define('FOPEN_READ_WRITE', 'r+b');
|
||||
defined('FOPEN_WRITE_CREATE_DESTRUCTIVE') OR define('FOPEN_WRITE_CREATE_DESTRUCTIVE', 'wb'); // truncates existing file data, use with care
|
||||
defined('FOPEN_READ_WRITE_CREATE_DESTRUCTIVE') OR define('FOPEN_READ_WRITE_CREATE_DESTRUCTIVE', 'w+b'); // truncates existing file data, use with care
|
||||
defined('FOPEN_WRITE_CREATE') OR define('FOPEN_WRITE_CREATE', 'ab');
|
||||
defined('FOPEN_READ_WRITE_CREATE') OR define('FOPEN_READ_WRITE_CREATE', 'a+b');
|
||||
defined('FOPEN_WRITE_CREATE_STRICT') OR define('FOPEN_WRITE_CREATE_STRICT', 'xb');
|
||||
defined('FOPEN_READ_WRITE_CREATE_STRICT') OR define('FOPEN_READ_WRITE_CREATE_STRICT', 'x+b');
|
||||
defined('FOPEN_READ') or define('FOPEN_READ', 'rb');
|
||||
defined('FOPEN_READ_WRITE') or define('FOPEN_READ_WRITE', 'r+b');
|
||||
defined('FOPEN_WRITE_CREATE_DESTRUCTIVE') or define('FOPEN_WRITE_CREATE_DESTRUCTIVE', 'wb'); // truncates existing file data, use with care
|
||||
defined('FOPEN_READ_WRITE_CREATE_DESTRUCTIVE') or define('FOPEN_READ_WRITE_CREATE_DESTRUCTIVE', 'w+b'); // truncates existing file data, use with care
|
||||
defined('FOPEN_WRITE_CREATE') or define('FOPEN_WRITE_CREATE', 'ab');
|
||||
defined('FOPEN_READ_WRITE_CREATE') or define('FOPEN_READ_WRITE_CREATE', 'a+b');
|
||||
defined('FOPEN_WRITE_CREATE_STRICT') or define('FOPEN_WRITE_CREATE_STRICT', 'xb');
|
||||
defined('FOPEN_READ_WRITE_CREATE_STRICT') or define('FOPEN_READ_WRITE_CREATE_STRICT', 'x+b');
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -73,13 +74,13 @@ defined('FOPEN_READ_WRITE_CREATE_STRICT') OR define('FOPEN_READ_WRITE_CREA
|
|||
| http://tldp.org/LDP/abs/html/exitcodes.html
|
||||
|
|
||||
*/
|
||||
defined('EXIT_SUCCESS') OR define('EXIT_SUCCESS', 0); // no errors
|
||||
defined('EXIT_ERROR') OR define('EXIT_ERROR', 1); // generic error
|
||||
defined('EXIT_CONFIG') OR define('EXIT_CONFIG', 3); // configuration error
|
||||
defined('EXIT_UNKNOWN_FILE') OR define('EXIT_UNKNOWN_FILE', 4); // file not found
|
||||
defined('EXIT_UNKNOWN_CLASS') OR define('EXIT_UNKNOWN_CLASS', 5); // unknown class
|
||||
defined('EXIT_UNKNOWN_METHOD') OR define('EXIT_UNKNOWN_METHOD', 6); // unknown class member
|
||||
defined('EXIT_USER_INPUT') OR define('EXIT_USER_INPUT', 7); // invalid user input
|
||||
defined('EXIT_DATABASE') OR define('EXIT_DATABASE', 8); // database error
|
||||
defined('EXIT__AUTO_MIN') OR define('EXIT__AUTO_MIN', 9); // lowest automatically-assigned error code
|
||||
defined('EXIT__AUTO_MAX') OR define('EXIT__AUTO_MAX', 125); // highest automatically-assigned error code
|
||||
defined('EXIT_SUCCESS') or define('EXIT_SUCCESS', 0); // no errors
|
||||
defined('EXIT_ERROR') or define('EXIT_ERROR', 1); // generic error
|
||||
defined('EXIT_CONFIG') or define('EXIT_CONFIG', 3); // configuration error
|
||||
defined('EXIT_UNKNOWN_FILE') or define('EXIT_UNKNOWN_FILE', 4); // file not found
|
||||
defined('EXIT_UNKNOWN_CLASS') or define('EXIT_UNKNOWN_CLASS', 5); // unknown class
|
||||
defined('EXIT_UNKNOWN_METHOD') or define('EXIT_UNKNOWN_METHOD', 6); // unknown class member
|
||||
defined('EXIT_USER_INPUT') or define('EXIT_USER_INPUT', 7); // invalid user input
|
||||
defined('EXIT_DATABASE') or define('EXIT_DATABASE', 8); // database error
|
||||
defined('EXIT__AUTO_MIN') or define('EXIT__AUTO_MIN', 9); // lowest automatically-assigned error code
|
||||
defined('EXIT__AUTO_MAX') or define('EXIT__AUTO_MAX', 125); // highest automatically-assigned error code
|
||||
|
|
|
@ -1,77 +1,20 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
/*
|
||||
| -------------------------------------------------------------------
|
||||
| DATABASE CONNECTIVITY SETTINGS
|
||||
| -------------------------------------------------------------------
|
||||
| This file will contain the settings needed to access your database.
|
||||
|
|
||||
| For complete instructions please consult the 'Database Connection'
|
||||
| page of the User Guide.
|
||||
|
|
||||
| -------------------------------------------------------------------
|
||||
| EXPLANATION OF VARIABLES
|
||||
| -------------------------------------------------------------------
|
||||
|
|
||||
| ['dsn'] The full DSN string describe a connection to the database.
|
||||
| ['hostname'] The hostname of your database server.
|
||||
| ['username'] The username used to connect to the database
|
||||
| ['password'] The password used to connect to the database
|
||||
| ['database'] The name of the database you want to connect to
|
||||
| ['dbdriver'] The database driver. e.g.: mysqli.
|
||||
| Currently supported:
|
||||
| cubrid, ibase, mssql, mysql, mysqli, oci8,
|
||||
| odbc, pdo, postgre, sqlite, sqlite3, sqlsrv
|
||||
| ['dbprefix'] You can add an optional prefix, which will be added
|
||||
| to the table name when using the Query Builder class
|
||||
| ['pconnect'] TRUE/FALSE - Whether to use a persistent connection
|
||||
| ['db_debug'] TRUE/FALSE - Whether database errors should be displayed.
|
||||
| ['cache_on'] TRUE/FALSE - Enables/disables query caching
|
||||
| ['cachedir'] The path to the folder where cache files should be stored
|
||||
| ['char_set'] The character set used in communicating with the database
|
||||
| ['dbcollat'] The character collation used in communicating with the database
|
||||
| NOTE: For MySQL and MySQLi databases, this setting is only used
|
||||
| as a backup if your server is running PHP < 5.2.3 or MySQL < 5.0.7
|
||||
| (and in table creation queries made with DB Forge).
|
||||
| There is an incompatibility in PHP with mysql_real_escape_string() which
|
||||
| can make your site vulnerable to SQL injection if you are using a
|
||||
| multi-byte character set and are running versions lower than these.
|
||||
| Sites using Latin-1 or UTF-8 database character set and collation are unaffected.
|
||||
| ['swap_pre'] A default table prefix that should be swapped with the dbprefix
|
||||
| ['encrypt'] Whether or not to use an encrypted connection.
|
||||
|
|
||||
| 'mysql' (deprecated), 'sqlsrv' and 'pdo/sqlsrv' drivers accept TRUE/FALSE
|
||||
| 'mysqli' and 'pdo/mysql' drivers accept an array with the following options:
|
||||
|
|
||||
| 'ssl_key' - Path to the private key file
|
||||
| 'ssl_cert' - Path to the public key certificate file
|
||||
| 'ssl_ca' - Path to the certificate authority file
|
||||
| 'ssl_capath' - Path to a directory containing trusted CA certificates in PEM format
|
||||
| 'ssl_cipher' - List of *allowed* ciphers to be used for the encryption, separated by colons (':')
|
||||
| 'ssl_verify' - TRUE/FALSE; Whether verify the server certificate or not
|
||||
|
|
||||
| ['compress'] Whether or not to use client compression (MySQL only)
|
||||
| ['stricton'] TRUE/FALSE - forces 'Strict Mode' connections
|
||||
| - good for ensuring strict SQL while developing
|
||||
| ['ssl_options'] Used to set various SSL options that can be used when making SSL connections.
|
||||
| ['failover'] array - A array with 0 or more data for connections if the main should fail.
|
||||
| ['save_queries'] TRUE/FALSE - Whether to "save" all executed queries.
|
||||
| NOTE: Disabling this will also effectively disable both
|
||||
| $this->db->last_query() and profiling of DB queries.
|
||||
| When you run a query, with this setting set to TRUE (default),
|
||||
| CodeIgniter will store the SQL statement for debugging purposes.
|
||||
| However, this may cause high memory usage, especially if you run
|
||||
| a lot of SQL queries ... disable this to avoid that problem.
|
||||
|
|
||||
| The $active_group variable lets you choose which connection group to
|
||||
| make active. By default there is only one group (the 'default' group).
|
||||
|
|
||||
| The $query_builder variables lets you determine whether or not to load
|
||||
| the query builder class.
|
||||
*/
|
||||
/**
|
||||
* This file handles the XYZ functionality in the application.
|
||||
* @category YourCategory
|
||||
* @package YourApplication
|
||||
* @subpackage YourSubpackage
|
||||
* @author Your Name
|
||||
* @date YYYY-MM-DD
|
||||
* @version 1.0
|
||||
*/
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
|
||||
$active_group = 'default';
|
||||
$query_builder = TRUE;
|
||||
$query_builder = true;
|
||||
|
||||
$db['default'] = array(
|
||||
'dsn' => '',
|
||||
|
@ -81,16 +24,16 @@ $db['default'] = array(
|
|||
'database' => 'google_forms',
|
||||
'dbdriver' => 'mysqli',
|
||||
'dbprefix' => '',
|
||||
'pconnect' => FALSE,
|
||||
'pconnect' => false,
|
||||
'db_debug' => (ENVIRONMENT !== 'production'),
|
||||
'cache_on' => FALSE,
|
||||
'cache_on' => false,
|
||||
'cachedir' => '',
|
||||
'char_set' => 'utf8',
|
||||
'dbcollat' => 'utf8_general_ci',
|
||||
'swap_pre' => '',
|
||||
'encrypt' => FALSE,
|
||||
'compress' => FALSE,
|
||||
'stricton' => FALSE,
|
||||
'encrypt' => false,
|
||||
'compress' => false,
|
||||
'stricton' => false,
|
||||
'failover' => array(),
|
||||
'save_queries' => TRUE
|
||||
'save_queries' => true
|
||||
);
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
$_doctypes = array(
|
||||
'xhtml11' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">',
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
/*
|
||||
| -------------------------------------------------------------------
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
/*
|
||||
| -------------------------------------------------------------------------
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
/*
|
||||
| -------------------------------------------------------------------------
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -11,7 +12,7 @@ defined('BASEPATH') OR exit('No direct script access allowed');
|
|||
| and disable it back when you're done.
|
||||
|
|
||||
*/
|
||||
$config['migration_enabled'] = FALSE;
|
||||
$config['migration_enabled'] = false;
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -57,7 +58,7 @@ $config['migration_table'] = 'migrations';
|
|||
| in your code to have the latest migration.
|
||||
|
|
||||
*/
|
||||
$config['migration_auto_latest'] = FALSE;
|
||||
$config['migration_auto_latest'] = false;
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
|
@ -81,4 +82,4 @@ $config['migration_version'] = 0;
|
|||
| Also, writing permission is required within the migrations path.
|
||||
|
|
||||
*/
|
||||
$config['migration_path'] = APPPATH.'migrations/';
|
||||
$config['migration_path'] = APPPATH . 'migrations/';
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
/*
|
||||
| -------------------------------------------------------------------
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
/*
|
||||
| -------------------------------------------------------------------------
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
$route['forms'] = 'home/index4';
|
||||
|
||||
|
@ -8,7 +9,7 @@ $route['responses/view/(:num)'] = 'Response_submit/viewresponse/$1';
|
|||
$route['publish/(:num)'] = 'forms/preview/$1';
|
||||
$route['default_controller'] = 'Form_controller/index_forms';
|
||||
$route['404_override'] = '';
|
||||
$route['translate_uri_dashes'] = FALSE;
|
||||
$route['translate_uri_dashes'] = false;
|
||||
$route['start'] = 'Form_controller/index_forms';
|
||||
$route['title_desc'] = 'homepage/title';
|
||||
$route['forms/delete/(:any)'] = 'Form_controller/delete/$1';
|
||||
|
@ -25,3 +26,4 @@ $route['response_preview/(:num)'] = 'forms/response_preview/$1';
|
|||
|
||||
$route['title'] = 'homepage/title';
|
||||
|
||||
$route['total_responses'] = 'Response_submit/index';
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
/*
|
||||
| -------------------------------------------------------------------
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
/*
|
||||
| -------------------------------------------------------------------
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<?php
|
||||
|
||||
namespace application\controllers;
|
||||
// namespace application\controllers;
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
// use application\models\Form_model;
|
||||
|
||||
class Form extends CI_Controller
|
||||
{
|
||||
public function __construct()
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
<?php
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
class Form_controller extends CI_Controller
|
||||
{
|
||||
|
||||
public function index_forms($form_id = null)
|
||||
{
|
||||
$this->load->model('Frontend_model');
|
||||
|
@ -25,7 +25,6 @@ class Form_controller extends CI_Controller
|
|||
$form_title = $form['title'];
|
||||
}
|
||||
}
|
||||
|
||||
// Fetch data from models
|
||||
$data['total_forms'] = $this->Form_model->get_total_forms($user_id);
|
||||
$data['published_forms'] = $this->Form_model->get_published_forms($user_id);
|
||||
|
@ -49,12 +48,13 @@ class Form_controller extends CI_Controller
|
|||
$this->load->model('Frontend_model');
|
||||
$this->Frontend_model->deleteForm($id);
|
||||
$this->session->set_flashdata('status', 'Form data deleted successfully');
|
||||
redirect('drafts');
|
||||
redirect('home');
|
||||
}
|
||||
public function __construct()
|
||||
{
|
||||
parent::__construct();
|
||||
$this->load->model('Updation_model');
|
||||
$this->load->model('Form_model');
|
||||
}
|
||||
|
||||
// Load the form for editing
|
||||
|
@ -63,11 +63,11 @@ class Form_controller extends CI_Controller
|
|||
$data['form'] = $this->Updation_model->get_form($form_id);
|
||||
$data['questions'] = $this->Updation_model->get_questions($form_id);
|
||||
$data['options'] = $this->Updation_model->get_options();
|
||||
$data['is_published'] = $this->Form_model->get_published_value($form_id);
|
||||
|
||||
// $this->load->view('templates/header');
|
||||
$this->load->view('edit_form_view', $data);
|
||||
// $this->load->view('templates/footer');
|
||||
|
||||
}
|
||||
|
||||
// Save the edited form
|
||||
|
@ -126,5 +126,4 @@ class Form_controller extends CI_Controller
|
|||
|
||||
$this->load->view('templates/footer');
|
||||
}
|
||||
|
||||
}
|
|
@ -10,9 +10,6 @@ class Forms extends CI_Controller
|
|||
// If not logged in, redirect to login page
|
||||
redirect('users/login');
|
||||
}
|
||||
|
||||
|
||||
|
||||
// Load the model that handles the form data
|
||||
$this->load->model('preview_model');
|
||||
|
||||
|
|
|
@ -1,9 +1,9 @@
|
|||
<?php
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
class Homepage extends CI_Controller
|
||||
{
|
||||
|
||||
// index2-default
|
||||
public function home()
|
||||
{
|
||||
|
@ -17,19 +17,15 @@ class Homepage extends CI_Controller
|
|||
{
|
||||
|
||||
$this->load->view('templates/forms_ui');
|
||||
|
||||
}
|
||||
public function title()
|
||||
{
|
||||
$this->load->view('templates/header');
|
||||
$this->load->view('templates/form_title');
|
||||
$this->load->view('templates/footer');
|
||||
|
||||
}
|
||||
public function ui_forms()
|
||||
{
|
||||
$this->load->view('templates/forms_ui');
|
||||
}
|
||||
|
||||
|
||||
}
|
|
@ -1,7 +1,9 @@
|
|||
<?php
|
||||
|
||||
class New_form extends CI_Controller
|
||||
{
|
||||
public function create_form() {
|
||||
public function create_form()
|
||||
{
|
||||
if (!$this->session->userdata('logged_in')) {
|
||||
// If not logged in, redirect to login page
|
||||
redirect('users/login');
|
||||
|
@ -11,7 +13,7 @@ class New_form extends CI_Controller
|
|||
$this->form_validation->set_rules('title', 'Title', 'required');
|
||||
$this->form_validation->set_rules('description', 'Description', 'required');
|
||||
|
||||
if ($this->form_validation->run() === FALSE) {
|
||||
if ($this->form_validation->run() === false) {
|
||||
$this->load->view('templates/header');
|
||||
$this->load->view('templates/form_title', $data);
|
||||
$this->load->view('templates/footer');
|
||||
|
@ -23,7 +25,4 @@ class New_form extends CI_Controller
|
|||
redirect('form/view/' . $form_id);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
?>
|
|
@ -1,22 +1,19 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
class New_form_controller extends CI_Controller {
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
public function submit_form() {
|
||||
class New_form_controller extends CI_Controller
|
||||
{
|
||||
public function submit_form()
|
||||
{
|
||||
if (!$this->session->userdata('logged_in')) {
|
||||
// If not logged in, redirect to login page
|
||||
echo json_encode(['status' => 'error', 'message' => 'User not logged in']);
|
||||
return;
|
||||
}
|
||||
|
||||
// Decode the formData from the POST request
|
||||
$formData = $this->input->post('formData');
|
||||
// Check if form_id is set in session
|
||||
$formId = $this->session->userdata('form_id');
|
||||
}// Decode the formData from the POST request$formData = $this->input->post('formData');
|
||||
// Check if form_id is set in session$formId = $this->session->userdata('form_id');
|
||||
if ($formId) {
|
||||
// Load the model and save form data
|
||||
$this->load->model('new_form_model');
|
||||
// Load the model and save form data$this->load->model('new_form_model');
|
||||
$saveStatus = $this->new_form_model->save_form_data($formId, $formData);
|
||||
|
||||
if ($saveStatus) {
|
||||
|
@ -29,4 +26,3 @@ class New_form_controller extends CI_Controller {
|
|||
}
|
||||
}
|
||||
}
|
||||
?>
|
||||
|
|
|
@ -1,10 +1,12 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
class Publish_controller extends CI_Controller {
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
class Publish_controller extends CI_Controller
|
||||
{
|
||||
// Method to publish a form
|
||||
public function publish_form($form_id) {
|
||||
public function publish_form($form_id)
|
||||
{
|
||||
// Generate a unique link
|
||||
if (!$this->session->userdata('logged_in')) {
|
||||
// If not logged in, redirect to login page
|
||||
|
@ -23,7 +25,8 @@ class Publish_controller extends CI_Controller {
|
|||
}
|
||||
|
||||
// Method to list published forms of a user
|
||||
public function list_user_published_forms() {
|
||||
public function list_user_published_forms()
|
||||
{
|
||||
if (!$this->session->userdata('logged_in')) {
|
||||
// If not logged in, redirect to login page
|
||||
redirect('users/login');
|
||||
|
@ -39,7 +42,8 @@ class Publish_controller extends CI_Controller {
|
|||
|
||||
|
||||
// Method to unpublish a form
|
||||
public function unpublish_form($form_id) {
|
||||
public function unpublish_form($form_id)
|
||||
{
|
||||
if (!$this->session->userdata('logged_in')) {
|
||||
// If not logged in, redirect to login page
|
||||
redirect('users/login');
|
||||
|
@ -51,7 +55,8 @@ class Publish_controller extends CI_Controller {
|
|||
|
||||
// redirect('published_forms');
|
||||
}
|
||||
public function toggle_responsive($form_id) {
|
||||
public function toggle_responsive($form_id)
|
||||
{
|
||||
if (!$this->session->userdata('logged_in')) {
|
||||
redirect('users/login');
|
||||
}
|
||||
|
@ -76,6 +81,4 @@ class Publish_controller extends CI_Controller {
|
|||
echo json_encode(['success' => false, 'message' => 'Failed to update']);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
|
|
@ -1,7 +1,9 @@
|
|||
<?php
|
||||
class Response_submit extends CI_Controller {
|
||||
|
||||
public function view($form_id) {
|
||||
class Response_submit extends CI_Controller
|
||||
{
|
||||
public function view($form_id)
|
||||
{
|
||||
$this->load->model('Response_model');
|
||||
|
||||
$data['form'] = $this->Response_model->get_form($form_id);
|
||||
|
@ -17,7 +19,8 @@ class Response_submit extends CI_Controller {
|
|||
redirect('responses/' . $form_id);
|
||||
}
|
||||
|
||||
public function view_responses($form_id) {
|
||||
public function view_responses($form_id)
|
||||
{
|
||||
$this->load->model('Response_model');
|
||||
|
||||
$data['form'] = $this->Response_model->get_form($form_id);
|
||||
|
@ -29,7 +32,8 @@ class Response_submit extends CI_Controller {
|
|||
}
|
||||
|
||||
|
||||
public function submit_form() {
|
||||
public function submit_form()
|
||||
{
|
||||
$this->load->model('Response_model');
|
||||
$responses = $this->input->post('responses');
|
||||
$user_id = $this->session->userdata('user_id'); // Assuming user_id is stored in session
|
||||
|
@ -52,7 +56,7 @@ class Response_submit extends CI_Controller {
|
|||
} else {
|
||||
$answered_text = $response['options'];
|
||||
}
|
||||
} else if (isset($response['answered_text'])) {
|
||||
} elseif (isset($response['answered_text'])) {
|
||||
$answered_text = $response['answered_text'];
|
||||
}
|
||||
|
||||
|
@ -71,7 +75,8 @@ class Response_submit extends CI_Controller {
|
|||
|
||||
|
||||
// Method to list responses for a form
|
||||
public function list_responses($form_id) {
|
||||
public function list_responses($form_id)
|
||||
{
|
||||
$this->load->model('Response_model');
|
||||
$data['form'] = $this->Response_model->get_form($form_id);
|
||||
$data['responses'] = $this->Response_model->get_responses($form_id);
|
||||
|
@ -82,7 +87,8 @@ class Response_submit extends CI_Controller {
|
|||
}
|
||||
|
||||
// Method to view questions and answers for a specific response
|
||||
public function viewresponse($response_id) {
|
||||
public function viewresponse($response_id)
|
||||
{
|
||||
$this->load->model('Response_model');
|
||||
$data['response'] = $this->Response_model->get_response($response_id);
|
||||
$data['form'] = $this->Response_model->get_form_by_response($response_id); // Get form details
|
||||
|
@ -94,7 +100,7 @@ class Response_submit extends CI_Controller {
|
|||
}
|
||||
|
||||
public function summary($form_id)
|
||||
{
|
||||
{
|
||||
$this->load->model('Form_model');
|
||||
$this->load->model('Response_model');
|
||||
|
||||
|
@ -115,15 +121,52 @@ class Response_submit extends CI_Controller {
|
|||
$data['form'] = $form;
|
||||
$data['summary_data'] = $summary_data;
|
||||
|
||||
$this->load->view('templates/header');
|
||||
$this->load->view('Forms/summary', $data);
|
||||
}
|
||||
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
parent::__construct();
|
||||
$this->load->model('response_model');
|
||||
}
|
||||
|
||||
public function index()
|
||||
{
|
||||
$data['responses'] = $this->response_model->get_responses_with_details();
|
||||
$this->load->view('templates/header');
|
||||
$this->load->view('allresponse_details_view', $data);
|
||||
$this->load->view('templates/footer');
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
public function response_summary()
|
||||
{
|
||||
$data['forms'] = $this->Response_model->get_forms();
|
||||
$this->load->view('templates/header');
|
||||
$this->load->view('responses/response_summary', $data);
|
||||
$this->load->view('templates/footer');
|
||||
}
|
||||
|
||||
public function response_summary_by_form($form_id)
|
||||
{
|
||||
$responses = $this->Response_model->get_response_summary_by_form($form_id);
|
||||
$data = $this->prepare_data($responses);
|
||||
$data['form_id'] = $form_id;
|
||||
|
||||
$this->load->view('templates/header');
|
||||
$this->load->view('responses/summary', $data);
|
||||
$this->load->view('templates/footer');
|
||||
}
|
||||
|
||||
private function prepare_data($responses)
|
||||
{
|
||||
$data = [];
|
||||
foreach ($responses as $response) {
|
||||
$question_text = $response->question_text;
|
||||
if (!isset($data[$question_text])) {
|
||||
$data[$question_text] = ['type' => $response->question_type, 'answers' => []];
|
||||
}
|
||||
$data[$question_text]['answers'][] = $response->answer_text;
|
||||
}
|
||||
return $data;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
<?php
|
||||
|
||||
class Users extends CI_Controller
|
||||
{
|
||||
//signup user
|
||||
|
@ -10,7 +11,7 @@ class Users extends CI_Controller
|
|||
$this->form_validation->set_rules('password', 'Password', 'required');
|
||||
$this->form_validation->set_rules('password2', 'Confirm Passsword', 'matches[password]');
|
||||
|
||||
if ($this->form_validation->run() === FALSE) {
|
||||
if ($this->form_validation->run() === false) {
|
||||
$this->load->view('templates/header');
|
||||
$this->load->view('users/register', $data);
|
||||
$this->load->view('templates/footer');
|
||||
|
@ -25,7 +26,6 @@ class Users extends CI_Controller
|
|||
$this->session->set_flashdata('user_registered', 'You are now registered and can log in');
|
||||
redirect('start');
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
@ -38,7 +38,7 @@ class Users extends CI_Controller
|
|||
$this->form_validation->set_rules('username', 'Username', 'required');
|
||||
$this->form_validation->set_rules('password', 'Password', 'required');
|
||||
|
||||
if ($this->form_validation->run() === FALSE) {
|
||||
if ($this->form_validation->run() === false) {
|
||||
$this->load->view('templates/header');
|
||||
$this->load->view('users/login', $data);
|
||||
$this->load->view('templates/footer');
|
||||
|
@ -85,7 +85,6 @@ class Users extends CI_Controller
|
|||
|
||||
$this->session->set_flashdata('user_loggedout', 'You are now logged out');
|
||||
redirect('users/login');
|
||||
|
||||
}
|
||||
// check if username exists
|
||||
public function check_username_exists($username)
|
||||
|
@ -122,6 +121,3 @@ class Users extends CI_Controller
|
|||
// }
|
||||
// }
|
||||
}
|
||||
|
||||
|
||||
?>
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,8 +1,10 @@
|
|||
|
||||
<?php
|
||||
class Create_model extends CI_Model {
|
||||
|
||||
public function details() {
|
||||
class Create_model extends CI_Model
|
||||
{
|
||||
public function details()
|
||||
{
|
||||
// Retrieve user_id from session
|
||||
$user_id = $this->session->userdata('user_id');
|
||||
|
||||
|
@ -20,8 +22,6 @@ class Create_model extends CI_Model {
|
|||
$formId = $this->db->insert_id();
|
||||
$this->session->set_userdata('form_id', $formId);
|
||||
|
||||
return $formId;
|
||||
return $formId;
|
||||
}
|
||||
|
||||
}
|
||||
?>
|
||||
|
|
|
@ -1,9 +1,22 @@
|
|||
<?php
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
class Form_model extends CI_Model
|
||||
{
|
||||
public function get_published_value($form_id)
|
||||
{
|
||||
$this->db->select('is_published');
|
||||
$this->db->from('forms'); // Adjust 'forms' to your table name
|
||||
$this->db->where('id', $form_id);
|
||||
$query = $this->db->get();
|
||||
|
||||
if ($query->num_rows() > 0) {
|
||||
return $query->row()->is_published;
|
||||
} else {
|
||||
return null; // or 0 or another default value if you prefer
|
||||
}
|
||||
}
|
||||
// Function to get form details by ID
|
||||
public function get_form_by_id($form_id)
|
||||
{
|
||||
|
@ -13,14 +26,16 @@ class Form_model extends CI_Model
|
|||
return $query->row();
|
||||
}
|
||||
// Get the total number of forms
|
||||
public function get_total_forms($user_id) {
|
||||
public function get_total_forms($user_id)
|
||||
{
|
||||
// Ensure user_id is passed as a parameter and used in the query
|
||||
$this->db->where('user_id', $user_id);
|
||||
return $this->db->count_all_results('forms'); // Use count_all_results to ensure WHERE conditions are applied
|
||||
}
|
||||
|
||||
// Function to count published forms
|
||||
public function get_published_forms($user_id) {
|
||||
public function get_published_forms($user_id)
|
||||
{
|
||||
// Ensure user_id and is_published are passed as parameters and used in the query
|
||||
$this->db->where('user_id', $user_id);
|
||||
$this->db->where('is_published', 1);
|
||||
|
@ -65,7 +80,7 @@ class Form_model extends CI_Model
|
|||
|
||||
$this->db->trans_complete();
|
||||
|
||||
if ($this->db->trans_status() === FALSE) {
|
||||
if ($this->db->trans_status() === false) {
|
||||
return false;
|
||||
} else {
|
||||
return true;
|
||||
|
|
|
@ -1,8 +1,10 @@
|
|||
|
||||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
class Frontend_model extends CI_Model {
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
class Frontend_model extends CI_Model
|
||||
{
|
||||
public function getforms()
|
||||
{
|
||||
// Get the user_id from session
|
||||
|
@ -21,7 +23,8 @@ class Frontend_model extends CI_Model {
|
|||
return $query->result(); // Return the result as an array of objects
|
||||
}
|
||||
|
||||
public function deleteForm($id){
|
||||
public function deleteForm($id)
|
||||
{
|
||||
return $this->db->delete('forms', ['id' => $id]);
|
||||
}
|
||||
public function getFormById($form_id)
|
||||
|
@ -29,13 +32,12 @@ class Frontend_model extends CI_Model {
|
|||
$query = $this->db->get_where('forms', ['id' => $form_id]);
|
||||
return $query->row_array();
|
||||
}
|
||||
public function getforms_draft($user_id) {
|
||||
public function getforms_draft($user_id)
|
||||
{
|
||||
$this->db->where('is_published', 0);
|
||||
$this->db->where('user_id', $user_id);
|
||||
$this->db->order_by('created_at', 'DESC');
|
||||
$query = $this->db->get('forms');
|
||||
return $query->result();
|
||||
}
|
||||
|
||||
|
||||
}
|
|
@ -1,7 +1,9 @@
|
|||
<?php
|
||||
class New_form_model extends CI_Model {
|
||||
|
||||
public function save_form_data($formId, $formData) {
|
||||
class New_form_model extends CI_Model
|
||||
{
|
||||
public function save_form_data($formId, $formData)
|
||||
{
|
||||
if (!$formId || !isset($formData['questions'])) {
|
||||
return false; // Handle error if formId is not valid or questions are missing
|
||||
}
|
||||
|
@ -36,7 +38,4 @@ class New_form_model extends CI_Model {
|
|||
|
||||
return true; // Return true indicating success
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
?>
|
||||
|
|
|
@ -1,22 +1,25 @@
|
|||
<?php
|
||||
class preview_model extends CI_Model {
|
||||
|
||||
public function get_form($form_id) {
|
||||
class preview_model extends CI_Model
|
||||
{
|
||||
public function get_form($form_id)
|
||||
{
|
||||
$this->db->where('id', $form_id);
|
||||
$query = $this->db->get('forms');
|
||||
return $query->row();
|
||||
}
|
||||
|
||||
public function get_questions($form_id) {
|
||||
public function get_questions($form_id)
|
||||
{
|
||||
$this->db->where('form_id', $form_id);
|
||||
$query = $this->db->get('questions');
|
||||
return $query->result(); // Ensure this returns objects with the 'is_required' field
|
||||
}
|
||||
|
||||
public function get_options($question_id) {
|
||||
public function get_options($question_id)
|
||||
{
|
||||
$this->db->where('question_id', $question_id);
|
||||
$query = $this->db->get('options');
|
||||
return $query->result(); // Ensure this returns the options related to the question
|
||||
}
|
||||
|
||||
}
|
|
@ -1,19 +1,21 @@
|
|||
<?php
|
||||
class Publish_model extends CI_Model {
|
||||
|
||||
// Method to update form details including is_published status
|
||||
public function update_form($form_id, $data) {
|
||||
class Publish_model extends CI_Model
|
||||
{
|
||||
// Method to update form details including is_published status
|
||||
public function update_form($form_id, $data)
|
||||
{
|
||||
$this->db->where('id', $form_id);
|
||||
return $this->db->update('forms', $data);
|
||||
}
|
||||
}
|
||||
|
||||
// Method to retrieve published forms by user
|
||||
public function get_published_forms_by_user($user_id) {
|
||||
// Method to retrieve published forms by user
|
||||
public function get_published_forms_by_user($user_id)
|
||||
{
|
||||
$this->db->where('user_id', $user_id);
|
||||
$this->db->where('is_published', 1);
|
||||
$this->db->order_by('id', 'DESC'); // Order by id column, most recent first
|
||||
$query = $this->db->get('forms');
|
||||
return $query->result();
|
||||
}
|
||||
|
||||
}
|
||||
}
|
|
@ -1,12 +1,15 @@
|
|||
<?php
|
||||
|
||||
class Response_model extends CI_Model
|
||||
{
|
||||
public function __construct() {
|
||||
public function __construct()
|
||||
{
|
||||
$this->load->database();
|
||||
}
|
||||
|
||||
// Get the total number of responses
|
||||
public function get_total_responses($user_id) {
|
||||
public function get_total_responses($user_id)
|
||||
{
|
||||
// Join the responses table with the forms table
|
||||
$this->db->select('responses.id');
|
||||
$this->db->from('responses');
|
||||
|
@ -168,5 +171,58 @@ class Response_model extends CI_Model
|
|||
|
||||
return $summary_data;
|
||||
}
|
||||
}
|
||||
|
||||
public function get_responses_with_details()
|
||||
{
|
||||
// Fetch responses with form title, submission time, and user email
|
||||
$this->db->select('responses.id as response_id, forms.title as form_title, responses.submitted_at, users.email');
|
||||
$this->db->from('responses');
|
||||
$this->db->join('forms', 'responses.form_id = forms.id');
|
||||
$this->db->join('users', 'responses.user_id = users.id');
|
||||
$this->db->order_by('responses.submitted_at', 'DESC');
|
||||
$responses_query = $this->db->get();
|
||||
$responses = $responses_query->result();
|
||||
|
||||
$response_details = [];
|
||||
foreach ($responses as $response) {
|
||||
// Fetch questions and answers for each response
|
||||
$this->db->select('questions.text, response_answers.answered_text');
|
||||
$this->db->from('response_answers');
|
||||
$this->db->join('questions', 'response_answers.question_id = questions.id');
|
||||
$this->db->where('response_answers.response_id', $response->response_id);
|
||||
$questions_query = $this->db->get();
|
||||
$questions_and_answers = $questions_query->result();
|
||||
|
||||
if (!isset($response_details[$response->form_title])) {
|
||||
$response_details[$response->form_title] = [];
|
||||
}
|
||||
|
||||
$response_details[$response->form_title][] = [
|
||||
'submitted_at' => $response->submitted_at,
|
||||
'email' => $response->email,
|
||||
'questions_and_answers' => $questions_and_answers
|
||||
];
|
||||
}
|
||||
|
||||
return $response_details;
|
||||
}
|
||||
|
||||
public function get_response_summary_by_form($form_id)
|
||||
{
|
||||
$this->db->select('questions.text as question_text, answers.text as answer_text, questions.type as question_type');
|
||||
$this->db->from('responses');
|
||||
$this->db->join('answers', 'responses.id = answers.response_id');
|
||||
$this->db->join('questions', 'answers.question_id = questions.id');
|
||||
$this->db->where('responses.form_id', $form_id);
|
||||
$query = $this->db->get();
|
||||
return $query->result();
|
||||
}
|
||||
|
||||
public function get_forms()
|
||||
{
|
||||
$this->db->select('id, title');
|
||||
$this->db->from('forms');
|
||||
$query = $this->db->get();
|
||||
return $query->result();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
<?php
|
||||
|
||||
class Updation_model extends CI_Model
|
||||
{
|
||||
|
||||
public function get_form($form_id)
|
||||
{
|
||||
$this->db->where('id', $form_id);
|
||||
|
@ -9,6 +9,7 @@ class Updation_model extends CI_Model
|
|||
return $query->row_array();
|
||||
}
|
||||
|
||||
|
||||
public function get_questions($form_id)
|
||||
{
|
||||
$this->db->where('form_id', $form_id);
|
||||
|
@ -90,8 +91,4 @@ class Updation_model extends CI_Model
|
|||
$this->db->delete('options');
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
?>
|
|
@ -1,49 +1,48 @@
|
|||
<?php
|
||||
class User_model extends CI_Model{
|
||||
public function register($enc_password){
|
||||
$data = array(
|
||||
'email'=> $this->input->post('email'),
|
||||
'username'=> $this->input->post('username'),
|
||||
'password'=> $enc_password
|
||||
);
|
||||
|
||||
return $this->db->insert('users', $data);
|
||||
class User_model extends CI_Model
|
||||
{
|
||||
public function register($enc_password)
|
||||
{
|
||||
$data = array(
|
||||
'email' => $this->input->post('email'),
|
||||
'username' => $this->input->post('username'),
|
||||
'password' => $enc_password
|
||||
);
|
||||
|
||||
return $this->db->insert('users', $data);
|
||||
}
|
||||
|
||||
public function login($username,$password){
|
||||
$this->db->where('username',$username);
|
||||
$this->db->where('password',$password);
|
||||
public function login($username, $password)
|
||||
{
|
||||
$this->db->where('username', $username);
|
||||
$this->db->where('password', $password);
|
||||
|
||||
$result = $this->db->get('users');
|
||||
if($result->num_rows()==1){
|
||||
if ($result->num_rows() == 1) {
|
||||
return $result->row(0)->id;
|
||||
}
|
||||
else{
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
public function check_username_exists($username){
|
||||
$query = $this->db->get_where('users',array('username'=>$username));
|
||||
if(empty($query->row_array())){
|
||||
public function check_username_exists($username)
|
||||
{
|
||||
$query = $this->db->get_where('users', array('username' => $username));
|
||||
if (empty($query->row_array())) {
|
||||
return true;
|
||||
}
|
||||
else{
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public function check_email_exists($email){
|
||||
$query = $this->db->get_where('users',array('email'=>$email));
|
||||
if(empty($query->row_array())){
|
||||
public function check_email_exists($email)
|
||||
{
|
||||
$query = $this->db->get_where('users', array('email' => $email));
|
||||
if (empty($query->row_array())) {
|
||||
return true;
|
||||
}
|
||||
else{
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
?>
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -28,16 +28,16 @@
|
|||
</div>
|
||||
<div class="card-body">
|
||||
<div id="charts">
|
||||
<?php foreach ($summary_data as $question): ?>
|
||||
<?php foreach ($summary_data as $question) : ?>
|
||||
<h5><?php echo $question['text']; ?></h5>
|
||||
<?php if (is_array($question['answers'])): ?>
|
||||
<?php if (is_array($question['answers'])) : ?>
|
||||
<div class="chart-container">
|
||||
<canvas id="chart-<?php echo $question['question_id']; ?>"></canvas>
|
||||
</div>
|
||||
<?php else: ?>
|
||||
<?php else : ?>
|
||||
<div class="short-answer">
|
||||
<ul>
|
||||
<?php foreach ($question['answers'] as $answer): ?>
|
||||
<?php foreach ($question['answers'] as $answer) : ?>
|
||||
<li><?php echo $answer; ?></li>
|
||||
<?php endforeach; ?>
|
||||
</ul>
|
||||
|
|
|
@ -21,7 +21,7 @@
|
|||
<div class="col-md-12 mt-4">
|
||||
<div class="card">
|
||||
<div class="card-header">
|
||||
<?php if ($this->session->flashdata('status')): ?>
|
||||
<?php if ($this->session->flashdata('status')) : ?>
|
||||
<div class="alert alert-success">
|
||||
<?= $this->session->flashdata('status'); ?>
|
||||
</div>
|
||||
|
@ -32,7 +32,7 @@
|
|||
<table id="basetable1" class="table table-bordered">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Drafts</th>
|
||||
<th>Serial No.</th>
|
||||
<th>Title</th>
|
||||
<th>Created On</th>
|
||||
<th>Edit</th>
|
||||
|
@ -43,7 +43,7 @@
|
|||
<tbody>
|
||||
<?php
|
||||
$serialNumber = 1; // Initialize the counter variable
|
||||
foreach ($forms as $row): ?>
|
||||
foreach ($forms as $row) : ?>
|
||||
<tr>
|
||||
<td><?php echo $serialNumber++; ?></td>
|
||||
<td class="title-column"><?php echo $row->title; ?></td>
|
||||
|
|
|
@ -1,12 +1,18 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
|
||||
<head>
|
||||
<!-- Other head elements -->
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title>Form List</title>
|
||||
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css">
|
||||
<link rel="stylesheet" href="https://fonts.googleapis.com/icon?family=Material+Icons">
|
||||
|
||||
<!-- <link rel="stylesheet" href="styles.css"> -->
|
||||
|
||||
<link rel="stylesheet" href=" < ?php echo base_url(); ?>assets/css/header_styles.css">
|
||||
|
||||
<style>
|
||||
/* CSS styles */
|
||||
.title-column {
|
||||
|
@ -35,15 +41,20 @@
|
|||
}
|
||||
|
||||
.card-title {
|
||||
color: rgb(103, 58, 183); /* Match the color theme */
|
||||
color: rgb(103, 58, 183);
|
||||
/* Match the color theme */
|
||||
margin-bottom: 10px;
|
||||
font-size: 20px; /* Increase the font size of the title */
|
||||
font-weight: bold; /* Make the title bold */
|
||||
font-size: 20px;
|
||||
/* Increase the font size of the title */
|
||||
font-weight: bold;
|
||||
/* Make the title bold */
|
||||
}
|
||||
|
||||
.card-text {
|
||||
font-size: 28px; /* Increase the font size */
|
||||
font-weight: bold; /* Make the text bold */
|
||||
font-size: 28px;
|
||||
/* Increase the font size */
|
||||
font-weight: bold;
|
||||
/* Make the text bold */
|
||||
}
|
||||
|
||||
.card-text.green {
|
||||
|
@ -65,16 +76,56 @@
|
|||
.card-text.purple {
|
||||
color: #6f42c1;
|
||||
}
|
||||
|
||||
.btn-icon {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
width: 25px;
|
||||
height: 25px;
|
||||
/* background-color: rgb(103, 58, 183); */
|
||||
border-radius: 4px;
|
||||
color: white;
|
||||
text-decoration: none;
|
||||
font-size: 16px;
|
||||
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
|
||||
transition: background-color 0.3s, transform 0.3s, box-shadow 0.3s;
|
||||
margin: 0 5px;
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.btn-icon:hover {
|
||||
background-color: rgba(255, 255, 255, 0.2);
|
||||
transform: scale(1.1);
|
||||
box-shadow: 0 6px 8px rgba(0, 0, 0, 0.2);
|
||||
}
|
||||
|
||||
.btn-icon.disabled {
|
||||
background-color: #ccc;
|
||||
color: #888;
|
||||
cursor: not-allowed;
|
||||
box-shadow: none;
|
||||
pointer-events: none;
|
||||
}
|
||||
|
||||
.btn-icon.disabled:hover {
|
||||
background-color: #ccc;
|
||||
transform: none;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div class="container">
|
||||
<div class="container">
|
||||
<div class="row">
|
||||
<div class="col-md-4">
|
||||
<div class="card card-stats">
|
||||
<div class="card-body">
|
||||
<h5 class="card-title">Total Forms Created</h5>
|
||||
<p class="card-text" id="total-forms"><?php echo $total_forms; ?></p>
|
||||
<p class="card-text" id="total-forms">
|
||||
<?php echo $total_forms; ?>
|
||||
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
@ -82,7 +133,8 @@
|
|||
<div class="card card-stats">
|
||||
<div class="card-body">
|
||||
<h5 class="card-title">Published Forms</h5>
|
||||
<p class="card-text" id="published-forms"><?php echo $published_forms; ?></p>
|
||||
<p class="card-text" id="published-forms">
|
||||
<?php echo $published_forms; ?></p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
@ -90,7 +142,8 @@
|
|||
<div class="card card-stats">
|
||||
<div class="card-body">
|
||||
<h5 class="card-title">Responses Submitted</h5>
|
||||
<p class="card-text" id="total-responses"><?php echo $total_responses; ?></p>
|
||||
<p class="card-text" id="total-responses">
|
||||
<?php echo $total_responses; ?></p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
@ -101,7 +154,7 @@
|
|||
<div class="col-md-12 mt-4 ">
|
||||
<div class="card">
|
||||
<div class="card-header">
|
||||
<?php if ($this->session->flashdata('status')): ?>
|
||||
<?php if ($this->session->flashdata('status')) : ?>
|
||||
<div class="alert alert-success">
|
||||
<?= $this->session->flashdata('status'); ?>
|
||||
</div>
|
||||
|
@ -113,33 +166,68 @@
|
|||
<table id="basetable1" class="table table-bordered">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Forms</th>
|
||||
<th>Serial No.</th>
|
||||
<th>Title</th>
|
||||
<th>Description</th>
|
||||
<th>Created On</th>
|
||||
<th>Status</th>
|
||||
<th>Actions</th>
|
||||
<th>Responses</th>
|
||||
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<?php
|
||||
$serialNumber = 1; // Initialize the counter variable
|
||||
foreach ($forms as $row): ?>
|
||||
<tr class="<?php echo ($row->is_published ? '' : 'draft-row'); ?>">
|
||||
<td><?php echo $serialNumber++; ?></td>
|
||||
<td class="title-column">
|
||||
<a href="<?php echo base_url('publish/' . $row->id); ?>"><?php echo $row->title; ?></a>
|
||||
foreach ($forms as $row) : ?>
|
||||
<tr
|
||||
class="<?php echo($row->is_published ? '' : 'draft-row'); ?>">
|
||||
<td><?php echo $serialNumber++; ?>
|
||||
</td>
|
||||
<td><?php echo $row->description; ?></td>
|
||||
<td><?php echo $row->created_at; ?></td>
|
||||
<td style="color: <?php echo ($row->is_published ? '#006400' : 'red'); ?>;">
|
||||
<?php echo ($row->is_published ? 'Published' : 'Draft'); ?>
|
||||
<td class="title-column">
|
||||
<a
|
||||
href="<?php echo base_url('publish/' . $row->id); ?>"><?php echo $row->title; ?></a>
|
||||
</td>
|
||||
<td><?php echo $row->description; ?>
|
||||
</td>
|
||||
<td><?php echo $row->created_at; ?>
|
||||
</td>
|
||||
<td
|
||||
style="color: <?php echo($row->is_published ? '#006400' : 'red'); ?>;">
|
||||
<?php echo($row->is_published ? 'Published' : 'Draft'); ?>
|
||||
</td>
|
||||
<td>
|
||||
<a href="<?php echo base_url('responses/' . $row->id); ?>">
|
||||
<?php if ($row->is_published == 0) : ?>
|
||||
<!-- Buttons are enabled -->
|
||||
<a href="<?php echo base_url('edit/' . $row->id); ?>"
|
||||
class="btn-icon" title="Edit">
|
||||
<i class="fas fa-edit"></i> <!-- For Font Awesome -->
|
||||
</a>
|
||||
<a href="<?php echo base_url('forms/delete/' . $row->id); ?>"
|
||||
class="btn-icon" title="Delete">
|
||||
<i class="fas fa-trash"></i> <!-- For Font Awesome -->
|
||||
</a>
|
||||
<?php else : ?>
|
||||
<!-- Buttons are disabled -->
|
||||
<span class="btn-icon disabled" title="Edit">
|
||||
<i class="fas fa-edit"></i> <!-- For Font Awesome -->
|
||||
</span>
|
||||
<a href="<?php echo base_url('forms/delete/' . $row->id); ?>"
|
||||
class="btn-icon" title="Delete">
|
||||
<i class="fas fa-trash"></i> <!-- For Font Awesome -->
|
||||
</a>
|
||||
<?php endif; ?>
|
||||
</td>
|
||||
|
||||
|
||||
|
||||
<td>
|
||||
<a
|
||||
href="<?php echo base_url('responses/' . $row->id); ?>">
|
||||
<i class="fas fa-eye"></i> <!-- Eye icon -->
|
||||
</a>
|
||||
</td>
|
||||
|
||||
</tr>
|
||||
<?php endforeach; ?>
|
||||
</tbody>
|
||||
|
@ -149,3 +237,8 @@
|
|||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<script>
|
||||
document.getElementById('total-responses').parentNode.addEventListener('click', function() {
|
||||
window.location.href = 'total_responses';
|
||||
});
|
||||
</script>
|
||||
|
|
|
@ -0,0 +1,135 @@
|
|||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<title>Response Details</title>
|
||||
<link rel="stylesheet" href="https://bootswatch.com/3/flatly/bootstrap.min.css">
|
||||
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/datatables/1.11.5/css/jquery.dataTables.min.css">
|
||||
<style>
|
||||
.question-label {
|
||||
display: inline;
|
||||
margin-bottom: 11px;
|
||||
padding: 0;
|
||||
border: none;
|
||||
background: none;
|
||||
}
|
||||
.form-section {
|
||||
border: 2px solid #ddd; /* Thicker border */
|
||||
border-radius: 5px;
|
||||
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); /* Box shadow */
|
||||
padding: 15px;
|
||||
background: #fff;
|
||||
margin-bottom: 15px;
|
||||
transition: transform 0.3s, box-shadow 0.3s;
|
||||
}
|
||||
.form-section:hover {
|
||||
transform: scale(1.02); /* Pop-out effect */
|
||||
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3); /* Enhanced box shadow on hover */
|
||||
}
|
||||
#scroll-up-btn {
|
||||
position: fixed;
|
||||
bottom: 20px;
|
||||
right: 20px;
|
||||
display: none;
|
||||
z-index: 9999; /* Ensure it's above other content */
|
||||
background-color: #007bff; /* Button color */
|
||||
color: #fff; /* Text color */
|
||||
border: none;
|
||||
border-radius: 50%; /* Rounded button */
|
||||
width: 50px;
|
||||
height: 50px;
|
||||
text-align: center;
|
||||
line-height: 50px; /* Center text vertically */
|
||||
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3); /* Box shadow */
|
||||
font-size: 20px; /* Font size */
|
||||
}
|
||||
#scroll-up-btn:hover {
|
||||
background-color: #0056b3; /* Darker color on hover */
|
||||
}
|
||||
.dataTables_wrapper .dataTables_paginate .paginate_button {
|
||||
padding: 5px 10px;
|
||||
margin: 0 2px;
|
||||
border: 2px solid #007bff; /* Thicker border for pagination */
|
||||
border-radius: 3px;
|
||||
background-color: #f8f9fa;
|
||||
}
|
||||
.dataTables_wrapper .dataTables_paginate .paginate_button.current,
|
||||
.dataTables_wrapper .dataTables_paginate .paginate_button:hover {
|
||||
background-color: #007bff;
|
||||
color: #fff;
|
||||
}
|
||||
table.dataTable thead th {
|
||||
border-bottom: 2px solid #007bff; /* Thicker border for table header */
|
||||
}
|
||||
table.dataTable tbody td, table.dataTable thead th {
|
||||
border: 2px solid #007bff; /* Thicker border for table cells */
|
||||
}
|
||||
.response-count {
|
||||
font-weight: bold;
|
||||
}
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<div class="container">
|
||||
<?php foreach ($responses as $form_title => $form_responses) : ?>
|
||||
<div class="form-section">
|
||||
<h2><?php echo $form_title; ?></h2>
|
||||
<p class="response-count">Number of responses: <span><?php echo count($form_responses); ?></span></p> <!-- Display response count -->
|
||||
<table class="table table-bordered" id="responses-table">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Question</th>
|
||||
<th>Answers</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<?php
|
||||
$all_questions = [];
|
||||
foreach ($form_responses as $response) {
|
||||
foreach ($response['questions_and_answers'] as $qa) {
|
||||
if (!isset($all_questions[$qa->text])) {
|
||||
$all_questions[$qa->text] = [];
|
||||
}
|
||||
$all_questions[$qa->text][] = $qa->answered_text;
|
||||
}
|
||||
}
|
||||
?>
|
||||
<?php foreach ($all_questions as $question => $answers) : ?>
|
||||
<tr>
|
||||
<td><?php echo $question; ?></td>
|
||||
<td><?php echo implode(", ", $answers); ?></td>
|
||||
</tr>
|
||||
<?php endforeach; ?>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
<?php endforeach; ?>
|
||||
</div>
|
||||
|
||||
<button id="scroll-up-btn" class="btn">↑</button>
|
||||
|
||||
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
|
||||
<script src="https://cdnjs.cloudflare.com/ajax/libs/datatables/1.11.5/js/jquery.dataTables.min.js"></script>
|
||||
<script>
|
||||
$(document).ready(function() {
|
||||
$('#responses-table').DataTable();
|
||||
|
||||
var scrollUpBtn = document.getElementById('scroll-up-btn');
|
||||
|
||||
window.addEventListener('scroll', function() {
|
||||
if (window.scrollY > 200) {
|
||||
scrollUpBtn.style.display = 'block';
|
||||
} else {
|
||||
scrollUpBtn.style.display = 'none';
|
||||
}
|
||||
});
|
||||
|
||||
scrollUpBtn.addEventListener('click', function() {
|
||||
window.scrollTo({ top: 0, behavior: 'smooth' });
|
||||
});
|
||||
});
|
||||
</script>
|
||||
</body>
|
||||
</html>
|
|
@ -15,14 +15,14 @@
|
|||
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
|
||||
<script src="https://cdn.datatables.net/1.11.5/js/jquery.dataTables.min.js"></script>
|
||||
<!-- Add SweetAlert CSS and JS -->
|
||||
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/sweetalert2@11/dist/sweetalert2.min.css">
|
||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
||||
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/sweetalert2@11/dist/sweetalert2.min.css">
|
||||
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
||||
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<style>
|
||||
.custom-select {
|
||||
.custom-select {
|
||||
width: 220px;
|
||||
height: 44px;
|
||||
display: block;
|
||||
|
@ -33,13 +33,12 @@
|
|||
background-image: none;
|
||||
border: 1px solid #dce4ec;
|
||||
border-radius: 4px;
|
||||
}
|
||||
|
||||
}
|
||||
</style>
|
||||
<!-- Navbar -->
|
||||
<nav class="navbar navbar-custom">
|
||||
<div class="container">
|
||||
<?php if ($this->session->userdata('logged_in')): ?>
|
||||
<?php if ($this->session->userdata('logged_in')) : ?>
|
||||
<div class="navbar-header">
|
||||
<a class="navbar-brand" href="<?php echo base_url(); ?>">Google Forms</a>
|
||||
</div>
|
||||
|
@ -47,41 +46,41 @@
|
|||
|
||||
<div id="navbar" class="navbar-collapse">
|
||||
<ul class="nav navbar-nav">
|
||||
<?php if ($this->session->userdata('logged_in')): ?>
|
||||
<?php if ($this->session->userdata('logged_in')) : ?>
|
||||
<li><a href="<?php echo base_url(); ?>published_forms">Published Forms</a></li>
|
||||
<li><a href="<?php echo base_url(); ?>drafts">Drafts</a></li>
|
||||
<?php endif; ?>
|
||||
</ul>
|
||||
<ul class="nav navbar-nav navbar-right">
|
||||
<?php if (!$this->session->userdata('logged_in')): ?>
|
||||
<?php if (!$this->session->userdata('logged_in')) : ?>
|
||||
<li><a href="<?php echo base_url(); ?>users/login">Login</a></li>
|
||||
<li><a href="<?php echo base_url(); ?>users/register">Register</a></li>
|
||||
<?php endif; ?>
|
||||
<?php if ($this->session->userdata('logged_in')): ?>
|
||||
|
||||
<?php if ($this->session->userdata('logged_in')) : ?>
|
||||
<li><a href="<?php echo base_url(); ?>homepage/title">Create Form</a></li>
|
||||
<li><a href="<?php echo base_url(); ?>users/logout">Logout</a></li>
|
||||
<?php endif; ?>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
</nav>
|
||||
|
||||
|
||||
<!-- Alert Messages -->
|
||||
<div class="container">
|
||||
<?php if ($this->session->flashdata('user_registered')): ?>
|
||||
<?php if ($this->session->flashdata('user_registered')) : ?>
|
||||
<p class="alert alert-success"><?php echo $this->session->flashdata('user_registered'); ?></p>
|
||||
<?php endif; ?>
|
||||
|
||||
<?php if ($this->session->flashdata('login_failed')): ?>
|
||||
<?php if ($this->session->flashdata('login_failed')) : ?>
|
||||
<p class="alert alert-danger"><?php echo $this->session->flashdata('login_failed'); ?></p>
|
||||
<?php endif; ?>
|
||||
|
||||
<?php if ($this->session->flashdata('user_loggedin')): ?>
|
||||
<?php if ($this->session->flashdata('user_loggedin')) : ?>
|
||||
<p class="alert alert-success"><?php echo $this->session->flashdata('user_loggedin'); ?></p>
|
||||
<?php endif; ?>
|
||||
|
||||
<?php if ($this->session->flashdata('user_loggedout')): ?>
|
||||
<?php if ($this->session->flashdata('user_loggedout')) : ?>
|
||||
<p class="alert alert-success"><?php echo $this->session->flashdata('user_loggedout'); ?></p>
|
||||
<?php endif; ?>
|
||||
</div>
|
||||
|
@ -102,7 +101,7 @@
|
|||
<button id="add-section-btn" class="btn btn-primary">+</button>
|
||||
</div>
|
||||
<div id="form-container">
|
||||
<?php foreach ($questions as $question): ?>
|
||||
<?php foreach ($questions as $question) : ?>
|
||||
<div class="form-section" data-index="<?php echo $question['id']; ?>" data-type="<?php echo $question['type']; ?>">
|
||||
<div class="header-row">
|
||||
<input type="text" class="form-control untitled-question" placeholder="Untitled Question" rows="1" value="<?php echo $question['text']; ?>">
|
||||
|
@ -123,7 +122,7 @@
|
|||
<?php
|
||||
$this->db->where('question_id', $question['id']);
|
||||
$options = $this->db->get('options')->result_array();
|
||||
foreach ($options as $option):
|
||||
foreach ($options as $option) :
|
||||
$iconClass = ($question['type'] === 'multiple-choice' || $question['type'] === 'dropdown') ? 'fa-circle' : 'fa-square';
|
||||
?>
|
||||
<div class="option">
|
||||
|
@ -133,11 +132,11 @@
|
|||
</div>
|
||||
<?php endforeach; ?>
|
||||
</div>
|
||||
<?php if ($question['type'] === 'multiple-choice' || $question['type'] === 'checkboxes' || $question['type'] === 'dropdown'): ?>
|
||||
<?php if ($question['type'] === 'multiple-choice' || $question['type'] === 'checkboxes' || $question['type'] === 'dropdown') : ?>
|
||||
<button class="btn btn-primary add-option-btn">Add Option</button>
|
||||
<?php endif; ?>
|
||||
</div>
|
||||
<?php endforeach; ?>
|
||||
<?php endforeach; ?>
|
||||
|
||||
</div>
|
||||
<button id="submit-btn" class="btn btn-success btn-custom">Submit</button>
|
||||
|
@ -148,18 +147,19 @@
|
|||
<script src="<?php echo base_url('assets/js/jquery-ui.js'); ?>"></script>
|
||||
|
||||
<script>
|
||||
$(document).ready(function () {
|
||||
$(document).ready(function() {
|
||||
var base_url = '<?php echo base_url(); ?>';
|
||||
var activeSection = null;
|
||||
$('#form-container').sortable({
|
||||
placeholder: 'ui-state-highlight',
|
||||
start: function (event, ui) {
|
||||
start: function(event, ui) {
|
||||
ui.placeholder.height(ui.item.height());
|
||||
},
|
||||
stop: function (event, ui) {
|
||||
stop: function(event, ui) {
|
||||
positionAddSectionButton();
|
||||
}
|
||||
});
|
||||
|
||||
function positionAddSectionButton() {
|
||||
if (activeSection) {
|
||||
var position = activeSection.position();
|
||||
|
@ -192,12 +192,12 @@
|
|||
</div>
|
||||
`;
|
||||
section.find('.options-container').append(optionHtml);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
// Add section button functionality
|
||||
$('#add-section-btn').on('click', function () {
|
||||
$('#add-section-btn').on('click', function() {
|
||||
createFormSection();
|
||||
$('.form-section').removeClass('active');
|
||||
activeSection = $('.form-section').last();
|
||||
|
@ -252,7 +252,7 @@
|
|||
// Initially hide add option button
|
||||
newSection.find('.add-option-btn').hide();
|
||||
|
||||
newSection.on('click', function () {
|
||||
newSection.on('click', function() {
|
||||
$('.form-section').removeClass('active');
|
||||
$(this).addClass('active');
|
||||
activeSection = $(this);
|
||||
|
@ -284,24 +284,24 @@
|
|||
}
|
||||
});
|
||||
|
||||
$(document).on('click', '.add-option-btn', function () {
|
||||
$(document).on('click', '.add-option-btn', function() {
|
||||
var $section = $(this).closest('.form-section');
|
||||
var questionType = $section.find('.question-type').val();
|
||||
appendNewOption($section, questionType);
|
||||
});
|
||||
|
||||
$(document).on('click', '.delete-section-icon', function () {
|
||||
$(document).on('click', '.delete-section-icon', function() {
|
||||
$(this).closest('.form-section').remove();
|
||||
activeSection = null;
|
||||
positionAddSectionButton();
|
||||
});
|
||||
|
||||
$(document).on('click', '.delete-option-icon', function () {
|
||||
$(document).on('click', '.delete-option-icon', function() {
|
||||
$(this).closest('.option').remove();
|
||||
});
|
||||
|
||||
$('.form-section').each(function () {
|
||||
$(this).on('click', function () {
|
||||
$('.form-section').each(function() {
|
||||
$(this).on('click', function() {
|
||||
$('.form-section').removeClass('active');
|
||||
$(this).addClass('active');
|
||||
activeSection = $(this);
|
||||
|
@ -309,15 +309,15 @@
|
|||
});
|
||||
});
|
||||
|
||||
$(window).on('resize', function () {
|
||||
$(window).on('resize', function() {
|
||||
positionAddSectionButton();
|
||||
});
|
||||
|
||||
// positionAddSectionButton();
|
||||
$(document).ready(function () {
|
||||
$(document).ready(function() {
|
||||
var base_url = '<?php echo base_url(); ?>';
|
||||
|
||||
$('#submit-btn').on('click', function () {
|
||||
$('#submit-btn').on('click', function() {
|
||||
var formData = collectFormData();
|
||||
formData['form_id'] = <?php echo $form['id']; ?>;
|
||||
|
||||
|
@ -330,9 +330,11 @@
|
|||
$.ajax({
|
||||
url: base_url + 'Form_controller/update_form',
|
||||
type: 'POST',
|
||||
data: { formData: formData },
|
||||
data: {
|
||||
formData: formData
|
||||
},
|
||||
dataType: 'JSON',
|
||||
success: function (response) {
|
||||
success: function(response) {
|
||||
if (response.status === 'success') {
|
||||
Swal.fire({
|
||||
title: 'Success!',
|
||||
|
@ -353,7 +355,7 @@
|
|||
});
|
||||
}
|
||||
},
|
||||
error: function (error) {
|
||||
error: function(error) {
|
||||
Swal.fire({
|
||||
title: 'Error!',
|
||||
text: 'Error updating form!',
|
||||
|
@ -373,7 +375,7 @@
|
|||
questions: []
|
||||
};
|
||||
|
||||
$('.form-section').each(function () {
|
||||
$('.form-section').each(function() {
|
||||
var questionData = {
|
||||
id: $(this).data('index'),
|
||||
text: $(this).find('.untitled-question').val(),
|
||||
|
@ -382,7 +384,7 @@
|
|||
options: []
|
||||
};
|
||||
|
||||
$(this).find('.option-label').each(function () {
|
||||
$(this).find('.option-label').each(function() {
|
||||
questionData.options.push($(this).val());
|
||||
});
|
||||
|
||||
|
@ -395,20 +397,31 @@
|
|||
function validateFormData(formData) {
|
||||
for (let question of formData.questions) {
|
||||
if (!question.text.trim()) {
|
||||
return { isValid: false, message: 'All questions must have text.' };
|
||||
return {
|
||||
isValid: false,
|
||||
message: 'All questions must have text.'
|
||||
};
|
||||
}
|
||||
if ((question.type === 'multiple-choice' || question.type === 'checkboxes' || question.type === 'dropdown') && question.options.length === 0) {
|
||||
return { isValid: false, message: 'All options-based questions must have at least one option.' };
|
||||
return {
|
||||
isValid: false,
|
||||
message: 'All options-based questions must have at least one option.'
|
||||
};
|
||||
}
|
||||
for (let option of question.options) {
|
||||
if (!option.trim()) {
|
||||
return { isValid: false, message: 'All options must have text.' };
|
||||
return {
|
||||
isValid: false,
|
||||
message: 'All options must have text.'
|
||||
};
|
||||
}
|
||||
}
|
||||
}
|
||||
return { isValid: true };
|
||||
return {
|
||||
isValid: true
|
||||
};
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
// Initialize
|
||||
|
||||
|
|
|
@ -1,8 +1,9 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
echo "\nERROR: ",
|
||||
$heading,
|
||||
"\n\n",
|
||||
$message,
|
||||
"\n\n";
|
||||
$heading,
|
||||
"\n\n",
|
||||
$message,
|
||||
"\n\n";
|
||||
|
|
|
@ -1,8 +1,9 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
echo "\nDatabase error: ",
|
||||
$heading,
|
||||
"\n\n",
|
||||
$message,
|
||||
"\n\n";
|
||||
$heading,
|
||||
"\n\n",
|
||||
$message,
|
||||
"\n\n";
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
<?php defined('BASEPATH') OR exit('No direct script access allowed'); ?>
|
||||
<?php defined('BASEPATH') or exit('No direct script access allowed'); ?>
|
||||
|
||||
An uncaught Exception was encountered
|
||||
|
||||
|
@ -7,15 +7,14 @@ Message: <?php echo $message, "\n"; ?>
|
|||
Filename: <?php echo $exception->getFile(), "\n"; ?>
|
||||
Line Number: <?php echo $exception->getLine(); ?>
|
||||
|
||||
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === TRUE): ?>
|
||||
|
||||
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === true) : ?>
|
||||
Backtrace:
|
||||
<?php foreach ($exception->getTrace() as $error): ?>
|
||||
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0): ?>
|
||||
<?php foreach ($exception->getTrace() as $error) : ?>
|
||||
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0) : ?>
|
||||
File: <?php echo $error['file'], "\n"; ?>
|
||||
Line: <?php echo $error['line'], "\n"; ?>
|
||||
Function: <?php echo $error['function'], "\n\n"; ?>
|
||||
<?php endif ?>
|
||||
<?php endforeach ?>
|
||||
<?php endif ?>
|
||||
<?php endforeach ?>
|
||||
|
||||
<?php endif ?>
|
||||
|
|
|
@ -1,8 +1,9 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
|
||||
echo "\nERROR: ",
|
||||
$heading,
|
||||
"\n\n",
|
||||
$message,
|
||||
"\n\n";
|
||||
$heading,
|
||||
"\n\n",
|
||||
$message,
|
||||
"\n\n";
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
<?php defined('BASEPATH') OR exit('No direct script access allowed'); ?>
|
||||
<?php defined('BASEPATH') or exit('No direct script access allowed'); ?>
|
||||
|
||||
A PHP Error was encountered
|
||||
|
||||
|
@ -7,15 +7,14 @@ Message: <?php echo $message, "\n"; ?>
|
|||
Filename: <?php echo $filepath, "\n"; ?>
|
||||
Line Number: <?php echo $line; ?>
|
||||
|
||||
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === TRUE): ?>
|
||||
|
||||
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === true) : ?>
|
||||
Backtrace:
|
||||
<?php foreach (debug_backtrace() as $error): ?>
|
||||
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0): ?>
|
||||
<?php foreach (debug_backtrace() as $error) : ?>
|
||||
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0) : ?>
|
||||
File: <?php echo $error['file'], "\n"; ?>
|
||||
Line: <?php echo $error['line'], "\n"; ?>
|
||||
Function: <?php echo $error['function'], "\n\n"; ?>
|
||||
<?php endif ?>
|
||||
<?php endforeach ?>
|
||||
<?php endif ?>
|
||||
<?php endforeach ?>
|
||||
|
||||
<?php endif ?>
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
?><!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
?><!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
?>
|
||||
|
||||
<div style="border:1px solid #990000;padding-left:20px;margin:0 0 10px 0;">
|
||||
|
@ -11,13 +11,10 @@ defined('BASEPATH') OR exit('No direct script access allowed');
|
|||
<p>Filename: <?php echo $exception->getFile(); ?></p>
|
||||
<p>Line Number: <?php echo $exception->getLine(); ?></p>
|
||||
|
||||
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === TRUE): ?>
|
||||
|
||||
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === true) : ?>
|
||||
<p>Backtrace:</p>
|
||||
<?php foreach ($exception->getTrace() as $error): ?>
|
||||
|
||||
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0): ?>
|
||||
|
||||
<?php foreach ($exception->getTrace() as $error) : ?>
|
||||
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0) : ?>
|
||||
<p style="margin-left:10px">
|
||||
File: <?php echo $error['file']; ?><br />
|
||||
Line: <?php echo $error['line']; ?><br />
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
?><!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
?>
|
||||
|
||||
<div style="border:1px solid #990000;padding-left:20px;margin:0 0 10px 0;">
|
||||
|
@ -11,13 +11,10 @@ defined('BASEPATH') OR exit('No direct script access allowed');
|
|||
<p>Filename: <?php echo $filepath; ?></p>
|
||||
<p>Line Number: <?php echo $line; ?></p>
|
||||
|
||||
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === TRUE): ?>
|
||||
|
||||
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === true) : ?>
|
||||
<p>Backtrace:</p>
|
||||
<?php foreach (debug_backtrace() as $error): ?>
|
||||
|
||||
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0): ?>
|
||||
|
||||
<?php foreach (debug_backtrace() as $error) : ?>
|
||||
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0) : ?>
|
||||
<p style="margin-left:10px">
|
||||
File: <?php echo $error['file'] ?><br />
|
||||
Line: <?php echo $error['line'] ?><br />
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -16,42 +16,42 @@
|
|||
<h4><?php echo $form->description; ?></h4>
|
||||
</div>
|
||||
|
||||
<?php foreach ($questions as $question): ?>
|
||||
<?php foreach ($questions as $question) : ?>
|
||||
<div class="form-section">
|
||||
<div class="question-section">
|
||||
<p class="question-label"><?php echo $question->text; ?></p>
|
||||
</div>
|
||||
|
||||
<?php if ($question->type == 'multiple-choice'): ?>
|
||||
<?php if ($question->type == 'multiple-choice') : ?>
|
||||
<div class="options-container">
|
||||
<?php foreach ($question->options as $option): ?>
|
||||
<?php foreach ($question->options as $option) : ?>
|
||||
<div class="option">
|
||||
<input type="radio" name="option-<?php echo $question->id; ?>" disabled>
|
||||
<label><?php echo $option->option_text; ?></label>
|
||||
</div>
|
||||
<?php endforeach; ?>
|
||||
</div>
|
||||
<?php elseif ($question->type == 'checkboxes'): ?>
|
||||
<?php elseif ($question->type == 'checkboxes') : ?>
|
||||
<div class="options-container">
|
||||
<?php foreach ($question->options as $option): ?>
|
||||
<?php foreach ($question->options as $option) : ?>
|
||||
<div class="option">
|
||||
<input type="checkbox" name="option-<?php echo $question->id; ?>" disabled>
|
||||
<label><?php echo $option->option_text; ?></label>
|
||||
</div>
|
||||
<?php endforeach; ?>
|
||||
</div>
|
||||
<?php elseif ($question->type == 'short-answer'): ?>
|
||||
<?php elseif ($question->type == 'short-answer') : ?>
|
||||
<div class="options-container">
|
||||
<input type="text" class="form-control" placeholder="Short answer text" disabled>
|
||||
</div>
|
||||
<?php elseif ($question->type == 'paragraph'): ?>
|
||||
<?php elseif ($question->type == 'paragraph') : ?>
|
||||
<div class="options-container">
|
||||
<textarea class="form-control" placeholder="Paragraph text" disabled></textarea>
|
||||
</div>
|
||||
<?php elseif ($question->type == 'dropdown'): ?>
|
||||
<?php elseif ($question->type == 'dropdown') : ?>
|
||||
<div class="options-container">
|
||||
<select class="form-control" disabled>
|
||||
<?php foreach ($question->options as $option): ?>
|
||||
<?php foreach ($question->options as $option) : ?>
|
||||
<option><?php echo $option->option_text; ?></option>
|
||||
<?php endforeach; ?>
|
||||
</select>
|
||||
|
@ -59,7 +59,7 @@
|
|||
<?php endif; ?>
|
||||
</div>
|
||||
<?php endforeach; ?>
|
||||
<a href="<?php echo base_url('Publish_controller/publish_form/'.$form->id); ?>" class="btn btn-success">Publish</a>
|
||||
<a href="<?php echo base_url('Publish_controller/publish_form/' . $form->id); ?>" class="btn btn-success">Publish</a>
|
||||
<br>
|
||||
</div>
|
||||
</body>
|
||||
|
|
|
@ -35,42 +35,42 @@
|
|||
<br>
|
||||
<h4><?php echo $form->description; ?></h4>
|
||||
</div>
|
||||
<?php foreach ($questions as $question): ?>
|
||||
<?php foreach ($questions as $question) : ?>
|
||||
<div class="form-section">
|
||||
<div class="question-section">
|
||||
<p class="question-label"><?php echo $question->text; ?></p>
|
||||
</div>
|
||||
|
||||
<?php if ($question->type == 'multiple-choice'): ?>
|
||||
<?php if ($question->type == 'multiple-choice') : ?>
|
||||
<div class="options-container">
|
||||
<?php foreach ($question->options as $option): ?>
|
||||
<?php foreach ($question->options as $option) : ?>
|
||||
<div class="option">
|
||||
<input type="radio" name="option-<?php echo $question->id; ?>" disabled>
|
||||
<label><?php echo $option->option_text; ?></label>
|
||||
</div>
|
||||
<?php endforeach; ?>
|
||||
</div>
|
||||
<?php elseif ($question->type == 'checkboxes'): ?>
|
||||
<?php elseif ($question->type == 'checkboxes') : ?>
|
||||
<div class="options-container">
|
||||
<?php foreach ($question->options as $option): ?>
|
||||
<?php foreach ($question->options as $option) : ?>
|
||||
<div class="option">
|
||||
<input type="checkbox" name="option-<?php echo $question->id; ?>" disabled>
|
||||
<label><?php echo $option->option_text; ?></label>
|
||||
</div>
|
||||
<?php endforeach; ?>
|
||||
</div>
|
||||
<?php elseif ($question->type == 'short-answer'): ?>
|
||||
<?php elseif ($question->type == 'short-answer') : ?>
|
||||
<div class="options-container">
|
||||
<input type="text" class="form-control" placeholder="Short answer text" disabled>
|
||||
</div>
|
||||
<?php elseif ($question->type == 'paragraph'): ?>
|
||||
<?php elseif ($question->type == 'paragraph') : ?>
|
||||
<div class="options-container">
|
||||
<textarea class="form-control" placeholder="Paragraph text" disabled></textarea>
|
||||
</div>
|
||||
<?php elseif ($question->type == 'dropdown'): ?>
|
||||
<?php elseif ($question->type == 'dropdown') : ?>
|
||||
<div class="options-container">
|
||||
<select class="form-control" disabled>
|
||||
<?php foreach ($question->options as $option): ?>
|
||||
<?php foreach ($question->options as $option) : ?>
|
||||
<option><?php echo $option->option_text; ?></option>
|
||||
<?php endforeach; ?>
|
||||
</select>
|
||||
|
|
|
@ -1,11 +1,9 @@
|
|||
<!DOCTYPE html>
|
||||
<!doctype html>
|
||||
<html>
|
||||
<head>
|
||||
<head>
|
||||
<title>403 Forbidden</title>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<p>Directory access is forbidden.</p>
|
||||
|
||||
</body>
|
||||
</head>
|
||||
<body>
|
||||
<p>Directory access is forbidden.</p>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -3,7 +3,7 @@
|
|||
<div class="col-md-12 mt-4">
|
||||
<div class="card">
|
||||
<div class="card-header">
|
||||
<?php if ($this->session->flashdata('status')): ?>
|
||||
<?php if ($this->session->flashdata('status')) : ?>
|
||||
<div class="alert alert-success">
|
||||
<?= $this->session->flashdata('status'); ?>
|
||||
</div>
|
||||
|
@ -15,7 +15,7 @@
|
|||
<table id="basetable1" class="table table-bordered">
|
||||
<thead>
|
||||
<tr>
|
||||
<th>Responses</th>
|
||||
<th>Serial No.</th>
|
||||
<th>Title</th>
|
||||
<th>Response Link</th>
|
||||
<th>Status</th>
|
||||
|
@ -24,7 +24,7 @@
|
|||
</thead>
|
||||
<tbody>
|
||||
<?php $serialNumber = 1;
|
||||
foreach ($forms as $row): ?>
|
||||
foreach ($forms as $row) : ?>
|
||||
<tr>
|
||||
<td><?php echo $serialNumber++; ?></td>
|
||||
<td class="title-column"><?php echo $row->title; ?></td>
|
||||
|
|
|
@ -46,7 +46,7 @@ padding-left: 0; /* Ensure no padding is affecting alignment */
|
|||
<p class="submitted-at">Submitted At: <?php echo $response->submitted_at; ?></p>
|
||||
<p class="user-email">User Email: <?php echo $response->email; ?></p>
|
||||
</div>
|
||||
<?php foreach ($questions_and_answers as $question): ?>
|
||||
<?php foreach ($questions_and_answers as $question) : ?>
|
||||
<div class="form-section">
|
||||
<div class="question-section">
|
||||
<p class="form-control question-label"><?php echo $question->question_text; ?></p>
|
||||
|
|
|
@ -106,41 +106,41 @@
|
|||
<h4><?php echo $form->description; ?></h4>
|
||||
</div> -->
|
||||
|
||||
<?php if (isset($message)): ?>
|
||||
<?php if (isset($message)) : ?>
|
||||
<div id="popup-message" class="popup-message">
|
||||
<p><?php echo $message; ?></p>
|
||||
<button onclick="closePopup()">Close</button>
|
||||
</div>
|
||||
<?php else: ?>
|
||||
<?php else : ?>
|
||||
<form action="<?php echo base_url('response_submit/submit_form'); ?>" method="post" onsubmit="return validateForm();">
|
||||
<input type="hidden" name="form_id" value="<?php echo $form->id; ?>">
|
||||
<div class="form-section">
|
||||
<?php foreach ($questions as $question): ?>
|
||||
<?php foreach ($questions as $question) : ?>
|
||||
<div class="question-container" data-required="<?php echo $question->is_required; ?>" data-type="<?php echo $question->type; ?>">
|
||||
<input type="hidden" name="responses[<?php echo $question->id; ?>][question_id]" value="<?php echo $question->id; ?>">
|
||||
<input type="hidden" name="responses[<?php echo $question->id; ?>][form_id]" value="<?php echo $form->id; ?>">
|
||||
<label class="<?php echo $question->is_required ? 'required-field' : ''; ?>"><?php echo $question->text; ?></label>
|
||||
<?php if ($question->type == 'multiple-choice'): ?>
|
||||
<?php foreach ($question->options as $option): ?>
|
||||
<?php if ($question->type == 'multiple-choice') : ?>
|
||||
<?php foreach ($question->options as $option) : ?>
|
||||
<div class="option">
|
||||
<input type="radio" name="responses[<?php echo $question->id; ?>][options][]" value="<?php echo $option->option_text; ?>">
|
||||
<label><?php echo $option->option_text; ?></label>
|
||||
</div>
|
||||
<?php endforeach; ?>
|
||||
<?php elseif ($question->type == 'checkboxes'): ?>
|
||||
<?php foreach ($question->options as $option): ?>
|
||||
<?php elseif ($question->type == 'checkboxes') : ?>
|
||||
<?php foreach ($question->options as $option) : ?>
|
||||
<div class="option">
|
||||
<input type="checkbox" name="responses[<?php echo $question->id; ?>][options][]" value="<?php echo $option->option_text; ?>">
|
||||
<label><?php echo $option->option_text; ?></label>
|
||||
</div>
|
||||
<?php endforeach; ?>
|
||||
<?php elseif ($question->type == 'short-answer'): ?>
|
||||
<?php elseif ($question->type == 'short-answer') : ?>
|
||||
<input type="text" class="form-control" name="responses[<?php echo $question->id; ?>][answered_text]" placeholder="Short answer text">
|
||||
<?php elseif ($question->type == 'paragraph'): ?>
|
||||
<?php elseif ($question->type == 'paragraph') : ?>
|
||||
<textarea class="form-control" name="responses[<?php echo $question->id; ?>][answered_text]" placeholder="Paragraph text"></textarea>
|
||||
<?php elseif ($question->type == 'dropdown'): ?>
|
||||
<?php elseif ($question->type == 'dropdown') : ?>
|
||||
<select class="form-control" name="responses[<?php echo $question->id; ?>][answered_text]">
|
||||
<?php foreach ($question->options as $option): ?>
|
||||
<?php foreach ($question->options as $option) : ?>
|
||||
<option value="<?php echo $option->option_text; ?>"><?php echo $option->option_text; ?></option>
|
||||
<?php endforeach; ?>
|
||||
</select>
|
||||
|
|
|
@ -0,0 +1,17 @@
|
|||
<div class="container">
|
||||
<h2>Select a form to view summary</h2>
|
||||
<?php foreach ($forms as $form) : ?>
|
||||
<div class="form-section" data-form-id="<?php echo $form->id; ?>">
|
||||
<h3><?php echo $form->title; ?></h3>
|
||||
</div>
|
||||
<?php endforeach; ?>
|
||||
</div>
|
||||
|
||||
<script>
|
||||
document.querySelectorAll('.form-section').forEach(function(section) {
|
||||
section.addEventListener('click', function() {
|
||||
var formId = this.getAttribute('data-form-id');
|
||||
window.location.href = '<?php echo base_url('response_submit/response_summary_by_form/'); ?>' + formId;
|
||||
});
|
||||
});
|
||||
</script>
|
|
@ -0,0 +1,38 @@
|
|||
<div class="container">
|
||||
<h2>Summary for Form <?php echo $form_id; ?></h2>
|
||||
<?php foreach ($data as $question => $info) : ?>
|
||||
<div class="chart-container">
|
||||
<h3><?php echo $question; ?></h3>
|
||||
<canvas id="chart-<?php echo md5($question); ?>" width="400" height="400"></canvas>
|
||||
</div>
|
||||
<script>
|
||||
var ctx = document.getElementById('chart-<?php echo md5($question); ?>').getContext('2d');
|
||||
var labels = <?php echo json_encode(array_unique($info['answers'])); ?>;
|
||||
var counts = labels.map(label => {
|
||||
return <?php echo json_encode(array_count_values($info['answers'])); ?>[label];
|
||||
});
|
||||
|
||||
var chartData = {
|
||||
labels: labels,
|
||||
datasets: [{
|
||||
data: counts,
|
||||
backgroundColor: labels.map(() => 'rgba(54, 162, 235, 0.2)'),
|
||||
borderColor: labels.map(() => 'rgba(54, 162, 235, 1)'),
|
||||
borderWidth: 1
|
||||
}]
|
||||
};
|
||||
|
||||
var chartType = '<?php echo ($info['type'] == 'checkbox') ? 'bar' : 'pie'; ?>';
|
||||
new Chart(ctx, {
|
||||
type: chartType,
|
||||
data: chartData,
|
||||
options: {
|
||||
responsive: true,
|
||||
maintainAspectRatio: false
|
||||
}
|
||||
});
|
||||
</script>
|
||||
<?php endforeach; ?>
|
||||
</div>
|
||||
|
||||
<script src="https://cdn.jsdelivr.net/npm/chart.js"></script>
|
|
@ -18,7 +18,7 @@
|
|||
<div class="col-md-12 mt-4">
|
||||
<div class="card">
|
||||
<div class="card-header">
|
||||
<?php if ($this->session->flashdata('status')): ?>
|
||||
<?php if ($this->session->flashdata('status')) : ?>
|
||||
<div class="alert alert-success">
|
||||
<?= $this->session->flashdata('status'); ?>
|
||||
</div>
|
||||
|
@ -36,7 +36,7 @@
|
|||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<?php foreach ($responses as $response): ?>
|
||||
<?php foreach ($responses as $response) : ?>
|
||||
<tr>
|
||||
<td class="username-column"><?php echo $response->username; ?></td>
|
||||
<td><?php echo $response->submitted_at; ?></td>
|
||||
|
|
|
@ -19,16 +19,16 @@
|
|||
<style>
|
||||
.navbar-custom .navbar-brand,
|
||||
.navbar-custom .navbar-nav .nav-link {
|
||||
color: white !important; /* Forces the text color to be white */
|
||||
text-decoration: none !important; /* Ensures no underline */
|
||||
background: none !important; /* Ensures no background color */
|
||||
color: white !important;
|
||||
text-decoration: none !important;
|
||||
background: none !important;
|
||||
}
|
||||
|
||||
.navbar-custom .navbar-brand:hover,
|
||||
.navbar-custom .navbar-nav .nav-link:hover {
|
||||
color: white !important; /* Keeps text color white on hover */
|
||||
text-decoration: none !important; /* Ensures no underline on hover */
|
||||
background: none !important; /* Ensures no background color on hover */
|
||||
color: white !important;
|
||||
text-decoration: none !important;
|
||||
background: none !important;
|
||||
}
|
||||
.title-column {
|
||||
color: darkblue;
|
||||
|
@ -114,7 +114,7 @@
|
|||
|
||||
<nav class="navbar navbar-inverse" style="background-color: rgb(103, 58, 183);">
|
||||
<div class="container" style="background-color: rgb(103, 58, 183);">
|
||||
<?php if ($this->session->userdata('logged_in')): ?>
|
||||
<?php if ($this->session->userdata('logged_in')) : ?>
|
||||
<div class="navbar-header">
|
||||
<a class="navbar-brand" href="<?php echo base_url(); ?>">Google Forms</a>
|
||||
</div>
|
||||
|
@ -122,18 +122,18 @@
|
|||
|
||||
<div id="navbar">
|
||||
<ul class="nav navbar-nav">
|
||||
<?php if ($this->session->userdata('logged_in')): ?>
|
||||
<?php if ($this->session->userdata('logged_in')) : ?>
|
||||
<li><a href="<?php echo base_url(); ?>published_forms">Published Forms</a></li>
|
||||
<li><a href="<?php echo base_url(); ?>drafts">Drafts</a></li>
|
||||
<!-- <li><a href="<?php echo base_url(); ?>drafts">Drafts</a></li> -->
|
||||
|
||||
<?php endif; ?>
|
||||
</ul>
|
||||
<ul class="nav navbar-nav navbar-right">
|
||||
<?php if (!$this->session->userdata('logged_in')): ?>
|
||||
<?php if (!$this->session->userdata('logged_in')) : ?>
|
||||
<li><a href="<?php echo base_url(); ?>users/login">Login</a></li>
|
||||
<li><a href="<?php echo base_url(); ?>users/register">Register</a></li>
|
||||
<?php endif; ?>
|
||||
<?php if ($this->session->userdata('logged_in')): ?>
|
||||
<?php if ($this->session->userdata('logged_in')) : ?>
|
||||
<li><a href="<?php echo base_url(); ?>title">Create Form</a></li>
|
||||
<li><a href="<?php echo base_url(); ?>users/logout">Logout</a></li>
|
||||
<?php endif; ?>
|
||||
|
@ -142,19 +142,19 @@
|
|||
</div>
|
||||
</nav>
|
||||
<div class="container">
|
||||
<?php if ($this->session->flashdata('user_registered')): ?>
|
||||
<?php if ($this->session->flashdata('user_registered')) : ?>
|
||||
<p class="alert alert-success flash-message" id="flash-user-registered"><?php echo $this->session->flashdata('user_registered'); ?></p>
|
||||
<?php endif; ?>
|
||||
|
||||
<?php if ($this->session->flashdata('login_failed')): ?>
|
||||
<?php if ($this->session->flashdata('login_failed')) : ?>
|
||||
<p class="alert alert-danger flash-message" id="flash-login-failed"><?php echo $this->session->flashdata('login_failed'); ?></p>
|
||||
<?php endif; ?>
|
||||
|
||||
<?php if ($this->session->flashdata('user_loggedin')): ?>
|
||||
<?php if ($this->session->flashdata('user_loggedin')) : ?>
|
||||
<p class="alert alert-success flash-message" id="flash-user-loggedin"><?php echo $this->session->flashdata('user_loggedin'); ?></p>
|
||||
<?php endif; ?>
|
||||
|
||||
<?php if ($this->session->flashdata('user_loggedout')): ?>
|
||||
<?php if ($this->session->flashdata('user_loggedout')) : ?>
|
||||
<p class="alert alert-success flash-message" id="flash-user-loggedout"><?php echo $this->session->flashdata('user_loggedout'); ?></p>
|
||||
<?php endif; ?>
|
||||
</div>
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
<?php echo form_open('users/login/'.$form_id); ?>
|
||||
<?php echo form_open('users/login/' . $form_id); ?>
|
||||
<div class="row">
|
||||
<div class="col-md-4 col-md-offset-4">
|
||||
<h1 class="text-center"><?= $title; ?></h1>
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
<?php
|
||||
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||
defined('BASEPATH') or exit('No direct script access allowed');
|
||||
?><!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
|
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
@ -3,7 +3,6 @@
|
|||
flex-direction: column;
|
||||
margin-bottom: 10px;
|
||||
margin-top: -56px;
|
||||
|
||||
}
|
||||
|
||||
.form-title,
|
||||
|
@ -32,7 +31,6 @@
|
|||
opacity: 0.5; /* Make the icon transparent */
|
||||
margin-right: 10px; /* Space between icon and option box */
|
||||
font-size: 10px; /* Adjust icon size here */
|
||||
|
||||
}
|
||||
|
||||
.option .form-control.option-label {
|
||||
|
|
|
@ -34,7 +34,8 @@ body {
|
|||
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
|
||||
margin-bottom: 20px;
|
||||
}
|
||||
.form-header h2, .form-header h4 {
|
||||
.form-header h2,
|
||||
.form-header h4 {
|
||||
margin: 0;
|
||||
text-align: left;
|
||||
}
|
||||
|
@ -62,12 +63,12 @@ body {
|
|||
display: flex;
|
||||
align-items: center;
|
||||
}
|
||||
.option input[type="checkbox"] {
|
||||
.option input[type='checkbox'] {
|
||||
margin-right: 10px;
|
||||
width: 16px; /* Adjust size of checkbox */
|
||||
height: 16px; /* Adjust size of checkbox */
|
||||
}
|
||||
.option input[type="radio"] {
|
||||
.option input[type='radio'] {
|
||||
margin-right: 10px;
|
||||
width: 16px; /* Adjust size of radio button */
|
||||
height: 16px; /* Adjust size of radio button */
|
||||
|
|
|
@ -1,4 +1,3 @@
|
|||
|
||||
.navbar-container {
|
||||
max-width: 100%;
|
||||
margin: 0 auto;
|
||||
|
@ -23,7 +22,6 @@
|
|||
padding: 15px 10px;
|
||||
}
|
||||
|
||||
|
||||
.navbar-custom .navbar-nav {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
|
@ -54,8 +52,6 @@
|
|||
margin: 0 10px;
|
||||
}
|
||||
|
||||
|
||||
#add-section-btn {
|
||||
position: absolute;
|
||||
|
||||
}
|
||||
|
|
|
@ -74,8 +74,6 @@ body {
|
|||
flex: 1; /* Allow items to grow/shrink to fill space */
|
||||
}
|
||||
|
||||
|
||||
|
||||
#submit-btn {
|
||||
margin-top: 20px;
|
||||
float: left;
|
||||
|
@ -96,36 +94,36 @@ body {
|
|||
padding: 10px;
|
||||
}
|
||||
|
||||
.post-date{
|
||||
.post-date {
|
||||
background: #f4f4f4;
|
||||
padding: 4px;
|
||||
margin: 3px 0;
|
||||
display: block;
|
||||
}
|
||||
|
||||
.post-thumb{
|
||||
.post-thumb {
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.pagination-link{
|
||||
.pagination-link {
|
||||
margin: 30px 0;
|
||||
}
|
||||
|
||||
.pagination-links strong{
|
||||
.pagination-links strong {
|
||||
padding: 8px 13px;
|
||||
margin: 5px;
|
||||
background: #f4f4f4;
|
||||
border: 1px #ccc solid;
|
||||
}
|
||||
|
||||
a.pagination-link{
|
||||
a.pagination-link {
|
||||
padding: 8px 13px;
|
||||
margin: 5px;
|
||||
background: #f4f4f4;
|
||||
border: 1px #ccc solid;
|
||||
}
|
||||
|
||||
.cat-delete{
|
||||
.cat-delete {
|
||||
display: inline;
|
||||
}
|
||||
|
||||
|
@ -133,8 +131,7 @@ a.pagination-link{
|
|||
border: 1px solid #3333336c; /* Darker border color */
|
||||
}
|
||||
|
||||
#basetable1 th, #basetable1 td {
|
||||
#basetable1 th,
|
||||
#basetable1 td {
|
||||
border: 1px solid #3333336c; /* Darker border color for table cells */
|
||||
}
|
||||
|
||||
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,5 +1,9 @@
|
|||
body { background-color: rgb(240, 235, 248); }
|
||||
.container { margin-top: 30px; }
|
||||
body {
|
||||
background-color: rgb(240, 235, 248);
|
||||
}
|
||||
.container {
|
||||
margin-top: 30px;
|
||||
}
|
||||
.form-header {
|
||||
background-color: white;
|
||||
padding: 20px;
|
||||
|
@ -13,8 +17,12 @@ body { background-color: rgb(240, 235, 248); }
|
|||
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
|
||||
margin-bottom: 20px;
|
||||
}
|
||||
.form-header h2 { margin: 0; }
|
||||
.form-header h4 { color: rgba(0, 0, 0, 0.5); }
|
||||
.form-header h2 {
|
||||
margin: 0;
|
||||
}
|
||||
.form-header h4 {
|
||||
color: rgba(0, 0, 0, 0.5);
|
||||
}
|
||||
.form-section {
|
||||
background-color: white;
|
||||
width: 56%;
|
||||
|
@ -36,8 +44,8 @@ body { background-color: rgb(240, 235, 248); }
|
|||
display: flex;
|
||||
align-items: center;
|
||||
}
|
||||
.option input[type="radio"],
|
||||
.option input[type="checkbox"] {
|
||||
.option input[type='radio'],
|
||||
.option input[type='checkbox'] {
|
||||
margin-right: 10px;
|
||||
}
|
||||
.required-field::after {
|
||||
|
|
|
@ -1,4 +1,3 @@
|
|||
|
||||
body {
|
||||
background-color: rgb(240, 235, 248);
|
||||
font-family: Arial, sans-serif;
|
||||
|
@ -13,12 +12,11 @@ body {
|
|||
}
|
||||
/* Navbar custom styles */
|
||||
|
||||
|
||||
.container {
|
||||
position: relative;
|
||||
margin-top: 30px;
|
||||
}
|
||||
.form_container_top{
|
||||
.form_container_top {
|
||||
box-sizing: border-box;
|
||||
margin-top: 10px;
|
||||
font-family: Arial, Helvetica, sans-serif;
|
||||
|
@ -31,7 +29,7 @@ body {
|
|||
border-bottom: 1px solid #f4f4f9;
|
||||
color: black;
|
||||
height: 20px;
|
||||
}
|
||||
}
|
||||
/* Form header styles */
|
||||
.form-header {
|
||||
background-color: white;
|
||||
|
@ -78,10 +76,8 @@ body {
|
|||
z-index: 1000;
|
||||
border-radius: 50%;
|
||||
background-color: rgb(103, 58, 183);
|
||||
|
||||
}
|
||||
|
||||
|
||||
.form-section {
|
||||
background-color: white;
|
||||
width: 56%;
|
||||
|
@ -125,7 +121,6 @@ body {
|
|||
border-radius: 4px;
|
||||
}
|
||||
|
||||
|
||||
.delete-section-icon {
|
||||
flex: 0.1;
|
||||
cursor: pointer;
|
||||
|
@ -152,8 +147,8 @@ body {
|
|||
margin-bottom: 5px;
|
||||
}
|
||||
|
||||
.option input[type="radio"],
|
||||
.option input[type="checkbox"] {
|
||||
.option input[type='radio'],
|
||||
.option input[type='checkbox'] {
|
||||
margin-right: 10px;
|
||||
}
|
||||
|
||||
|
@ -169,16 +164,13 @@ body {
|
|||
text-align: left;
|
||||
}
|
||||
|
||||
|
||||
.add-option-btn {
|
||||
background-color: rgb(66, 133, 244);
|
||||
/* color: rgb(66, 133, 244); */
|
||||
margin-top: 11px;
|
||||
font-size: 0.8em;
|
||||
|
||||
}
|
||||
|
||||
|
||||
.ui-state-highlight {
|
||||
background-color: transparent !important;
|
||||
border: none !important;
|
||||
|
@ -210,19 +202,19 @@ body {
|
|||
right: 0;
|
||||
bottom: 0;
|
||||
background-color: #ccc;
|
||||
transition: .4s;
|
||||
transition: 0.4s;
|
||||
border-radius: 34px;
|
||||
}
|
||||
|
||||
.slider:before {
|
||||
position: absolute;
|
||||
content: "";
|
||||
content: '';
|
||||
height: 14px;
|
||||
width: 14px;
|
||||
left: 3px;
|
||||
bottom: 3px;
|
||||
background-color: white;
|
||||
transition: .4s;
|
||||
transition: 0.4s;
|
||||
border-radius: 50%;
|
||||
}
|
||||
|
||||
|
@ -233,8 +225,8 @@ input:checked + .slider {
|
|||
input:checked + .slider:before {
|
||||
transform: translateX(14px);
|
||||
}
|
||||
.body_header_bg{
|
||||
background-color: rgb(240,235,248);
|
||||
.body_header_bg {
|
||||
background-color: rgb(240, 235, 248);
|
||||
}
|
||||
table a:not(.btn) {
|
||||
color: blue !important;
|
||||
|
@ -259,11 +251,11 @@ table a:not(.btn):hover {
|
|||
|
||||
/* Assuming you have a stylesheet named styles.css */
|
||||
.btn.btn-primary.btn-block {
|
||||
margin-top: 20px;
|
||||
position: relative;
|
||||
background-color: rgb(103, 58, 183);
|
||||
border-color: rgb(103, 58, 183);
|
||||
color: white;
|
||||
margin-top: 20px;
|
||||
position: relative;
|
||||
background-color: rgb(103, 58, 183);
|
||||
border-color: rgb(103, 58, 183);
|
||||
color: white;
|
||||
}
|
||||
.flash-message {
|
||||
opacity: 1;
|
||||
|
@ -277,4 +269,3 @@ color: white;
|
|||
margin-top: 5px;
|
||||
display: none;
|
||||
}
|
||||
|
||||
|
|
|
@ -135,8 +135,8 @@ body {
|
|||
margin-bottom: 5px;
|
||||
}
|
||||
|
||||
.option input[type="radio"],
|
||||
.option input[type="checkbox"] {
|
||||
.option input[type='radio'],
|
||||
.option input[type='checkbox'] {
|
||||
margin-right: 10px;
|
||||
}
|
||||
|
||||
|
@ -191,19 +191,19 @@ body {
|
|||
right: 0;
|
||||
bottom: 0;
|
||||
background-color: #ccc;
|
||||
transition: .4s;
|
||||
transition: 0.4s;
|
||||
border-radius: 34px;
|
||||
}
|
||||
|
||||
.slider:before {
|
||||
position: absolute;
|
||||
content: "";
|
||||
content: '';
|
||||
height: 14px;
|
||||
width: 14px;
|
||||
left: 3px;
|
||||
bottom: 3px;
|
||||
background-color: white;
|
||||
transition: .4s;
|
||||
transition: 0.4s;
|
||||
border-radius: 50%;
|
||||
}
|
||||
|
||||
|
|
|
@ -0,0 +1,50 @@
|
|||
// src/index.js
|
||||
|
||||
// Example function to add two numbers
|
||||
function add(a, b) {
|
||||
return a + b
|
||||
}
|
||||
|
||||
// Example usage of the add function
|
||||
|
||||
const result = add(5, 10)
|
||||
console.log('The result is:', result)
|
||||
|
||||
// Example object with properties
|
||||
const person = {
|
||||
name: 'John Doe',
|
||||
age: 30,
|
||||
greet: function () {
|
||||
console.log(
|
||||
`Hello, my name is ${this.name} and I am ${this.age} years old.`
|
||||
)
|
||||
},
|
||||
}
|
||||
|
||||
// Call the greet method
|
||||
person.greet()
|
||||
|
||||
// Example of an arrow function
|
||||
const multiply = (x, y) => x * y
|
||||
|
||||
console.log('The product is:', multiply(4, 5))
|
||||
|
||||
// Example of a variable declared with let
|
||||
let count = 0
|
||||
for (let i = 0; i < 5; i++) {
|
||||
count += i
|
||||
}
|
||||
console.log('The count is:', count)
|
||||
|
||||
// Example of a variable declared with const
|
||||
const message = 'This is a constant message.'
|
||||
console.log(message)
|
||||
|
||||
// Example of a function with default parameters
|
||||
function greet(name = 'Guest') {
|
||||
console.log(`Welcome, ${name}!`)
|
||||
}
|
||||
|
||||
// Call the function with and without arguments
|
||||
greet('Alice')
|
||||
greet()
|
|
@ -1,8 +1,8 @@
|
|||
$(document).ready(function() {
|
||||
$(document).ready(function () {
|
||||
var base_url = '<?php echo base_url(); ?>';
|
||||
|
||||
// Add section button functionality
|
||||
$('#add-section-btn').on('click', function() {
|
||||
$('#add-section-btn').on('click', function () {
|
||||
var sectionHtml = `
|
||||
<div class="form-section" data-type="">
|
||||
<div class="header-row">
|
||||
|
@ -21,14 +21,12 @@ $(document).ready(function() {
|
|||
<span class="delete-section-icon"><i class="fas fa-trash-alt"></i></span>
|
||||
</div>
|
||||
<div class="options-container"></div>
|
||||
<button class="btn btn-secondary add-option-btn" style="display: none;">Add Option</button>
|
||||
</div>
|
||||
`;
|
||||
$('#form-container').append(sectionHtml);
|
||||
<button class="btn btn-secondary add-option-btn" style="display: none;">Add Option</button></div>
|
||||
`; $('#form-container').append(sectionHtml);
|
||||
});
|
||||
|
||||
// Add option button functionality
|
||||
$(document).on('click', '.add-option-btn', function() {
|
||||
$(document).on('click', '.add-option-btn', function () {
|
||||
var optionHtml = `
|
||||
<div class="option">
|
||||
<input type="text" class="form-control option-label" placeholder="Option">
|
||||
|
@ -39,17 +37,17 @@ $(document).ready(function() {
|
|||
});
|
||||
|
||||
// Delete option functionality
|
||||
$(document).on('click', '.delete-option-icon', function() {
|
||||
$(document).on('click', '.delete-option-icon', function () {
|
||||
$(this).parent().remove();
|
||||
});
|
||||
|
||||
// Delete section functionality
|
||||
$(document).on('click', '.delete-section-icon', function() {
|
||||
$(document).on('click', '.delete-section-icon', function () {
|
||||
$(this).closest('.form-section').remove();
|
||||
});
|
||||
|
||||
// Show/Hide "Add Option" button based on question type
|
||||
$(document).on('change', '.custom-select', function() {
|
||||
$(document).on('change', '.custom-select', function () {
|
||||
var type = $(this).val();
|
||||
var $section = $(this).closest('.form-section');
|
||||
if (type === 'multiple-choice' || type === 'checkboxes' || type === 'dropdown') {
|
||||
|
@ -60,9 +58,9 @@ $(document).ready(function() {
|
|||
}).trigger('change'); // Trigger change to apply to existing sections
|
||||
|
||||
// Submit button functionality
|
||||
$('#submit-btn').on('click', function() {
|
||||
$('#submit-btn').on('click', function () {
|
||||
var formData = collectFormData();
|
||||
formData['form_id'] = <?php echo $form['id']; ?>;
|
||||
formData['form_id'] = <? php echo $form['id']; ?>;
|
||||
|
||||
let validation = validateFormData(formData);
|
||||
if (!validation.isValid) {
|
||||
|
@ -75,7 +73,7 @@ $(document).ready(function() {
|
|||
type: 'POST',
|
||||
data: { formData: formData },
|
||||
dataType: 'JSON',
|
||||
success: function(response) {
|
||||
success: function (response) {
|
||||
if (response.status === 'success') {
|
||||
alert('Form updated successfully!');
|
||||
window.location.href = base_url + 'Form_controller/index_forms_draft';
|
||||
|
@ -83,7 +81,7 @@ $(document).ready(function() {
|
|||
alert(response.message);
|
||||
}
|
||||
},
|
||||
error: function(error) {
|
||||
error: function (error) {
|
||||
alert('Error updating form!');
|
||||
console.log(error);
|
||||
}
|
||||
|
@ -98,7 +96,7 @@ $(document).ready(function() {
|
|||
questions: []
|
||||
};
|
||||
|
||||
$('.form-section').each(function() {
|
||||
$('.form-section').each(function () {
|
||||
var questionData = {
|
||||
id: $(this).data('index'),
|
||||
text: $(this).find('.untitled-question').val(),
|
||||
|
@ -107,7 +105,7 @@ $(document).ready(function() {
|
|||
options: []
|
||||
};
|
||||
|
||||
$(this).find('.option-label').each(function() {
|
||||
$(this).find('.option-label').each(function () {
|
||||
questionData.options.push($(this).val());
|
||||
});
|
||||
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,10 +1,10 @@
|
|||
$(document).ready(function() {
|
||||
let index = 1;
|
||||
let activeSection = null;
|
||||
$(document).ready(function () {
|
||||
let index = 1
|
||||
let activeSection = null
|
||||
|
||||
function addOption(type, container) {
|
||||
function addOption(type, container) {
|
||||
// let optionIndex = container.children().length + 1;
|
||||
let optionHtml;
|
||||
let optionHtml
|
||||
if (type === 'multiple-choice' || type === 'checkboxes') {
|
||||
optionHtml = `
|
||||
<div class="option">
|
||||
|
@ -12,18 +12,17 @@ function addOption(type, container) {
|
|||
<input type="text" class="form-control option-label" >
|
||||
<span class="delete-option-icon">×</span>
|
||||
</div>
|
||||
`;
|
||||
}
|
||||
else if (type === 'dropdown') {
|
||||
`
|
||||
} else if (type === 'dropdown') {
|
||||
optionHtml = `
|
||||
<div class="option">
|
||||
<input type="text" class="form-control option-label">
|
||||
<span class="delete-option-icon">×</span>
|
||||
</div>
|
||||
`;
|
||||
`
|
||||
}
|
||||
container.append(optionHtml)
|
||||
}
|
||||
container.append(optionHtml);
|
||||
}
|
||||
|
||||
function createFormSection() {
|
||||
let newSection = `
|
||||
|
@ -45,88 +44,100 @@ function addOption(type, container) {
|
|||
</div>
|
||||
<div class="options-container"></div>
|
||||
</div>
|
||||
`;
|
||||
$('#form-container').append(newSection);
|
||||
index++;
|
||||
positionAddSectionButton();
|
||||
`
|
||||
$('#form-container').append(newSection)
|
||||
index++
|
||||
positionAddSectionButton()
|
||||
}
|
||||
|
||||
function positionAddSectionButton() {
|
||||
if (activeSection) {
|
||||
let position = activeSection.position();
|
||||
let buttonWidth = $('#add-section-btn').outerWidth();
|
||||
let buttonHeight = $('#add-section-btn').outerHeight();
|
||||
let position = activeSection.position()
|
||||
let buttonWidth = $('#add-section-btn').outerWidth()
|
||||
let buttonHeight = $('#add-section-btn').outerHeight()
|
||||
|
||||
$('#add-section-btn').css({
|
||||
position: 'absolute',
|
||||
left: position.left - buttonWidth - 47 + 'px',
|
||||
top: position.top + activeSection.height() / 2 - buttonHeight / 2 + 'px'
|
||||
});
|
||||
top:
|
||||
position.top + activeSection.height() / 2 - buttonHeight / 2 + 'px',
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
$('#add-section-btn').on('click', function() {
|
||||
createFormSection();
|
||||
$('.form-section').removeClass('active');
|
||||
activeSection = $('.form-section').last();
|
||||
activeSection.addClass('active');
|
||||
positionAddSectionButton();
|
||||
});
|
||||
$('#add-section-btn').on('click', function () {
|
||||
createFormSection()
|
||||
$('.form-section').removeClass('active')
|
||||
activeSection = $('.form-section').last()
|
||||
activeSection.addClass('active')
|
||||
positionAddSectionButton()
|
||||
})
|
||||
|
||||
$(document).on('change', '.custom-select', function() {
|
||||
let type = $(this).val();
|
||||
let container = $(this).closest('.form-section').find('.options-container');
|
||||
container.empty();
|
||||
$(this).closest('.form-section').find('.add-option-btn').remove();
|
||||
$(document).on('change', '.custom-select', function () {
|
||||
let type = $(this).val()
|
||||
let container = $(this).closest('.form-section').find('.options-container')
|
||||
container.empty()
|
||||
$(this).closest('.form-section').find('.add-option-btn').remove()
|
||||
|
||||
if (type === 'short-answer') {
|
||||
container.append('<input type="text" class="form-control" disabled placeholder="Short answer text">');
|
||||
container.append(
|
||||
'<input type="text" class="form-control" disabled placeholder="Short answer text">'
|
||||
)
|
||||
} else if (type === 'paragraph') {
|
||||
container.append('<textarea class="form-control" disabled placeholder="Paragraph text"></textarea>');
|
||||
container.append(
|
||||
'<textarea class="form-control" disabled placeholder="Paragraph text"></textarea>'
|
||||
)
|
||||
} else {
|
||||
addOption(type, container);
|
||||
$(this).closest('.form-section').append('<button class="btn btn-secondary add-option-btn">Add Option</button>');
|
||||
addOption(type, container)
|
||||
$(this)
|
||||
.closest('.form-section')
|
||||
.append(
|
||||
'<button class="btn btn-secondary add-option-btn">Add Option</button>'
|
||||
)
|
||||
}
|
||||
});
|
||||
})
|
||||
|
||||
$(document).on('click', '.add-option-btn', function() {
|
||||
let type = $(this).closest('.form-section').find('.custom-select').val();
|
||||
let container = $(this).closest('.form-section').find('.options-container');
|
||||
addOption(type, container);
|
||||
});
|
||||
$(document).on('click', '.add-option-btn', function () {
|
||||
let type = $(this).closest('.form-section').find('.custom-select').val()
|
||||
let container = $(this).closest('.form-section').find('.options-container')
|
||||
addOption(type, container)
|
||||
})
|
||||
|
||||
$(document).on('click', '.delete-section-icon', function() {
|
||||
let section = $(this).closest('.form-section');
|
||||
let prevSection = section.prev('.form-section');
|
||||
let nextSection = section.next('.form-section');
|
||||
section.remove();
|
||||
$(document).on('click', '.delete-section-icon', function () {
|
||||
let section = $(this).closest('.form-section')
|
||||
let prevSection = section.prev('.form-section')
|
||||
let nextSection = section.next('.form-section')
|
||||
section.remove()
|
||||
if (section.hasClass('active')) {
|
||||
activeSection = null;
|
||||
activeSection = null
|
||||
}
|
||||
if (prevSection.length > 0) {
|
||||
prevSection.find('.delete-section-icon').appendTo(prevSection.find('.form-section'));
|
||||
activeSection = prevSection;row
|
||||
prevSection
|
||||
.find('.delete-section-icon')
|
||||
.appendTo(prevSection.find('.form-section'))
|
||||
activeSection = prevSection
|
||||
row
|
||||
} else if (nextSection.length > 0) {
|
||||
nextSection
|
||||
.find('.delete-section-icon')
|
||||
.appendTo(nextSection.find('.form-header'))
|
||||
activeSection = nextSection
|
||||
}
|
||||
else if (nextSection.length > 0) {
|
||||
nextSection.find('.delete-section-icon').appendTo(nextSection.find('.form-header'));
|
||||
activeSection = nextSection;
|
||||
}
|
||||
positionAddSectionButton();
|
||||
});
|
||||
positionAddSectionButton()
|
||||
})
|
||||
|
||||
$(document).on('click', '.delete-option-icon', function() {
|
||||
let option = $(this).closest('.option');
|
||||
let container = option.closest('.options-container');
|
||||
option.remove();
|
||||
$(document).on('click', '.delete-option-icon', function () {
|
||||
let option = $(this).closest('.option')
|
||||
let container = option.closest('.options-container')
|
||||
option.remove()
|
||||
})
|
||||
|
||||
});
|
||||
$(document).on('click', '.required-toggle', function () {
|
||||
$(this).closest('.form-section').toggleClass('required')
|
||||
})
|
||||
|
||||
$(document).on('click', '.required-toggle', function() {
|
||||
$(this).closest('.form-section').toggleClass('required');
|
||||
});
|
||||
|
||||
$('#preview-btn').on('click', function() {
|
||||
let previewWindow = window.open('', '_blank');
|
||||
$('#preview-btn').on('click', function () {
|
||||
let previewWindow = window.open('', '_blank')
|
||||
let previewContent = `
|
||||
<html>
|
||||
<head>
|
||||
|
@ -146,126 +157,144 @@ function addOption(type, container) {
|
|||
<div class="form-header">
|
||||
<h3>Form Preview</h3>
|
||||
</div>
|
||||
`;
|
||||
$('.form-section').each(function() {
|
||||
previewContent += '<div class="form-section">';
|
||||
previewContent += '<div class="question-section">';
|
||||
previewContent += '<div class="question-label">' + $(this).find('.untitled-question').val() + '</div>';
|
||||
previewContent += '</div>';
|
||||
let type = $(this).find('.custom-select').val();
|
||||
let optionsContainer = $(this).find('.options-container');
|
||||
`
|
||||
$('.form-section').each(function () {
|
||||
previewContent += '<div class="form-section">'
|
||||
previewContent += '<div class="question-section">'
|
||||
previewContent +=
|
||||
'<div class="question-label">' +
|
||||
$(this).find('.untitled-question').val() +
|
||||
'</div>'
|
||||
previewContent += '</div>'
|
||||
let type = $(this).find('.custom-select').val()
|
||||
let optionsContainer = $(this).find('.options-container')
|
||||
|
||||
if (type === 'multiple-choice') {
|
||||
optionsContainer.find('.option').each(function() {
|
||||
optionsContainer.find('.option').each(function () {
|
||||
previewContent += `
|
||||
<div class="option">
|
||||
<input type="radio" name="option-${index}">
|
||||
<label>${$(this).find('.option-label').val()}</label>
|
||||
</div>
|
||||
`;
|
||||
});
|
||||
`
|
||||
})
|
||||
} else if (type === 'checkboxes') {
|
||||
optionsContainer.find('.option').each(function() {
|
||||
optionsContainer.find('.option').each(function () {
|
||||
previewContent += `
|
||||
<div class="option">
|
||||
<input type="checkbox">
|
||||
<label>${$(this).find('.option-label').val()}</label>
|
||||
</div>
|
||||
`;
|
||||
});
|
||||
`
|
||||
})
|
||||
} else if (type === 'short-answer') {
|
||||
previewContent += '<input type="text" class="form-control" placeholder="Short answer text">';
|
||||
previewContent +=
|
||||
'<input type="text" class="form-control" placeholder="Short answer text">'
|
||||
} else if (type === 'paragraph') {
|
||||
previewContent += '<textarea class="form-control" placeholder="Paragraph text"></textarea>';
|
||||
previewContent +=
|
||||
'<textarea class="form-control" placeholder="Paragraph text"></textarea>'
|
||||
} else if (type === 'dropdown') {
|
||||
let dropdownHtml = '<select class="form-control">';
|
||||
optionsContainer.find('.option .option-label').each(function() {
|
||||
dropdownHtml += `<option>${$(this).val()}</option>`;
|
||||
});
|
||||
dropdownHtml += '</select>';
|
||||
previewContent += dropdownHtml;
|
||||
let dropdownHtml = '<select class="form-control">'
|
||||
optionsContainer.find('.option .option-label').each(function () {
|
||||
dropdownHtml += `<option>${$(this).val()}</option>`
|
||||
})
|
||||
dropdownHtml += '</select>'
|
||||
previewContent += dropdownHtml
|
||||
}
|
||||
previewContent += '</div>';
|
||||
});
|
||||
previewContent += '</div>'
|
||||
})
|
||||
previewContent += `
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
||||
`;
|
||||
previewWindow.document.write(previewContent);
|
||||
previewWindow.document.close();
|
||||
});
|
||||
`
|
||||
previewWindow.document.write(previewContent)
|
||||
previewWindow.document.close()
|
||||
})
|
||||
|
||||
$(document).on('click', '.form-section', function() {
|
||||
$('.form-section').removeClass('active');
|
||||
$(this).addClass('active');
|
||||
activeSection = $(this);
|
||||
positionAddSectionButton();
|
||||
});
|
||||
$(document).on('click', '.form-section', function () {
|
||||
$('.form-section').removeClass('active')
|
||||
$(this).addClass('active')
|
||||
activeSection = $(this)
|
||||
positionAddSectionButton()
|
||||
})
|
||||
|
||||
$('#form-container').sortable({
|
||||
placeholder: 'ui-state-highlight',
|
||||
start: function (event, ui) {
|
||||
ui.placeholder.height(ui.item.height());
|
||||
ui.placeholder.height(ui.item.height())
|
||||
},
|
||||
stop: function (event, ui) {
|
||||
positionAddSectionButton();
|
||||
}
|
||||
});
|
||||
positionAddSectionButton()
|
||||
},
|
||||
})
|
||||
|
||||
function collectFormData() {
|
||||
var formData = {
|
||||
questions: []
|
||||
};
|
||||
questions: [],
|
||||
}
|
||||
|
||||
$('.form-section').each(function() {
|
||||
var questionType = $(this).find('.custom-select').val();
|
||||
$('.form-section').each(function () {
|
||||
var questionType = $(this).find('.custom-select').val()
|
||||
var questionData = {
|
||||
text: $(this).find('.untitled-question').val(),
|
||||
type: questionType,
|
||||
is_required: $(this).find('.required-toggle').is(':checked'),
|
||||
options: []
|
||||
};
|
||||
options: [],
|
||||
}
|
||||
|
||||
// Only add options if the question type supports them
|
||||
if (questionType === 'multiple-choice' || questionType === 'checkboxes' || questionType === 'dropdown') {
|
||||
$(this).find('.option-label').each(function() {
|
||||
questionData.options.push($(this).val());
|
||||
});
|
||||
if (
|
||||
questionType === 'multiple-choice' ||
|
||||
questionType === 'checkboxes' ||
|
||||
questionType === 'dropdown'
|
||||
) {
|
||||
$(this)
|
||||
.find('.option-label')
|
||||
.each(function () {
|
||||
questionData.options.push($(this).val())
|
||||
})
|
||||
}
|
||||
|
||||
formData.questions.push(questionData);
|
||||
});
|
||||
formData.questions.push(questionData)
|
||||
})
|
||||
|
||||
console.log(formData);
|
||||
return formData;
|
||||
console.log(formData)
|
||||
return formData
|
||||
}
|
||||
|
||||
|
||||
function validateFormData(formData) {
|
||||
for (let question of formData.questions) {
|
||||
if (!question.text.trim()) {
|
||||
return { isValid: false, message: 'All questions must have text.' };
|
||||
return { isValid: false, message: 'All questions must have text.' }
|
||||
}
|
||||
if (
|
||||
(question.type === 'multiple-choice' ||
|
||||
question.type === 'checkboxes' ||
|
||||
question.type === 'dropdown') &&
|
||||
question.options.length === 0
|
||||
) {
|
||||
return {
|
||||
isValid: false,
|
||||
message: 'All options-based questions must have at least one option.',
|
||||
}
|
||||
if ((question.type === 'multiple-choice' || question.type === 'checkboxes' || question.type === 'dropdown') && question.options.length === 0) {
|
||||
return { isValid: false, message: 'All options-based questions must have at least one option.' };
|
||||
}
|
||||
for (let option of question.options) {
|
||||
if (!option.trim()) {
|
||||
return { isValid: false, message: 'All options must have text.' };
|
||||
return { isValid: false, message: 'All options must have text.' }
|
||||
}
|
||||
}
|
||||
}
|
||||
return { isValid: true };
|
||||
return { isValid: true }
|
||||
}
|
||||
$('#submit-btn').on('click', function() {
|
||||
let formData = collectFormData();
|
||||
console.log(formData);
|
||||
$('#submit-btn').on('click', function () {
|
||||
let formData = collectFormData()
|
||||
console.log(formData)
|
||||
|
||||
let validation = validateFormData(formData);
|
||||
let validation = validateFormData(formData)
|
||||
if (!validation.isValid) {
|
||||
alert(validation.message);
|
||||
return;
|
||||
alert(validation.message)
|
||||
return
|
||||
}
|
||||
|
||||
$.ajax({
|
||||
|
@ -273,27 +302,27 @@ function addOption(type, container) {
|
|||
type: 'POST',
|
||||
data: { formData: formData },
|
||||
dataType: 'JSON',
|
||||
success: function(response) {
|
||||
success: function (response) {
|
||||
if (response.status === 'success') {
|
||||
Swal.fire({
|
||||
title: 'Success!',
|
||||
text: 'Form submitted successfully!',
|
||||
icon: 'success',
|
||||
confirmButtonText: 'OK'
|
||||
confirmButtonText: 'OK',
|
||||
}).then((result) => {
|
||||
window.location.href = base_url;
|
||||
});
|
||||
window.location.href = base_url
|
||||
})
|
||||
} else {
|
||||
Swal.fire({
|
||||
title: 'Error!',
|
||||
text: response.message,
|
||||
icon: 'error',
|
||||
confirmButtonText: 'OK'
|
||||
});
|
||||
console.log(response);
|
||||
confirmButtonText: 'OK',
|
||||
})
|
||||
console.log(response)
|
||||
}
|
||||
},
|
||||
error: function(error) {
|
||||
error: function (error) {
|
||||
Swal.fire({
|
||||
title: 'Error!',
|
||||
text: 'Error submitting form!',
|
||||
|
@ -304,16 +333,13 @@ function addOption(type, container) {
|
|||
padding: 'auto',
|
||||
}).then((result) => {
|
||||
if (result.isConfirmed) {
|
||||
window.location.href = home;
|
||||
window.location.href = home
|
||||
}
|
||||
});
|
||||
console.log(error);
|
||||
}
|
||||
});
|
||||
});
|
||||
})
|
||||
console.log(error)
|
||||
},
|
||||
})
|
||||
})
|
||||
|
||||
|
||||
|
||||
|
||||
$('#form-container').disableSelection();
|
||||
});
|
||||
$('#form-container').disableSelection()
|
||||
})
|
||||
|
|
|
@ -2,7 +2,7 @@ $(document).ready(function () {
|
|||
let index = 1
|
||||
let activeSection = null
|
||||
|
||||
function addOption(type, container)
|
||||
function addOption(type, container) {
|
||||
let optionHtml
|
||||
|
||||
if (type === 'multiple-choice' || type === 'checkboxes') {
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -30,6 +30,7 @@
|
|||
},
|
||||
"require-dev": {
|
||||
"mikey179/vfsstream": "1.6.*",
|
||||
"phpunit/phpunit": "4.* || 5.* || 9.*"
|
||||
"phpunit/phpunit": "4.* || 5.* || 9.*",
|
||||
"squizlabs/php_codesniffer": "^3.5"
|
||||
}
|
||||
}
|
||||
|
|
File diff suppressed because it is too large
Load Diff
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue