Compare commits

..

8 Commits

Author SHA1 Message Date
RameshT f9bc85d5f8 Your commit message 2024-08-09 17:34:48 +05:30
RameshT aac7f7ed1b Your commit message 2024-08-09 14:15:48 +05:30
RameshT ee45c0f04b Your commit message 2024-08-09 12:39:33 +05:30
RameshT 0505d21383 Your commit message 2024-08-09 12:33:11 +05:30
RameshT 77d538cd26 Your commit message 2024-08-09 12:31:44 +05:30
RameshT 320830fe6c Your commit message 2024-08-09 12:29:24 +05:30
RameshT 1478e07d7f Your commit message 2024-08-08 17:20:35 +05:30
RameshT 0fee63db20 Your commit message 2024-08-08 17:18:50 +05:30
9520 changed files with 1011600 additions and 79979 deletions

3
.babelrc.json Normal file
View File

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

32
.eslintrc.json Normal file
View File

@ -0,0 +1,32 @@
{
"env": {
"browser": true,
"jquery": true
},
"parser": "@babel/eslint-parser",
"parserOptions": {
"ecmaVersion": 2020,
"sourceType": "module"
},
"plugins": [
"prettier"
],
"extends": [
"eslint:recommended",
"prettier"
],
"rules": {
"prettier/prettier": "error",
"no-undef": "off",
"no-unused-vars": "off"
},
"globals": {
"$": "readonly",
"jQuery": "readonly",
"document": "readonly",
"window": "readonly",
"console": "readonly"
}
}

View File

@ -1,6 +1,11 @@
#!/bin/sh
. "$(dirname "$0")/_/husky.sh"
# Run JS/CSS checks
.husky/pre-commit-js-css
if [ $? -ne 0 ]; then
echo "JS/CSS checks failed"
exit 1
fi
# Get the list of staged PHP files
STAGED_FILES=$(git diff --cached --name-only --diff-filter=ACM | grep '\.php$')
@ -57,4 +62,5 @@ for FILE in $STAGED_FILES; do
git add "$FILE"
done
echo "Pre-commit checks completed."

48
.husky/pre-commit-js-css Executable file
View File

@ -0,0 +1,48 @@
#!/bin/sh
. "$(dirname "$0")/_/husky.sh"
# Get the list of staged JS/CSS files
STAGED_FILES=$(git diff --cached --name-only --diff-filter=ACM | grep -E '\.(js|jsx|ts|tsx|css|scss)$')
# If there are no staged JS/CSS files, exit
if [ -z "$STAGED_FILES" ]; then
echo "No JS/CSS files staged for commit."
exit 0
fi
# Function to display errors
display_errors() {
local errors="$1"
echo "Errors detected:"
echo "---------------------------------------"
echo "$errors"
echo "---------------------------------------"
}
# Run Prettier
echo "Running Prettier..."
for FILE in $STAGED_FILES; do
npx prettier --write "$FILE"
done
# Run ESLint
echo "Running ESLint..."
ESLINT_ERRORS=0
for FILE in $STAGED_FILES; do
ESLINT_OUTPUT=$(npx eslint "$FILE" 2>&1)
if [ $? -ne 0 ]; then
display_errors "$ESLINT_OUTPUT"
ESLINT_ERRORS=1
fi
done
if [ $ESLINT_ERRORS -ne 0 ]; then
echo "ESLint errors detected. Please fix them before committing."
exit 1
fi
# Add the fixed files back to the staging area
for FILE in $STAGED_FILES; do
git add "$FILE"
done
echo "JS/CSS pre-commit checks completed."

1
.php-cs-fixer.cache Normal file

File diff suppressed because one or more lines are too long

22
.prettierignore Normal file
View File

@ -0,0 +1,22 @@
# Ignore node_modules directory
node_modules/
# Ignore build directory
build/
# Ignore all minified JavaScript files
*.min.js
# Ignore specific files
public/vendor/jquery.js
public/vendor/bootstrap.js
# Ignore all files in a specific directory
src/vendor/
# Ignore specific file
path/to/specific/file.js
# Ignore all JavaScript files in a specific directory
src/vendor/*.js

15
.prettierrc.json Normal file
View File

@ -0,0 +1,15 @@
{
"trailingComma": "es5",
"tabWidth": 2,
"semi": false,
"singleQuote": true,
"jsxSingleQuote": true,
"bracketSpacing": true,
"parser": "babel-ts",
"requirePragma": false,
"insertPragma": false,
"proseWrap": "preserve",
"htmlWhitespaceSensitivity": "css",
"endOfLine": "lf",
"embeddedLanguageFormatting": "off"
}

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

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

View File

@ -1,5 +1,6 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
/*
|--------------------------------------------------------------------------
@ -102,7 +103,7 @@ $config['charset'] = 'UTF-8';
| setting this variable to TRUE (boolean). See the user guide for details.
|
*/
$config['enable_hooks'] = FALSE;
$config['enable_hooks'] = false;
/*
|--------------------------------------------------------------------------
@ -138,7 +139,7 @@ $config['subclass_prefix'] = 'MY_';
| Note: This will NOT disable or override the CodeIgniter-specific
| autoloading (application/config/autoload.php)
*/
$config['composer_autoload'] = FALSE;
$config['composer_autoload'] = false;
/*
|--------------------------------------------------------------------------
@ -184,7 +185,7 @@ $config['permitted_uri_chars'] = 'a-z 0-9~%.:_\-';
| use segment based URLs.
|
*/
$config['enable_query_strings'] = FALSE;
$config['enable_query_strings'] = false;
$config['controller_trigger'] = 'c';
$config['function_trigger'] = 'm';
$config['directory_trigger'] = 'd';
@ -201,7 +202,7 @@ $config['directory_trigger'] = 'd';
| for backwards compatibility purposes!
|
*/
$config['allow_get_array'] = TRUE;
$config['allow_get_array'] = true;
/*
|--------------------------------------------------------------------------
@ -313,7 +314,7 @@ $config['cache_path'] = '';
| of query parameters.
|
*/
$config['cache_query_string'] = FALSE;
$config['cache_query_string'] = false;
/*
|--------------------------------------------------------------------------
@ -387,10 +388,10 @@ $config['sess_driver'] = 'files';
$config['sess_cookie_name'] = 'ci_session';
$config['sess_samesite'] = 'Lax';
$config['sess_expiration'] = 7200;
$config['sess_save_path'] = NULL;
$config['sess_match_ip'] = FALSE;
$config['sess_save_path'] = null;
$config['sess_match_ip'] = false;
$config['sess_time_to_update'] = 300;
$config['sess_regenerate_destroy'] = FALSE;
$config['sess_regenerate_destroy'] = false;
/*
|--------------------------------------------------------------------------
@ -411,8 +412,8 @@ $config['sess_regenerate_destroy'] = FALSE;
$config['cookie_prefix'] = '';
$config['cookie_domain'] = '';
$config['cookie_path'] = '/';
$config['cookie_secure'] = FALSE;
$config['cookie_httponly'] = FALSE;
$config['cookie_secure'] = false;
$config['cookie_httponly'] = false;
$config['cookie_samesite'] = 'Lax';
/*
@ -427,7 +428,7 @@ $config['cookie_samesite'] = 'Lax';
| for backwards compatibility purposes!
|
*/
$config['standardize_newlines'] = FALSE;
$config['standardize_newlines'] = false;
/*
|--------------------------------------------------------------------------
@ -441,7 +442,7 @@ $config['standardize_newlines'] = FALSE;
| for backwards compatibility purposes!
|
*/
$config['global_xss_filtering'] = FALSE;
$config['global_xss_filtering'] = false;
/*
|--------------------------------------------------------------------------
@ -457,11 +458,11 @@ $config['global_xss_filtering'] = FALSE;
| 'csrf_regenerate' = Regenerate token on every submission
| 'csrf_exclude_uris' = Array of URIs which ignore CSRF checks
*/
$config['csrf_protection'] = FALSE;
$config['csrf_protection'] = false;
$config['csrf_token_name'] = 'csrf_test_name';
$config['csrf_cookie_name'] = 'csrf_cookie_name';
$config['csrf_expire'] = 7200;
$config['csrf_regenerate'] = TRUE;
$config['csrf_regenerate'] = true;
$config['csrf_exclude_uris'] = array();
/*
@ -484,7 +485,7 @@ $config['csrf_exclude_uris'] = array();
| by the output class. Do not 'echo' any values with compression enabled.
|
*/
$config['compress_output'] = FALSE;
$config['compress_output'] = false;
/*
|--------------------------------------------------------------------------
@ -511,7 +512,7 @@ $config['time_reference'] = 'local';
| Note: You need to have eval() enabled for this to work.
|
*/
$config['rewrite_short_tags'] = FALSE;
$config['rewrite_short_tags'] = false;
/*
|--------------------------------------------------------------------------

View File

@ -1,5 +1,6 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
/*
|--------------------------------------------------------------------------
@ -11,7 +12,7 @@ defined('BASEPATH') OR exit('No direct script access allowed');
| of this setting
|
*/
defined('SHOW_DEBUG_BACKTRACE') OR define('SHOW_DEBUG_BACKTRACE', TRUE);
defined('SHOW_DEBUG_BACKTRACE') or define('SHOW_DEBUG_BACKTRACE', true);
/*
|--------------------------------------------------------------------------
@ -26,10 +27,10 @@ defined('SHOW_DEBUG_BACKTRACE') OR define('SHOW_DEBUG_BACKTRACE', TRUE);
| always be used to set the mode correctly.
|
*/
defined('FILE_READ_MODE') OR define('FILE_READ_MODE', 0644);
defined('FILE_WRITE_MODE') OR define('FILE_WRITE_MODE', 0666);
defined('DIR_READ_MODE') OR define('DIR_READ_MODE', 0755);
defined('DIR_WRITE_MODE') OR define('DIR_WRITE_MODE', 0755);
defined('FILE_READ_MODE') or define('FILE_READ_MODE', 0644);
defined('FILE_WRITE_MODE') or define('FILE_WRITE_MODE', 0666);
defined('DIR_READ_MODE') or define('DIR_READ_MODE', 0755);
defined('DIR_WRITE_MODE') or define('DIR_WRITE_MODE', 0755);
/*
|--------------------------------------------------------------------------
@ -39,14 +40,14 @@ defined('DIR_WRITE_MODE') OR define('DIR_WRITE_MODE', 0755);
| These modes are used when working with fopen()/popen()
|
*/
defined('FOPEN_READ') OR define('FOPEN_READ', 'rb');
defined('FOPEN_READ_WRITE') OR define('FOPEN_READ_WRITE', 'r+b');
defined('FOPEN_WRITE_CREATE_DESTRUCTIVE') OR define('FOPEN_WRITE_CREATE_DESTRUCTIVE', 'wb'); // truncates existing file data, use with care
defined('FOPEN_READ_WRITE_CREATE_DESTRUCTIVE') OR define('FOPEN_READ_WRITE_CREATE_DESTRUCTIVE', 'w+b'); // truncates existing file data, use with care
defined('FOPEN_WRITE_CREATE') OR define('FOPEN_WRITE_CREATE', 'ab');
defined('FOPEN_READ_WRITE_CREATE') OR define('FOPEN_READ_WRITE_CREATE', 'a+b');
defined('FOPEN_WRITE_CREATE_STRICT') OR define('FOPEN_WRITE_CREATE_STRICT', 'xb');
defined('FOPEN_READ_WRITE_CREATE_STRICT') OR define('FOPEN_READ_WRITE_CREATE_STRICT', 'x+b');
defined('FOPEN_READ') or define('FOPEN_READ', 'rb');
defined('FOPEN_READ_WRITE') or define('FOPEN_READ_WRITE', 'r+b');
defined('FOPEN_WRITE_CREATE_DESTRUCTIVE') or define('FOPEN_WRITE_CREATE_DESTRUCTIVE', 'wb'); // truncates existing file data, use with care
defined('FOPEN_READ_WRITE_CREATE_DESTRUCTIVE') or define('FOPEN_READ_WRITE_CREATE_DESTRUCTIVE', 'w+b'); // truncates existing file data, use with care
defined('FOPEN_WRITE_CREATE') or define('FOPEN_WRITE_CREATE', 'ab');
defined('FOPEN_READ_WRITE_CREATE') or define('FOPEN_READ_WRITE_CREATE', 'a+b');
defined('FOPEN_WRITE_CREATE_STRICT') or define('FOPEN_WRITE_CREATE_STRICT', 'xb');
defined('FOPEN_READ_WRITE_CREATE_STRICT') or define('FOPEN_READ_WRITE_CREATE_STRICT', 'x+b');
/*
|--------------------------------------------------------------------------
@ -73,13 +74,13 @@ defined('FOPEN_READ_WRITE_CREATE_STRICT') OR define('FOPEN_READ_WRITE_CREA
| http://tldp.org/LDP/abs/html/exitcodes.html
|
*/
defined('EXIT_SUCCESS') OR define('EXIT_SUCCESS', 0); // no errors
defined('EXIT_ERROR') OR define('EXIT_ERROR', 1); // generic error
defined('EXIT_CONFIG') OR define('EXIT_CONFIG', 3); // configuration error
defined('EXIT_UNKNOWN_FILE') OR define('EXIT_UNKNOWN_FILE', 4); // file not found
defined('EXIT_UNKNOWN_CLASS') OR define('EXIT_UNKNOWN_CLASS', 5); // unknown class
defined('EXIT_UNKNOWN_METHOD') OR define('EXIT_UNKNOWN_METHOD', 6); // unknown class member
defined('EXIT_USER_INPUT') OR define('EXIT_USER_INPUT', 7); // invalid user input
defined('EXIT_DATABASE') OR define('EXIT_DATABASE', 8); // database error
defined('EXIT__AUTO_MIN') OR define('EXIT__AUTO_MIN', 9); // lowest automatically-assigned error code
defined('EXIT__AUTO_MAX') OR define('EXIT__AUTO_MAX', 125); // highest automatically-assigned error code
defined('EXIT_SUCCESS') or define('EXIT_SUCCESS', 0); // no errors
defined('EXIT_ERROR') or define('EXIT_ERROR', 1); // generic error
defined('EXIT_CONFIG') or define('EXIT_CONFIG', 3); // configuration error
defined('EXIT_UNKNOWN_FILE') or define('EXIT_UNKNOWN_FILE', 4); // file not found
defined('EXIT_UNKNOWN_CLASS') or define('EXIT_UNKNOWN_CLASS', 5); // unknown class
defined('EXIT_UNKNOWN_METHOD') or define('EXIT_UNKNOWN_METHOD', 6); // unknown class member
defined('EXIT_USER_INPUT') or define('EXIT_USER_INPUT', 7); // invalid user input
defined('EXIT_DATABASE') or define('EXIT_DATABASE', 8); // database error
defined('EXIT__AUTO_MIN') or define('EXIT__AUTO_MIN', 9); // lowest automatically-assigned error code
defined('EXIT__AUTO_MAX') or define('EXIT__AUTO_MAX', 125); // highest automatically-assigned error code

