Compare commits
1 Commits
f9bc85d5f8
...
49b00bd108
Author | SHA1 | Date |
---|---|---|
RameshT | 49b00bd108 |
|
@ -1,3 +0,0 @@
|
||||||
{
|
|
||||||
"presets": ["@babel/preset-env"]
|
|
||||||
}
|
|
|
@ -1,32 +0,0 @@
|
||||||
{
|
|
||||||
"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,11 +1,6 @@
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
. "$(dirname "$0")/_/husky.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
|
# Get the list of staged PHP files
|
||||||
STAGED_FILES=$(git diff --cached --name-only --diff-filter=ACM | grep '\.php$')
|
STAGED_FILES=$(git diff --cached --name-only --diff-filter=ACM | grep '\.php$')
|
||||||
|
|
||||||
|
@ -62,5 +57,4 @@ for FILE in $STAGED_FILES; do
|
||||||
git add "$FILE"
|
git add "$FILE"
|
||||||
done
|
done
|
||||||
|
|
||||||
|
|
||||||
echo "Pre-commit checks completed."
|
echo "Pre-commit checks completed."
|
||||||
|
|
|
@ -1,48 +0,0 @@
|
||||||
#!/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
|
@ -1,22 +0,0 @@
|
||||||
# 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
|
|
|
@ -1,15 +0,0 @@
|
||||||
{
|
|
||||||
"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,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
| -------------------------------------------------------------------
|
| -------------------------------------------------------------------
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -103,7 +102,7 @@ $config['charset'] = 'UTF-8';
|
||||||
| setting this variable to TRUE (boolean). See the user guide for details.
|
| setting this variable to TRUE (boolean). See the user guide for details.
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
$config['enable_hooks'] = false;
|
$config['enable_hooks'] = FALSE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -139,7 +138,7 @@ $config['subclass_prefix'] = 'MY_';
|
||||||
| Note: This will NOT disable or override the CodeIgniter-specific
|
| Note: This will NOT disable or override the CodeIgniter-specific
|
||||||
| autoloading (application/config/autoload.php)
|
| autoloading (application/config/autoload.php)
|
||||||
*/
|
*/
|
||||||
$config['composer_autoload'] = false;
|
$config['composer_autoload'] = FALSE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -185,7 +184,7 @@ $config['permitted_uri_chars'] = 'a-z 0-9~%.:_\-';
|
||||||
| use segment based URLs.
|
| use segment based URLs.
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
$config['enable_query_strings'] = false;
|
$config['enable_query_strings'] = FALSE;
|
||||||
$config['controller_trigger'] = 'c';
|
$config['controller_trigger'] = 'c';
|
||||||
$config['function_trigger'] = 'm';
|
$config['function_trigger'] = 'm';
|
||||||
$config['directory_trigger'] = 'd';
|
$config['directory_trigger'] = 'd';
|
||||||
|
@ -202,7 +201,7 @@ $config['directory_trigger'] = 'd';
|
||||||
| for backwards compatibility purposes!
|
| for backwards compatibility purposes!
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
$config['allow_get_array'] = true;
|
$config['allow_get_array'] = TRUE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -314,7 +313,7 @@ $config['cache_path'] = '';
|
||||||
| of query parameters.
|
| of query parameters.
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
$config['cache_query_string'] = false;
|
$config['cache_query_string'] = FALSE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -388,10 +387,10 @@ $config['sess_driver'] = 'files';
|
||||||
$config['sess_cookie_name'] = 'ci_session';
|
$config['sess_cookie_name'] = 'ci_session';
|
||||||
$config['sess_samesite'] = 'Lax';
|
$config['sess_samesite'] = 'Lax';
|
||||||
$config['sess_expiration'] = 7200;
|
$config['sess_expiration'] = 7200;
|
||||||
$config['sess_save_path'] = null;
|
$config['sess_save_path'] = NULL;
|
||||||
$config['sess_match_ip'] = false;
|
$config['sess_match_ip'] = FALSE;
|
||||||
$config['sess_time_to_update'] = 300;
|
$config['sess_time_to_update'] = 300;
|
||||||
$config['sess_regenerate_destroy'] = false;
|
$config['sess_regenerate_destroy'] = FALSE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -412,8 +411,8 @@ $config['sess_regenerate_destroy'] = false;
|
||||||
$config['cookie_prefix'] = '';
|
$config['cookie_prefix'] = '';
|
||||||
$config['cookie_domain'] = '';
|
$config['cookie_domain'] = '';
|
||||||
$config['cookie_path'] = '/';
|
$config['cookie_path'] = '/';
|
||||||
$config['cookie_secure'] = false;
|
$config['cookie_secure'] = FALSE;
|
||||||
$config['cookie_httponly'] = false;
|
$config['cookie_httponly'] = FALSE;
|
||||||
$config['cookie_samesite'] = 'Lax';
|
$config['cookie_samesite'] = 'Lax';
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -428,7 +427,7 @@ $config['cookie_samesite'] = 'Lax';
|
||||||
| for backwards compatibility purposes!
|
| for backwards compatibility purposes!
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
$config['standardize_newlines'] = false;
|
$config['standardize_newlines'] = FALSE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -442,7 +441,7 @@ $config['standardize_newlines'] = false;
|
||||||
| for backwards compatibility purposes!
|
| for backwards compatibility purposes!
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
$config['global_xss_filtering'] = false;
|
$config['global_xss_filtering'] = FALSE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -458,11 +457,11 @@ $config['global_xss_filtering'] = false;
|
||||||
| 'csrf_regenerate' = Regenerate token on every submission
|
| 'csrf_regenerate' = Regenerate token on every submission
|
||||||
| 'csrf_exclude_uris' = Array of URIs which ignore CSRF checks
|
| '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_token_name'] = 'csrf_test_name';
|
||||||
$config['csrf_cookie_name'] = 'csrf_cookie_name';
|
$config['csrf_cookie_name'] = 'csrf_cookie_name';
|
||||||
$config['csrf_expire'] = 7200;
|
$config['csrf_expire'] = 7200;
|
||||||
$config['csrf_regenerate'] = true;
|
$config['csrf_regenerate'] = TRUE;
|
||||||
$config['csrf_exclude_uris'] = array();
|
$config['csrf_exclude_uris'] = array();
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -485,7 +484,7 @@ $config['csrf_exclude_uris'] = array();
|
||||||
| by the output class. Do not 'echo' any values with compression enabled.
|
| by the output class. Do not 'echo' any values with compression enabled.
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
$config['compress_output'] = false;
|
$config['compress_output'] = FALSE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -512,7 +511,7 @@ $config['time_reference'] = 'local';
|
||||||
| Note: You need to have eval() enabled for this to work.
|
| Note: You need to have eval() enabled for this to work.
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
$config['rewrite_short_tags'] = false;
|
$config['rewrite_short_tags'] = FALSE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -12,7 +11,7 @@ defined('BASEPATH') or exit('No direct script access allowed');
|
||||||
| of this setting
|
| of this setting
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
defined('SHOW_DEBUG_BACKTRACE') or define('SHOW_DEBUG_BACKTRACE', true);
|
defined('SHOW_DEBUG_BACKTRACE') OR define('SHOW_DEBUG_BACKTRACE', TRUE);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -27,10 +26,10 @@ defined('SHOW_DEBUG_BACKTRACE') or define('SHOW_DEBUG_BACKTRACE', true);
|
||||||
| always be used to set the mode correctly.
|
| always be used to set the mode correctly.
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
defined('FILE_READ_MODE') or define('FILE_READ_MODE', 0644);
|
defined('FILE_READ_MODE') OR define('FILE_READ_MODE', 0644);
|
||||||
defined('FILE_WRITE_MODE') or define('FILE_WRITE_MODE', 0666);
|
defined('FILE_WRITE_MODE') OR define('FILE_WRITE_MODE', 0666);
|
||||||
defined('DIR_READ_MODE') or define('DIR_READ_MODE', 0755);
|
defined('DIR_READ_MODE') OR define('DIR_READ_MODE', 0755);
|
||||||
defined('DIR_WRITE_MODE') or define('DIR_WRITE_MODE', 0755);
|
defined('DIR_WRITE_MODE') OR define('DIR_WRITE_MODE', 0755);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -40,14 +39,14 @@ defined('DIR_WRITE_MODE') or define('DIR_WRITE_MODE', 0755);
|
||||||
| These modes are used when working with fopen()/popen()
|
| These modes are used when working with fopen()/popen()
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
defined('FOPEN_READ') or define('FOPEN_READ', 'rb');
|
defined('FOPEN_READ') OR define('FOPEN_READ', 'rb');
|
||||||
defined('FOPEN_READ_WRITE') or define('FOPEN_READ_WRITE', 'r+b');
|
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_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_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_WRITE_CREATE') OR define('FOPEN_WRITE_CREATE', 'ab');
|
||||||
defined('FOPEN_READ_WRITE_CREATE') or define('FOPEN_READ_WRITE_CREATE', 'a+b');
|
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_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_WRITE_CREATE_STRICT') OR define('FOPEN_READ_WRITE_CREATE_STRICT', 'x+b');
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -74,13 +73,13 @@ defined('FOPEN_READ_WRITE_CREATE_STRICT') or define('FOPEN_READ_WRITE_CREA
|
||||||
| http://tldp.org/LDP/abs/html/exitcodes.html
|
| http://tldp.org/LDP/abs/html/exitcodes.html
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
defined('EXIT_SUCCESS') or define('EXIT_SUCCESS', 0); // no errors
|
defined('EXIT_SUCCESS') OR define('EXIT_SUCCESS', 0); // no errors
|
||||||
defined('EXIT_ERROR') or define('EXIT_ERROR', 1); // generic error
|
defined('EXIT_ERROR') OR define('EXIT_ERROR', 1); // generic error
|
||||||
defined('EXIT_CONFIG') or define('EXIT_CONFIG', 3); // configuration 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_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_CLASS') OR define('EXIT_UNKNOWN_CLASS', 5); // unknown class
|
||||||
defined('EXIT_UNKNOWN_METHOD') or define('EXIT_UNKNOWN_METHOD', 6); // unknown class member
|
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_USER_INPUT') OR define('EXIT_USER_INPUT', 7); // invalid user input
|
||||||
defined('EXIT_DATABASE') or define('EXIT_DATABASE', 8); // database error
|
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_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__AUTO_MAX') OR define('EXIT__AUTO_MAX', 125); // highest automatically-assigned error code
|
||||||
|
|
|
@ -1,20 +1,77 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
|
|
||||||
/**
|
/*
|
||||||
* This file handles the XYZ functionality in the application.
|
| -------------------------------------------------------------------
|
||||||
* @category YourCategory
|
| DATABASE CONNECTIVITY SETTINGS
|
||||||
* @package YourApplication
|
| -------------------------------------------------------------------
|
||||||
* @subpackage YourSubpackage
|
| This file will contain the settings needed to access your database.
|
||||||
* @author Your Name
|
|
|
||||||
* @date YYYY-MM-DD
|
| For complete instructions please consult the 'Database Connection'
|
||||||
* @version 1.0
|
| page of the User Guide.
|
||||||
*/
|
|
|
||||||
|
| -------------------------------------------------------------------
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
| 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.
|
||||||
|
*/
|
||||||
$active_group = 'default';
|
$active_group = 'default';
|
||||||
$query_builder = true;
|
$query_builder = TRUE;
|
||||||
|
|
||||||
$db['default'] = array(
|
$db['default'] = array(
|
||||||
'dsn' => '',
|
'dsn' => '',
|
||||||
|
@ -24,16 +81,16 @@ $db['default'] = array(
|
||||||
'database' => 'google_forms',
|
'database' => 'google_forms',
|
||||||
'dbdriver' => 'mysqli',
|
'dbdriver' => 'mysqli',
|
||||||
'dbprefix' => '',
|
'dbprefix' => '',
|
||||||
'pconnect' => false,
|
'pconnect' => FALSE,
|
||||||
'db_debug' => (ENVIRONMENT !== 'production'),
|
'db_debug' => (ENVIRONMENT !== 'production'),
|
||||||
'cache_on' => false,
|
'cache_on' => FALSE,
|
||||||
'cachedir' => '',
|
'cachedir' => '',
|
||||||
'char_set' => 'utf8',
|
'char_set' => 'utf8',
|
||||||
'dbcollat' => 'utf8_general_ci',
|
'dbcollat' => 'utf8_general_ci',
|
||||||
'swap_pre' => '',
|
'swap_pre' => '',
|
||||||
'encrypt' => false,
|
'encrypt' => FALSE,
|
||||||
'compress' => false,
|
'compress' => FALSE,
|
||||||
'stricton' => false,
|
'stricton' => FALSE,
|
||||||
'failover' => array(),
|
'failover' => array(),
|
||||||
'save_queries' => true
|
'save_queries' => TRUE
|
||||||
);
|
);
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
$_doctypes = array(
|
$_doctypes = array(
|
||||||
'xhtml11' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">',
|
'xhtml11' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">',
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
| -------------------------------------------------------------------
|
| -------------------------------------------------------------------
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
| -------------------------------------------------------------------------
|
| -------------------------------------------------------------------------
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
| -------------------------------------------------------------------------
|
| -------------------------------------------------------------------------
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -12,7 +11,7 @@ defined('BASEPATH') or exit('No direct script access allowed');
|
||||||
| and disable it back when you're done.
|
| and disable it back when you're done.
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
$config['migration_enabled'] = false;
|
$config['migration_enabled'] = FALSE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -58,7 +57,7 @@ $config['migration_table'] = 'migrations';
|
||||||
| in your code to have the latest migration.
|
| in your code to have the latest migration.
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
$config['migration_auto_latest'] = false;
|
$config['migration_auto_latest'] = FALSE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|--------------------------------------------------------------------------
|
|--------------------------------------------------------------------------
|
||||||
|
@ -82,4 +81,4 @@ $config['migration_version'] = 0;
|
||||||
| Also, writing permission is required within the migrations path.
|
| Also, writing permission is required within the migrations path.
|
||||||
|
|
|
|
||||||
*/
|
*/
|
||||||
$config['migration_path'] = APPPATH . 'migrations/';
|
$config['migration_path'] = APPPATH.'migrations/';
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
| -------------------------------------------------------------------
|
| -------------------------------------------------------------------
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
| -------------------------------------------------------------------------
|
| -------------------------------------------------------------------------
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
$route['forms'] = 'home/index4';
|
$route['forms'] = 'home/index4';
|
||||||
|
|
||||||
|
@ -9,7 +8,7 @@ $route['responses/view/(:num)'] = 'Response_submit/viewresponse/$1';
|
||||||
$route['publish/(:num)'] = 'forms/preview/$1';
|
$route['publish/(:num)'] = 'forms/preview/$1';
|
||||||
$route['default_controller'] = 'Form_controller/index_forms';
|
$route['default_controller'] = 'Form_controller/index_forms';
|
||||||
$route['404_override'] = '';
|
$route['404_override'] = '';
|
||||||
$route['translate_uri_dashes'] = false;
|
$route['translate_uri_dashes'] = FALSE;
|
||||||
$route['start'] = 'Form_controller/index_forms';
|
$route['start'] = 'Form_controller/index_forms';
|
||||||
$route['title_desc'] = 'homepage/title';
|
$route['title_desc'] = 'homepage/title';
|
||||||
$route['forms/delete/(:any)'] = 'Form_controller/delete/$1';
|
$route['forms/delete/(:any)'] = 'Form_controller/delete/$1';
|
||||||
|
@ -26,4 +25,3 @@ $route['response_preview/(:num)'] = 'forms/response_preview/$1';
|
||||||
|
|
||||||
$route['title'] = 'homepage/title';
|
$route['title'] = 'homepage/title';
|
||||||
|
|
||||||
$route['total_responses'] = 'Response_submit/index';
|
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
| -------------------------------------------------------------------
|
| -------------------------------------------------------------------
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
| -------------------------------------------------------------------
|
| -------------------------------------------------------------------
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
// namespace application\controllers;
|
namespace application\controllers;
|
||||||
|
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
defined('BASEPATH') or exit('No direct script access allowed');
|
||||||
|
|
||||||
|
// use application\models\Form_model;
|
||||||
|
|
||||||
class Form extends CI_Controller
|
class Form extends CI_Controller
|
||||||
{
|
{
|
||||||
public function __construct()
|
public function __construct()
|
||||||
|
@ -13,7 +15,6 @@ class Form extends CI_Controller
|
||||||
}
|
}
|
||||||
public function submit()
|
public function submit()
|
||||||
{
|
{
|
||||||
|
|
||||||
if (!$this->session->userdata('logged_in')) {
|
if (!$this->session->userdata('logged_in')) {
|
||||||
// If not logged in, redirect to login page
|
// If not logged in, redirect to login page
|
||||||
redirect('users/login');
|
redirect('users/login');
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
defined('BASEPATH') or exit('No direct script access allowed');
|
||||||
|
|
||||||
class Form_controller extends CI_Controller
|
class Form_controller extends CI_Controller
|
||||||
{
|
{
|
||||||
|
|
||||||
public function index_forms($form_id = null)
|
public function index_forms($form_id = null)
|
||||||
{
|
{
|
||||||
$this->load->model('Frontend_model');
|
$this->load->model('Frontend_model');
|
||||||
|
@ -25,6 +25,7 @@ class Form_controller extends CI_Controller
|
||||||
$form_title = $form['title'];
|
$form_title = $form['title'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fetch data from models
|
// Fetch data from models
|
||||||
$data['total_forms'] = $this->Form_model->get_total_forms($user_id);
|
$data['total_forms'] = $this->Form_model->get_total_forms($user_id);
|
||||||
$data['published_forms'] = $this->Form_model->get_published_forms($user_id);
|
$data['published_forms'] = $this->Form_model->get_published_forms($user_id);
|
||||||
|
@ -48,13 +49,12 @@ class Form_controller extends CI_Controller
|
||||||
$this->load->model('Frontend_model');
|
$this->load->model('Frontend_model');
|
||||||
$this->Frontend_model->deleteForm($id);
|
$this->Frontend_model->deleteForm($id);
|
||||||
$this->session->set_flashdata('status', 'Form data deleted successfully');
|
$this->session->set_flashdata('status', 'Form data deleted successfully');
|
||||||
redirect('home');
|
redirect('drafts');
|
||||||
}
|
}
|
||||||
public function __construct()
|
public function __construct()
|
||||||
{
|
{
|
||||||
parent::__construct();
|
parent::__construct();
|
||||||
$this->load->model('Updation_model');
|
$this->load->model('Updation_model');
|
||||||
$this->load->model('Form_model');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Load the form for editing
|
// 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['form'] = $this->Updation_model->get_form($form_id);
|
||||||
$data['questions'] = $this->Updation_model->get_questions($form_id);
|
$data['questions'] = $this->Updation_model->get_questions($form_id);
|
||||||
$data['options'] = $this->Updation_model->get_options();
|
$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('templates/header');
|
||||||
$this->load->view('edit_form_view', $data);
|
$this->load->view('edit_form_view', $data);
|
||||||
// $this->load->view('templates/footer');
|
// $this->load->view('templates/footer');
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Save the edited form
|
// Save the edited form
|
||||||
|
@ -126,4 +126,5 @@ class Form_controller extends CI_Controller
|
||||||
|
|
||||||
$this->load->view('templates/footer');
|
$this->load->view('templates/footer');
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -10,6 +10,9 @@ class Forms extends CI_Controller
|
||||||
// If not logged in, redirect to login page
|
// If not logged in, redirect to login page
|
||||||
redirect('users/login');
|
redirect('users/login');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Load the model that handles the form data
|
// Load the model that handles the form data
|
||||||
$this->load->model('preview_model');
|
$this->load->model('preview_model');
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
defined('BASEPATH') or exit('No direct script access allowed');
|
||||||
|
|
||||||
class Homepage extends CI_Controller
|
class Homepage extends CI_Controller
|
||||||
{
|
{
|
||||||
|
|
||||||
// index2-default
|
// index2-default
|
||||||
public function home()
|
public function home()
|
||||||
{
|
{
|
||||||
|
@ -17,15 +17,19 @@ class Homepage extends CI_Controller
|
||||||
{
|
{
|
||||||
|
|
||||||
$this->load->view('templates/forms_ui');
|
$this->load->view('templates/forms_ui');
|
||||||
|
|
||||||
}
|
}
|
||||||
public function title()
|
public function title()
|
||||||
{
|
{
|
||||||
$this->load->view('templates/header');
|
$this->load->view('templates/header');
|
||||||
$this->load->view('templates/form_title');
|
$this->load->view('templates/form_title');
|
||||||
$this->load->view('templates/footer');
|
$this->load->view('templates/footer');
|
||||||
|
|
||||||
}
|
}
|
||||||
public function ui_forms()
|
public function ui_forms()
|
||||||
{
|
{
|
||||||
$this->load->view('templates/forms_ui');
|
$this->load->view('templates/forms_ui');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,9 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
class New_form extends CI_Controller
|
class New_form extends CI_Controller
|
||||||
{
|
{
|
||||||
public function create_form()
|
public function create_form() {
|
||||||
{
|
|
||||||
if (!$this->session->userdata('logged_in')) {
|
if (!$this->session->userdata('logged_in')) {
|
||||||
// If not logged in, redirect to login page
|
// If not logged in, redirect to login page
|
||||||
redirect('users/login');
|
redirect('users/login');
|
||||||
|
@ -13,7 +11,7 @@ class New_form extends CI_Controller
|
||||||
$this->form_validation->set_rules('title', 'Title', 'required');
|
$this->form_validation->set_rules('title', 'Title', 'required');
|
||||||
$this->form_validation->set_rules('description', 'Description', '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/header');
|
||||||
$this->load->view('templates/form_title', $data);
|
$this->load->view('templates/form_title', $data);
|
||||||
$this->load->view('templates/footer');
|
$this->load->view('templates/footer');
|
||||||
|
@ -25,4 +23,7 @@ class New_form extends CI_Controller
|
||||||
redirect('form/view/' . $form_id);
|
redirect('form/view/' . $form_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
?>
|
|
@ -1,19 +1,22 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
|
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
class New_form_controller extends CI_Controller {
|
||||||
|
|
||||||
class New_form_controller extends CI_Controller
|
public function submit_form() {
|
||||||
{
|
|
||||||
public function submit_form()
|
|
||||||
{
|
|
||||||
if (!$this->session->userdata('logged_in')) {
|
if (!$this->session->userdata('logged_in')) {
|
||||||
// If not logged in, redirect to login page
|
// If not logged in, redirect to login page
|
||||||
echo json_encode(['status' => 'error', 'message' => 'User not logged in']);
|
echo json_encode(['status' => 'error', 'message' => 'User not logged in']);
|
||||||
return;
|
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) {
|
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);
|
$saveStatus = $this->new_form_model->save_form_data($formId, $formData);
|
||||||
|
|
||||||
if ($saveStatus) {
|
if ($saveStatus) {
|
||||||
|
@ -26,3 +29,4 @@ class New_form_controller extends CI_Controller
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
?>
|
||||||
|
|
|
@ -1,12 +1,10 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
|
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
class Publish_controller extends CI_Controller {
|
||||||
|
|
||||||
class Publish_controller extends CI_Controller
|
|
||||||
{
|
|
||||||
// Method to publish a form
|
// Method to publish a form
|
||||||
public function publish_form($form_id)
|
public function publish_form($form_id) {
|
||||||
{
|
|
||||||
// Generate a unique link
|
// Generate a unique link
|
||||||
if (!$this->session->userdata('logged_in')) {
|
if (!$this->session->userdata('logged_in')) {
|
||||||
// If not logged in, redirect to login page
|
// If not logged in, redirect to login page
|
||||||
|
@ -25,8 +23,7 @@ class Publish_controller extends CI_Controller
|
||||||
}
|
}
|
||||||
|
|
||||||
// Method to list published forms of a user
|
// 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 (!$this->session->userdata('logged_in')) {
|
||||||
// If not logged in, redirect to login page
|
// If not logged in, redirect to login page
|
||||||
redirect('users/login');
|
redirect('users/login');
|
||||||
|
@ -42,8 +39,7 @@ class Publish_controller extends CI_Controller
|
||||||
|
|
||||||
|
|
||||||
// Method to unpublish a form
|
// Method to unpublish a form
|
||||||
public function unpublish_form($form_id)
|
public function unpublish_form($form_id) {
|
||||||
{
|
|
||||||
if (!$this->session->userdata('logged_in')) {
|
if (!$this->session->userdata('logged_in')) {
|
||||||
// If not logged in, redirect to login page
|
// If not logged in, redirect to login page
|
||||||
redirect('users/login');
|
redirect('users/login');
|
||||||
|
@ -55,8 +51,7 @@ class Publish_controller extends CI_Controller
|
||||||
|
|
||||||
// redirect('published_forms');
|
// redirect('published_forms');
|
||||||
}
|
}
|
||||||
public function toggle_responsive($form_id)
|
public function toggle_responsive($form_id) {
|
||||||
{
|
|
||||||
if (!$this->session->userdata('logged_in')) {
|
if (!$this->session->userdata('logged_in')) {
|
||||||
redirect('users/login');
|
redirect('users/login');
|
||||||
}
|
}
|
||||||
|
@ -81,4 +76,6 @@ class Publish_controller extends CI_Controller
|
||||||
echo json_encode(['success' => false, 'message' => 'Failed to update']);
|
echo json_encode(['success' => false, 'message' => 'Failed to update']);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
class Response_submit extends CI_Controller {
|
||||||
|
|
||||||
class Response_submit extends CI_Controller
|
public function view($form_id) {
|
||||||
{
|
|
||||||
public function view($form_id)
|
|
||||||
{
|
|
||||||
$this->load->model('Response_model');
|
$this->load->model('Response_model');
|
||||||
|
|
||||||
$data['form'] = $this->Response_model->get_form($form_id);
|
$data['form'] = $this->Response_model->get_form($form_id);
|
||||||
|
@ -19,8 +17,7 @@ class Response_submit extends CI_Controller
|
||||||
redirect('responses/' . $form_id);
|
redirect('responses/' . $form_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function view_responses($form_id)
|
public function view_responses($form_id) {
|
||||||
{
|
|
||||||
$this->load->model('Response_model');
|
$this->load->model('Response_model');
|
||||||
|
|
||||||
$data['form'] = $this->Response_model->get_form($form_id);
|
$data['form'] = $this->Response_model->get_form($form_id);
|
||||||
|
@ -32,8 +29,7 @@ class Response_submit extends CI_Controller
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function submit_form()
|
public function submit_form() {
|
||||||
{
|
|
||||||
$this->load->model('Response_model');
|
$this->load->model('Response_model');
|
||||||
$responses = $this->input->post('responses');
|
$responses = $this->input->post('responses');
|
||||||
$user_id = $this->session->userdata('user_id'); // Assuming user_id is stored in session
|
$user_id = $this->session->userdata('user_id'); // Assuming user_id is stored in session
|
||||||
|
@ -56,7 +52,7 @@ class Response_submit extends CI_Controller
|
||||||
} else {
|
} else {
|
||||||
$answered_text = $response['options'];
|
$answered_text = $response['options'];
|
||||||
}
|
}
|
||||||
} elseif (isset($response['answered_text'])) {
|
} else if (isset($response['answered_text'])) {
|
||||||
$answered_text = $response['answered_text'];
|
$answered_text = $response['answered_text'];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -75,8 +71,7 @@ class Response_submit extends CI_Controller
|
||||||
|
|
||||||
|
|
||||||
// Method to list responses for a form
|
// Method to list responses for a form
|
||||||
public function list_responses($form_id)
|
public function list_responses($form_id) {
|
||||||
{
|
|
||||||
$this->load->model('Response_model');
|
$this->load->model('Response_model');
|
||||||
$data['form'] = $this->Response_model->get_form($form_id);
|
$data['form'] = $this->Response_model->get_form($form_id);
|
||||||
$data['responses'] = $this->Response_model->get_responses($form_id);
|
$data['responses'] = $this->Response_model->get_responses($form_id);
|
||||||
|
@ -87,8 +82,7 @@ class Response_submit extends CI_Controller
|
||||||
}
|
}
|
||||||
|
|
||||||
// Method to view questions and answers for a specific response
|
// 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');
|
$this->load->model('Response_model');
|
||||||
$data['response'] = $this->Response_model->get_response($response_id);
|
$data['response'] = $this->Response_model->get_response($response_id);
|
||||||
$data['form'] = $this->Response_model->get_form_by_response($response_id); // Get form details
|
$data['form'] = $this->Response_model->get_form_by_response($response_id); // Get form details
|
||||||
|
@ -100,7 +94,7 @@ class Response_submit extends CI_Controller
|
||||||
}
|
}
|
||||||
|
|
||||||
public function summary($form_id)
|
public function summary($form_id)
|
||||||
{
|
{
|
||||||
$this->load->model('Form_model');
|
$this->load->model('Form_model');
|
||||||
$this->load->model('Response_model');
|
$this->load->model('Response_model');
|
||||||
|
|
||||||
|
@ -121,52 +115,15 @@ class Response_submit extends CI_Controller
|
||||||
$data['form'] = $form;
|
$data['form'] = $form;
|
||||||
$data['summary_data'] = $summary_data;
|
$data['summary_data'] = $summary_data;
|
||||||
|
|
||||||
|
$this->load->view('templates/header');
|
||||||
$this->load->view('Forms/summary', $data);
|
$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');
|
$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,5 +1,4 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
class Users extends CI_Controller
|
class Users extends CI_Controller
|
||||||
{
|
{
|
||||||
//signup user
|
//signup user
|
||||||
|
@ -11,7 +10,7 @@ class Users extends CI_Controller
|
||||||
$this->form_validation->set_rules('password', 'Password', 'required');
|
$this->form_validation->set_rules('password', 'Password', 'required');
|
||||||
$this->form_validation->set_rules('password2', 'Confirm Passsword', 'matches[password]');
|
$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('templates/header');
|
||||||
$this->load->view('users/register', $data);
|
$this->load->view('users/register', $data);
|
||||||
$this->load->view('templates/footer');
|
$this->load->view('templates/footer');
|
||||||
|
@ -26,6 +25,7 @@ class Users extends CI_Controller
|
||||||
$this->session->set_flashdata('user_registered', 'You are now registered and can log in');
|
$this->session->set_flashdata('user_registered', 'You are now registered and can log in');
|
||||||
redirect('start');
|
redirect('start');
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@ class Users extends CI_Controller
|
||||||
$this->form_validation->set_rules('username', 'Username', 'required');
|
$this->form_validation->set_rules('username', 'Username', 'required');
|
||||||
$this->form_validation->set_rules('password', 'Password', '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('templates/header');
|
||||||
$this->load->view('users/login', $data);
|
$this->load->view('users/login', $data);
|
||||||
$this->load->view('templates/footer');
|
$this->load->view('templates/footer');
|
||||||
|
@ -85,6 +85,7 @@ class Users extends CI_Controller
|
||||||
|
|
||||||
$this->session->set_flashdata('user_loggedout', 'You are now logged out');
|
$this->session->set_flashdata('user_loggedout', 'You are now logged out');
|
||||||
redirect('users/login');
|
redirect('users/login');
|
||||||
|
|
||||||
}
|
}
|
||||||
// check if username exists
|
// check if username exists
|
||||||
public function check_username_exists($username)
|
public function check_username_exists($username)
|
||||||
|
@ -121,3 +122,6 @@ class Users extends CI_Controller
|
||||||
// }
|
// }
|
||||||
// }
|
// }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
?>
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
|
|
||||||
<?php
|
<?php
|
||||||
|
class Create_model extends CI_Model {
|
||||||
|
|
||||||
class Create_model extends CI_Model
|
public function details() {
|
||||||
{
|
|
||||||
public function details()
|
|
||||||
{
|
|
||||||
// Retrieve user_id from session
|
// Retrieve user_id from session
|
||||||
$user_id = $this->session->userdata('user_id');
|
$user_id = $this->session->userdata('user_id');
|
||||||
|
|
||||||
|
@ -22,6 +20,8 @@ class Create_model extends CI_Model
|
||||||
$formId = $this->db->insert_id();
|
$formId = $this->db->insert_id();
|
||||||
$this->session->set_userdata('form_id', $formId);
|
$this->session->set_userdata('form_id', $formId);
|
||||||
|
|
||||||
return $formId;
|
return $formId;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
?>
|
||||||
|
|
|
@ -1,22 +1,9 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
defined('BASEPATH') or exit('No direct script access allowed');
|
||||||
|
|
||||||
class Form_model extends CI_Model
|
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
|
// Function to get form details by ID
|
||||||
public function get_form_by_id($form_id)
|
public function get_form_by_id($form_id)
|
||||||
{
|
{
|
||||||
|
@ -26,16 +13,14 @@ class Form_model extends CI_Model
|
||||||
return $query->row();
|
return $query->row();
|
||||||
}
|
}
|
||||||
// Get the total number of forms
|
// 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
|
// Ensure user_id is passed as a parameter and used in the query
|
||||||
$this->db->where('user_id', $user_id);
|
$this->db->where('user_id', $user_id);
|
||||||
return $this->db->count_all_results('forms'); // Use count_all_results to ensure WHERE conditions are applied
|
return $this->db->count_all_results('forms'); // Use count_all_results to ensure WHERE conditions are applied
|
||||||
}
|
}
|
||||||
|
|
||||||
// Function to count published forms
|
// 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
|
// 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('user_id', $user_id);
|
||||||
$this->db->where('is_published', 1);
|
$this->db->where('is_published', 1);
|
||||||
|
@ -80,7 +65,7 @@ class Form_model extends CI_Model
|
||||||
|
|
||||||
$this->db->trans_complete();
|
$this->db->trans_complete();
|
||||||
|
|
||||||
if ($this->db->trans_status() === false) {
|
if ($this->db->trans_status() === FALSE) {
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -1,10 +1,8 @@
|
||||||
|
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
|
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
class Frontend_model extends CI_Model {
|
||||||
|
|
||||||
class Frontend_model extends CI_Model
|
|
||||||
{
|
|
||||||
public function getforms()
|
public function getforms()
|
||||||
{
|
{
|
||||||
// Get the user_id from session
|
// Get the user_id from session
|
||||||
|
@ -23,8 +21,7 @@ class Frontend_model extends CI_Model
|
||||||
return $query->result(); // Return the result as an array of objects
|
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]);
|
return $this->db->delete('forms', ['id' => $id]);
|
||||||
}
|
}
|
||||||
public function getFormById($form_id)
|
public function getFormById($form_id)
|
||||||
|
@ -32,12 +29,13 @@ class Frontend_model extends CI_Model
|
||||||
$query = $this->db->get_where('forms', ['id' => $form_id]);
|
$query = $this->db->get_where('forms', ['id' => $form_id]);
|
||||||
return $query->row_array();
|
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('is_published', 0);
|
||||||
$this->db->where('user_id', $user_id);
|
$this->db->where('user_id', $user_id);
|
||||||
$this->db->order_by('created_at', 'DESC');
|
$this->db->order_by('created_at', 'DESC');
|
||||||
$query = $this->db->get('forms');
|
$query = $this->db->get('forms');
|
||||||
return $query->result();
|
return $query->result();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,9 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
|
class New_form_model extends CI_Model {
|
||||||
|
|
||||||
class New_form_model extends CI_Model
|
public function save_form_data($formId, $formData) {
|
||||||
{
|
|
||||||
public function save_form_data($formId, $formData)
|
|
||||||
{
|
|
||||||
if (!$formId || !isset($formData['questions'])) {
|
if (!$formId || !isset($formData['questions'])) {
|
||||||
return false; // Handle error if formId is not valid or questions are missing
|
return false; // Handle error if formId is not valid or questions are missing
|
||||||
}
|
}
|
||||||
|
@ -38,4 +36,7 @@ class New_form_model extends CI_Model
|
||||||
|
|
||||||
return true; // Return true indicating success
|
return true; // Return true indicating success
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
?>
|
||||||
|
|
|
@ -1,25 +1,22 @@
|
||||||
<?php
|
<?php
|
||||||
|
class preview_model extends CI_Model {
|
||||||
|
|
||||||
class preview_model extends CI_Model
|
public function get_form($form_id) {
|
||||||
{
|
|
||||||
public function get_form($form_id)
|
|
||||||
{
|
|
||||||
$this->db->where('id', $form_id);
|
$this->db->where('id', $form_id);
|
||||||
$query = $this->db->get('forms');
|
$query = $this->db->get('forms');
|
||||||
return $query->row();
|
return $query->row();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function get_questions($form_id)
|
public function get_questions($form_id) {
|
||||||
{
|
|
||||||
$this->db->where('form_id', $form_id);
|
$this->db->where('form_id', $form_id);
|
||||||
$query = $this->db->get('questions');
|
$query = $this->db->get('questions');
|
||||||
return $query->result(); // Ensure this returns objects with the 'is_required' field
|
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);
|
$this->db->where('question_id', $question_id);
|
||||||
$query = $this->db->get('options');
|
$query = $this->db->get('options');
|
||||||
return $query->result(); // Ensure this returns the options related to the question
|
return $query->result(); // Ensure this returns the options related to the question
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,21 +1,19 @@
|
||||||
<?php
|
<?php
|
||||||
|
class Publish_model extends CI_Model {
|
||||||
|
|
||||||
class Publish_model extends CI_Model
|
// Method to update form details including is_published status
|
||||||
{
|
public function update_form($form_id, $data) {
|
||||||
// Method to update form details including is_published status
|
|
||||||
public function update_form($form_id, $data)
|
|
||||||
{
|
|
||||||
$this->db->where('id', $form_id);
|
$this->db->where('id', $form_id);
|
||||||
return $this->db->update('forms', $data);
|
return $this->db->update('forms', $data);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Method to retrieve published forms by user
|
// Method to retrieve published forms by user
|
||||||
public function get_published_forms_by_user($user_id)
|
public function get_published_forms_by_user($user_id) {
|
||||||
{
|
|
||||||
$this->db->where('user_id', $user_id);
|
$this->db->where('user_id', $user_id);
|
||||||
$this->db->where('is_published', 1);
|
$this->db->where('is_published', 1);
|
||||||
$this->db->order_by('id', 'DESC'); // Order by id column, most recent first
|
$this->db->order_by('id', 'DESC'); // Order by id column, most recent first
|
||||||
$query = $this->db->get('forms');
|
$query = $this->db->get('forms');
|
||||||
return $query->result();
|
return $query->result();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,15 +1,12 @@
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
class Response_model extends CI_Model
|
class Response_model extends CI_Model
|
||||||
{
|
{
|
||||||
public function __construct()
|
public function __construct() {
|
||||||
{
|
|
||||||
$this->load->database();
|
$this->load->database();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Get the total number of responses
|
// 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
|
// Join the responses table with the forms table
|
||||||
$this->db->select('responses.id');
|
$this->db->select('responses.id');
|
||||||
$this->db->from('responses');
|
$this->db->from('responses');
|
||||||
|
@ -171,58 +168,5 @@ class Response_model extends CI_Model
|
||||||
|
|
||||||
return $summary_data;
|
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
|
<?php
|
||||||
|
|
||||||
class Updation_model extends CI_Model
|
class Updation_model extends CI_Model
|
||||||
{
|
{
|
||||||
|
|
||||||
public function get_form($form_id)
|
public function get_form($form_id)
|
||||||
{
|
{
|
||||||
$this->db->where('id', $form_id);
|
$this->db->where('id', $form_id);
|
||||||
|
@ -9,7 +9,6 @@ class Updation_model extends CI_Model
|
||||||
return $query->row_array();
|
return $query->row_array();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public function get_questions($form_id)
|
public function get_questions($form_id)
|
||||||
{
|
{
|
||||||
$this->db->where('form_id', $form_id);
|
$this->db->where('form_id', $form_id);
|
||||||
|
@ -91,4 +90,8 @@ class Updation_model extends CI_Model
|
||||||
$this->db->delete('options');
|
$this->db->delete('options');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
?>
|
|
@ -1,48 +1,49 @@
|
||||||
<?php
|
<?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
|
||||||
|
);
|
||||||
|
|
||||||
class User_model extends CI_Model
|
return $this->db->insert('users', $data);
|
||||||
{
|
|
||||||
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)
|
public function login($username,$password){
|
||||||
{
|
$this->db->where('username',$username);
|
||||||
$this->db->where('username', $username);
|
$this->db->where('password',$password);
|
||||||
$this->db->where('password', $password);
|
|
||||||
|
|
||||||
$result = $this->db->get('users');
|
$result = $this->db->get('users');
|
||||||
if ($result->num_rows() == 1) {
|
if($result->num_rows()==1){
|
||||||
return $result->row(0)->id;
|
return $result->row(0)->id;
|
||||||
} else {
|
}
|
||||||
|
else{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function check_username_exists($username)
|
public function check_username_exists($username){
|
||||||
{
|
$query = $this->db->get_where('users',array('username'=>$username));
|
||||||
$query = $this->db->get_where('users', array('username' => $username));
|
if(empty($query->row_array())){
|
||||||
if (empty($query->row_array())) {
|
|
||||||
return true;
|
return true;
|
||||||
} else {
|
}
|
||||||
|
else{
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public function check_email_exists($email)
|
|
||||||
{
|
|
||||||
$query = $this->db->get_where('users', array('email' => $email));
|
|
||||||
if (empty($query->row_array())) {
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public function check_email_exists($email){
|
||||||
|
$query = $this->db->get_where('users',array('email'=>$email));
|
||||||
|
if(empty($query->row_array())){
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -28,16 +28,16 @@
|
||||||
</div>
|
</div>
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<div id="charts">
|
<div id="charts">
|
||||||
<?php foreach ($summary_data as $question) : ?>
|
<?php foreach ($summary_data as $question): ?>
|
||||||
<h5><?php echo $question['text']; ?></h5>
|
<h5><?php echo $question['text']; ?></h5>
|
||||||
<?php if (is_array($question['answers'])) : ?>
|
<?php if (is_array($question['answers'])): ?>
|
||||||
<div class="chart-container">
|
<div class="chart-container">
|
||||||
<canvas id="chart-<?php echo $question['question_id']; ?>"></canvas>
|
<canvas id="chart-<?php echo $question['question_id']; ?>"></canvas>
|
||||||
</div>
|
</div>
|
||||||
<?php else : ?>
|
<?php else: ?>
|
||||||
<div class="short-answer">
|
<div class="short-answer">
|
||||||
<ul>
|
<ul>
|
||||||
<?php foreach ($question['answers'] as $answer) : ?>
|
<?php foreach ($question['answers'] as $answer): ?>
|
||||||
<li><?php echo $answer; ?></li>
|
<li><?php echo $answer; ?></li>
|
||||||
<?php endforeach; ?>
|
<?php endforeach; ?>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
|
@ -21,7 +21,7 @@
|
||||||
<div class="col-md-12 mt-4">
|
<div class="col-md-12 mt-4">
|
||||||
<div class="card">
|
<div class="card">
|
||||||
<div class="card-header">
|
<div class="card-header">
|
||||||
<?php if ($this->session->flashdata('status')) : ?>
|
<?php if ($this->session->flashdata('status')): ?>
|
||||||
<div class="alert alert-success">
|
<div class="alert alert-success">
|
||||||
<?= $this->session->flashdata('status'); ?>
|
<?= $this->session->flashdata('status'); ?>
|
||||||
</div>
|
</div>
|
||||||
|
@ -32,7 +32,7 @@
|
||||||
<table id="basetable1" class="table table-bordered">
|
<table id="basetable1" class="table table-bordered">
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th>Serial No.</th>
|
<th>Drafts</th>
|
||||||
<th>Title</th>
|
<th>Title</th>
|
||||||
<th>Created On</th>
|
<th>Created On</th>
|
||||||
<th>Edit</th>
|
<th>Edit</th>
|
||||||
|
@ -43,7 +43,7 @@
|
||||||
<tbody>
|
<tbody>
|
||||||
<?php
|
<?php
|
||||||
$serialNumber = 1; // Initialize the counter variable
|
$serialNumber = 1; // Initialize the counter variable
|
||||||
foreach ($forms as $row) : ?>
|
foreach ($forms as $row): ?>
|
||||||
<tr>
|
<tr>
|
||||||
<td><?php echo $serialNumber++; ?></td>
|
<td><?php echo $serialNumber++; ?></td>
|
||||||
<td class="title-column"><?php echo $row->title; ?></td>
|
<td class="title-column"><?php echo $row->title; ?></td>
|
||||||
|
|
|
@ -1,18 +1,12 @@
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
|
|
||||||
<head>
|
<head>
|
||||||
<!-- Other head elements -->
|
<!-- Other head elements -->
|
||||||
<meta charset="UTF-8">
|
<meta charset="UTF-8">
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||||
<title>Form List</title>
|
<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://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="styles.css"> -->
|
||||||
|
|
||||||
<link rel="stylesheet" href=" < ?php echo base_url(); ?>assets/css/header_styles.css">
|
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
/* CSS styles */
|
/* CSS styles */
|
||||||
.title-column {
|
.title-column {
|
||||||
|
@ -41,20 +35,15 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.card-title {
|
.card-title {
|
||||||
color: rgb(103, 58, 183);
|
color: rgb(103, 58, 183); /* Match the color theme */
|
||||||
/* Match the color theme */
|
|
||||||
margin-bottom: 10px;
|
margin-bottom: 10px;
|
||||||
font-size: 20px;
|
font-size: 20px; /* Increase the font size of the title */
|
||||||
/* Increase the font size of the title */
|
font-weight: bold; /* Make the title bold */
|
||||||
font-weight: bold;
|
|
||||||
/* Make the title bold */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.card-text {
|
.card-text {
|
||||||
font-size: 28px;
|
font-size: 28px; /* Increase the font size */
|
||||||
/* Increase the font size */
|
font-weight: bold; /* Make the text bold */
|
||||||
font-weight: bold;
|
|
||||||
/* Make the text bold */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.card-text.green {
|
.card-text.green {
|
||||||
|
@ -76,56 +65,16 @@
|
||||||
.card-text.purple {
|
.card-text.purple {
|
||||||
color: #6f42c1;
|
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>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-4">
|
<div class="col-md-4">
|
||||||
<div class="card card-stats">
|
<div class="card card-stats">
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<h5 class="card-title">Total Forms Created</h5>
|
<h5 class="card-title">Total Forms Created</h5>
|
||||||
<p class="card-text" id="total-forms">
|
<p class="card-text" id="total-forms"><?php echo $total_forms; ?></p>
|
||||||
<?php echo $total_forms; ?>
|
|
||||||
|
|
||||||
</p>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -133,8 +82,7 @@
|
||||||
<div class="card card-stats">
|
<div class="card card-stats">
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<h5 class="card-title">Published Forms</h5>
|
<h5 class="card-title">Published Forms</h5>
|
||||||
<p class="card-text" id="published-forms">
|
<p class="card-text" id="published-forms"><?php echo $published_forms; ?></p>
|
||||||
<?php echo $published_forms; ?></p>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -142,8 +90,7 @@
|
||||||
<div class="card card-stats">
|
<div class="card card-stats">
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<h5 class="card-title">Responses Submitted</h5>
|
<h5 class="card-title">Responses Submitted</h5>
|
||||||
<p class="card-text" id="total-responses">
|
<p class="card-text" id="total-responses"><?php echo $total_responses; ?></p>
|
||||||
<?php echo $total_responses; ?></p>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -154,7 +101,7 @@
|
||||||
<div class="col-md-12 mt-4 ">
|
<div class="col-md-12 mt-4 ">
|
||||||
<div class="card">
|
<div class="card">
|
||||||
<div class="card-header">
|
<div class="card-header">
|
||||||
<?php if ($this->session->flashdata('status')) : ?>
|
<?php if ($this->session->flashdata('status')): ?>
|
||||||
<div class="alert alert-success">
|
<div class="alert alert-success">
|
||||||
<?= $this->session->flashdata('status'); ?>
|
<?= $this->session->flashdata('status'); ?>
|
||||||
</div>
|
</div>
|
||||||
|
@ -166,68 +113,33 @@
|
||||||
<table id="basetable1" class="table table-bordered">
|
<table id="basetable1" class="table table-bordered">
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th>Serial No.</th>
|
<th>Forms</th>
|
||||||
<th>Title</th>
|
<th>Title</th>
|
||||||
<th>Description</th>
|
<th>Description</th>
|
||||||
<th>Created On</th>
|
<th>Created On</th>
|
||||||
<th>Status</th>
|
<th>Status</th>
|
||||||
<th>Actions</th>
|
|
||||||
<th>Responses</th>
|
<th>Responses</th>
|
||||||
|
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
<?php
|
<?php
|
||||||
$serialNumber = 1; // Initialize the counter variable
|
$serialNumber = 1; // Initialize the counter variable
|
||||||
foreach ($forms as $row) : ?>
|
foreach ($forms as $row): ?>
|
||||||
<tr
|
<tr class="<?php echo ($row->is_published ? '' : 'draft-row'); ?>">
|
||||||
class="<?php echo($row->is_published ? '' : 'draft-row'); ?>">
|
<td><?php echo $serialNumber++; ?></td>
|
||||||
<td><?php echo $serialNumber++; ?>
|
|
||||||
</td>
|
|
||||||
<td class="title-column">
|
<td class="title-column">
|
||||||
<a
|
<a href="<?php echo base_url('publish/' . $row->id); ?>"><?php echo $row->title; ?></a>
|
||||||
href="<?php echo base_url('publish/' . $row->id); ?>"><?php echo $row->title; ?></a>
|
|
||||||
</td>
|
</td>
|
||||||
<td><?php echo $row->description; ?>
|
<td><?php echo $row->description; ?></td>
|
||||||
</td>
|
<td><?php echo $row->created_at; ?></td>
|
||||||
<td><?php echo $row->created_at; ?>
|
<td style="color: <?php echo ($row->is_published ? '#006400' : 'red'); ?>;">
|
||||||
</td>
|
<?php echo ($row->is_published ? 'Published' : 'Draft'); ?>
|
||||||
<td
|
|
||||||
style="color: <?php echo($row->is_published ? '#006400' : 'red'); ?>;">
|
|
||||||
<?php echo($row->is_published ? 'Published' : 'Draft'); ?>
|
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
<?php if ($row->is_published == 0) : ?>
|
<a href="<?php echo base_url('responses/' . $row->id); ?>">
|
||||||
<!-- 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 -->
|
<i class="fas fa-eye"></i> <!-- Eye icon -->
|
||||||
</a>
|
</a>
|
||||||
</td>
|
</td>
|
||||||
|
|
||||||
</tr>
|
</tr>
|
||||||
<?php endforeach; ?>
|
<?php endforeach; ?>
|
||||||
</tbody>
|
</tbody>
|
||||||
|
@ -237,8 +149,3 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<script>
|
|
||||||
document.getElementById('total-responses').parentNode.addEventListener('click', function() {
|
|
||||||
window.location.href = 'total_responses';
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
|
|
|
@ -1,135 +0,0 @@
|
||||||
<!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://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>
|
<script src="https://cdn.datatables.net/1.11.5/js/jquery.dataTables.min.js"></script>
|
||||||
<!-- Add SweetAlert CSS and JS -->
|
<!-- Add SweetAlert CSS and JS -->
|
||||||
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/sweetalert2@11/dist/sweetalert2.min.css">
|
<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>
|
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
|
||||||
|
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
<style>
|
<style>
|
||||||
.custom-select {
|
.custom-select {
|
||||||
width: 220px;
|
width: 220px;
|
||||||
height: 44px;
|
height: 44px;
|
||||||
display: block;
|
display: block;
|
||||||
|
@ -33,12 +33,13 @@
|
||||||
background-image: none;
|
background-image: none;
|
||||||
border: 1px solid #dce4ec;
|
border: 1px solid #dce4ec;
|
||||||
border-radius: 4px;
|
border-radius: 4px;
|
||||||
}
|
}
|
||||||
|
|
||||||
</style>
|
</style>
|
||||||
<!-- Navbar -->
|
<!-- Navbar -->
|
||||||
<nav class="navbar navbar-custom">
|
<nav class="navbar navbar-custom">
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<?php if ($this->session->userdata('logged_in')) : ?>
|
<?php if ($this->session->userdata('logged_in')): ?>
|
||||||
<div class="navbar-header">
|
<div class="navbar-header">
|
||||||
<a class="navbar-brand" href="<?php echo base_url(); ?>">Google Forms</a>
|
<a class="navbar-brand" href="<?php echo base_url(); ?>">Google Forms</a>
|
||||||
</div>
|
</div>
|
||||||
|
@ -46,41 +47,41 @@
|
||||||
|
|
||||||
<div id="navbar" class="navbar-collapse">
|
<div id="navbar" class="navbar-collapse">
|
||||||
<ul class="nav navbar-nav">
|
<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(); ?>published_forms">Published Forms</a></li>
|
||||||
|
<li><a href="<?php echo base_url(); ?>drafts">Drafts</a></li>
|
||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
</ul>
|
</ul>
|
||||||
<ul class="nav navbar-nav navbar-right">
|
<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/login">Login</a></li>
|
||||||
<li><a href="<?php echo base_url(); ?>users/register">Register</a></li>
|
<li><a href="<?php echo base_url(); ?>users/register">Register</a></li>
|
||||||
<?php endif; ?>
|
<?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(); ?>homepage/title">Create Form</a></li>
|
||||||
<li><a href="<?php echo base_url(); ?>users/logout">Logout</a></li>
|
<li><a href="<?php echo base_url(); ?>users/logout">Logout</a></li>
|
||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</nav>
|
</nav>
|
||||||
|
|
||||||
|
|
||||||
<!-- Alert Messages -->
|
<!-- Alert Messages -->
|
||||||
<div class="container">
|
<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>
|
<p class="alert alert-success"><?php echo $this->session->flashdata('user_registered'); ?></p>
|
||||||
<?php endif; ?>
|
<?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>
|
<p class="alert alert-danger"><?php echo $this->session->flashdata('login_failed'); ?></p>
|
||||||
<?php endif; ?>
|
<?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>
|
<p class="alert alert-success"><?php echo $this->session->flashdata('user_loggedin'); ?></p>
|
||||||
<?php endif; ?>
|
<?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>
|
<p class="alert alert-success"><?php echo $this->session->flashdata('user_loggedout'); ?></p>
|
||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
</div>
|
</div>
|
||||||
|
@ -101,7 +102,7 @@
|
||||||
<button id="add-section-btn" class="btn btn-primary">+</button>
|
<button id="add-section-btn" class="btn btn-primary">+</button>
|
||||||
</div>
|
</div>
|
||||||
<div id="form-container">
|
<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="form-section" data-index="<?php echo $question['id']; ?>" data-type="<?php echo $question['type']; ?>">
|
||||||
<div class="header-row">
|
<div class="header-row">
|
||||||
<input type="text" class="form-control untitled-question" placeholder="Untitled Question" rows="1" value="<?php echo $question['text']; ?>">
|
<input type="text" class="form-control untitled-question" placeholder="Untitled Question" rows="1" value="<?php echo $question['text']; ?>">
|
||||||
|
@ -122,7 +123,7 @@
|
||||||
<?php
|
<?php
|
||||||
$this->db->where('question_id', $question['id']);
|
$this->db->where('question_id', $question['id']);
|
||||||
$options = $this->db->get('options')->result_array();
|
$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';
|
$iconClass = ($question['type'] === 'multiple-choice' || $question['type'] === 'dropdown') ? 'fa-circle' : 'fa-square';
|
||||||
?>
|
?>
|
||||||
<div class="option">
|
<div class="option">
|
||||||
|
@ -132,11 +133,11 @@
|
||||||
</div>
|
</div>
|
||||||
<?php endforeach; ?>
|
<?php endforeach; ?>
|
||||||
</div>
|
</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>
|
<button class="btn btn-primary add-option-btn">Add Option</button>
|
||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
</div>
|
</div>
|
||||||
<?php endforeach; ?>
|
<?php endforeach; ?>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<button id="submit-btn" class="btn btn-success btn-custom">Submit</button>
|
<button id="submit-btn" class="btn btn-success btn-custom">Submit</button>
|
||||||
|
@ -147,19 +148,18 @@
|
||||||
<script src="<?php echo base_url('assets/js/jquery-ui.js'); ?>"></script>
|
<script src="<?php echo base_url('assets/js/jquery-ui.js'); ?>"></script>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
$(document).ready(function() {
|
$(document).ready(function () {
|
||||||
var base_url = '<?php echo base_url(); ?>';
|
var base_url = '<?php echo base_url(); ?>';
|
||||||
var activeSection = null;
|
var activeSection = null;
|
||||||
$('#form-container').sortable({
|
$('#form-container').sortable({
|
||||||
placeholder: 'ui-state-highlight',
|
placeholder: 'ui-state-highlight',
|
||||||
start: function(event, ui) {
|
start: function (event, ui) {
|
||||||
ui.placeholder.height(ui.item.height());
|
ui.placeholder.height(ui.item.height());
|
||||||
},
|
},
|
||||||
stop: function(event, ui) {
|
stop: function (event, ui) {
|
||||||
positionAddSectionButton();
|
positionAddSectionButton();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
function positionAddSectionButton() {
|
function positionAddSectionButton() {
|
||||||
if (activeSection) {
|
if (activeSection) {
|
||||||
var position = activeSection.position();
|
var position = activeSection.position();
|
||||||
|
@ -192,12 +192,12 @@
|
||||||
</div>
|
</div>
|
||||||
`;
|
`;
|
||||||
section.find('.options-container').append(optionHtml);
|
section.find('.options-container').append(optionHtml);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Add section button functionality
|
// Add section button functionality
|
||||||
$('#add-section-btn').on('click', function() {
|
$('#add-section-btn').on('click', function () {
|
||||||
createFormSection();
|
createFormSection();
|
||||||
$('.form-section').removeClass('active');
|
$('.form-section').removeClass('active');
|
||||||
activeSection = $('.form-section').last();
|
activeSection = $('.form-section').last();
|
||||||
|
@ -252,7 +252,7 @@
|
||||||
// Initially hide add option button
|
// Initially hide add option button
|
||||||
newSection.find('.add-option-btn').hide();
|
newSection.find('.add-option-btn').hide();
|
||||||
|
|
||||||
newSection.on('click', function() {
|
newSection.on('click', function () {
|
||||||
$('.form-section').removeClass('active');
|
$('.form-section').removeClass('active');
|
||||||
$(this).addClass('active');
|
$(this).addClass('active');
|
||||||
activeSection = $(this);
|
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 $section = $(this).closest('.form-section');
|
||||||
var questionType = $section.find('.question-type').val();
|
var questionType = $section.find('.question-type').val();
|
||||||
appendNewOption($section, questionType);
|
appendNewOption($section, questionType);
|
||||||
});
|
});
|
||||||
|
|
||||||
$(document).on('click', '.delete-section-icon', function() {
|
$(document).on('click', '.delete-section-icon', function () {
|
||||||
$(this).closest('.form-section').remove();
|
$(this).closest('.form-section').remove();
|
||||||
activeSection = null;
|
activeSection = null;
|
||||||
positionAddSectionButton();
|
positionAddSectionButton();
|
||||||
});
|
});
|
||||||
|
|
||||||
$(document).on('click', '.delete-option-icon', function() {
|
$(document).on('click', '.delete-option-icon', function () {
|
||||||
$(this).closest('.option').remove();
|
$(this).closest('.option').remove();
|
||||||
});
|
});
|
||||||
|
|
||||||
$('.form-section').each(function() {
|
$('.form-section').each(function () {
|
||||||
$(this).on('click', function() {
|
$(this).on('click', function () {
|
||||||
$('.form-section').removeClass('active');
|
$('.form-section').removeClass('active');
|
||||||
$(this).addClass('active');
|
$(this).addClass('active');
|
||||||
activeSection = $(this);
|
activeSection = $(this);
|
||||||
|
@ -309,15 +309,15 @@
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
$(window).on('resize', function() {
|
$(window).on('resize', function () {
|
||||||
positionAddSectionButton();
|
positionAddSectionButton();
|
||||||
});
|
});
|
||||||
|
|
||||||
// positionAddSectionButton();
|
// positionAddSectionButton();
|
||||||
$(document).ready(function() {
|
$(document).ready(function () {
|
||||||
var base_url = '<?php echo base_url(); ?>';
|
var base_url = '<?php echo base_url(); ?>';
|
||||||
|
|
||||||
$('#submit-btn').on('click', function() {
|
$('#submit-btn').on('click', function () {
|
||||||
var formData = collectFormData();
|
var formData = collectFormData();
|
||||||
formData['form_id'] = <?php echo $form['id']; ?>;
|
formData['form_id'] = <?php echo $form['id']; ?>;
|
||||||
|
|
||||||
|
@ -330,11 +330,9 @@
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: base_url + 'Form_controller/update_form',
|
url: base_url + 'Form_controller/update_form',
|
||||||
type: 'POST',
|
type: 'POST',
|
||||||
data: {
|
data: { formData: formData },
|
||||||
formData: formData
|
|
||||||
},
|
|
||||||
dataType: 'JSON',
|
dataType: 'JSON',
|
||||||
success: function(response) {
|
success: function (response) {
|
||||||
if (response.status === 'success') {
|
if (response.status === 'success') {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
title: 'Success!',
|
title: 'Success!',
|
||||||
|
@ -355,7 +353,7 @@
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
error: function(error) {
|
error: function (error) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
title: 'Error!',
|
title: 'Error!',
|
||||||
text: 'Error updating form!',
|
text: 'Error updating form!',
|
||||||
|
@ -375,7 +373,7 @@
|
||||||
questions: []
|
questions: []
|
||||||
};
|
};
|
||||||
|
|
||||||
$('.form-section').each(function() {
|
$('.form-section').each(function () {
|
||||||
var questionData = {
|
var questionData = {
|
||||||
id: $(this).data('index'),
|
id: $(this).data('index'),
|
||||||
text: $(this).find('.untitled-question').val(),
|
text: $(this).find('.untitled-question').val(),
|
||||||
|
@ -384,7 +382,7 @@
|
||||||
options: []
|
options: []
|
||||||
};
|
};
|
||||||
|
|
||||||
$(this).find('.option-label').each(function() {
|
$(this).find('.option-label').each(function () {
|
||||||
questionData.options.push($(this).val());
|
questionData.options.push($(this).val());
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -397,31 +395,20 @@
|
||||||
function validateFormData(formData) {
|
function validateFormData(formData) {
|
||||||
for (let question of formData.questions) {
|
for (let question of formData.questions) {
|
||||||
if (!question.text.trim()) {
|
if (!question.text.trim()) {
|
||||||
return {
|
return { isValid: false, message: 'All questions must have text.' };
|
||||||
isValid: false,
|
|
||||||
message: 'All questions must have text.'
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
if ((question.type === 'multiple-choice' || question.type === 'checkboxes' || question.type === 'dropdown') && question.options.length === 0) {
|
if ((question.type === 'multiple-choice' || question.type === 'checkboxes' || question.type === 'dropdown') && question.options.length === 0) {
|
||||||
return {
|
return { isValid: false, message: 'All options-based questions must have at least one option.' };
|
||||||
isValid: false,
|
|
||||||
message: 'All options-based questions must have at least one option.'
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
for (let option of question.options) {
|
for (let option of question.options) {
|
||||||
if (!option.trim()) {
|
if (!option.trim()) {
|
||||||
return {
|
return { isValid: false, message: 'All options must have text.' };
|
||||||
isValid: false,
|
|
||||||
message: 'All options must have text.'
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return {
|
return { isValid: true };
|
||||||
isValid: true
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// Initialize
|
// Initialize
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,8 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
echo "\nERROR: ",
|
echo "\nERROR: ",
|
||||||
$heading,
|
$heading,
|
||||||
"\n\n",
|
"\n\n",
|
||||||
$message,
|
$message,
|
||||||
"\n\n";
|
"\n\n";
|
|
@ -1,9 +1,8 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
echo "\nDatabase error: ",
|
echo "\nDatabase error: ",
|
||||||
$heading,
|
$heading,
|
||||||
"\n\n",
|
"\n\n",
|
||||||
$message,
|
$message,
|
||||||
"\n\n";
|
"\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
|
An uncaught Exception was encountered
|
||||||
|
|
||||||
|
@ -7,14 +7,15 @@ Message: <?php echo $message, "\n"; ?>
|
||||||
Filename: <?php echo $exception->getFile(), "\n"; ?>
|
Filename: <?php echo $exception->getFile(), "\n"; ?>
|
||||||
Line Number: <?php echo $exception->getLine(); ?>
|
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:
|
Backtrace:
|
||||||
<?php foreach ($exception->getTrace() as $error) : ?>
|
<?php foreach ($exception->getTrace() as $error): ?>
|
||||||
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0) : ?>
|
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0): ?>
|
||||||
File: <?php echo $error['file'], "\n"; ?>
|
File: <?php echo $error['file'], "\n"; ?>
|
||||||
Line: <?php echo $error['line'], "\n"; ?>
|
Line: <?php echo $error['line'], "\n"; ?>
|
||||||
Function: <?php echo $error['function'], "\n\n"; ?>
|
Function: <?php echo $error['function'], "\n\n"; ?>
|
||||||
<?php endif ?>
|
<?php endif ?>
|
||||||
<?php endforeach ?>
|
<?php endforeach ?>
|
||||||
|
|
||||||
<?php endif ?>
|
<?php endif ?>
|
||||||
|
|
|
@ -1,9 +1,8 @@
|
||||||
<?php
|
<?php
|
||||||
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
|
||||||
|
|
||||||
echo "\nERROR: ",
|
echo "\nERROR: ",
|
||||||
$heading,
|
$heading,
|
||||||
"\n\n",
|
"\n\n",
|
||||||
$message,
|
$message,
|
||||||
"\n\n";
|
"\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
|
A PHP Error was encountered
|
||||||
|
|
||||||
|
@ -7,14 +7,15 @@ Message: <?php echo $message, "\n"; ?>
|
||||||
Filename: <?php echo $filepath, "\n"; ?>
|
Filename: <?php echo $filepath, "\n"; ?>
|
||||||
Line Number: <?php echo $line; ?>
|
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:
|
Backtrace:
|
||||||
<?php foreach (debug_backtrace() as $error) : ?>
|
<?php foreach (debug_backtrace() as $error): ?>
|
||||||
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0) : ?>
|
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0): ?>
|
||||||
File: <?php echo $error['file'], "\n"; ?>
|
File: <?php echo $error['file'], "\n"; ?>
|
||||||
Line: <?php echo $error['line'], "\n"; ?>
|
Line: <?php echo $error['line'], "\n"; ?>
|
||||||
Function: <?php echo $error['function'], "\n\n"; ?>
|
Function: <?php echo $error['function'], "\n\n"; ?>
|
||||||
<?php endif ?>
|
<?php endif ?>
|
||||||
<?php endforeach ?>
|
<?php endforeach ?>
|
||||||
|
|
||||||
<?php endif ?>
|
<?php endif ?>
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
?><!DOCTYPE html>
|
?><!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
?><!DOCTYPE html>
|
?><!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<?php
|
<?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;">
|
<div style="border:1px solid #990000;padding-left:20px;margin:0 0 10px 0;">
|
||||||
|
@ -11,10 +11,13 @@ defined('BASEPATH') or exit('No direct script access allowed');
|
||||||
<p>Filename: <?php echo $exception->getFile(); ?></p>
|
<p>Filename: <?php echo $exception->getFile(); ?></p>
|
||||||
<p>Line Number: <?php echo $exception->getLine(); ?></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>
|
<p>Backtrace:</p>
|
||||||
<?php foreach ($exception->getTrace() as $error) : ?>
|
<?php foreach ($exception->getTrace() as $error): ?>
|
||||||
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0) : ?>
|
|
||||||
|
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0): ?>
|
||||||
|
|
||||||
<p style="margin-left:10px">
|
<p style="margin-left:10px">
|
||||||
File: <?php echo $error['file']; ?><br />
|
File: <?php echo $error['file']; ?><br />
|
||||||
Line: <?php echo $error['line']; ?><br />
|
Line: <?php echo $error['line']; ?><br />
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
?><!DOCTYPE html>
|
?><!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<?php
|
<?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;">
|
<div style="border:1px solid #990000;padding-left:20px;margin:0 0 10px 0;">
|
||||||
|
@ -11,10 +11,13 @@ defined('BASEPATH') or exit('No direct script access allowed');
|
||||||
<p>Filename: <?php echo $filepath; ?></p>
|
<p>Filename: <?php echo $filepath; ?></p>
|
||||||
<p>Line Number: <?php echo $line; ?></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>
|
<p>Backtrace:</p>
|
||||||
<?php foreach (debug_backtrace() as $error) : ?>
|
<?php foreach (debug_backtrace() as $error): ?>
|
||||||
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0) : ?>
|
|
||||||
|
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0): ?>
|
||||||
|
|
||||||
<p style="margin-left:10px">
|
<p style="margin-left:10px">
|
||||||
File: <?php echo $error['file'] ?><br />
|
File: <?php echo $error['file'] ?><br />
|
||||||
Line: <?php echo $error['line'] ?><br />
|
Line: <?php echo $error['line'] ?><br />
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -16,42 +16,42 @@
|
||||||
<h4><?php echo $form->description; ?></h4>
|
<h4><?php echo $form->description; ?></h4>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<?php foreach ($questions as $question) : ?>
|
<?php foreach ($questions as $question): ?>
|
||||||
<div class="form-section">
|
<div class="form-section">
|
||||||
<div class="question-section">
|
<div class="question-section">
|
||||||
<p class="question-label"><?php echo $question->text; ?></p>
|
<p class="question-label"><?php echo $question->text; ?></p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<?php if ($question->type == 'multiple-choice') : ?>
|
<?php if ($question->type == 'multiple-choice'): ?>
|
||||||
<div class="options-container">
|
<div class="options-container">
|
||||||
<?php foreach ($question->options as $option) : ?>
|
<?php foreach ($question->options as $option): ?>
|
||||||
<div class="option">
|
<div class="option">
|
||||||
<input type="radio" name="option-<?php echo $question->id; ?>" disabled>
|
<input type="radio" name="option-<?php echo $question->id; ?>" disabled>
|
||||||
<label><?php echo $option->option_text; ?></label>
|
<label><?php echo $option->option_text; ?></label>
|
||||||
</div>
|
</div>
|
||||||
<?php endforeach; ?>
|
<?php endforeach; ?>
|
||||||
</div>
|
</div>
|
||||||
<?php elseif ($question->type == 'checkboxes') : ?>
|
<?php elseif ($question->type == 'checkboxes'): ?>
|
||||||
<div class="options-container">
|
<div class="options-container">
|
||||||
<?php foreach ($question->options as $option) : ?>
|
<?php foreach ($question->options as $option): ?>
|
||||||
<div class="option">
|
<div class="option">
|
||||||
<input type="checkbox" name="option-<?php echo $question->id; ?>" disabled>
|
<input type="checkbox" name="option-<?php echo $question->id; ?>" disabled>
|
||||||
<label><?php echo $option->option_text; ?></label>
|
<label><?php echo $option->option_text; ?></label>
|
||||||
</div>
|
</div>
|
||||||
<?php endforeach; ?>
|
<?php endforeach; ?>
|
||||||
</div>
|
</div>
|
||||||
<?php elseif ($question->type == 'short-answer') : ?>
|
<?php elseif ($question->type == 'short-answer'): ?>
|
||||||
<div class="options-container">
|
<div class="options-container">
|
||||||
<input type="text" class="form-control" placeholder="Short answer text" disabled>
|
<input type="text" class="form-control" placeholder="Short answer text" disabled>
|
||||||
</div>
|
</div>
|
||||||
<?php elseif ($question->type == 'paragraph') : ?>
|
<?php elseif ($question->type == 'paragraph'): ?>
|
||||||
<div class="options-container">
|
<div class="options-container">
|
||||||
<textarea class="form-control" placeholder="Paragraph text" disabled></textarea>
|
<textarea class="form-control" placeholder="Paragraph text" disabled></textarea>
|
||||||
</div>
|
</div>
|
||||||
<?php elseif ($question->type == 'dropdown') : ?>
|
<?php elseif ($question->type == 'dropdown'): ?>
|
||||||
<div class="options-container">
|
<div class="options-container">
|
||||||
<select class="form-control" disabled>
|
<select class="form-control" disabled>
|
||||||
<?php foreach ($question->options as $option) : ?>
|
<?php foreach ($question->options as $option): ?>
|
||||||
<option><?php echo $option->option_text; ?></option>
|
<option><?php echo $option->option_text; ?></option>
|
||||||
<?php endforeach; ?>
|
<?php endforeach; ?>
|
||||||
</select>
|
</select>
|
||||||
|
@ -59,7 +59,7 @@
|
||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
</div>
|
</div>
|
||||||
<?php endforeach; ?>
|
<?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>
|
<br>
|
||||||
</div>
|
</div>
|
||||||
</body>
|
</body>
|
||||||
|
|
|
@ -35,42 +35,42 @@
|
||||||
<br>
|
<br>
|
||||||
<h4><?php echo $form->description; ?></h4>
|
<h4><?php echo $form->description; ?></h4>
|
||||||
</div>
|
</div>
|
||||||
<?php foreach ($questions as $question) : ?>
|
<?php foreach ($questions as $question): ?>
|
||||||
<div class="form-section">
|
<div class="form-section">
|
||||||
<div class="question-section">
|
<div class="question-section">
|
||||||
<p class="question-label"><?php echo $question->text; ?></p>
|
<p class="question-label"><?php echo $question->text; ?></p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<?php if ($question->type == 'multiple-choice') : ?>
|
<?php if ($question->type == 'multiple-choice'): ?>
|
||||||
<div class="options-container">
|
<div class="options-container">
|
||||||
<?php foreach ($question->options as $option) : ?>
|
<?php foreach ($question->options as $option): ?>
|
||||||
<div class="option">
|
<div class="option">
|
||||||
<input type="radio" name="option-<?php echo $question->id; ?>" disabled>
|
<input type="radio" name="option-<?php echo $question->id; ?>" disabled>
|
||||||
<label><?php echo $option->option_text; ?></label>
|
<label><?php echo $option->option_text; ?></label>
|
||||||
</div>
|
</div>
|
||||||
<?php endforeach; ?>
|
<?php endforeach; ?>
|
||||||
</div>
|
</div>
|
||||||
<?php elseif ($question->type == 'checkboxes') : ?>
|
<?php elseif ($question->type == 'checkboxes'): ?>
|
||||||
<div class="options-container">
|
<div class="options-container">
|
||||||
<?php foreach ($question->options as $option) : ?>
|
<?php foreach ($question->options as $option): ?>
|
||||||
<div class="option">
|
<div class="option">
|
||||||
<input type="checkbox" name="option-<?php echo $question->id; ?>" disabled>
|
<input type="checkbox" name="option-<?php echo $question->id; ?>" disabled>
|
||||||
<label><?php echo $option->option_text; ?></label>
|
<label><?php echo $option->option_text; ?></label>
|
||||||
</div>
|
</div>
|
||||||
<?php endforeach; ?>
|
<?php endforeach; ?>
|
||||||
</div>
|
</div>
|
||||||
<?php elseif ($question->type == 'short-answer') : ?>
|
<?php elseif ($question->type == 'short-answer'): ?>
|
||||||
<div class="options-container">
|
<div class="options-container">
|
||||||
<input type="text" class="form-control" placeholder="Short answer text" disabled>
|
<input type="text" class="form-control" placeholder="Short answer text" disabled>
|
||||||
</div>
|
</div>
|
||||||
<?php elseif ($question->type == 'paragraph') : ?>
|
<?php elseif ($question->type == 'paragraph'): ?>
|
||||||
<div class="options-container">
|
<div class="options-container">
|
||||||
<textarea class="form-control" placeholder="Paragraph text" disabled></textarea>
|
<textarea class="form-control" placeholder="Paragraph text" disabled></textarea>
|
||||||
</div>
|
</div>
|
||||||
<?php elseif ($question->type == 'dropdown') : ?>
|
<?php elseif ($question->type == 'dropdown'): ?>
|
||||||
<div class="options-container">
|
<div class="options-container">
|
||||||
<select class="form-control" disabled>
|
<select class="form-control" disabled>
|
||||||
<?php foreach ($question->options as $option) : ?>
|
<?php foreach ($question->options as $option): ?>
|
||||||
<option><?php echo $option->option_text; ?></option>
|
<option><?php echo $option->option_text; ?></option>
|
||||||
<?php endforeach; ?>
|
<?php endforeach; ?>
|
||||||
</select>
|
</select>
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
<!doctype html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<title>403 Forbidden</title>
|
<title>403 Forbidden</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<p>Directory access is forbidden.</p>
|
|
||||||
</body>
|
<p>Directory access is forbidden.</p>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
<div class="col-md-12 mt-4">
|
<div class="col-md-12 mt-4">
|
||||||
<div class="card">
|
<div class="card">
|
||||||
<div class="card-header">
|
<div class="card-header">
|
||||||
<?php if ($this->session->flashdata('status')) : ?>
|
<?php if ($this->session->flashdata('status')): ?>
|
||||||
<div class="alert alert-success">
|
<div class="alert alert-success">
|
||||||
<?= $this->session->flashdata('status'); ?>
|
<?= $this->session->flashdata('status'); ?>
|
||||||
</div>
|
</div>
|
||||||
|
@ -15,7 +15,7 @@
|
||||||
<table id="basetable1" class="table table-bordered">
|
<table id="basetable1" class="table table-bordered">
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th>Serial No.</th>
|
<th>Responses</th>
|
||||||
<th>Title</th>
|
<th>Title</th>
|
||||||
<th>Response Link</th>
|
<th>Response Link</th>
|
||||||
<th>Status</th>
|
<th>Status</th>
|
||||||
|
@ -24,7 +24,7 @@
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
<?php $serialNumber = 1;
|
<?php $serialNumber = 1;
|
||||||
foreach ($forms as $row) : ?>
|
foreach ($forms as $row): ?>
|
||||||
<tr>
|
<tr>
|
||||||
<td><?php echo $serialNumber++; ?></td>
|
<td><?php echo $serialNumber++; ?></td>
|
||||||
<td class="title-column"><?php echo $row->title; ?></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="submitted-at">Submitted At: <?php echo $response->submitted_at; ?></p>
|
||||||
<p class="user-email">User Email: <?php echo $response->email; ?></p>
|
<p class="user-email">User Email: <?php echo $response->email; ?></p>
|
||||||
</div>
|
</div>
|
||||||
<?php foreach ($questions_and_answers as $question) : ?>
|
<?php foreach ($questions_and_answers as $question): ?>
|
||||||
<div class="form-section">
|
<div class="form-section">
|
||||||
<div class="question-section">
|
<div class="question-section">
|
||||||
<p class="form-control question-label"><?php echo $question->question_text; ?></p>
|
<p class="form-control question-label"><?php echo $question->question_text; ?></p>
|
||||||
|
|
|
@ -106,41 +106,41 @@
|
||||||
<h4><?php echo $form->description; ?></h4>
|
<h4><?php echo $form->description; ?></h4>
|
||||||
</div> -->
|
</div> -->
|
||||||
|
|
||||||
<?php if (isset($message)) : ?>
|
<?php if (isset($message)): ?>
|
||||||
<div id="popup-message" class="popup-message">
|
<div id="popup-message" class="popup-message">
|
||||||
<p><?php echo $message; ?></p>
|
<p><?php echo $message; ?></p>
|
||||||
<button onclick="closePopup()">Close</button>
|
<button onclick="closePopup()">Close</button>
|
||||||
</div>
|
</div>
|
||||||
<?php else : ?>
|
<?php else: ?>
|
||||||
<form action="<?php echo base_url('response_submit/submit_form'); ?>" method="post" onsubmit="return validateForm();">
|
<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; ?>">
|
<input type="hidden" name="form_id" value="<?php echo $form->id; ?>">
|
||||||
<div class="form-section">
|
<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; ?>">
|
<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; ?>][question_id]" value="<?php echo $question->id; ?>">
|
||||||
<input type="hidden" name="responses[<?php echo $question->id; ?>][form_id]" value="<?php echo $form->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>
|
<label class="<?php echo $question->is_required ? 'required-field' : ''; ?>"><?php echo $question->text; ?></label>
|
||||||
<?php if ($question->type == 'multiple-choice') : ?>
|
<?php if ($question->type == 'multiple-choice'): ?>
|
||||||
<?php foreach ($question->options as $option) : ?>
|
<?php foreach ($question->options as $option): ?>
|
||||||
<div class="option">
|
<div class="option">
|
||||||
<input type="radio" name="responses[<?php echo $question->id; ?>][options][]" value="<?php echo $option->option_text; ?>">
|
<input type="radio" name="responses[<?php echo $question->id; ?>][options][]" value="<?php echo $option->option_text; ?>">
|
||||||
<label><?php echo $option->option_text; ?></label>
|
<label><?php echo $option->option_text; ?></label>
|
||||||
</div>
|
</div>
|
||||||
<?php endforeach; ?>
|
<?php endforeach; ?>
|
||||||
<?php elseif ($question->type == 'checkboxes') : ?>
|
<?php elseif ($question->type == 'checkboxes'): ?>
|
||||||
<?php foreach ($question->options as $option) : ?>
|
<?php foreach ($question->options as $option): ?>
|
||||||
<div class="option">
|
<div class="option">
|
||||||
<input type="checkbox" name="responses[<?php echo $question->id; ?>][options][]" value="<?php echo $option->option_text; ?>">
|
<input type="checkbox" name="responses[<?php echo $question->id; ?>][options][]" value="<?php echo $option->option_text; ?>">
|
||||||
<label><?php echo $option->option_text; ?></label>
|
<label><?php echo $option->option_text; ?></label>
|
||||||
</div>
|
</div>
|
||||||
<?php endforeach; ?>
|
<?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">
|
<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>
|
<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]">
|
<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>
|
<option value="<?php echo $option->option_text; ?>"><?php echo $option->option_text; ?></option>
|
||||||
<?php endforeach; ?>
|
<?php endforeach; ?>
|
||||||
</select>
|
</select>
|
||||||
|
|
|
@ -1,17 +0,0 @@
|
||||||
<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>
|
|
|
@ -1,38 +0,0 @@
|
||||||
<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="col-md-12 mt-4">
|
||||||
<div class="card">
|
<div class="card">
|
||||||
<div class="card-header">
|
<div class="card-header">
|
||||||
<?php if ($this->session->flashdata('status')) : ?>
|
<?php if ($this->session->flashdata('status')): ?>
|
||||||
<div class="alert alert-success">
|
<div class="alert alert-success">
|
||||||
<?= $this->session->flashdata('status'); ?>
|
<?= $this->session->flashdata('status'); ?>
|
||||||
</div>
|
</div>
|
||||||
|
@ -36,7 +36,7 @@
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
<?php foreach ($responses as $response) : ?>
|
<?php foreach ($responses as $response): ?>
|
||||||
<tr>
|
<tr>
|
||||||
<td class="username-column"><?php echo $response->username; ?></td>
|
<td class="username-column"><?php echo $response->username; ?></td>
|
||||||
<td><?php echo $response->submitted_at; ?></td>
|
<td><?php echo $response->submitted_at; ?></td>
|
||||||
|
|
|
@ -19,16 +19,16 @@
|
||||||
<style>
|
<style>
|
||||||
.navbar-custom .navbar-brand,
|
.navbar-custom .navbar-brand,
|
||||||
.navbar-custom .navbar-nav .nav-link {
|
.navbar-custom .navbar-nav .nav-link {
|
||||||
color: white !important;
|
color: white !important; /* Forces the text color to be white */
|
||||||
text-decoration: none !important;
|
text-decoration: none !important; /* Ensures no underline */
|
||||||
background: none !important;
|
background: none !important; /* Ensures no background color */
|
||||||
}
|
}
|
||||||
|
|
||||||
.navbar-custom .navbar-brand:hover,
|
.navbar-custom .navbar-brand:hover,
|
||||||
.navbar-custom .navbar-nav .nav-link:hover {
|
.navbar-custom .navbar-nav .nav-link:hover {
|
||||||
color: white !important;
|
color: white !important; /* Keeps text color white on hover */
|
||||||
text-decoration: none !important;
|
text-decoration: none !important; /* Ensures no underline on hover */
|
||||||
background: none !important;
|
background: none !important; /* Ensures no background color on hover */
|
||||||
}
|
}
|
||||||
.title-column {
|
.title-column {
|
||||||
color: darkblue;
|
color: darkblue;
|
||||||
|
@ -114,7 +114,7 @@
|
||||||
|
|
||||||
<nav class="navbar navbar-inverse" style="background-color: rgb(103, 58, 183);">
|
<nav class="navbar navbar-inverse" style="background-color: rgb(103, 58, 183);">
|
||||||
<div class="container" 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">
|
<div class="navbar-header">
|
||||||
<a class="navbar-brand" href="<?php echo base_url(); ?>">Google Forms</a>
|
<a class="navbar-brand" href="<?php echo base_url(); ?>">Google Forms</a>
|
||||||
</div>
|
</div>
|
||||||
|
@ -122,18 +122,18 @@
|
||||||
|
|
||||||
<div id="navbar">
|
<div id="navbar">
|
||||||
<ul class="nav navbar-nav">
|
<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(); ?>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; ?>
|
<?php endif; ?>
|
||||||
</ul>
|
</ul>
|
||||||
<ul class="nav navbar-nav navbar-right">
|
<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/login">Login</a></li>
|
||||||
<li><a href="<?php echo base_url(); ?>users/register">Register</a></li>
|
<li><a href="<?php echo base_url(); ?>users/register">Register</a></li>
|
||||||
<?php endif; ?>
|
<?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(); ?>title">Create Form</a></li>
|
||||||
<li><a href="<?php echo base_url(); ?>users/logout">Logout</a></li>
|
<li><a href="<?php echo base_url(); ?>users/logout">Logout</a></li>
|
||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
|
@ -142,19 +142,19 @@
|
||||||
</div>
|
</div>
|
||||||
</nav>
|
</nav>
|
||||||
<div class="container">
|
<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>
|
<p class="alert alert-success flash-message" id="flash-user-registered"><?php echo $this->session->flashdata('user_registered'); ?></p>
|
||||||
<?php endif; ?>
|
<?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>
|
<p class="alert alert-danger flash-message" id="flash-login-failed"><?php echo $this->session->flashdata('login_failed'); ?></p>
|
||||||
<?php endif; ?>
|
<?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>
|
<p class="alert alert-success flash-message" id="flash-user-loggedin"><?php echo $this->session->flashdata('user_loggedin'); ?></p>
|
||||||
<?php endif; ?>
|
<?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>
|
<p class="alert alert-success flash-message" id="flash-user-loggedout"><?php echo $this->session->flashdata('user_loggedout'); ?></p>
|
||||||
<?php endif; ?>
|
<?php endif; ?>
|
||||||
</div>
|
</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="row">
|
||||||
<div class="col-md-4 col-md-offset-4">
|
<div class="col-md-4 col-md-offset-4">
|
||||||
<h1 class="text-center"><?= $title; ?></h1>
|
<h1 class="text-center"><?= $title; ?></h1>
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
<?php
|
<?php
|
||||||
defined('BASEPATH') or exit('No direct script access allowed');
|
defined('BASEPATH') OR exit('No direct script access allowed');
|
||||||
?><!DOCTYPE html>
|
?><!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
|
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
@ -3,6 +3,7 @@
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
margin-bottom: 10px;
|
margin-bottom: 10px;
|
||||||
margin-top: -56px;
|
margin-top: -56px;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.form-title,
|
.form-title,
|
||||||
|
@ -31,6 +32,7 @@
|
||||||
opacity: 0.5; /* Make the icon transparent */
|
opacity: 0.5; /* Make the icon transparent */
|
||||||
margin-right: 10px; /* Space between icon and option box */
|
margin-right: 10px; /* Space between icon and option box */
|
||||||
font-size: 10px; /* Adjust icon size here */
|
font-size: 10px; /* Adjust icon size here */
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.option .form-control.option-label {
|
.option .form-control.option-label {
|
||||||
|
|
|
@ -34,8 +34,7 @@ body {
|
||||||
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
|
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
|
||||||
margin-bottom: 20px;
|
margin-bottom: 20px;
|
||||||
}
|
}
|
||||||
.form-header h2,
|
.form-header h2, .form-header h4 {
|
||||||
.form-header h4 {
|
|
||||||
margin: 0;
|
margin: 0;
|
||||||
text-align: left;
|
text-align: left;
|
||||||
}
|
}
|
||||||
|
@ -63,12 +62,12 @@ body {
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
}
|
}
|
||||||
.option input[type='checkbox'] {
|
.option input[type="checkbox"] {
|
||||||
margin-right: 10px;
|
margin-right: 10px;
|
||||||
width: 16px; /* Adjust size of checkbox */
|
width: 16px; /* Adjust size of checkbox */
|
||||||
height: 16px; /* Adjust size of checkbox */
|
height: 16px; /* Adjust size of checkbox */
|
||||||
}
|
}
|
||||||
.option input[type='radio'] {
|
.option input[type="radio"] {
|
||||||
margin-right: 10px;
|
margin-right: 10px;
|
||||||
width: 16px; /* Adjust size of radio button */
|
width: 16px; /* Adjust size of radio button */
|
||||||
height: 16px; /* Adjust size of radio button */
|
height: 16px; /* Adjust size of radio button */
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
|
||||||
.navbar-container {
|
.navbar-container {
|
||||||
max-width: 100%;
|
max-width: 100%;
|
||||||
margin: 0 auto;
|
margin: 0 auto;
|
||||||
|
@ -22,6 +23,7 @@
|
||||||
padding: 15px 10px;
|
padding: 15px 10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
.navbar-custom .navbar-nav {
|
.navbar-custom .navbar-nav {
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
@ -52,6 +54,8 @@
|
||||||
margin: 0 10px;
|
margin: 0 10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#add-section-btn {
|
#add-section-btn {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -74,6 +74,8 @@ body {
|
||||||
flex: 1; /* Allow items to grow/shrink to fill space */
|
flex: 1; /* Allow items to grow/shrink to fill space */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#submit-btn {
|
#submit-btn {
|
||||||
margin-top: 20px;
|
margin-top: 20px;
|
||||||
float: left;
|
float: left;
|
||||||
|
@ -94,36 +96,36 @@ body {
|
||||||
padding: 10px;
|
padding: 10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-date {
|
.post-date{
|
||||||
background: #f4f4f4;
|
background: #f4f4f4;
|
||||||
padding: 4px;
|
padding: 4px;
|
||||||
margin: 3px 0;
|
margin: 3px 0;
|
||||||
display: block;
|
display: block;
|
||||||
}
|
}
|
||||||
|
|
||||||
.post-thumb {
|
.post-thumb{
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
|
|
||||||
.pagination-link {
|
.pagination-link{
|
||||||
margin: 30px 0;
|
margin: 30px 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
.pagination-links strong {
|
.pagination-links strong{
|
||||||
padding: 8px 13px;
|
padding: 8px 13px;
|
||||||
margin: 5px;
|
margin: 5px;
|
||||||
background: #f4f4f4;
|
background: #f4f4f4;
|
||||||
border: 1px #ccc solid;
|
border: 1px #ccc solid;
|
||||||
}
|
}
|
||||||
|
|
||||||
a.pagination-link {
|
a.pagination-link{
|
||||||
padding: 8px 13px;
|
padding: 8px 13px;
|
||||||
margin: 5px;
|
margin: 5px;
|
||||||
background: #f4f4f4;
|
background: #f4f4f4;
|
||||||
border: 1px #ccc solid;
|
border: 1px #ccc solid;
|
||||||
}
|
}
|
||||||
|
|
||||||
.cat-delete {
|
.cat-delete{
|
||||||
display: inline;
|
display: inline;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -131,7 +133,8 @@ a.pagination-link {
|
||||||
border: 1px solid #3333336c; /* Darker border color */
|
border: 1px solid #3333336c; /* Darker border color */
|
||||||
}
|
}
|
||||||
|
|
||||||
#basetable1 th,
|
#basetable1 th, #basetable1 td {
|
||||||
#basetable1 td {
|
|
||||||
border: 1px solid #3333336c; /* Darker border color for table cells */
|
border: 1px solid #3333336c; /* Darker border color for table cells */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,9 +1,5 @@
|
||||||
body {
|
body { background-color: rgb(240, 235, 248); }
|
||||||
background-color: rgb(240, 235, 248);
|
.container { margin-top: 30px; }
|
||||||
}
|
|
||||||
.container {
|
|
||||||
margin-top: 30px;
|
|
||||||
}
|
|
||||||
.form-header {
|
.form-header {
|
||||||
background-color: white;
|
background-color: white;
|
||||||
padding: 20px;
|
padding: 20px;
|
||||||
|
@ -17,12 +13,8 @@ body {
|
||||||
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
|
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
|
||||||
margin-bottom: 20px;
|
margin-bottom: 20px;
|
||||||
}
|
}
|
||||||
.form-header h2 {
|
.form-header h2 { margin: 0; }
|
||||||
margin: 0;
|
.form-header h4 { color: rgba(0, 0, 0, 0.5); }
|
||||||
}
|
|
||||||
.form-header h4 {
|
|
||||||
color: rgba(0, 0, 0, 0.5);
|
|
||||||
}
|
|
||||||
.form-section {
|
.form-section {
|
||||||
background-color: white;
|
background-color: white;
|
||||||
width: 56%;
|
width: 56%;
|
||||||
|
@ -44,8 +36,8 @@ body {
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
}
|
}
|
||||||
.option input[type='radio'],
|
.option input[type="radio"],
|
||||||
.option input[type='checkbox'] {
|
.option input[type="checkbox"] {
|
||||||
margin-right: 10px;
|
margin-right: 10px;
|
||||||
}
|
}
|
||||||
.required-field::after {
|
.required-field::after {
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
|
||||||
body {
|
body {
|
||||||
background-color: rgb(240, 235, 248);
|
background-color: rgb(240, 235, 248);
|
||||||
font-family: Arial, sans-serif;
|
font-family: Arial, sans-serif;
|
||||||
|
@ -12,11 +13,12 @@ body {
|
||||||
}
|
}
|
||||||
/* Navbar custom styles */
|
/* Navbar custom styles */
|
||||||
|
|
||||||
|
|
||||||
.container {
|
.container {
|
||||||
position: relative;
|
position: relative;
|
||||||
margin-top: 30px;
|
margin-top: 30px;
|
||||||
}
|
}
|
||||||
.form_container_top {
|
.form_container_top{
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
margin-top: 10px;
|
margin-top: 10px;
|
||||||
font-family: Arial, Helvetica, sans-serif;
|
font-family: Arial, Helvetica, sans-serif;
|
||||||
|
@ -29,7 +31,7 @@ body {
|
||||||
border-bottom: 1px solid #f4f4f9;
|
border-bottom: 1px solid #f4f4f9;
|
||||||
color: black;
|
color: black;
|
||||||
height: 20px;
|
height: 20px;
|
||||||
}
|
}
|
||||||
/* Form header styles */
|
/* Form header styles */
|
||||||
.form-header {
|
.form-header {
|
||||||
background-color: white;
|
background-color: white;
|
||||||
|
@ -76,8 +78,10 @@ body {
|
||||||
z-index: 1000;
|
z-index: 1000;
|
||||||
border-radius: 50%;
|
border-radius: 50%;
|
||||||
background-color: rgb(103, 58, 183);
|
background-color: rgb(103, 58, 183);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
.form-section {
|
.form-section {
|
||||||
background-color: white;
|
background-color: white;
|
||||||
width: 56%;
|
width: 56%;
|
||||||
|
@ -121,6 +125,7 @@ body {
|
||||||
border-radius: 4px;
|
border-radius: 4px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
.delete-section-icon {
|
.delete-section-icon {
|
||||||
flex: 0.1;
|
flex: 0.1;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
|
@ -147,8 +152,8 @@ body {
|
||||||
margin-bottom: 5px;
|
margin-bottom: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.option input[type='radio'],
|
.option input[type="radio"],
|
||||||
.option input[type='checkbox'] {
|
.option input[type="checkbox"] {
|
||||||
margin-right: 10px;
|
margin-right: 10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -164,13 +169,16 @@ body {
|
||||||
text-align: left;
|
text-align: left;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
.add-option-btn {
|
.add-option-btn {
|
||||||
background-color: rgb(66, 133, 244);
|
background-color: rgb(66, 133, 244);
|
||||||
/* color: rgb(66, 133, 244); */
|
/* color: rgb(66, 133, 244); */
|
||||||
margin-top: 11px;
|
margin-top: 11px;
|
||||||
font-size: 0.8em;
|
font-size: 0.8em;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
.ui-state-highlight {
|
.ui-state-highlight {
|
||||||
background-color: transparent !important;
|
background-color: transparent !important;
|
||||||
border: none !important;
|
border: none !important;
|
||||||
|
@ -202,19 +210,19 @@ body {
|
||||||
right: 0;
|
right: 0;
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
background-color: #ccc;
|
background-color: #ccc;
|
||||||
transition: 0.4s;
|
transition: .4s;
|
||||||
border-radius: 34px;
|
border-radius: 34px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.slider:before {
|
.slider:before {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
content: '';
|
content: "";
|
||||||
height: 14px;
|
height: 14px;
|
||||||
width: 14px;
|
width: 14px;
|
||||||
left: 3px;
|
left: 3px;
|
||||||
bottom: 3px;
|
bottom: 3px;
|
||||||
background-color: white;
|
background-color: white;
|
||||||
transition: 0.4s;
|
transition: .4s;
|
||||||
border-radius: 50%;
|
border-radius: 50%;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -225,8 +233,8 @@ input:checked + .slider {
|
||||||
input:checked + .slider:before {
|
input:checked + .slider:before {
|
||||||
transform: translateX(14px);
|
transform: translateX(14px);
|
||||||
}
|
}
|
||||||
.body_header_bg {
|
.body_header_bg{
|
||||||
background-color: rgb(240, 235, 248);
|
background-color: rgb(240,235,248);
|
||||||
}
|
}
|
||||||
table a:not(.btn) {
|
table a:not(.btn) {
|
||||||
color: blue !important;
|
color: blue !important;
|
||||||
|
@ -251,11 +259,11 @@ table a:not(.btn):hover {
|
||||||
|
|
||||||
/* Assuming you have a stylesheet named styles.css */
|
/* Assuming you have a stylesheet named styles.css */
|
||||||
.btn.btn-primary.btn-block {
|
.btn.btn-primary.btn-block {
|
||||||
margin-top: 20px;
|
margin-top: 20px;
|
||||||
position: relative;
|
position: relative;
|
||||||
background-color: rgb(103, 58, 183);
|
background-color: rgb(103, 58, 183);
|
||||||
border-color: rgb(103, 58, 183);
|
border-color: rgb(103, 58, 183);
|
||||||
color: white;
|
color: white;
|
||||||
}
|
}
|
||||||
.flash-message {
|
.flash-message {
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
|
@ -269,3 +277,4 @@ table a:not(.btn):hover {
|
||||||
margin-top: 5px;
|
margin-top: 5px;
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -135,8 +135,8 @@ body {
|
||||||
margin-bottom: 5px;
|
margin-bottom: 5px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.option input[type='radio'],
|
.option input[type="radio"],
|
||||||
.option input[type='checkbox'] {
|
.option input[type="checkbox"] {
|
||||||
margin-right: 10px;
|
margin-right: 10px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -191,19 +191,19 @@ body {
|
||||||
right: 0;
|
right: 0;
|
||||||
bottom: 0;
|
bottom: 0;
|
||||||
background-color: #ccc;
|
background-color: #ccc;
|
||||||
transition: 0.4s;
|
transition: .4s;
|
||||||
border-radius: 34px;
|
border-radius: 34px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.slider:before {
|
.slider:before {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
content: '';
|
content: "";
|
||||||
height: 14px;
|
height: 14px;
|
||||||
width: 14px;
|
width: 14px;
|
||||||
left: 3px;
|
left: 3px;
|
||||||
bottom: 3px;
|
bottom: 3px;
|
||||||
background-color: white;
|
background-color: white;
|
||||||
transition: 0.4s;
|
transition: .4s;
|
||||||
border-radius: 50%;
|
border-radius: 50%;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,50 +0,0 @@
|
||||||
// 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(); ?>';
|
var base_url = '<?php echo base_url(); ?>';
|
||||||
|
|
||||||
// Add section button functionality
|
// Add section button functionality
|
||||||
$('#add-section-btn').on('click', function () {
|
$('#add-section-btn').on('click', function() {
|
||||||
var sectionHtml = `
|
var sectionHtml = `
|
||||||
<div class="form-section" data-type="">
|
<div class="form-section" data-type="">
|
||||||
<div class="header-row">
|
<div class="header-row">
|
||||||
|
@ -21,12 +21,14 @@ $(document).ready(function () {
|
||||||
<span class="delete-section-icon"><i class="fas fa-trash-alt"></i></span>
|
<span class="delete-section-icon"><i class="fas fa-trash-alt"></i></span>
|
||||||
</div>
|
</div>
|
||||||
<div class="options-container"></div>
|
<div class="options-container"></div>
|
||||||
<button class="btn btn-secondary add-option-btn" style="display: none;">Add Option</button></div>
|
<button class="btn btn-secondary add-option-btn" style="display: none;">Add Option</button>
|
||||||
`; $('#form-container').append(sectionHtml);
|
</div>
|
||||||
|
`;
|
||||||
|
$('#form-container').append(sectionHtml);
|
||||||
});
|
});
|
||||||
|
|
||||||
// Add option button functionality
|
// Add option button functionality
|
||||||
$(document).on('click', '.add-option-btn', function () {
|
$(document).on('click', '.add-option-btn', function() {
|
||||||
var optionHtml = `
|
var optionHtml = `
|
||||||
<div class="option">
|
<div class="option">
|
||||||
<input type="text" class="form-control option-label" placeholder="Option">
|
<input type="text" class="form-control option-label" placeholder="Option">
|
||||||
|
@ -37,17 +39,17 @@ $(document).ready(function () {
|
||||||
});
|
});
|
||||||
|
|
||||||
// Delete option functionality
|
// Delete option functionality
|
||||||
$(document).on('click', '.delete-option-icon', function () {
|
$(document).on('click', '.delete-option-icon', function() {
|
||||||
$(this).parent().remove();
|
$(this).parent().remove();
|
||||||
});
|
});
|
||||||
|
|
||||||
// Delete section functionality
|
// Delete section functionality
|
||||||
$(document).on('click', '.delete-section-icon', function () {
|
$(document).on('click', '.delete-section-icon', function() {
|
||||||
$(this).closest('.form-section').remove();
|
$(this).closest('.form-section').remove();
|
||||||
});
|
});
|
||||||
|
|
||||||
// Show/Hide "Add Option" button based on question type
|
// 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 type = $(this).val();
|
||||||
var $section = $(this).closest('.form-section');
|
var $section = $(this).closest('.form-section');
|
||||||
if (type === 'multiple-choice' || type === 'checkboxes' || type === 'dropdown') {
|
if (type === 'multiple-choice' || type === 'checkboxes' || type === 'dropdown') {
|
||||||
|
@ -58,9 +60,9 @@ $(document).ready(function () {
|
||||||
}).trigger('change'); // Trigger change to apply to existing sections
|
}).trigger('change'); // Trigger change to apply to existing sections
|
||||||
|
|
||||||
// Submit button functionality
|
// Submit button functionality
|
||||||
$('#submit-btn').on('click', function () {
|
$('#submit-btn').on('click', function() {
|
||||||
var formData = collectFormData();
|
var formData = collectFormData();
|
||||||
formData['form_id'] = <? php echo $form['id']; ?>;
|
formData['form_id'] = <?php echo $form['id']; ?>;
|
||||||
|
|
||||||
let validation = validateFormData(formData);
|
let validation = validateFormData(formData);
|
||||||
if (!validation.isValid) {
|
if (!validation.isValid) {
|
||||||
|
@ -73,7 +75,7 @@ $(document).ready(function () {
|
||||||
type: 'POST',
|
type: 'POST',
|
||||||
data: { formData: formData },
|
data: { formData: formData },
|
||||||
dataType: 'JSON',
|
dataType: 'JSON',
|
||||||
success: function (response) {
|
success: function(response) {
|
||||||
if (response.status === 'success') {
|
if (response.status === 'success') {
|
||||||
alert('Form updated successfully!');
|
alert('Form updated successfully!');
|
||||||
window.location.href = base_url + 'Form_controller/index_forms_draft';
|
window.location.href = base_url + 'Form_controller/index_forms_draft';
|
||||||
|
@ -81,7 +83,7 @@ $(document).ready(function () {
|
||||||
alert(response.message);
|
alert(response.message);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
error: function (error) {
|
error: function(error) {
|
||||||
alert('Error updating form!');
|
alert('Error updating form!');
|
||||||
console.log(error);
|
console.log(error);
|
||||||
}
|
}
|
||||||
|
@ -96,7 +98,7 @@ $(document).ready(function () {
|
||||||
questions: []
|
questions: []
|
||||||
};
|
};
|
||||||
|
|
||||||
$('.form-section').each(function () {
|
$('.form-section').each(function() {
|
||||||
var questionData = {
|
var questionData = {
|
||||||
id: $(this).data('index'),
|
id: $(this).data('index'),
|
||||||
text: $(this).find('.untitled-question').val(),
|
text: $(this).find('.untitled-question').val(),
|
||||||
|
@ -105,7 +107,7 @@ $(document).ready(function () {
|
||||||
options: []
|
options: []
|
||||||
};
|
};
|
||||||
|
|
||||||
$(this).find('.option-label').each(function () {
|
$(this).find('.option-label').each(function() {
|
||||||
questionData.options.push($(this).val());
|
questionData.options.push($(this).val());
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,10 +1,10 @@
|
||||||
$(document).ready(function () {
|
$(document).ready(function() {
|
||||||
let index = 1
|
let index = 1;
|
||||||
let activeSection = null
|
let activeSection = null;
|
||||||
|
|
||||||
function addOption(type, container) {
|
function addOption(type, container) {
|
||||||
// let optionIndex = container.children().length + 1;
|
// let optionIndex = container.children().length + 1;
|
||||||
let optionHtml
|
let optionHtml;
|
||||||
if (type === 'multiple-choice' || type === 'checkboxes') {
|
if (type === 'multiple-choice' || type === 'checkboxes') {
|
||||||
optionHtml = `
|
optionHtml = `
|
||||||
<div class="option">
|
<div class="option">
|
||||||
|
@ -12,17 +12,18 @@ $(document).ready(function () {
|
||||||
<input type="text" class="form-control option-label" >
|
<input type="text" class="form-control option-label" >
|
||||||
<span class="delete-option-icon">×</span>
|
<span class="delete-option-icon">×</span>
|
||||||
</div>
|
</div>
|
||||||
`
|
`;
|
||||||
} else if (type === 'dropdown') {
|
}
|
||||||
|
else if (type === 'dropdown') {
|
||||||
optionHtml = `
|
optionHtml = `
|
||||||
<div class="option">
|
<div class="option">
|
||||||
<input type="text" class="form-control option-label">
|
<input type="text" class="form-control option-label">
|
||||||
<span class="delete-option-icon">×</span>
|
<span class="delete-option-icon">×</span>
|
||||||
</div>
|
</div>
|
||||||
`
|
`;
|
||||||
}
|
|
||||||
container.append(optionHtml)
|
|
||||||
}
|
}
|
||||||
|
container.append(optionHtml);
|
||||||
|
}
|
||||||
|
|
||||||
function createFormSection() {
|
function createFormSection() {
|
||||||
let newSection = `
|
let newSection = `
|
||||||
|
@ -44,100 +45,88 @@ $(document).ready(function () {
|
||||||
</div>
|
</div>
|
||||||
<div class="options-container"></div>
|
<div class="options-container"></div>
|
||||||
</div>
|
</div>
|
||||||
`
|
`;
|
||||||
$('#form-container').append(newSection)
|
$('#form-container').append(newSection);
|
||||||
index++
|
index++;
|
||||||
positionAddSectionButton()
|
positionAddSectionButton();
|
||||||
}
|
}
|
||||||
|
|
||||||
function positionAddSectionButton() {
|
function positionAddSectionButton() {
|
||||||
if (activeSection) {
|
if (activeSection) {
|
||||||
let position = activeSection.position()
|
let position = activeSection.position();
|
||||||
let buttonWidth = $('#add-section-btn').outerWidth()
|
let buttonWidth = $('#add-section-btn').outerWidth();
|
||||||
let buttonHeight = $('#add-section-btn').outerHeight()
|
let buttonHeight = $('#add-section-btn').outerHeight();
|
||||||
|
|
||||||
$('#add-section-btn').css({
|
$('#add-section-btn').css({
|
||||||
position: 'absolute',
|
position: 'absolute',
|
||||||
left: position.left - buttonWidth - 47 + 'px',
|
left: position.left - buttonWidth - 47 + 'px',
|
||||||
top:
|
top: position.top + activeSection.height() / 2 - buttonHeight / 2 + 'px'
|
||||||
position.top + activeSection.height() / 2 - buttonHeight / 2 + 'px',
|
});
|
||||||
})
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$('#add-section-btn').on('click', function () {
|
$('#add-section-btn').on('click', function() {
|
||||||
createFormSection()
|
createFormSection();
|
||||||
$('.form-section').removeClass('active')
|
$('.form-section').removeClass('active');
|
||||||
activeSection = $('.form-section').last()
|
activeSection = $('.form-section').last();
|
||||||
activeSection.addClass('active')
|
activeSection.addClass('active');
|
||||||
positionAddSectionButton()
|
positionAddSectionButton();
|
||||||
})
|
});
|
||||||
|
|
||||||
$(document).on('change', '.custom-select', function () {
|
$(document).on('change', '.custom-select', function() {
|
||||||
let type = $(this).val()
|
let type = $(this).val();
|
||||||
let container = $(this).closest('.form-section').find('.options-container')
|
let container = $(this).closest('.form-section').find('.options-container');
|
||||||
container.empty()
|
container.empty();
|
||||||
$(this).closest('.form-section').find('.add-option-btn').remove()
|
$(this).closest('.form-section').find('.add-option-btn').remove();
|
||||||
|
|
||||||
if (type === 'short-answer') {
|
if (type === 'short-answer') {
|
||||||
container.append(
|
container.append('<input type="text" class="form-control" disabled placeholder="Short answer text">');
|
||||||
'<input type="text" class="form-control" disabled placeholder="Short answer text">'
|
|
||||||
)
|
|
||||||
} else if (type === 'paragraph') {
|
} else if (type === 'paragraph') {
|
||||||
container.append(
|
container.append('<textarea class="form-control" disabled placeholder="Paragraph text"></textarea>');
|
||||||
'<textarea class="form-control" disabled placeholder="Paragraph text"></textarea>'
|
|
||||||
)
|
|
||||||
} else {
|
} else {
|
||||||
addOption(type, container)
|
addOption(type, container);
|
||||||
$(this)
|
$(this).closest('.form-section').append('<button class="btn btn-secondary add-option-btn">Add Option</button>');
|
||||||
.closest('.form-section')
|
|
||||||
.append(
|
|
||||||
'<button class="btn btn-secondary add-option-btn">Add Option</button>'
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
})
|
});
|
||||||
|
|
||||||
$(document).on('click', '.add-option-btn', function () {
|
$(document).on('click', '.add-option-btn', function() {
|
||||||
let type = $(this).closest('.form-section').find('.custom-select').val()
|
let type = $(this).closest('.form-section').find('.custom-select').val();
|
||||||
let container = $(this).closest('.form-section').find('.options-container')
|
let container = $(this).closest('.form-section').find('.options-container');
|
||||||
addOption(type, container)
|
addOption(type, container);
|
||||||
})
|
});
|
||||||
|
|
||||||
$(document).on('click', '.delete-section-icon', function () {
|
$(document).on('click', '.delete-section-icon', function() {
|
||||||
let section = $(this).closest('.form-section')
|
let section = $(this).closest('.form-section');
|
||||||
let prevSection = section.prev('.form-section')
|
let prevSection = section.prev('.form-section');
|
||||||
let nextSection = section.next('.form-section')
|
let nextSection = section.next('.form-section');
|
||||||
section.remove()
|
section.remove();
|
||||||
if (section.hasClass('active')) {
|
if (section.hasClass('active')) {
|
||||||
activeSection = null
|
activeSection = null;
|
||||||
}
|
}
|
||||||
if (prevSection.length > 0) {
|
if (prevSection.length > 0) {
|
||||||
prevSection
|
prevSection.find('.delete-section-icon').appendTo(prevSection.find('.form-section'));
|
||||||
.find('.delete-section-icon')
|
activeSection = prevSection;row
|
||||||
.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
|
|
||||||
}
|
}
|
||||||
positionAddSectionButton()
|
else if (nextSection.length > 0) {
|
||||||
})
|
nextSection.find('.delete-section-icon').appendTo(nextSection.find('.form-header'));
|
||||||
|
activeSection = nextSection;
|
||||||
|
}
|
||||||
|
positionAddSectionButton();
|
||||||
|
});
|
||||||
|
|
||||||
$(document).on('click', '.delete-option-icon', function () {
|
$(document).on('click', '.delete-option-icon', function() {
|
||||||
let option = $(this).closest('.option')
|
let option = $(this).closest('.option');
|
||||||
let container = option.closest('.options-container')
|
let container = option.closest('.options-container');
|
||||||
option.remove()
|
option.remove();
|
||||||
})
|
|
||||||
|
|
||||||
$(document).on('click', '.required-toggle', function () {
|
});
|
||||||
$(this).closest('.form-section').toggleClass('required')
|
|
||||||
})
|
|
||||||
|
|
||||||
$('#preview-btn').on('click', function () {
|
$(document).on('click', '.required-toggle', function() {
|
||||||
let previewWindow = window.open('', '_blank')
|
$(this).closest('.form-section').toggleClass('required');
|
||||||
|
});
|
||||||
|
|
||||||
|
$('#preview-btn').on('click', function() {
|
||||||
|
let previewWindow = window.open('', '_blank');
|
||||||
let previewContent = `
|
let previewContent = `
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
|
@ -157,144 +146,126 @@ $(document).ready(function () {
|
||||||
<div class="form-header">
|
<div class="form-header">
|
||||||
<h3>Form Preview</h3>
|
<h3>Form Preview</h3>
|
||||||
</div>
|
</div>
|
||||||
`
|
`;
|
||||||
$('.form-section').each(function () {
|
$('.form-section').each(function() {
|
||||||
previewContent += '<div class="form-section">'
|
previewContent += '<div class="form-section">';
|
||||||
previewContent += '<div class="question-section">'
|
previewContent += '<div class="question-section">';
|
||||||
previewContent +=
|
previewContent += '<div class="question-label">' + $(this).find('.untitled-question').val() + '</div>';
|
||||||
'<div class="question-label">' +
|
previewContent += '</div>';
|
||||||
$(this).find('.untitled-question').val() +
|
let type = $(this).find('.custom-select').val();
|
||||||
'</div>'
|
let optionsContainer = $(this).find('.options-container');
|
||||||
previewContent += '</div>'
|
|
||||||
let type = $(this).find('.custom-select').val()
|
|
||||||
let optionsContainer = $(this).find('.options-container')
|
|
||||||
|
|
||||||
if (type === 'multiple-choice') {
|
if (type === 'multiple-choice') {
|
||||||
optionsContainer.find('.option').each(function () {
|
optionsContainer.find('.option').each(function() {
|
||||||
previewContent += `
|
previewContent += `
|
||||||
<div class="option">
|
<div class="option">
|
||||||
<input type="radio" name="option-${index}">
|
<input type="radio" name="option-${index}">
|
||||||
<label>${$(this).find('.option-label').val()}</label>
|
<label>${$(this).find('.option-label').val()}</label>
|
||||||
</div>
|
</div>
|
||||||
`
|
`;
|
||||||
})
|
});
|
||||||
} else if (type === 'checkboxes') {
|
} else if (type === 'checkboxes') {
|
||||||
optionsContainer.find('.option').each(function () {
|
optionsContainer.find('.option').each(function() {
|
||||||
previewContent += `
|
previewContent += `
|
||||||
<div class="option">
|
<div class="option">
|
||||||
<input type="checkbox">
|
<input type="checkbox">
|
||||||
<label>${$(this).find('.option-label').val()}</label>
|
<label>${$(this).find('.option-label').val()}</label>
|
||||||
</div>
|
</div>
|
||||||
`
|
`;
|
||||||
})
|
});
|
||||||
} else if (type === 'short-answer') {
|
} else if (type === 'short-answer') {
|
||||||
previewContent +=
|
previewContent += '<input type="text" class="form-control" placeholder="Short answer text">';
|
||||||
'<input type="text" class="form-control" placeholder="Short answer text">'
|
|
||||||
} else if (type === 'paragraph') {
|
} else if (type === 'paragraph') {
|
||||||
previewContent +=
|
previewContent += '<textarea class="form-control" placeholder="Paragraph text"></textarea>';
|
||||||
'<textarea class="form-control" placeholder="Paragraph text"></textarea>'
|
|
||||||
} else if (type === 'dropdown') {
|
} else if (type === 'dropdown') {
|
||||||
let dropdownHtml = '<select class="form-control">'
|
let dropdownHtml = '<select class="form-control">';
|
||||||
optionsContainer.find('.option .option-label').each(function () {
|
optionsContainer.find('.option .option-label').each(function() {
|
||||||
dropdownHtml += `<option>${$(this).val()}</option>`
|
dropdownHtml += `<option>${$(this).val()}</option>`;
|
||||||
})
|
});
|
||||||
dropdownHtml += '</select>'
|
dropdownHtml += '</select>';
|
||||||
previewContent += dropdownHtml
|
previewContent += dropdownHtml;
|
||||||
}
|
}
|
||||||
previewContent += '</div>'
|
previewContent += '</div>';
|
||||||
})
|
});
|
||||||
previewContent += `
|
previewContent += `
|
||||||
</div>
|
</div>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
`
|
`;
|
||||||
previewWindow.document.write(previewContent)
|
previewWindow.document.write(previewContent);
|
||||||
previewWindow.document.close()
|
previewWindow.document.close();
|
||||||
})
|
});
|
||||||
|
|
||||||
$(document).on('click', '.form-section', function () {
|
$(document).on('click', '.form-section', function() {
|
||||||
$('.form-section').removeClass('active')
|
$('.form-section').removeClass('active');
|
||||||
$(this).addClass('active')
|
$(this).addClass('active');
|
||||||
activeSection = $(this)
|
activeSection = $(this);
|
||||||
positionAddSectionButton()
|
positionAddSectionButton();
|
||||||
})
|
});
|
||||||
|
|
||||||
$('#form-container').sortable({
|
$('#form-container').sortable({
|
||||||
placeholder: 'ui-state-highlight',
|
placeholder: 'ui-state-highlight',
|
||||||
start: function (event, ui) {
|
start: function (event, ui) {
|
||||||
ui.placeholder.height(ui.item.height())
|
ui.placeholder.height(ui.item.height());
|
||||||
},
|
},
|
||||||
stop: function (event, ui) {
|
stop: function (event, ui) {
|
||||||
positionAddSectionButton()
|
positionAddSectionButton();
|
||||||
},
|
}
|
||||||
})
|
});
|
||||||
|
|
||||||
function collectFormData() {
|
function collectFormData() {
|
||||||
var formData = {
|
var formData = {
|
||||||
questions: [],
|
questions: []
|
||||||
}
|
};
|
||||||
|
|
||||||
$('.form-section').each(function () {
|
$('.form-section').each(function() {
|
||||||
var questionType = $(this).find('.custom-select').val()
|
var questionType = $(this).find('.custom-select').val();
|
||||||
var questionData = {
|
var questionData = {
|
||||||
text: $(this).find('.untitled-question').val(),
|
text: $(this).find('.untitled-question').val(),
|
||||||
type: questionType,
|
type: questionType,
|
||||||
is_required: $(this).find('.required-toggle').is(':checked'),
|
is_required: $(this).find('.required-toggle').is(':checked'),
|
||||||
options: [],
|
options: []
|
||||||
}
|
};
|
||||||
|
|
||||||
// Only add options if the question type supports them
|
// Only add options if the question type supports them
|
||||||
if (
|
if (questionType === 'multiple-choice' || questionType === 'checkboxes' || questionType === 'dropdown') {
|
||||||
questionType === 'multiple-choice' ||
|
$(this).find('.option-label').each(function() {
|
||||||
questionType === 'checkboxes' ||
|
questionData.options.push($(this).val());
|
||||||
questionType === 'dropdown'
|
});
|
||||||
) {
|
|
||||||
$(this)
|
|
||||||
.find('.option-label')
|
|
||||||
.each(function () {
|
|
||||||
questionData.options.push($(this).val())
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
formData.questions.push(questionData)
|
formData.questions.push(questionData);
|
||||||
})
|
});
|
||||||
|
|
||||||
console.log(formData)
|
console.log(formData);
|
||||||
return formData
|
return formData;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function validateFormData(formData) {
|
function validateFormData(formData) {
|
||||||
for (let question of formData.questions) {
|
for (let question of formData.questions) {
|
||||||
if (!question.text.trim()) {
|
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) {
|
for (let option of question.options) {
|
||||||
if (!option.trim()) {
|
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 () {
|
$('#submit-btn').on('click', function() {
|
||||||
let formData = collectFormData()
|
let formData = collectFormData();
|
||||||
console.log(formData)
|
console.log(formData);
|
||||||
|
|
||||||
let validation = validateFormData(formData)
|
let validation = validateFormData(formData);
|
||||||
if (!validation.isValid) {
|
if (!validation.isValid) {
|
||||||
alert(validation.message)
|
alert(validation.message);
|
||||||
return
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$.ajax({
|
$.ajax({
|
||||||
|
@ -302,27 +273,27 @@ $(document).ready(function () {
|
||||||
type: 'POST',
|
type: 'POST',
|
||||||
data: { formData: formData },
|
data: { formData: formData },
|
||||||
dataType: 'JSON',
|
dataType: 'JSON',
|
||||||
success: function (response) {
|
success: function(response) {
|
||||||
if (response.status === 'success') {
|
if (response.status === 'success') {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
title: 'Success!',
|
title: 'Success!',
|
||||||
text: 'Form submitted successfully!',
|
text: 'Form submitted successfully!',
|
||||||
icon: 'success',
|
icon: 'success',
|
||||||
confirmButtonText: 'OK',
|
confirmButtonText: 'OK'
|
||||||
}).then((result) => {
|
}).then((result) => {
|
||||||
window.location.href = base_url
|
window.location.href = base_url;
|
||||||
})
|
});
|
||||||
} else {
|
} else {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
title: 'Error!',
|
title: 'Error!',
|
||||||
text: response.message,
|
text: response.message,
|
||||||
icon: 'error',
|
icon: 'error',
|
||||||
confirmButtonText: 'OK',
|
confirmButtonText: 'OK'
|
||||||
})
|
});
|
||||||
console.log(response)
|
console.log(response);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
error: function (error) {
|
error: function(error) {
|
||||||
Swal.fire({
|
Swal.fire({
|
||||||
title: 'Error!',
|
title: 'Error!',
|
||||||
text: 'Error submitting form!',
|
text: 'Error submitting form!',
|
||||||
|
@ -333,13 +304,16 @@ $(document).ready(function () {
|
||||||
padding: 'auto',
|
padding: 'auto',
|
||||||
}).then((result) => {
|
}).then((result) => {
|
||||||
if (result.isConfirmed) {
|
if (result.isConfirmed) {
|
||||||
window.location.href = home
|
window.location.href = home;
|
||||||
}
|
}
|
||||||
})
|
});
|
||||||
console.log(error)
|
console.log(error);
|
||||||
},
|
}
|
||||||
})
|
});
|
||||||
})
|
});
|
||||||
|
|
||||||
$('#form-container').disableSelection()
|
|
||||||
})
|
|
||||||
|
|
||||||
|
$('#form-container').disableSelection();
|
||||||
|
});
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
$(document).ready(function () {
|
$(document).ready(function () {
|
||||||
let index = 1
|
let index = 1
|
||||||
let activeSection = null
|
let activeSection = null
|
||||||
|
|
||||||
function addOption(type, container) {
|
function addOption(type, container) {
|
||||||
let optionHtml
|
let optionHtml
|
||||||
|
|
||||||
|
|
1745
composer-setup.php
1745
composer-setup.php
File diff suppressed because it is too large
Load Diff
|
@ -30,7 +30,6 @@
|
||||||
},
|
},
|
||||||
"require-dev": {
|
"require-dev": {
|
||||||
"mikey179/vfsstream": "1.6.*",
|
"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