Compare commits

..

1 Commits

Author SHA1 Message Date
RameshT 49b00bd108 Update .husky/pre-commit 2024-08-08 11:30:15 +00:00
9520 changed files with 79881 additions and 1011502 deletions

View File

@ -1,3 +0,0 @@
{
"presets": ["@babel/preset-env"]
}

View File

@ -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"
}
}

View File

@ -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."

View File

@ -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

View File

@ -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

View File

@ -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"
}

View File

@ -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>

View File

@ -1,6 +1,5 @@
<?php <?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
/* /*
| ------------------------------------------------------------------- | -------------------------------------------------------------------

View File

@ -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;
/* /*
|-------------------------------------------------------------------------- |--------------------------------------------------------------------------

View File

@ -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

View File

@ -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
); );

View File

@ -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">',

View File

@ -1,6 +1,5 @@
<?php <?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
/* /*
| ------------------------------------------------------------------- | -------------------------------------------------------------------

View File

@ -1,6 +1,5 @@
<?php <?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
/* /*
| ------------------------------------------------------------------------- | -------------------------------------------------------------------------

View File

@ -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>

View File

@ -1,6 +1,5 @@
<?php <?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
/* /*
| ------------------------------------------------------------------------- | -------------------------------------------------------------------------

View File

@ -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/';

View File

@ -1,6 +1,5 @@
<?php <?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
/* /*
| ------------------------------------------------------------------- | -------------------------------------------------------------------

View File

@ -1,6 +1,5 @@
<?php <?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
/* /*
| ------------------------------------------------------------------------- | -------------------------------------------------------------------------

View File

@ -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';

View File

@ -1,6 +1,5 @@
<?php <?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
/* /*
| ------------------------------------------------------------------- | -------------------------------------------------------------------

View File

@ -1,6 +1,5 @@
<?php <?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
/* /*
| ------------------------------------------------------------------- | -------------------------------------------------------------------

View File

@ -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');

View File

@ -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');
} }
} }

View File

@ -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');

View File

@ -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');
} }
} }

View File

@ -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);
} }
} }
} }
?>

View File

@ -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
} }
} }
} }
?>

View File

@ -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']);
} }
} }
} }

View File

@ -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;
}
} }

View File

@ -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
// } // }
// } // }
} }
?>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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;
} }
} }
?>

View File

@ -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;

View File

@ -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();
} }
} }

View File

@ -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
} }
} }
?>

View File

@ -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
} }
} }

View File

@ -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();
} }
} }

View File

@ -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();
}
} }

View File

@ -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');
} }
} }
} }
?>

View File

@ -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;
}
}
}
?>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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

View File

@ -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";

View File

@ -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";

View File

@ -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 ?>

View File

@ -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";

View File

@ -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 ?>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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 />

View File

@ -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>

View File

@ -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 />

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

4646
assets/css/all.min.css vendored

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -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 {

View File

@ -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 */

View File

@ -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;
} }

View File

@ -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

View File

@ -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 {

View File

@ -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;
} }

View File

@ -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%;
} }

View File

@ -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()

View File

@ -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());
}); });

23563
assets/js/jquery-ui.js vendored

File diff suppressed because it is too large Load Diff

View File

@ -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">&times;</span> <span class="delete-option-icon">&times;</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">&times;</span> <span class="delete-option-icon">&times;</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();
});

View File

@ -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

File diff suppressed because it is too large Load Diff

View File

@ -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"
} }
} }

1721
composer.lock generated

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