View File

@ -1,77 +1,20 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
/*
| -------------------------------------------------------------------
| DATABASE CONNECTIVITY SETTINGS
| -------------------------------------------------------------------
| This file will contain the settings needed to access your database.
|
| For complete instructions please consult the 'Database Connection'
| page of the User Guide.
|
| -------------------------------------------------------------------
| EXPLANATION OF VARIABLES
| -------------------------------------------------------------------
|
| ['dsn'] The full DSN string describe a connection to the database.
| ['hostname'] The hostname of your database server.
| ['username'] The username used to connect to the database
| ['password'] The password used to connect to the database
| ['database'] The name of the database you want to connect to
| ['dbdriver'] The database driver. e.g.: mysqli.
| Currently supported:
| cubrid, ibase, mssql, mysql, mysqli, oci8,
| odbc, pdo, postgre, sqlite, sqlite3, sqlsrv
| ['dbprefix'] You can add an optional prefix, which will be added
| to the table name when using the Query Builder class
| ['pconnect'] TRUE/FALSE - Whether to use a persistent connection
| ['db_debug'] TRUE/FALSE - Whether database errors should be displayed.
| ['cache_on'] TRUE/FALSE - Enables/disables query caching
| ['cachedir'] The path to the folder where cache files should be stored
| ['char_set'] The character set used in communicating with the database
| ['dbcollat'] The character collation used in communicating with the database
| NOTE: For MySQL and MySQLi databases, this setting is only used
| as a backup if your server is running PHP < 5.2.3 or MySQL < 5.0.7
| (and in table creation queries made with DB Forge).
| There is an incompatibility in PHP with mysql_real_escape_string() which
| can make your site vulnerable to SQL injection if you are using a
| multi-byte character set and are running versions lower than these.
| Sites using Latin-1 or UTF-8 database character set and collation are unaffected.
| ['swap_pre'] A default table prefix that should be swapped with the dbprefix
| ['encrypt'] Whether or not to use an encrypted connection.
|
| 'mysql' (deprecated), 'sqlsrv' and 'pdo/sqlsrv' drivers accept TRUE/FALSE
| 'mysqli' and 'pdo/mysql' drivers accept an array with the following options:
|
| 'ssl_key' - Path to the private key file
| 'ssl_cert' - Path to the public key certificate file
| 'ssl_ca' - Path to the certificate authority file
| 'ssl_capath' - Path to a directory containing trusted CA certificates in PEM format
| 'ssl_cipher' - List of *allowed* ciphers to be used for the encryption, separated by colons (':')
| 'ssl_verify' - TRUE/FALSE; Whether verify the server certificate or not
|
| ['compress'] Whether or not to use client compression (MySQL only)
| ['stricton'] TRUE/FALSE - forces 'Strict Mode' connections
| - good for ensuring strict SQL while developing
| ['ssl_options'] Used to set various SSL options that can be used when making SSL connections.
| ['failover'] array - A array with 0 or more data for connections if the main should fail.
| ['save_queries'] TRUE/FALSE - Whether to "save" all executed queries.
| NOTE: Disabling this will also effectively disable both
| $this->db->last_query() and profiling of DB queries.
| When you run a query, with this setting set to TRUE (default),
| CodeIgniter will store the SQL statement for debugging purposes.
| However, this may cause high memory usage, especially if you run
| a lot of SQL queries ... disable this to avoid that problem.
|
| The $active_group variable lets you choose which connection group to
| make active. By default there is only one group (the 'default' group).
|
| The $query_builder variables lets you determine whether or not to load
| the query builder class.
*/
/**
* This file handles the XYZ functionality in the application.
* @category YourCategory
* @package YourApplication
* @subpackage YourSubpackage
* @author Your Name
* @date YYYY-MM-DD
* @version 1.0
*/
defined('BASEPATH') or exit('No direct script access allowed');
$active_group = 'default';
$query_builder = TRUE;
$query_builder = true;
$db['default'] = array(
'dsn' => '',
@ -81,16 +24,16 @@ $db['default'] = array(
'database' => 'google_forms',
'dbdriver' => 'mysqli',
'dbprefix' => '',
'pconnect' => FALSE,
'pconnect' => false,
'db_debug' => (ENVIRONMENT !== 'production'),
'cache_on' => FALSE,
'cache_on' => false,
'cachedir' => '',
'char_set' => 'utf8',
'dbcollat' => 'utf8_general_ci',
'swap_pre' => '',
'encrypt' => FALSE,
'compress' => FALSE,
'stricton' => FALSE,
'encrypt' => false,
'compress' => false,
'stricton' => false,
'failover' => array(),
'save_queries' => TRUE
'save_queries' => true
);

View File

@ -1,5 +1,6 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
$_doctypes = array(
'xhtml11' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">',

View File

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

View File

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

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

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

View File

@ -1,5 +1,6 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
/*
|--------------------------------------------------------------------------
@ -11,7 +12,7 @@ defined('BASEPATH') OR exit('No direct script access allowed');
| and disable it back when you're done.
|
*/
$config['migration_enabled'] = FALSE;
$config['migration_enabled'] = false;
/*
|--------------------------------------------------------------------------
@ -57,7 +58,7 @@ $config['migration_table'] = 'migrations';
| in your code to have the latest migration.
|
*/
$config['migration_auto_latest'] = FALSE;
$config['migration_auto_latest'] = false;
/*
|--------------------------------------------------------------------------
@ -81,4 +82,4 @@ $config['migration_version'] = 0;
| Also, writing permission is required within the migrations path.
|
*/
$config['migration_path'] = APPPATH.'migrations/';
$config['migration_path'] = APPPATH . 'migrations/';

View File

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

View File

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

View File

@ -1,5 +1,6 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
$route['forms'] = 'home/index4';
@ -8,7 +9,7 @@ $route['responses/view/(:num)'] = 'Response_submit/viewresponse/$1';
$route['publish/(:num)'] = 'forms/preview/$1';
$route['default_controller'] = 'Form_controller/index_forms';
$route['404_override'] = '';
$route['translate_uri_dashes'] = FALSE;
$route['translate_uri_dashes'] = false;
$route['start'] = 'Form_controller/index_forms';
$route['title_desc'] = 'homepage/title';
$route['forms/delete/(:any)'] = 'Form_controller/delete/$1';
@ -25,3 +26,4 @@ $route['response_preview/(:num)'] = 'forms/response_preview/$1';
$route['title'] = 'homepage/title';
$route['total_responses'] = 'Response_submit/index';

View File

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

View File

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

View File

@ -1,11 +1,9 @@
<?php
namespace application\controllers;
// namespace application\controllers;
defined('BASEPATH') or exit('No direct script access allowed');
// use application\models\Form_model;
class Form extends CI_Controller
{
public function __construct()
@ -15,6 +13,7 @@ class Form extends CI_Controller
}
public function submit()
{
if (!$this->session->userdata('logged_in')) {
// If not logged in, redirect to login page
redirect('users/login');

View File

@ -1,9 +1,9 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class Form_controller extends CI_Controller
{
public function index_forms($form_id = null)
{
$this->load->model('Frontend_model');
@ -25,7 +25,6 @@ class Form_controller extends CI_Controller
$form_title = $form['title'];
}
}
// Fetch data from models
$data['total_forms'] = $this->Form_model->get_total_forms($user_id);
$data['published_forms'] = $this->Form_model->get_published_forms($user_id);
@ -49,12 +48,13 @@ class Form_controller extends CI_Controller
$this->load->model('Frontend_model');
$this->Frontend_model->deleteForm($id);
$this->session->set_flashdata('status', 'Form data deleted successfully');
redirect('drafts');
redirect('home');
}
public function __construct()
{
parent::__construct();
$this->load->model('Updation_model');
$this->load->model('Form_model');
}
// Load the form for editing
@ -63,11 +63,11 @@ class Form_controller extends CI_Controller
$data['form'] = $this->Updation_model->get_form($form_id);
$data['questions'] = $this->Updation_model->get_questions($form_id);
$data['options'] = $this->Updation_model->get_options();
$data['is_published'] = $this->Form_model->get_published_value($form_id);
// $this->load->view('templates/header');
$this->load->view('edit_form_view', $data);
// $this->load->view('templates/footer');
}
// Save the edited form
@ -126,5 +126,4 @@ class Form_controller extends CI_Controller
$this->load->view('templates/footer');
}
}

View File

@ -10,9 +10,6 @@ class Forms extends CI_Controller
// If not logged in, redirect to login page
redirect('users/login');
}
// Load the model that handles the form data
$this->load->model('preview_model');

View File

@ -1,9 +1,9 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class Homepage extends CI_Controller
{
// index2-default
public function home()
{
@ -17,19 +17,15 @@ class Homepage extends CI_Controller
{
$this->load->view('templates/forms_ui');
}
public function title()
{
$this->load->view('templates/header');
$this->load->view('templates/form_title');
$this->load->view('templates/footer');
}
public function ui_forms()
{
$this->load->view('templates/forms_ui');
}
}

View File

@ -1,7 +1,9 @@
<?php
class New_form extends CI_Controller
{
public function create_form() {
public function create_form()
{
if (!$this->session->userdata('logged_in')) {
// If not logged in, redirect to login page
redirect('users/login');
@ -11,7 +13,7 @@ class New_form extends CI_Controller
$this->form_validation->set_rules('title', 'Title', 'required');
$this->form_validation->set_rules('description', 'Description', 'required');
if ($this->form_validation->run() === FALSE) {
if ($this->form_validation->run() === false) {
$this->load->view('templates/header');
$this->load->view('templates/form_title', $data);
$this->load->view('templates/footer');
@ -23,7 +25,4 @@ class New_form extends CI_Controller
redirect('form/view/' . $form_id);
}
}
}
?>

View File

@ -1,22 +1,19 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
class New_form_controller extends CI_Controller {
defined('BASEPATH') or exit('No direct script access allowed');
public function submit_form() {
class New_form_controller extends CI_Controller
{
public function submit_form()
{
if (!$this->session->userdata('logged_in')) {
// If not logged in, redirect to login page
echo json_encode(['status' => 'error', 'message' => 'User not logged in']);
return;
}
// Decode the formData from the POST request
$formData = $this->input->post('formData');
// Check if form_id is set in session
$formId = $this->session->userdata('form_id');
}// Decode the formData from the POST request$formData = $this->input->post('formData');
// Check if form_id is set in session$formId = $this->session->userdata('form_id');
if ($formId) {
// Load the model and save form data
$this->load->model('new_form_model');
// Load the model and save form data$this->load->model('new_form_model');
$saveStatus = $this->new_form_model->save_form_data($formId, $formData);
if ($saveStatus) {
@ -29,4 +26,3 @@ class New_form_controller extends CI_Controller {
}
}
}
?>

View File

@ -1,10 +1,12 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
class Publish_controller extends CI_Controller {
defined('BASEPATH') or exit('No direct script access allowed');
class Publish_controller extends CI_Controller
{
// Method to publish a form
public function publish_form($form_id) {
public function publish_form($form_id)
{
// Generate a unique link
if (!$this->session->userdata('logged_in')) {
// If not logged in, redirect to login page
@ -23,7 +25,8 @@ class Publish_controller extends CI_Controller {
}
// Method to list published forms of a user
public function list_user_published_forms() {
public function list_user_published_forms()
{
if (!$this->session->userdata('logged_in')) {
// If not logged in, redirect to login page
redirect('users/login');
@ -39,7 +42,8 @@ class Publish_controller extends CI_Controller {
// Method to unpublish a form
public function unpublish_form($form_id) {
public function unpublish_form($form_id)
{
if (!$this->session->userdata('logged_in')) {
// If not logged in, redirect to login page
redirect('users/login');
@ -51,7 +55,8 @@ class Publish_controller extends CI_Controller {
// redirect('published_forms');
}
public function toggle_responsive($form_id) {
public function toggle_responsive($form_id)
{
if (!$this->session->userdata('logged_in')) {
redirect('users/login');
}
@ -76,6 +81,4 @@ class Publish_controller extends CI_Controller {
echo json_encode(['success' => false, 'message' => 'Failed to update']);
}
}
}

View File

@ -1,7 +1,9 @@
<?php
class Response_submit extends CI_Controller {
public function view($form_id) {
class Response_submit extends CI_Controller
{
public function view($form_id)
{
$this->load->model('Response_model');
$data['form'] = $this->Response_model->get_form($form_id);
@ -17,7 +19,8 @@ class Response_submit extends CI_Controller {
redirect('responses/' . $form_id);
}
public function view_responses($form_id) {
public function view_responses($form_id)
{
$this->load->model('Response_model');
$data['form'] = $this->Response_model->get_form($form_id);
@ -29,7 +32,8 @@ class Response_submit extends CI_Controller {
}
public function submit_form() {
public function submit_form()
{
$this->load->model('Response_model');
$responses = $this->input->post('responses');
$user_id = $this->session->userdata('user_id'); // Assuming user_id is stored in session
@ -52,7 +56,7 @@ class Response_submit extends CI_Controller {
} else {
$answered_text = $response['options'];
}
} else if (isset($response['answered_text'])) {
} elseif (isset($response['answered_text'])) {
$answered_text = $response['answered_text'];
}
@ -71,7 +75,8 @@ class Response_submit extends CI_Controller {
// Method to list responses for a form
public function list_responses($form_id) {
public function list_responses($form_id)
{
$this->load->model('Response_model');
$data['form'] = $this->Response_model->get_form($form_id);
$data['responses'] = $this->Response_model->get_responses($form_id);
@ -82,7 +87,8 @@ class Response_submit extends CI_Controller {
}
// Method to view questions and answers for a specific response
public function viewresponse($response_id) {
public function viewresponse($response_id)
{
$this->load->model('Response_model');
$data['response'] = $this->Response_model->get_response($response_id);
$data['form'] = $this->Response_model->get_form_by_response($response_id); // Get form details
@ -94,7 +100,7 @@ class Response_submit extends CI_Controller {
}
public function summary($form_id)
{
{
$this->load->model('Form_model');
$this->load->model('Response_model');
@ -115,15 +121,52 @@ class Response_submit extends CI_Controller {
$data['form'] = $form;
$data['summary_data'] = $summary_data;
$this->load->view('templates/header');
$this->load->view('Forms/summary', $data);
}
public function __construct()
{
parent::__construct();
$this->load->model('response_model');
}
public function index()
{
$data['responses'] = $this->response_model->get_responses_with_details();
$this->load->view('templates/header');
$this->load->view('allresponse_details_view', $data);
$this->load->view('templates/footer');
}
}
public function response_summary()
{
$data['forms'] = $this->Response_model->get_forms();
$this->load->view('templates/header');
$this->load->view('responses/response_summary', $data);
$this->load->view('templates/footer');
}
public function response_summary_by_form($form_id)
{
$responses = $this->Response_model->get_response_summary_by_form($form_id);
$data = $this->prepare_data($responses);
$data['form_id'] = $form_id;
$this->load->view('templates/header');
$this->load->view('responses/summary', $data);
$this->load->view('templates/footer');
}
private function prepare_data($responses)
{
$data = [];
foreach ($responses as $response) {
$question_text = $response->question_text;
if (!isset($data[$question_text])) {
$data[$question_text] = ['type' => $response->question_type, 'answers' => []];
}
$data[$question_text]['answers'][] = $response->answer_text;
}
return $data;
}
}

View File

@ -1,4 +1,5 @@
<?php
class Users extends CI_Controller
{
//signup user
@ -10,7 +11,7 @@ class Users extends CI_Controller
$this->form_validation->set_rules('password', 'Password', 'required');
$this->form_validation->set_rules('password2', 'Confirm Passsword', 'matches[password]');
if ($this->form_validation->run() === FALSE) {
if ($this->form_validation->run() === false) {
$this->load->view('templates/header');
$this->load->view('users/register', $data);
$this->load->view('templates/footer');
@ -25,7 +26,6 @@ class Users extends CI_Controller
$this->session->set_flashdata('user_registered', 'You are now registered and can log in');
redirect('start');
}
}
@ -38,7 +38,7 @@ class Users extends CI_Controller
$this->form_validation->set_rules('username', 'Username', 'required');
$this->form_validation->set_rules('password', 'Password', 'required');
if ($this->form_validation->run() === FALSE) {
if ($this->form_validation->run() === false) {
$this->load->view('templates/header');
$this->load->view('users/login', $data);
$this->load->view('templates/footer');
@ -85,7 +85,6 @@ class Users extends CI_Controller
$this->session->set_flashdata('user_loggedout', 'You are now logged out');
redirect('users/login');
}
// check if username exists
public function check_username_exists($username)
@ -122,6 +121,3 @@ class Users extends CI_Controller
// }
// }
}
?>

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -1,8 +1,10 @@
<?php
class Create_model extends CI_Model {
public function details() {
class Create_model extends CI_Model
{
public function details()
{
// Retrieve user_id from session
$user_id = $this->session->userdata('user_id');
@ -20,8 +22,6 @@ class Create_model extends CI_Model {
$formId = $this->db->insert_id();
$this->session->set_userdata('form_id', $formId);
return $formId;
return $formId;
}
}
?>

View File

@ -1,9 +1,22 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class Form_model extends CI_Model
{
public function get_published_value($form_id)
{
$this->db->select('is_published');
$this->db->from('forms'); // Adjust 'forms' to your table name
$this->db->where('id', $form_id);
$query = $this->db->get();
if ($query->num_rows() > 0) {
return $query->row()->is_published;
} else {
return null; // or 0 or another default value if you prefer
}
}
// Function to get form details by ID
public function get_form_by_id($form_id)
{
@ -13,14 +26,16 @@ class Form_model extends CI_Model
return $query->row();
}
// Get the total number of forms
public function get_total_forms($user_id) {
public function get_total_forms($user_id)
{
// Ensure user_id is passed as a parameter and used in the query
$this->db->where('user_id', $user_id);
return $this->db->count_all_results('forms'); // Use count_all_results to ensure WHERE conditions are applied
}
// Function to count published forms
public function get_published_forms($user_id) {
public function get_published_forms($user_id)
{
// Ensure user_id and is_published are passed as parameters and used in the query
$this->db->where('user_id', $user_id);
$this->db->where('is_published', 1);
@ -65,7 +80,7 @@ class Form_model extends CI_Model
$this->db->trans_complete();
if ($this->db->trans_status() === FALSE) {
if ($this->db->trans_status() === false) {
return false;
} else {
return true;

View File

@ -1,8 +1,10 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
class Frontend_model extends CI_Model {
defined('BASEPATH') or exit('No direct script access allowed');
class Frontend_model extends CI_Model
{
public function getforms()
{
// Get the user_id from session
@ -21,7 +23,8 @@ class Frontend_model extends CI_Model {
return $query->result(); // Return the result as an array of objects
}
public function deleteForm($id){
public function deleteForm($id)
{
return $this->db->delete('forms', ['id' => $id]);
}
public function getFormById($form_id)
@ -29,13 +32,12 @@ class Frontend_model extends CI_Model {
$query = $this->db->get_where('forms', ['id' => $form_id]);
return $query->row_array();
}
public function getforms_draft($user_id) {
public function getforms_draft($user_id)
{
$this->db->where('is_published', 0);
$this->db->where('user_id', $user_id);
$this->db->order_by('created_at', 'DESC');
$query = $this->db->get('forms');
return $query->result();
}
}

View File

@ -1,7 +1,9 @@
<?php
class New_form_model extends CI_Model {
public function save_form_data($formId, $formData) {
class New_form_model extends CI_Model
{
public function save_form_data($formId, $formData)
{
if (!$formId || !isset($formData['questions'])) {
return false; // Handle error if formId is not valid or questions are missing
}
@ -36,7 +38,4 @@ class New_form_model extends CI_Model {
return true; // Return true indicating success
}
}
?>

View File

@ -1,22 +1,25 @@
<?php
class preview_model extends CI_Model {
public function get_form($form_id) {
class preview_model extends CI_Model
{
public function get_form($form_id)
{
$this->db->where('id', $form_id);
$query = $this->db->get('forms');
return $query->row();
}
public function get_questions($form_id) {
public function get_questions($form_id)
{
$this->db->where('form_id', $form_id);
$query = $this->db->get('questions');
return $query->result(); // Ensure this returns objects with the 'is_required' field
}
public function get_options($question_id) {
public function get_options($question_id)
{
$this->db->where('question_id', $question_id);
$query = $this->db->get('options');
return $query->result(); // Ensure this returns the options related to the question
}
}

View File

@ -1,19 +1,21 @@
<?php
class Publish_model extends CI_Model {
// Method to update form details including is_published status
public function update_form($form_id, $data) {
class Publish_model extends CI_Model
{
// Method to update form details including is_published status
public function update_form($form_id, $data)
{
$this->db->where('id', $form_id);
return $this->db->update('forms', $data);
}
}
// Method to retrieve published forms by user
public function get_published_forms_by_user($user_id) {
// Method to retrieve published forms by user
public function get_published_forms_by_user($user_id)
{
$this->db->where('user_id', $user_id);
$this->db->where('is_published', 1);
$this->db->order_by('id', 'DESC'); // Order by id column, most recent first
$query = $this->db->get('forms');
return $query->result();
}
}
}

View File

@ -1,12 +1,15 @@
<?php
class Response_model extends CI_Model
{
public function __construct() {
public function __construct()
{
$this->load->database();
}
// Get the total number of responses
public function get_total_responses($user_id) {
public function get_total_responses($user_id)
{
// Join the responses table with the forms table
$this->db->select('responses.id');
$this->db->from('responses');
@ -168,5 +171,58 @@ class Response_model extends CI_Model
return $summary_data;
}
}
public function get_responses_with_details()
{
// Fetch responses with form title, submission time, and user email
$this->db->select('responses.id as response_id, forms.title as form_title, responses.submitted_at, users.email');
$this->db->from('responses');
$this->db->join('forms', 'responses.form_id = forms.id');
$this->db->join('users', 'responses.user_id = users.id');
$this->db->order_by('responses.submitted_at', 'DESC');
$responses_query = $this->db->get();
$responses = $responses_query->result();
$response_details = [];
foreach ($responses as $response) {
// Fetch questions and answers for each response
$this->db->select('questions.text, response_answers.answered_text');
$this->db->from('response_answers');
$this->db->join('questions', 'response_answers.question_id = questions.id');
$this->db->where('response_answers.response_id', $response->response_id);
$questions_query = $this->db->get();
$questions_and_answers = $questions_query->result();
if (!isset($response_details[$response->form_title])) {
$response_details[$response->form_title] = [];
}
$response_details[$response->form_title][] = [
'submitted_at' => $response->submitted_at,
'email' => $response->email,
'questions_and_answers' => $questions_and_answers
];
}
return $response_details;
}
public function get_response_summary_by_form($form_id)
{
$this->db->select('questions.text as question_text, answers.text as answer_text, questions.type as question_type');
$this->db->from('responses');
$this->db->join('answers', 'responses.id = answers.response_id');
$this->db->join('questions', 'answers.question_id = questions.id');
$this->db->where('responses.form_id', $form_id);
$query = $this->db->get();
return $query->result();
}
public function get_forms()
{
$this->db->select('id, title');
$this->db->from('forms');
$query = $this->db->get();
return $query->result();
}
}

View File

@ -1,7 +1,7 @@
<?php
class Updation_model extends CI_Model
{
public function get_form($form_id)
{
$this->db->where('id', $form_id);
@ -9,6 +9,7 @@ class Updation_model extends CI_Model
return $query->row_array();
}
public function get_questions($form_id)
{
$this->db->where('form_id', $form_id);
@ -90,8 +91,4 @@ class Updation_model extends CI_Model
$this->db->delete('options');
}
}
}
?>

View File

@ -1,49 +1,48 @@
<?php
class User_model extends CI_Model{
public function register($enc_password){
$data = array(
'email'=> $this->input->post('email'),
'username'=> $this->input->post('username'),
'password'=> $enc_password
);
return $this->db->insert('users', $data);
class User_model extends CI_Model
{
public function register($enc_password)
{
$data = array(
'email' => $this->input->post('email'),
'username' => $this->input->post('username'),
'password' => $enc_password
);
return $this->db->insert('users', $data);
}
public function login($username,$password){
$this->db->where('username',$username);
$this->db->where('password',$password);
public function login($username, $password)
{
$this->db->where('username', $username);
$this->db->where('password', $password);
$result = $this->db->get('users');
if($result->num_rows()==1){
if ($result->num_rows() == 1) {
return $result->row(0)->id;
}
else{
} else {
return false;
}
}
public function check_username_exists($username){
$query = $this->db->get_where('users',array('username'=>$username));
if(empty($query->row_array())){
public function check_username_exists($username)
{
$query = $this->db->get_where('users', array('username' => $username));
if (empty($query->row_array())) {
return true;
}
else{
} else {
return false;
}
}
}
}
public function check_email_exists($email){
$query = $this->db->get_where('users',array('email'=>$email));
if(empty($query->row_array())){
public function check_email_exists($email)
{
$query = $this->db->get_where('users', array('email' => $email));
if (empty($query->row_array())) {
return true;
}
else{
} else {
return false;
}
}
}
}
}
?>

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -28,16 +28,16 @@
</div>
<div class="card-body">
<div id="charts">
<?php foreach ($summary_data as $question): ?>
<?php foreach ($summary_data as $question) : ?>
<h5><?php echo $question['text']; ?></h5>
<?php if (is_array($question['answers'])): ?>
<?php if (is_array($question['answers'])) : ?>
<div class="chart-container">
<canvas id="chart-<?php echo $question['question_id']; ?>"></canvas>
</div>
<?php else: ?>
<?php else : ?>
<div class="short-answer">
<ul>
<?php foreach ($question['answers'] as $answer): ?>
<?php foreach ($question['answers'] as $answer) : ?>
<li><?php echo $answer; ?></li>
<?php endforeach; ?>
</ul>

View File

@ -21,7 +21,7 @@
<div class="col-md-12 mt-4">
<div class="card">
<div class="card-header">
<?php if ($this->session->flashdata('status')): ?>
<?php if ($this->session->flashdata('status')) : ?>
<div class="alert alert-success">
<?= $this->session->flashdata('status'); ?>
</div>
@ -32,7 +32,7 @@
<table id="basetable1" class="table table-bordered">
<thead>
<tr>
<th>Drafts</th>
<th>Serial No.</th>
<th>Title</th>
<th>Created On</th>
<th>Edit</th>
@ -43,7 +43,7 @@
<tbody>
<?php
$serialNumber = 1; // Initialize the counter variable
foreach ($forms as $row): ?>
foreach ($forms as $row) : ?>
<tr>
<td><?php echo $serialNumber++; ?></td>
<td class="title-column"><?php echo $row->title; ?></td>

View File

@ -1,12 +1,18 @@
<!DOCTYPE html>
<html lang="en">
<head>
<!-- Other head elements -->
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Form List</title>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0-beta3/css/all.min.css">
<link rel="stylesheet" href="https://fonts.googleapis.com/icon?family=Material+Icons">
<!-- <link rel="stylesheet" href="styles.css"> -->
<link rel="stylesheet" href=" < ?php echo base_url(); ?>assets/css/header_styles.css">
<style>
/* CSS styles */
.title-column {
@ -35,15 +41,20 @@
}
.card-title {
color: rgb(103, 58, 183); /* Match the color theme */
color: rgb(103, 58, 183);
/* Match the color theme */
margin-bottom: 10px;
font-size: 20px; /* Increase the font size of the title */
font-weight: bold; /* Make the title bold */
font-size: 20px;
/* Increase the font size of the title */
font-weight: bold;
/* Make the title bold */
}
.card-text {
font-size: 28px; /* Increase the font size */
font-weight: bold; /* Make the text bold */
font-size: 28px;
/* Increase the font size */
font-weight: bold;
/* Make the text bold */
}
.card-text.green {
@ -65,16 +76,56 @@
.card-text.purple {
color: #6f42c1;
}
.btn-icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 25px;
height: 25px;
/* background-color: rgb(103, 58, 183); */
border-radius: 4px;
color: white;
text-decoration: none;
font-size: 16px;
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
transition: background-color 0.3s, transform 0.3s, box-shadow 0.3s;
margin: 0 5px;
position: relative;
}
.btn-icon:hover {
background-color: rgba(255, 255, 255, 0.2);
transform: scale(1.1);
box-shadow: 0 6px 8px rgba(0, 0, 0, 0.2);
}
.btn-icon.disabled {
background-color: #ccc;
color: #888;
cursor: not-allowed;
box-shadow: none;
pointer-events: none;
}
.btn-icon.disabled:hover {
background-color: #ccc;
transform: none;
}
</style>
</head>
<body>
<div class="container">
<div class="container">
<div class="row">
<div class="col-md-4">
<div class="card card-stats">
<div class="card-body">
<h5 class="card-title">Total Forms Created</h5>
<p class="card-text" id="total-forms"><?php echo $total_forms; ?></p>
<p class="card-text" id="total-forms">
<?php echo $total_forms; ?>
</p>
</div>
</div>
</div>
@ -82,7 +133,8 @@
<div class="card card-stats">
<div class="card-body">
<h5 class="card-title">Published Forms</h5>
<p class="card-text" id="published-forms"><?php echo $published_forms; ?></p>
<p class="card-text" id="published-forms">
<?php echo $published_forms; ?></p>
</div>
</div>
</div>
@ -90,7 +142,8 @@
<div class="card card-stats">
<div class="card-body">
<h5 class="card-title">Responses Submitted</h5>
<p class="card-text" id="total-responses"><?php echo $total_responses; ?></p>
<p class="card-text" id="total-responses">
<?php echo $total_responses; ?></p>
</div>
</div>
</div>
@ -101,7 +154,7 @@
<div class="col-md-12 mt-4 ">
<div class="card">
<div class="card-header">
<?php if ($this->session->flashdata('status')): ?>
<?php if ($this->session->flashdata('status')) : ?>
<div class="alert alert-success">
<?= $this->session->flashdata('status'); ?>
</div>
@ -113,33 +166,68 @@
<table id="basetable1" class="table table-bordered">
<thead>
<tr>
<th>Forms</th>
<th>Serial No.</th>
<th>Title</th>
<th>Description</th>
<th>Created On</th>
<th>Status</th>
<th>Actions</th>
<th>Responses</th>
</tr>
</thead>
<tbody>
<?php
$serialNumber = 1; // Initialize the counter variable
foreach ($forms as $row): ?>
<tr class="<?php echo ($row->is_published ? '' : 'draft-row'); ?>">
<td><?php echo $serialNumber++; ?></td>
<td class="title-column">
<a href="<?php echo base_url('publish/' . $row->id); ?>"><?php echo $row->title; ?></a>
foreach ($forms as $row) : ?>
<tr
class="<?php echo($row->is_published ? '' : 'draft-row'); ?>">
<td><?php echo $serialNumber++; ?>
</td>
<td><?php echo $row->description; ?></td>
<td><?php echo $row->created_at; ?></td>
<td style="color: <?php echo ($row->is_published ? '#006400' : 'red'); ?>;">
<?php echo ($row->is_published ? 'Published' : 'Draft'); ?>
<td class="title-column">
<a
href="<?php echo base_url('publish/' . $row->id); ?>"><?php echo $row->title; ?></a>
</td>
<td><?php echo $row->description; ?>
</td>
<td><?php echo $row->created_at; ?>
</td>
<td
style="color: <?php echo($row->is_published ? '#006400' : 'red'); ?>;">
<?php echo($row->is_published ? 'Published' : 'Draft'); ?>
</td>
<td>
<a href="<?php echo base_url('responses/' . $row->id); ?>">
<?php if ($row->is_published == 0) : ?>
<!-- Buttons are enabled -->
<a href="<?php echo base_url('edit/' . $row->id); ?>"
class="btn-icon" title="Edit">
<i class="fas fa-edit"></i> <!-- For Font Awesome -->
</a>
<a href="<?php echo base_url('forms/delete/' . $row->id); ?>"
class="btn-icon" title="Delete">
<i class="fas fa-trash"></i> <!-- For Font Awesome -->
</a>
<?php else : ?>
<!-- Buttons are disabled -->
<span class="btn-icon disabled" title="Edit">
<i class="fas fa-edit"></i> <!-- For Font Awesome -->
</span>
<a href="<?php echo base_url('forms/delete/' . $row->id); ?>"
class="btn-icon" title="Delete">
<i class="fas fa-trash"></i> <!-- For Font Awesome -->
</a>
<?php endif; ?>
</td>
<td>
<a
href="<?php echo base_url('responses/' . $row->id); ?>">
<i class="fas fa-eye"></i> <!-- Eye icon -->
</a>
</td>
</tr>
<?php endforeach; ?>
</tbody>
@ -149,3 +237,8 @@
</div>
</div>
</div>
<script>
document.getElementById('total-responses').parentNode.addEventListener('click', function() {
window.location.href = 'total_responses';
});
</script>

View File

@ -0,0 +1,135 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Response Details</title>
<link rel="stylesheet" href="https://bootswatch.com/3/flatly/bootstrap.min.css">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/datatables/1.11.5/css/jquery.dataTables.min.css">
<style>
.question-label {
display: inline;
margin-bottom: 11px;
padding: 0;
border: none;
background: none;
}
.form-section {
border: 2px solid #ddd; /* Thicker border */
border-radius: 5px;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); /* Box shadow */
padding: 15px;
background: #fff;
margin-bottom: 15px;
transition: transform 0.3s, box-shadow 0.3s;
}
.form-section:hover {
transform: scale(1.02); /* Pop-out effect */
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3); /* Enhanced box shadow on hover */
}
#scroll-up-btn {
position: fixed;
bottom: 20px;
right: 20px;
display: none;
z-index: 9999; /* Ensure it's above other content */
background-color: #007bff; /* Button color */
color: #fff; /* Text color */
border: none;
border-radius: 50%; /* Rounded button */
width: 50px;
height: 50px;
text-align: center;
line-height: 50px; /* Center text vertically */
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3); /* Box shadow */
font-size: 20px; /* Font size */
}
#scroll-up-btn:hover {
background-color: #0056b3; /* Darker color on hover */
}
.dataTables_wrapper .dataTables_paginate .paginate_button {
padding: 5px 10px;
margin: 0 2px;
border: 2px solid #007bff; /* Thicker border for pagination */
border-radius: 3px;
background-color: #f8f9fa;
}
.dataTables_wrapper .dataTables_paginate .paginate_button.current,
.dataTables_wrapper .dataTables_paginate .paginate_button:hover {
background-color: #007bff;
color: #fff;
}
table.dataTable thead th {
border-bottom: 2px solid #007bff; /* Thicker border for table header */
}
table.dataTable tbody td, table.dataTable thead th {
border: 2px solid #007bff; /* Thicker border for table cells */
}
.response-count {
font-weight: bold;
}
</style>
</head>
<body>
<div class="container">
<?php foreach ($responses as $form_title => $form_responses) : ?>
<div class="form-section">
<h2><?php echo $form_title; ?></h2>
<p class="response-count">Number of responses: <span><?php echo count($form_responses); ?></span></p> <!-- Display response count -->
<table class="table table-bordered" id="responses-table">
<thead>
<tr>
<th>Question</th>
<th>Answers</th>
</tr>
</thead>
<tbody>
<?php
$all_questions = [];
foreach ($form_responses as $response) {
foreach ($response['questions_and_answers'] as $qa) {
if (!isset($all_questions[$qa->text])) {
$all_questions[$qa->text] = [];
}
$all_questions[$qa->text][] = $qa->answered_text;
}
}
?>
<?php foreach ($all_questions as $question => $answers) : ?>
<tr>
<td><?php echo $question; ?></td>
<td><?php echo implode(", ", $answers); ?></td>
</tr>
<?php endforeach; ?>
</tbody>
</table>
</div>
<?php endforeach; ?>
</div>
<button id="scroll-up-btn" class="btn"></button>
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/datatables/1.11.5/js/jquery.dataTables.min.js"></script>
<script>
$(document).ready(function() {
$('#responses-table').DataTable();
var scrollUpBtn = document.getElementById('scroll-up-btn');
window.addEventListener('scroll', function() {
if (window.scrollY > 200) {
scrollUpBtn.style.display = 'block';
} else {
scrollUpBtn.style.display = 'none';
}
});
scrollUpBtn.addEventListener('click', function() {
window.scrollTo({ top: 0, behavior: 'smooth' });
});
});
</script>
</body>
</html>

View File

@ -15,14 +15,14 @@
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script src="https://cdn.datatables.net/1.11.5/js/jquery.dataTables.min.js"></script>
<!-- Add SweetAlert CSS and JS -->
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/sweetalert2@11/dist/sweetalert2.min.css">
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/sweetalert2@11/dist/sweetalert2.min.css">
<script src="https://cdn.jsdelivr.net/npm/sweetalert2@11"></script>
</head>
<body>
<style>
.custom-select {
.custom-select {
width: 220px;
height: 44px;
display: block;
@ -33,13 +33,12 @@
background-image: none;
border: 1px solid #dce4ec;
border-radius: 4px;
}
}
</style>
<!-- Navbar -->
<nav class="navbar navbar-custom">
<div class="container">
<?php if ($this->session->userdata('logged_in')): ?>
<?php if ($this->session->userdata('logged_in')) : ?>
<div class="navbar-header">
<a class="navbar-brand" href="<?php echo base_url(); ?>">Google Forms</a>
</div>
@ -47,41 +46,41 @@
<div id="navbar" class="navbar-collapse">
<ul class="nav navbar-nav">
<?php if ($this->session->userdata('logged_in')): ?>
<?php if ($this->session->userdata('logged_in')) : ?>
<li><a href="<?php echo base_url(); ?>published_forms">Published Forms</a></li>
<li><a href="<?php echo base_url(); ?>drafts">Drafts</a></li>
<?php endif; ?>
</ul>
<ul class="nav navbar-nav navbar-right">
<?php if (!$this->session->userdata('logged_in')): ?>
<?php if (!$this->session->userdata('logged_in')) : ?>
<li><a href="<?php echo base_url(); ?>users/login">Login</a></li>
<li><a href="<?php echo base_url(); ?>users/register">Register</a></li>
<?php endif; ?>
<?php if ($this->session->userdata('logged_in')): ?>
<?php if ($this->session->userdata('logged_in')) : ?>
<li><a href="<?php echo base_url(); ?>homepage/title">Create Form</a></li>
<li><a href="<?php echo base_url(); ?>users/logout">Logout</a></li>
<?php endif; ?>
</ul>
</div>
</div>
</nav>
</nav>
<!-- Alert Messages -->
<div class="container">
<?php if ($this->session->flashdata('user_registered')): ?>
<?php if ($this->session->flashdata('user_registered')) : ?>
<p class="alert alert-success"><?php echo $this->session->flashdata('user_registered'); ?></p>
<?php endif; ?>
<?php if ($this->session->flashdata('login_failed')): ?>
<?php if ($this->session->flashdata('login_failed')) : ?>
<p class="alert alert-danger"><?php echo $this->session->flashdata('login_failed'); ?></p>
<?php endif; ?>
<?php if ($this->session->flashdata('user_loggedin')): ?>
<?php if ($this->session->flashdata('user_loggedin')) : ?>
<p class="alert alert-success"><?php echo $this->session->flashdata('user_loggedin'); ?></p>
<?php endif; ?>
<?php if ($this->session->flashdata('user_loggedout')): ?>
<?php if ($this->session->flashdata('user_loggedout')) : ?>
<p class="alert alert-success"><?php echo $this->session->flashdata('user_loggedout'); ?></p>
<?php endif; ?>
</div>
@ -102,7 +101,7 @@
<button id="add-section-btn" class="btn btn-primary">+</button>
</div>
<div id="form-container">
<?php foreach ($questions as $question): ?>
<?php foreach ($questions as $question) : ?>
<div class="form-section" data-index="<?php echo $question['id']; ?>" data-type="<?php echo $question['type']; ?>">
<div class="header-row">
<input type="text" class="form-control untitled-question" placeholder="Untitled Question" rows="1" value="<?php echo $question['text']; ?>">
@ -123,7 +122,7 @@
<?php
$this->db->where('question_id', $question['id']);
$options = $this->db->get('options')->result_array();
foreach ($options as $option):
foreach ($options as $option) :
$iconClass = ($question['type'] === 'multiple-choice' || $question['type'] === 'dropdown') ? 'fa-circle' : 'fa-square';
?>
<div class="option">
@ -133,11 +132,11 @@
</div>
<?php endforeach; ?>
</div>
<?php if ($question['type'] === 'multiple-choice' || $question['type'] === 'checkboxes' || $question['type'] === 'dropdown'): ?>
<?php if ($question['type'] === 'multiple-choice' || $question['type'] === 'checkboxes' || $question['type'] === 'dropdown') : ?>
<button class="btn btn-primary add-option-btn">Add Option</button>
<?php endif; ?>
</div>
<?php endforeach; ?>
<?php endforeach; ?>
</div>
<button id="submit-btn" class="btn btn-success btn-custom">Submit</button>
@ -148,18 +147,19 @@
<script src="<?php echo base_url('assets/js/jquery-ui.js'); ?>"></script>
<script>
$(document).ready(function () {
$(document).ready(function() {
var base_url = '<?php echo base_url(); ?>';
var activeSection = null;
$('#form-container').sortable({
placeholder: 'ui-state-highlight',
start: function (event, ui) {
start: function(event, ui) {
ui.placeholder.height(ui.item.height());
},
stop: function (event, ui) {
stop: function(event, ui) {
positionAddSectionButton();
}
});
function positionAddSectionButton() {
if (activeSection) {
var position = activeSection.position();
@ -192,12 +192,12 @@
</div>
`;
section.find('.options-container').append(optionHtml);
}
}
// Add section button functionality
$('#add-section-btn').on('click', function () {
$('#add-section-btn').on('click', function() {
createFormSection();
$('.form-section').removeClass('active');
activeSection = $('.form-section').last();
@ -252,7 +252,7 @@
// Initially hide add option button
newSection.find('.add-option-btn').hide();
newSection.on('click', function () {
newSection.on('click', function() {
$('.form-section').removeClass('active');
$(this).addClass('active');
activeSection = $(this);
@ -284,24 +284,24 @@
}
});
$(document).on('click', '.add-option-btn', function () {
$(document).on('click', '.add-option-btn', function() {
var $section = $(this).closest('.form-section');
var questionType = $section.find('.question-type').val();
appendNewOption($section, questionType);
});
$(document).on('click', '.delete-section-icon', function () {
$(document).on('click', '.delete-section-icon', function() {
$(this).closest('.form-section').remove();
activeSection = null;
positionAddSectionButton();
});
$(document).on('click', '.delete-option-icon', function () {
$(document).on('click', '.delete-option-icon', function() {
$(this).closest('.option').remove();
});
$('.form-section').each(function () {
$(this).on('click', function () {
$('.form-section').each(function() {
$(this).on('click', function() {
$('.form-section').removeClass('active');
$(this).addClass('active');
activeSection = $(this);
@ -309,15 +309,15 @@
});
});
$(window).on('resize', function () {
$(window).on('resize', function() {
positionAddSectionButton();
});
// positionAddSectionButton();
$(document).ready(function () {
$(document).ready(function() {
var base_url = '<?php echo base_url(); ?>';
$('#submit-btn').on('click', function () {
$('#submit-btn').on('click', function() {
var formData = collectFormData();
formData['form_id'] = <?php echo $form['id']; ?>;
@ -330,9 +330,11 @@
$.ajax({
url: base_url + 'Form_controller/update_form',
type: 'POST',
data: { formData: formData },
data: {
formData: formData
},
dataType: 'JSON',
success: function (response) {
success: function(response) {
if (response.status === 'success') {
Swal.fire({
title: 'Success!',
@ -353,7 +355,7 @@
});
}
},
error: function (error) {
error: function(error) {
Swal.fire({
title: 'Error!',
text: 'Error updating form!',
@ -373,7 +375,7 @@
questions: []
};
$('.form-section').each(function () {
$('.form-section').each(function() {
var questionData = {
id: $(this).data('index'),
text: $(this).find('.untitled-question').val(),
@ -382,7 +384,7 @@
options: []
};
$(this).find('.option-label').each(function () {
$(this).find('.option-label').each(function() {
questionData.options.push($(this).val());
});
@ -395,20 +397,31 @@
function validateFormData(formData) {
for (let question of formData.questions) {
if (!question.text.trim()) {
return { isValid: false, message: 'All questions must have text.' };
return {
isValid: false,
message: 'All questions must have text.'
};
}
if ((question.type === 'multiple-choice' || question.type === 'checkboxes' || question.type === 'dropdown') && question.options.length === 0) {
return { isValid: false, message: 'All options-based questions must have at least one option.' };
return {
isValid: false,
message: 'All options-based questions must have at least one option.'
};
}
for (let option of question.options) {
if (!option.trim()) {
return { isValid: false, message: 'All options must have text.' };
return {
isValid: false,
message: 'All options must have text.'
};
}
}
}
return { isValid: true };
return {
isValid: true
};
}
});
});
// Initialize

View File

@ -1,8 +1,9 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
echo "\nERROR: ",
$heading,
"\n\n",
$message,
"\n\n";
$heading,
"\n\n",
$message,
"\n\n";

View File

@ -1,8 +1,9 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
echo "\nDatabase error: ",
$heading,
"\n\n",
$message,
"\n\n";
$heading,
"\n\n",
$message,
"\n\n";

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
@ -7,15 +7,14 @@ Message: <?php echo $message, "\n"; ?>
Filename: <?php echo $exception->getFile(), "\n"; ?>
Line Number: <?php echo $exception->getLine(); ?>
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === TRUE): ?>
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === true) : ?>
Backtrace:
<?php foreach ($exception->getTrace() as $error): ?>
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0): ?>
<?php foreach ($exception->getTrace() as $error) : ?>
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0) : ?>
File: <?php echo $error['file'], "\n"; ?>
Line: <?php echo $error['line'], "\n"; ?>
Function: <?php echo $error['function'], "\n\n"; ?>
<?php endif ?>
<?php endforeach ?>
<?php endif ?>
<?php endforeach ?>
<?php endif ?>

View File

@ -1,8 +1,9 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
echo "\nERROR: ",
$heading,
"\n\n",
$message,
"\n\n";
$heading,
"\n\n",
$message,
"\n\n";

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
@ -7,15 +7,14 @@ Message: <?php echo $message, "\n"; ?>
Filename: <?php echo $filepath, "\n"; ?>
Line Number: <?php echo $line; ?>
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === TRUE): ?>
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === true) : ?>
Backtrace:
<?php foreach (debug_backtrace() as $error): ?>
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0): ?>
<?php foreach (debug_backtrace() as $error) : ?>
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0) : ?>
File: <?php echo $error['file'], "\n"; ?>
Line: <?php echo $error['line'], "\n"; ?>
Function: <?php echo $error['function'], "\n\n"; ?>
<?php endif ?>
<?php endforeach ?>
<?php endif ?>
<?php endforeach ?>
<?php endif ?>

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -1,5 +1,5 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
?><!DOCTYPE html>
<html lang="en">
<head>

View File

@ -1,5 +1,5 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
?><!DOCTYPE html>
<html lang="en">
<head>

View File

@ -1,5 +1,5 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
?>
<div style="border:1px solid #990000;padding-left:20px;margin:0 0 10px 0;">
@ -11,13 +11,10 @@ defined('BASEPATH') OR exit('No direct script access allowed');
<p>Filename: <?php echo $exception->getFile(); ?></p>
<p>Line Number: <?php echo $exception->getLine(); ?></p>
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === TRUE): ?>
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === true) : ?>
<p>Backtrace:</p>
<?php foreach ($exception->getTrace() as $error): ?>
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0): ?>
<?php foreach ($exception->getTrace() as $error) : ?>
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0) : ?>
<p style="margin-left:10px">
File: <?php echo $error['file']; ?><br />
Line: <?php echo $error['line']; ?><br />

View File

@ -1,5 +1,5 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
?><!DOCTYPE html>
<html lang="en">
<head>

View File

@ -1,5 +1,5 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
?>
<div style="border:1px solid #990000;padding-left:20px;margin:0 0 10px 0;">
@ -11,13 +11,10 @@ defined('BASEPATH') OR exit('No direct script access allowed');
<p>Filename: <?php echo $filepath; ?></p>
<p>Line Number: <?php echo $line; ?></p>
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === TRUE): ?>
<?php if (defined('SHOW_DEBUG_BACKTRACE') && SHOW_DEBUG_BACKTRACE === true) : ?>
<p>Backtrace:</p>
<?php foreach (debug_backtrace() as $error): ?>
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0): ?>
<?php foreach (debug_backtrace() as $error) : ?>
<?php if (isset($error['file']) && strpos($error['file'], realpath(BASEPATH)) !== 0) : ?>
<p style="margin-left:10px">
File: <?php echo $error['file'] ?><br />
Line: <?php echo $error['line'] ?><br />

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -16,42 +16,42 @@
<h4><?php echo $form->description; ?></h4>
</div>
<?php foreach ($questions as $question): ?>
<?php foreach ($questions as $question) : ?>
<div class="form-section">
<div class="question-section">
<p class="question-label"><?php echo $question->text; ?></p>
</div>
<?php if ($question->type == 'multiple-choice'): ?>
<?php if ($question->type == 'multiple-choice') : ?>
<div class="options-container">
<?php foreach ($question->options as $option): ?>
<?php foreach ($question->options as $option) : ?>
<div class="option">
<input type="radio" name="option-<?php echo $question->id; ?>" disabled>
<label><?php echo $option->option_text; ?></label>
</div>
<?php endforeach; ?>
</div>
<?php elseif ($question->type == 'checkboxes'): ?>
<?php elseif ($question->type == 'checkboxes') : ?>
<div class="options-container">
<?php foreach ($question->options as $option): ?>
<?php foreach ($question->options as $option) : ?>
<div class="option">
<input type="checkbox" name="option-<?php echo $question->id; ?>" disabled>
<label><?php echo $option->option_text; ?></label>
</div>
<?php endforeach; ?>
</div>
<?php elseif ($question->type == 'short-answer'): ?>
<?php elseif ($question->type == 'short-answer') : ?>
<div class="options-container">
<input type="text" class="form-control" placeholder="Short answer text" disabled>
</div>
<?php elseif ($question->type == 'paragraph'): ?>
<?php elseif ($question->type == 'paragraph') : ?>
<div class="options-container">
<textarea class="form-control" placeholder="Paragraph text" disabled></textarea>
</div>
<?php elseif ($question->type == 'dropdown'): ?>
<?php elseif ($question->type == 'dropdown') : ?>
<div class="options-container">
<select class="form-control" disabled>
<?php foreach ($question->options as $option): ?>
<?php foreach ($question->options as $option) : ?>
<option><?php echo $option->option_text; ?></option>
<?php endforeach; ?>
</select>
@ -59,7 +59,7 @@
<?php endif; ?>
</div>
<?php endforeach; ?>
<a href="<?php echo base_url('Publish_controller/publish_form/'.$form->id); ?>" class="btn btn-success">Publish</a>
<a href="<?php echo base_url('Publish_controller/publish_form/' . $form->id); ?>" class="btn btn-success">Publish</a>
<br>
</div>
</body>

View File

@ -35,42 +35,42 @@
<br>
<h4><?php echo $form->description; ?></h4>
</div>
<?php foreach ($questions as $question): ?>
<?php foreach ($questions as $question) : ?>
<div class="form-section">
<div class="question-section">
<p class="question-label"><?php echo $question->text; ?></p>
</div>
<?php if ($question->type == 'multiple-choice'): ?>
<?php if ($question->type == 'multiple-choice') : ?>
<div class="options-container">
<?php foreach ($question->options as $option): ?>
<?php foreach ($question->options as $option) : ?>
<div class="option">
<input type="radio" name="option-<?php echo $question->id; ?>" disabled>
<label><?php echo $option->option_text; ?></label>
</div>
<?php endforeach; ?>
</div>
<?php elseif ($question->type == 'checkboxes'): ?>
<?php elseif ($question->type == 'checkboxes') : ?>
<div class="options-container">
<?php foreach ($question->options as $option): ?>
<?php foreach ($question->options as $option) : ?>
<div class="option">
<input type="checkbox" name="option-<?php echo $question->id; ?>" disabled>
<label><?php echo $option->option_text; ?></label>
</div>
<?php endforeach; ?>
</div>
<?php elseif ($question->type == 'short-answer'): ?>
<?php elseif ($question->type == 'short-answer') : ?>
<div class="options-container">
<input type="text" class="form-control" placeholder="Short answer text" disabled>
</div>
<?php elseif ($question->type == 'paragraph'): ?>
<?php elseif ($question->type == 'paragraph') : ?>
<div class="options-container">
<textarea class="form-control" placeholder="Paragraph text" disabled></textarea>
</div>
<?php elseif ($question->type == 'dropdown'): ?>
<?php elseif ($question->type == 'dropdown') : ?>
<div class="options-container">
<select class="form-control" disabled>
<?php foreach ($question->options as $option): ?>
<?php foreach ($question->options as $option) : ?>
<option><?php echo $option->option_text; ?></option>
<?php endforeach; ?>
</select>

View File

@ -1,11 +1,9 @@
<!DOCTYPE html>
<!doctype html>
<html>
<head>
<head>
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>
</html>

View File

@ -3,7 +3,7 @@
<div class="col-md-12 mt-4">
<div class="card">
<div class="card-header">
<?php if ($this->session->flashdata('status')): ?>
<?php if ($this->session->flashdata('status')) : ?>
<div class="alert alert-success">
<?= $this->session->flashdata('status'); ?>
</div>
@ -15,7 +15,7 @@
<table id="basetable1" class="table table-bordered">
<thead>
<tr>
<th>Responses</th>
<th>Serial No.</th>
<th>Title</th>
<th>Response Link</th>
<th>Status</th>
@ -24,7 +24,7 @@
</thead>
<tbody>
<?php $serialNumber = 1;
foreach ($forms as $row): ?>
foreach ($forms as $row) : ?>
<tr>
<td><?php echo $serialNumber++; ?></td>
<td class="title-column"><?php echo $row->title; ?></td>

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="user-email">User Email: <?php echo $response->email; ?></p>
</div>
<?php foreach ($questions_and_answers as $question): ?>
<?php foreach ($questions_and_answers as $question) : ?>
<div class="form-section">
<div class="question-section">
<p class="form-control question-label"><?php echo $question->question_text; ?></p>

View File

@ -106,41 +106,41 @@
<h4><?php echo $form->description; ?></h4>
</div> -->
<?php if (isset($message)): ?>
<?php if (isset($message)) : ?>
<div id="popup-message" class="popup-message">
<p><?php echo $message; ?></p>
<button onclick="closePopup()">Close</button>
</div>
<?php else: ?>
<?php else : ?>
<form action="<?php echo base_url('response_submit/submit_form'); ?>" method="post" onsubmit="return validateForm();">
<input type="hidden" name="form_id" value="<?php echo $form->id; ?>">
<div class="form-section">
<?php foreach ($questions as $question): ?>
<?php foreach ($questions as $question) : ?>
<div class="question-container" data-required="<?php echo $question->is_required; ?>" data-type="<?php echo $question->type; ?>">
<input type="hidden" name="responses[<?php echo $question->id; ?>][question_id]" value="<?php echo $question->id; ?>">
<input type="hidden" name="responses[<?php echo $question->id; ?>][form_id]" value="<?php echo $form->id; ?>">
<label class="<?php echo $question->is_required ? 'required-field' : ''; ?>"><?php echo $question->text; ?></label>
<?php if ($question->type == 'multiple-choice'): ?>
<?php foreach ($question->options as $option): ?>
<?php if ($question->type == 'multiple-choice') : ?>
<?php foreach ($question->options as $option) : ?>
<div class="option">
<input type="radio" name="responses[<?php echo $question->id; ?>][options][]" value="<?php echo $option->option_text; ?>">
<label><?php echo $option->option_text; ?></label>
</div>
<?php endforeach; ?>
<?php elseif ($question->type == 'checkboxes'): ?>
<?php foreach ($question->options as $option): ?>
<?php elseif ($question->type == 'checkboxes') : ?>
<?php foreach ($question->options as $option) : ?>
<div class="option">
<input type="checkbox" name="responses[<?php echo $question->id; ?>][options][]" value="<?php echo $option->option_text; ?>">
<label><?php echo $option->option_text; ?></label>
</div>
<?php endforeach; ?>
<?php elseif ($question->type == 'short-answer'): ?>
<?php elseif ($question->type == 'short-answer') : ?>
<input type="text" class="form-control" name="responses[<?php echo $question->id; ?>][answered_text]" placeholder="Short answer text">
<?php elseif ($question->type == 'paragraph'): ?>
<?php elseif ($question->type == 'paragraph') : ?>
<textarea class="form-control" name="responses[<?php echo $question->id; ?>][answered_text]" placeholder="Paragraph text"></textarea>
<?php elseif ($question->type == 'dropdown'): ?>
<?php elseif ($question->type == 'dropdown') : ?>
<select class="form-control" name="responses[<?php echo $question->id; ?>][answered_text]">
<?php foreach ($question->options as $option): ?>
<?php foreach ($question->options as $option) : ?>
<option value="<?php echo $option->option_text; ?>"><?php echo $option->option_text; ?></option>
<?php endforeach; ?>
</select>

View File

@ -0,0 +1,17 @@
<div class="container">
<h2>Select a form to view summary</h2>
<?php foreach ($forms as $form) : ?>
<div class="form-section" data-form-id="<?php echo $form->id; ?>">
<h3><?php echo $form->title; ?></h3>
</div>
<?php endforeach; ?>
</div>
<script>
document.querySelectorAll('.form-section').forEach(function(section) {
section.addEventListener('click', function() {
var formId = this.getAttribute('data-form-id');
window.location.href = '<?php echo base_url('response_submit/response_summary_by_form/'); ?>' + formId;
});
});
</script>

View File

@ -0,0 +1,38 @@
<div class="container">
<h2>Summary for Form <?php echo $form_id; ?></h2>
<?php foreach ($data as $question => $info) : ?>
<div class="chart-container">
<h3><?php echo $question; ?></h3>
<canvas id="chart-<?php echo md5($question); ?>" width="400" height="400"></canvas>
</div>
<script>
var ctx = document.getElementById('chart-<?php echo md5($question); ?>').getContext('2d');
var labels = <?php echo json_encode(array_unique($info['answers'])); ?>;
var counts = labels.map(label => {
return <?php echo json_encode(array_count_values($info['answers'])); ?>[label];
});
var chartData = {
labels: labels,
datasets: [{
data: counts,
backgroundColor: labels.map(() => 'rgba(54, 162, 235, 0.2)'),
borderColor: labels.map(() => 'rgba(54, 162, 235, 1)'),
borderWidth: 1
}]
};
var chartType = '<?php echo ($info['type'] == 'checkbox') ? 'bar' : 'pie'; ?>';
new Chart(ctx, {
type: chartType,
data: chartData,
options: {
responsive: true,
maintainAspectRatio: false
}
});
</script>
<?php endforeach; ?>
</div>
<script src="https://cdn.jsdelivr.net/npm/chart.js"></script>

View File

@ -18,7 +18,7 @@
<div class="col-md-12 mt-4">
<div class="card">
<div class="card-header">
<?php if ($this->session->flashdata('status')): ?>
<?php if ($this->session->flashdata('status')) : ?>
<div class="alert alert-success">
<?= $this->session->flashdata('status'); ?>
</div>
@ -36,7 +36,7 @@
</tr>
</thead>
<tbody>
<?php foreach ($responses as $response): ?>
<?php foreach ($responses as $response) : ?>
<tr>
<td class="username-column"><?php echo $response->username; ?></td>
<td><?php echo $response->submitted_at; ?></td>

View File

@ -19,16 +19,16 @@
<style>
.navbar-custom .navbar-brand,
.navbar-custom .navbar-nav .nav-link {
color: white !important; /* Forces the text color to be white */
text-decoration: none !important; /* Ensures no underline */
background: none !important; /* Ensures no background color */
color: white !important;
text-decoration: none !important;
background: none !important;
}
.navbar-custom .navbar-brand:hover,
.navbar-custom .navbar-nav .nav-link:hover {
color: white !important; /* Keeps text color white on hover */
text-decoration: none !important; /* Ensures no underline on hover */
background: none !important; /* Ensures no background color on hover */
color: white !important;
text-decoration: none !important;
background: none !important;
}
.title-column {
color: darkblue;
@ -114,7 +114,7 @@
<nav class="navbar navbar-inverse" style="background-color: rgb(103, 58, 183);">
<div class="container" style="background-color: rgb(103, 58, 183);">
<?php if ($this->session->userdata('logged_in')): ?>
<?php if ($this->session->userdata('logged_in')) : ?>
<div class="navbar-header">
<a class="navbar-brand" href="<?php echo base_url(); ?>">Google Forms</a>
</div>
@ -122,18 +122,18 @@
<div id="navbar">
<ul class="nav navbar-nav">
<?php if ($this->session->userdata('logged_in')): ?>
<?php if ($this->session->userdata('logged_in')) : ?>
<li><a href="<?php echo base_url(); ?>published_forms">Published Forms</a></li>
<li><a href="<?php echo base_url(); ?>drafts">Drafts</a></li>
<!-- <li><a href="<?php echo base_url(); ?>drafts">Drafts</a></li> -->
<?php endif; ?>
</ul>
<ul class="nav navbar-nav navbar-right">
<?php if (!$this->session->userdata('logged_in')): ?>
<?php if (!$this->session->userdata('logged_in')) : ?>
<li><a href="<?php echo base_url(); ?>users/login">Login</a></li>
<li><a href="<?php echo base_url(); ?>users/register">Register</a></li>
<?php endif; ?>
<?php if ($this->session->userdata('logged_in')): ?>
<?php if ($this->session->userdata('logged_in')) : ?>
<li><a href="<?php echo base_url(); ?>title">Create Form</a></li>
<li><a href="<?php echo base_url(); ?>users/logout">Logout</a></li>
<?php endif; ?>
@ -142,19 +142,19 @@
</div>
</nav>
<div class="container">
<?php if ($this->session->flashdata('user_registered')): ?>
<?php if ($this->session->flashdata('user_registered')) : ?>
<p class="alert alert-success flash-message" id="flash-user-registered"><?php echo $this->session->flashdata('user_registered'); ?></p>
<?php endif; ?>
<?php if ($this->session->flashdata('login_failed')): ?>
<?php if ($this->session->flashdata('login_failed')) : ?>
<p class="alert alert-danger flash-message" id="flash-login-failed"><?php echo $this->session->flashdata('login_failed'); ?></p>
<?php endif; ?>
<?php if ($this->session->flashdata('user_loggedin')): ?>
<?php if ($this->session->flashdata('user_loggedin')) : ?>
<p class="alert alert-success flash-message" id="flash-user-loggedin"><?php echo $this->session->flashdata('user_loggedin'); ?></p>
<?php endif; ?>
<?php if ($this->session->flashdata('user_loggedout')): ?>
<?php if ($this->session->flashdata('user_loggedout')) : ?>
<p class="alert alert-success flash-message" id="flash-user-loggedout"><?php echo $this->session->flashdata('user_loggedout'); ?></p>
<?php endif; ?>
</div>

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="col-md-4 col-md-offset-4">
<h1 class="text-center"><?= $title; ?></h1>

View File

@ -1,5 +1,5 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
defined('BASEPATH') or exit('No direct script access allowed');
?><!DOCTYPE html>
<html lang="en">
<head>

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,7 +3,6 @@
flex-direction: column;
margin-bottom: 10px;
margin-top: -56px;
}
.form-title,
@ -32,7 +31,6 @@
opacity: 0.5; /* Make the icon transparent */
margin-right: 10px; /* Space between icon and option box */
font-size: 10px; /* Adjust icon size here */
}
.option .form-control.option-label {

View File

@ -34,7 +34,8 @@ body {
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
margin-bottom: 20px;
}
.form-header h2, .form-header h4 {
.form-header h2,
.form-header h4 {
margin: 0;
text-align: left;
}
@ -62,12 +63,12 @@ body {
display: flex;
align-items: center;
}
.option input[type="checkbox"] {
.option input[type='checkbox'] {
margin-right: 10px;
width: 16px; /* Adjust size of checkbox */
height: 16px; /* Adjust size of checkbox */
}
.option input[type="radio"] {
.option input[type='radio'] {
margin-right: 10px;
width: 16px; /* Adjust size of radio button */
height: 16px; /* Adjust size of radio button */

View File

@ -1,4 +1,3 @@
.navbar-container {
max-width: 100%;
margin: 0 auto;
@ -23,7 +22,6 @@
padding: 15px 10px;
}
.navbar-custom .navbar-nav {
display: flex;
align-items: center;
@ -54,8 +52,6 @@
margin: 0 10px;
}
#add-section-btn {
position: absolute;
}

View File

@ -74,8 +74,6 @@ body {
flex: 1; /* Allow items to grow/shrink to fill space */
}
#submit-btn {
margin-top: 20px;
float: left;
@ -96,36 +94,36 @@ body {
padding: 10px;
}
.post-date{
.post-date {
background: #f4f4f4;
padding: 4px;
margin: 3px 0;
display: block;
}
.post-thumb{
.post-thumb {
width: 100%;
}
.pagination-link{
.pagination-link {
margin: 30px 0;
}
.pagination-links strong{
.pagination-links strong {
padding: 8px 13px;
margin: 5px;
background: #f4f4f4;
border: 1px #ccc solid;
}
a.pagination-link{
a.pagination-link {
padding: 8px 13px;
margin: 5px;
background: #f4f4f4;
border: 1px #ccc solid;
}
.cat-delete{
.cat-delete {
display: inline;
}
@ -133,8 +131,7 @@ a.pagination-link{
border: 1px solid #3333336c; /* Darker border color */
}
#basetable1 th, #basetable1 td {
#basetable1 th,
#basetable1 td {
border: 1px solid #3333336c; /* Darker border color for table cells */
}

File diff suppressed because it is too large Load Diff

View File

@ -1,5 +1,9 @@
body { background-color: rgb(240, 235, 248); }
.container { margin-top: 30px; }
body {
background-color: rgb(240, 235, 248);
}
.container {
margin-top: 30px;
}
.form-header {
background-color: white;
padding: 20px;
@ -13,8 +17,12 @@ body { background-color: rgb(240, 235, 248); }
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
margin-bottom: 20px;
}
.form-header h2 { margin: 0; }
.form-header h4 { color: rgba(0, 0, 0, 0.5); }
.form-header h2 {
margin: 0;
}
.form-header h4 {
color: rgba(0, 0, 0, 0.5);
}
.form-section {
background-color: white;
width: 56%;
@ -36,8 +44,8 @@ body { background-color: rgb(240, 235, 248); }
display: flex;
align-items: center;
}
.option input[type="radio"],
.option input[type="checkbox"] {
.option input[type='radio'],
.option input[type='checkbox'] {
margin-right: 10px;
}
.required-field::after {

View File

@ -1,4 +1,3 @@
body {
background-color: rgb(240, 235, 248);
font-family: Arial, sans-serif;
@ -13,12 +12,11 @@ body {
}
/* Navbar custom styles */
.container {
position: relative;
margin-top: 30px;
}
.form_container_top{
.form_container_top {
box-sizing: border-box;
margin-top: 10px;
font-family: Arial, Helvetica, sans-serif;
@ -31,7 +29,7 @@ body {
border-bottom: 1px solid #f4f4f9;
color: black;
height: 20px;
}
}
/* Form header styles */
.form-header {
background-color: white;
@ -78,10 +76,8 @@ body {
z-index: 1000;
border-radius: 50%;
background-color: rgb(103, 58, 183);
}
.form-section {
background-color: white;
width: 56%;
@ -125,7 +121,6 @@ body {
border-radius: 4px;
}
.delete-section-icon {
flex: 0.1;
cursor: pointer;
@ -152,8 +147,8 @@ body {
margin-bottom: 5px;
}
.option input[type="radio"],
.option input[type="checkbox"] {
.option input[type='radio'],
.option input[type='checkbox'] {
margin-right: 10px;
}
@ -169,16 +164,13 @@ body {
text-align: left;
}
.add-option-btn {
background-color: rgb(66, 133, 244);
/* color: rgb(66, 133, 244); */
margin-top: 11px;
font-size: 0.8em;
}
.ui-state-highlight {
background-color: transparent !important;
border: none !important;
@ -210,19 +202,19 @@ body {
right: 0;
bottom: 0;
background-color: #ccc;
transition: .4s;
transition: 0.4s;
border-radius: 34px;
}
.slider:before {
position: absolute;
content: "";
content: '';
height: 14px;
width: 14px;
left: 3px;
bottom: 3px;
background-color: white;
transition: .4s;
transition: 0.4s;
border-radius: 50%;
}
@ -233,8 +225,8 @@ input:checked + .slider {
input:checked + .slider:before {
transform: translateX(14px);
}
.body_header_bg{
background-color: rgb(240,235,248);
.body_header_bg {
background-color: rgb(240, 235, 248);
}
table a:not(.btn) {
color: blue !important;
@ -259,11 +251,11 @@ table a:not(.btn):hover {
/* Assuming you have a stylesheet named styles.css */
.btn.btn-primary.btn-block {
margin-top: 20px;
position: relative;
background-color: rgb(103, 58, 183);
border-color: rgb(103, 58, 183);
color: white;
margin-top: 20px;
position: relative;
background-color: rgb(103, 58, 183);
border-color: rgb(103, 58, 183);
color: white;
}
.flash-message {
opacity: 1;
@ -277,4 +269,3 @@ color: white;
margin-top: 5px;
display: none;
}

View File

@ -135,8 +135,8 @@ body {
margin-bottom: 5px;
}
.option input[type="radio"],
.option input[type="checkbox"] {
.option input[type='radio'],
.option input[type='checkbox'] {
margin-right: 10px;
}
@ -191,19 +191,19 @@ body {
right: 0;
bottom: 0;
background-color: #ccc;
transition: .4s;
transition: 0.4s;
border-radius: 34px;
}
.slider:before {
position: absolute;
content: "";
content: '';
height: 14px;
width: 14px;
left: 3px;
bottom: 3px;
background-color: white;
transition: .4s;
transition: 0.4s;
border-radius: 50%;
}

50
assets/js/dummy.js Normal file
View File

@ -0,0 +1,50 @@
// src/index.js
// Example function to add two numbers
function add(a, b) {
return a + b
}
// Example usage of the add function
const result = add(5, 10)
console.log('The result is:', result)
// Example object with properties
const person = {
name: 'John Doe',
age: 30,
greet: function () {
console.log(
`Hello, my name is ${this.name} and I am ${this.age} years old.`
)
},
}
// Call the greet method
person.greet()
// Example of an arrow function
const multiply = (x, y) => x * y
console.log('The product is:', multiply(4, 5))
// Example of a variable declared with let
let count = 0
for (let i = 0; i < 5; i++) {
count += i
}
console.log('The count is:', count)
// Example of a variable declared with const
const message = 'This is a constant message.'
console.log(message)
// Example of a function with default parameters
function greet(name = 'Guest') {
console.log(`Welcome, ${name}!`)
}
// Call the function with and without arguments
greet('Alice')
greet()

View File

@ -1,8 +1,8 @@
$(document).ready(function() {
$(document).ready(function () {
var base_url = '<?php echo base_url(); ?>';
// Add section button functionality
$('#add-section-btn').on('click', function() {
$('#add-section-btn').on('click', function () {
var sectionHtml = `
<div class="form-section" data-type="">
<div class="header-row">
@ -21,14 +21,12 @@ $(document).ready(function() {
<span class="delete-section-icon"><i class="fas fa-trash-alt"></i></span>
</div>
<div class="options-container"></div>
<button class="btn btn-secondary add-option-btn" style="display: none;">Add Option</button>
</div>
`;
$('#form-container').append(sectionHtml);
<button class="btn btn-secondary add-option-btn" style="display: none;">Add Option</button></div>
`; $('#form-container').append(sectionHtml);
});
// Add option button functionality
$(document).on('click', '.add-option-btn', function() {
$(document).on('click', '.add-option-btn', function () {
var optionHtml = `
<div class="option">
<input type="text" class="form-control option-label" placeholder="Option">
@ -39,17 +37,17 @@ $(document).ready(function() {
});
// Delete option functionality
$(document).on('click', '.delete-option-icon', function() {
$(document).on('click', '.delete-option-icon', function () {
$(this).parent().remove();
});
// Delete section functionality
$(document).on('click', '.delete-section-icon', function() {
$(document).on('click', '.delete-section-icon', function () {
$(this).closest('.form-section').remove();
});
// Show/Hide "Add Option" button based on question type
$(document).on('change', '.custom-select', function() {
$(document).on('change', '.custom-select', function () {
var type = $(this).val();
var $section = $(this).closest('.form-section');
if (type === 'multiple-choice' || type === 'checkboxes' || type === 'dropdown') {
@ -60,9 +58,9 @@ $(document).ready(function() {
}).trigger('change'); // Trigger change to apply to existing sections
// Submit button functionality
$('#submit-btn').on('click', function() {
$('#submit-btn').on('click', function () {
var formData = collectFormData();
formData['form_id'] = <?php echo $form['id']; ?>;
formData['form_id'] = <? php echo $form['id']; ?>;
let validation = validateFormData(formData);
if (!validation.isValid) {
@ -75,7 +73,7 @@ $(document).ready(function() {
type: 'POST',
data: { formData: formData },
dataType: 'JSON',
success: function(response) {
success: function (response) {
if (response.status === 'success') {
alert('Form updated successfully!');
window.location.href = base_url + 'Form_controller/index_forms_draft';
@ -83,7 +81,7 @@ $(document).ready(function() {
alert(response.message);
}
},
error: function(error) {
error: function (error) {
alert('Error updating form!');
console.log(error);
}
@ -98,7 +96,7 @@ $(document).ready(function() {
questions: []
};
$('.form-section').each(function() {
$('.form-section').each(function () {
var questionData = {
id: $(this).data('index'),
text: $(this).find('.untitled-question').val(),
@ -107,7 +105,7 @@ $(document).ready(function() {
options: []
};
$(this).find('.option-label').each(function() {
$(this).find('.option-label').each(function () {
questionData.options.push($(this).val());
});

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() {
let index = 1;
let activeSection = null;
$(document).ready(function () {
let index = 1
let activeSection = null
function addOption(type, container) {
function addOption(type, container) {
// let optionIndex = container.children().length + 1;
let optionHtml;
let optionHtml
if (type === 'multiple-choice' || type === 'checkboxes') {
optionHtml = `
<div class="option">
@ -12,18 +12,17 @@ function addOption(type, container) {
<input type="text" class="form-control option-label" >
<span class="delete-option-icon">&times;</span>
</div>
`;
}
else if (type === 'dropdown') {
`
} else if (type === 'dropdown') {
optionHtml = `
<div class="option">
<input type="text" class="form-control option-label">
<span class="delete-option-icon">&times;</span>
</div>
`;
`
}
container.append(optionHtml)
}
container.append(optionHtml);
}
function createFormSection() {
let newSection = `
@ -45,88 +44,100 @@ function addOption(type, container) {
</div>
<div class="options-container"></div>
</div>
`;
$('#form-container').append(newSection);
index++;
positionAddSectionButton();
`
$('#form-container').append(newSection)
index++
positionAddSectionButton()
}
function positionAddSectionButton() {
if (activeSection) {
let position = activeSection.position();
let buttonWidth = $('#add-section-btn').outerWidth();
let buttonHeight = $('#add-section-btn').outerHeight();
let position = activeSection.position()
let buttonWidth = $('#add-section-btn').outerWidth()
let buttonHeight = $('#add-section-btn').outerHeight()
$('#add-section-btn').css({
position: 'absolute',
left: position.left - buttonWidth - 47 + 'px',
top: position.top + activeSection.height() / 2 - buttonHeight / 2 + 'px'
});
top:
position.top + activeSection.height() / 2 - buttonHeight / 2 + 'px',
})
}
}
$('#add-section-btn').on('click', function() {
createFormSection();
$('.form-section').removeClass('active');
activeSection = $('.form-section').last();
activeSection.addClass('active');
positionAddSectionButton();
});
$('#add-section-btn').on('click', function () {
createFormSection()
$('.form-section').removeClass('active')
activeSection = $('.form-section').last()
activeSection.addClass('active')
positionAddSectionButton()
})
$(document).on('change', '.custom-select', function() {
let type = $(this).val();
let container = $(this).closest('.form-section').find('.options-container');
container.empty();
$(this).closest('.form-section').find('.add-option-btn').remove();
$(document).on('change', '.custom-select', function () {
let type = $(this).val()
let container = $(this).closest('.form-section').find('.options-container')
container.empty()
$(this).closest('.form-section').find('.add-option-btn').remove()
if (type === 'short-answer') {
container.append('<input type="text" class="form-control" disabled placeholder="Short answer text">');
container.append(
'<input type="text" class="form-control" disabled placeholder="Short answer text">'
)
} else if (type === 'paragraph') {
container.append('<textarea class="form-control" disabled placeholder="Paragraph text"></textarea>');
container.append(
'<textarea class="form-control" disabled placeholder="Paragraph text"></textarea>'
)
} else {
addOption(type, container);
$(this).closest('.form-section').append('<button class="btn btn-secondary add-option-btn">Add Option</button>');
addOption(type, container)
$(this)
.closest('.form-section')
.append(
'<button class="btn btn-secondary add-option-btn">Add Option</button>'
)
}
});
})
$(document).on('click', '.add-option-btn', function() {
let type = $(this).closest('.form-section').find('.custom-select').val();
let container = $(this).closest('.form-section').find('.options-container');
addOption(type, container);
});
$(document).on('click', '.add-option-btn', function () {
let type = $(this).closest('.form-section').find('.custom-select').val()
let container = $(this).closest('.form-section').find('.options-container')
addOption(type, container)
})
$(document).on('click', '.delete-section-icon', function() {
let section = $(this).closest('.form-section');
let prevSection = section.prev('.form-section');
let nextSection = section.next('.form-section');
section.remove();
$(document).on('click', '.delete-section-icon', function () {
let section = $(this).closest('.form-section')
let prevSection = section.prev('.form-section')
let nextSection = section.next('.form-section')
section.remove()
if (section.hasClass('active')) {
activeSection = null;
activeSection = null
}
if (prevSection.length > 0) {
prevSection.find('.delete-section-icon').appendTo(prevSection.find('.form-section'));
activeSection = prevSection;row
prevSection
.find('.delete-section-icon')
.appendTo(prevSection.find('.form-section'))
activeSection = prevSection
row
} else if (nextSection.length > 0) {
nextSection
.find('.delete-section-icon')
.appendTo(nextSection.find('.form-header'))
activeSection = nextSection
}
else if (nextSection.length > 0) {
nextSection.find('.delete-section-icon').appendTo(nextSection.find('.form-header'));
activeSection = nextSection;
}
positionAddSectionButton();
});
positionAddSectionButton()
})
$(document).on('click', '.delete-option-icon', function() {
let option = $(this).closest('.option');
let container = option.closest('.options-container');
option.remove();
$(document).on('click', '.delete-option-icon', function () {
let option = $(this).closest('.option')
let container = option.closest('.options-container')
option.remove()
})
});
$(document).on('click', '.required-toggle', function () {
$(this).closest('.form-section').toggleClass('required')
})
$(document).on('click', '.required-toggle', function() {
$(this).closest('.form-section').toggleClass('required');
});
$('#preview-btn').on('click', function() {
let previewWindow = window.open('', '_blank');
$('#preview-btn').on('click', function () {
let previewWindow = window.open('', '_blank')
let previewContent = `
<html>
<head>
@ -146,126 +157,144 @@ function addOption(type, container) {
<div class="form-header">
<h3>Form Preview</h3>
</div>
`;
$('.form-section').each(function() {
previewContent += '<div class="form-section">';
previewContent += '<div class="question-section">';
previewContent += '<div class="question-label">' + $(this).find('.untitled-question').val() + '</div>';
previewContent += '</div>';
let type = $(this).find('.custom-select').val();
let optionsContainer = $(this).find('.options-container');
`
$('.form-section').each(function () {
previewContent += '<div class="form-section">'
previewContent += '<div class="question-section">'
previewContent +=
'<div class="question-label">' +
$(this).find('.untitled-question').val() +
'</div>'
previewContent += '</div>'
let type = $(this).find('.custom-select').val()
let optionsContainer = $(this).find('.options-container')
if (type === 'multiple-choice') {
optionsContainer.find('.option').each(function() {
optionsContainer.find('.option').each(function () {
previewContent += `
<div class="option">
<input type="radio" name="option-${index}">
<label>${$(this).find('.option-label').val()}</label>
</div>
`;
});
`
})
} else if (type === 'checkboxes') {
optionsContainer.find('.option').each(function() {
optionsContainer.find('.option').each(function () {
previewContent += `
<div class="option">
<input type="checkbox">
<label>${$(this).find('.option-label').val()}</label>
</div>
`;
});
`
})
} else if (type === 'short-answer') {
previewContent += '<input type="text" class="form-control" placeholder="Short answer text">';
previewContent +=
'<input type="text" class="form-control" placeholder="Short answer text">'
} else if (type === 'paragraph') {
previewContent += '<textarea class="form-control" placeholder="Paragraph text"></textarea>';
previewContent +=
'<textarea class="form-control" placeholder="Paragraph text"></textarea>'
} else if (type === 'dropdown') {
let dropdownHtml = '<select class="form-control">';
optionsContainer.find('.option .option-label').each(function() {
dropdownHtml += `<option>${$(this).val()}</option>`;
});
dropdownHtml += '</select>';
previewContent += dropdownHtml;
let dropdownHtml = '<select class="form-control">'
optionsContainer.find('.option .option-label').each(function () {
dropdownHtml += `<option>${$(this).val()}</option>`
})
dropdownHtml += '</select>'
previewContent += dropdownHtml
}
previewContent += '</div>';
});
previewContent += '</div>'
})
previewContent += `
</div>
</body>
</html>
`;
previewWindow.document.write(previewContent);
previewWindow.document.close();
});
`
previewWindow.document.write(previewContent)
previewWindow.document.close()
})
$(document).on('click', '.form-section', function() {
$('.form-section').removeClass('active');
$(this).addClass('active');
activeSection = $(this);
positionAddSectionButton();
});
$(document).on('click', '.form-section', function () {
$('.form-section').removeClass('active')
$(this).addClass('active')
activeSection = $(this)
positionAddSectionButton()
})
$('#form-container').sortable({
placeholder: 'ui-state-highlight',
start: function (event, ui) {
ui.placeholder.height(ui.item.height());
ui.placeholder.height(ui.item.height())
},
stop: function (event, ui) {
positionAddSectionButton();
}
});
positionAddSectionButton()
},
})
function collectFormData() {
var formData = {
questions: []
};
questions: [],
}
$('.form-section').each(function() {
var questionType = $(this).find('.custom-select').val();
$('.form-section').each(function () {
var questionType = $(this).find('.custom-select').val()
var questionData = {
text: $(this).find('.untitled-question').val(),
type: questionType,
is_required: $(this).find('.required-toggle').is(':checked'),
options: []
};
options: [],
}
// Only add options if the question type supports them
if (questionType === 'multiple-choice' || questionType === 'checkboxes' || questionType === 'dropdown') {
$(this).find('.option-label').each(function() {
questionData.options.push($(this).val());
});
if (
questionType === 'multiple-choice' ||
questionType === 'checkboxes' ||
questionType === 'dropdown'
) {
$(this)
.find('.option-label')
.each(function () {
questionData.options.push($(this).val())
})
}
formData.questions.push(questionData);
});
formData.questions.push(questionData)
})
console.log(formData);
return formData;
console.log(formData)
return formData
}
function validateFormData(formData) {
for (let question of formData.questions) {
if (!question.text.trim()) {
return { isValid: false, message: 'All questions must have text.' };
return { isValid: false, message: 'All questions must have text.' }
}
if (
(question.type === 'multiple-choice' ||
question.type === 'checkboxes' ||
question.type === 'dropdown') &&
question.options.length === 0
) {
return {
isValid: false,
message: 'All options-based questions must have at least one option.',
}
if ((question.type === 'multiple-choice' || question.type === 'checkboxes' || question.type === 'dropdown') && question.options.length === 0) {
return { isValid: false, message: 'All options-based questions must have at least one option.' };
}
for (let option of question.options) {
if (!option.trim()) {
return { isValid: false, message: 'All options must have text.' };
return { isValid: false, message: 'All options must have text.' }
}
}
}
return { isValid: true };
return { isValid: true }
}
$('#submit-btn').on('click', function() {
let formData = collectFormData();
console.log(formData);
$('#submit-btn').on('click', function () {
let formData = collectFormData()
console.log(formData)
let validation = validateFormData(formData);
let validation = validateFormData(formData)
if (!validation.isValid) {
alert(validation.message);
return;
alert(validation.message)
return
}
$.ajax({
@ -273,27 +302,27 @@ function addOption(type, container) {
type: 'POST',
data: { formData: formData },
dataType: 'JSON',
success: function(response) {
success: function (response) {
if (response.status === 'success') {
Swal.fire({
title: 'Success!',
text: 'Form submitted successfully!',
icon: 'success',
confirmButtonText: 'OK'
confirmButtonText: 'OK',
}).then((result) => {
window.location.href = base_url;
});
window.location.href = base_url
})
} else {
Swal.fire({
title: 'Error!',
text: response.message,
icon: 'error',
confirmButtonText: 'OK'
});
console.log(response);
confirmButtonText: 'OK',
})
console.log(response)
}
},
error: function(error) {
error: function (error) {
Swal.fire({
title: 'Error!',
text: 'Error submitting form!',
@ -304,16 +333,13 @@ function addOption(type, container) {
padding: 'auto',
}).then((result) => {
if (result.isConfirmed) {
window.location.href = home;
window.location.href = home
}
});
console.log(error);
}
});
});
})
console.log(error)
},
})
})
$('#form-container').disableSelection();
});
$('#form-container').disableSelection()
})

View File

@ -1,6 +1,7 @@
$(document).ready(function () {
let index = 1
let activeSection = null
function addOption(type, container) {
let optionHtml

1745
composer-setup.php Normal file

File diff suppressed because it is too large Load Diff

View File

@ -30,6 +30,7 @@
},
"require-dev": {
"mikey179/vfsstream": "1.6.*",
"phpunit/phpunit": "4.* || 5.* || 9.*"
"phpunit/phpunit": "4.* || 5.* || 9.*",
"squizlabs/php_codesniffer": "^3.5"
}
}

1721
composer.lock generated Normal file

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