commitall

This commit is contained in:
Sampanna Rimal
2024-07-10 18:28:19 +05:45
parent 140abda4e6
commit 9cd05ef3cb
15723 changed files with 4818733 additions and 0 deletions

View File

@@ -0,0 +1,5 @@
RewriteEngine On
RewriteCond $1 !^(index\.php|assets|images|js|css|uploads|favicon.png)
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ ./index.php/$1 [L]

11
hostel/application/cache/index.html vendored Normal file
View File

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

View File

@@ -0,0 +1,135 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
/*
| -------------------------------------------------------------------
| AUTO-LOADER
| -------------------------------------------------------------------
| This file specifies which systems should be loaded by default.
|
| In order to keep the framework as light-weight as possible only the
| absolute minimal resources are loaded by default. For example,
| the database is not connected to automatically since no assumption
| is made regarding whether you intend to use it. This file lets
| you globally define which systems you would like loaded with every
| request.
|
| -------------------------------------------------------------------
| Instructions
| -------------------------------------------------------------------
|
| These are the things you can load automatically:
|
| 1. Packages
| 2. Libraries
| 3. Drivers
| 4. Helper files
| 5. Custom config files
| 6. Language files
| 7. Models
|
*/
/*
| -------------------------------------------------------------------
| Auto-load Packages
| -------------------------------------------------------------------
| Prototype:
|
| $autoload['packages'] = array(APPPATH.'third_party', '/usr/local/shared');
|
*/
$autoload['packages'] = array();
/*
| -------------------------------------------------------------------
| Auto-load Libraries
| -------------------------------------------------------------------
| These are the classes located in system/libraries/ or your
| application/libraries/ directory, with the addition of the
| 'database' library, which is somewhat of a special case.
|
| Prototype:
|
| $autoload['libraries'] = array('database', 'email', 'session');
|
| You can also supply an alternative library name to be assigned
| in the controller:
|
| $autoload['libraries'] = array('user_agent' => 'ua');
*/
$autoload['libraries'] = array('database','session','encryption','form_validation');
/*
| -------------------------------------------------------------------
| Auto-load Drivers
| -------------------------------------------------------------------
| These classes are located in system/libraries/ or in your
| application/libraries/ directory, but are also placed inside their
| own subdirectory and they extend the CI_Driver_Library class. They
| offer multiple interchangeable driver options.
|
| Prototype:
|
| $autoload['drivers'] = array('cache');
|
| You can also supply an alternative property name to be assigned in
| the controller:
|
| $autoload['drivers'] = array('cache' => 'cch');
|
*/
$autoload['drivers'] = array();
/*
| -------------------------------------------------------------------
| Auto-load Helper Files
| -------------------------------------------------------------------
| Prototype:
|
| $autoload['helper'] = array('url', 'file');
*/
$autoload['helper'] = array('url');
/*
| -------------------------------------------------------------------
| Auto-load Config files
| -------------------------------------------------------------------
| Prototype:
|
| $autoload['config'] = array('config1', 'config2');
|
| NOTE: This item is intended for use ONLY if you have created custom
| config files. Otherwise, leave it blank.
|
*/
$autoload['config'] = array();
/*
| -------------------------------------------------------------------
| Auto-load Language files
| -------------------------------------------------------------------
| Prototype:
|
| $autoload['language'] = array('lang1', 'lang2');
|
| NOTE: Do not include the "_lang" part of your file. For example
| "codeigniter_lang.php" would be referenced as array('codeigniter');
|
*/
$autoload['language'] = array();
/*
| -------------------------------------------------------------------
| Auto-load Models
| -------------------------------------------------------------------
| Prototype:
|
| $autoload['model'] = array('first_model', 'second_model');
|
| You can also supply an alternative model name to be assigned
| in the controller:
|
| $autoload['model'] = array('first_model' => 'first');
*/
$autoload['model'] = array();

View File

@@ -0,0 +1,531 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
/*
|--------------------------------------------------------------------------
| Base Site URL
|--------------------------------------------------------------------------
|
| URL to your CodeIgniter root. Typically this will be your base URL,
| WITH a trailing slash:
|
| http://example.com/
|
| WARNING: You MUST set this value!
|
| If it is not set, then CodeIgniter will try guess the protocol and path
| your installation, but due to security concerns the hostname will be set
| to $_SERVER['SERVER_ADDR'] if available, or localhost otherwise.
| The auto-detection mechanism exists only for convenience during
| development and MUST NOT be used in production!
|
| If you need to allow multiple domains, remember that this file is still
| a PHP script and you can easily do that on your own.
|
*/
//$config['base_url'] = 'http://localhost/erisn-classroom-lms/';
/*$root = "https://".$_SERVER['HTTP_HOST'];
$root .= str_replace(basename($_SERVER['SCRIPT_NAME']),"",$_SERVER['SCRIPT_NAME']);
$config['base_url'] = $root;*/
$config['base_url'] = ((isset($_SERVER['HTTPS']) && $_SERVER['HTTPS'] == "on") ? "https" : "http");
$config['base_url'] .= "://".$_SERVER['HTTP_HOST'];
$config['base_url'] .= str_replace(basename($_SERVER['SCRIPT_NAME']),"",$_SERVER['SCRIPT_NAME']);
/*
|--------------------------------------------------------------------------
| Index File
|--------------------------------------------------------------------------
|
| Typically this will be your index.php file, unless you've renamed it to
| something else. If you are using mod_rewrite to remove the page set this
| variable so that it is blank.
|
*/
$config['index_page'] = '';
/*
|--------------------------------------------------------------------------
| URI PROTOCOL
|--------------------------------------------------------------------------
|
| This item determines which server global should be used to retrieve the
| URI string. The default setting of 'REQUEST_URI' works for most servers.
| If your links do not seem to work, try one of the other delicious flavors:
|
| 'REQUEST_URI' Uses $_SERVER['REQUEST_URI']
| 'QUERY_STRING' Uses $_SERVER['QUERY_STRING']
| 'PATH_INFO' Uses $_SERVER['PATH_INFO']
|
| WARNING: If you set this to 'PATH_INFO', URIs will always be URL-decoded!
*/
$config['uri_protocol'] = 'REQUEST_URI';
/*
|--------------------------------------------------------------------------
| URL suffix
|--------------------------------------------------------------------------
|
| This option allows you to add a suffix to all URLs generated by CodeIgniter.
| For more information please see the user guide:
|
| https://codeigniter.com/user_guide/general/urls.html
*/
$config['url_suffix'] = '';
/*
|--------------------------------------------------------------------------
| Default Language
|--------------------------------------------------------------------------
|
| This determines which set of language files should be used. Make sure
| there is an available translation if you intend to use something other
| than english.
|
*/
$config['language'] = 'english';
/*
|--------------------------------------------------------------------------
| Default Character Set
|--------------------------------------------------------------------------
|
| This determines which character set is used by default in various methods
| that require a character set to be provided.
|
| See http://php.net/htmlspecialchars for a list of supported charsets.
|
*/
$config['charset'] = 'UTF-8';
/*
|--------------------------------------------------------------------------
| Enable/Disable System Hooks
|--------------------------------------------------------------------------
|
| If you would like to use the 'hooks' feature you must enable it by
| setting this variable to TRUE (boolean). See the user guide for details.
|
*/
$config['enable_hooks'] = FALSE;
/*
|--------------------------------------------------------------------------
| Class Extension Prefix
|--------------------------------------------------------------------------
|
| This item allows you to set the filename/classname prefix when extending
| native libraries. For more information please see the user guide:
|
| https://codeigniter.com/user_guide/general/core_classes.html
| https://codeigniter.com/user_guide/general/creating_libraries.html
|
*/
$config['subclass_prefix'] = 'MY_';
/*
|--------------------------------------------------------------------------
| Composer auto-loading
|--------------------------------------------------------------------------
|
| Enabling this setting will tell CodeIgniter to look for a Composer
| package auto-loader script in application/vendor/autoload.php.
|
| $config['composer_autoload'] = TRUE;
|
| Or if you have your vendor/ directory located somewhere else, you
| can opt to set a specific path as well:
|
| $config['composer_autoload'] = '/path/to/vendor/autoload.php';
|
| For more information about Composer, please visit http://getcomposer.org/
|
| Note: This will NOT disable or override the CodeIgniter-specific
| autoloading (application/config/autoload.php)
*/
$config['composer_autoload'] = FALSE;
/*
|--------------------------------------------------------------------------
| Allowed URL Characters
|--------------------------------------------------------------------------
|
| This lets you specify which characters are permitted within your URLs.
| When someone tries to submit a URL with disallowed characters they will
| get a warning message.
|
| As a security measure you are STRONGLY encouraged to restrict URLs to
| as few characters as possible. By default only these are allowed: a-z 0-9~%.:_-
|
| Leave blank to allow all characters -- but only if you are insane.
|
| The configured value is actually a regular expression character group
| and it will be executed as: ! preg_match('/^[<permitted_uri_chars>]+$/i
|
| DO NOT CHANGE THIS UNLESS YOU FULLY UNDERSTAND THE REPERCUSSIONS!!
|
*/
$config['permitted_uri_chars'] = 'a-z 0-9~%.:_\-';
/*
|--------------------------------------------------------------------------
| Enable Query Strings
|--------------------------------------------------------------------------
|
| By default CodeIgniter uses search-engine friendly segment based URLs:
| example.com/who/what/where/
|
| You can optionally enable standard query string based URLs:
| example.com?who=me&what=something&where=here
|
| Options are: TRUE or FALSE (boolean)
|
| The other items let you set the query string 'words' that will
| invoke your controllers and its functions:
| example.com/index.php?c=controller&m=function
|
| Please note that some of the helpers won't work as expected when
| this feature is enabled, since CodeIgniter is designed primarily to
| use segment based URLs.
|
*/
$config['enable_query_strings'] = FALSE;
$config['controller_trigger'] = 'c';
$config['function_trigger'] = 'm';
$config['directory_trigger'] = 'd';
/*
|--------------------------------------------------------------------------
| Allow $_GET array
|--------------------------------------------------------------------------
|
| By default CodeIgniter enables access to the $_GET array. If for some
| reason you would like to disable it, set 'allow_get_array' to FALSE.
|
| WARNING: This feature is DEPRECATED and currently available only
| for backwards compatibility purposes!
|
*/
$config['allow_get_array'] = TRUE;
/*
|--------------------------------------------------------------------------
| Error Logging Threshold
|--------------------------------------------------------------------------
|
| You can enable error logging by setting a threshold over zero. The
| threshold determines what gets logged. Threshold options are:
|
| 0 = Disables logging, Error logging TURNED OFF
| 1 = Error Messages (including PHP errors)
| 2 = Debug Messages
| 3 = Informational Messages
| 4 = All Messages
|
| You can also pass an array with threshold levels to show individual error types
|
| array(2) = Debug Messages, without Error Messages
|
| For a live site you'll usually only enable Errors (1) to be logged otherwise
| your log files will fill up very fast.
|
*/
$config['log_threshold'] = 0;
/*
|--------------------------------------------------------------------------
| Error Logging Directory Path
|--------------------------------------------------------------------------
|
| Leave this BLANK unless you would like to set something other than the default
| application/logs/ directory. Use a full server path with trailing slash.
|
*/
$config['log_path'] = '';
/*
|--------------------------------------------------------------------------
| Log File Extension
|--------------------------------------------------------------------------
|
| The default filename extension for log files. The default 'php' allows for
| protecting the log files via basic scripting, when they are to be stored
| under a publicly accessible directory.
|
| Note: Leaving it blank will default to 'php'.
|
*/
$config['log_file_extension'] = '';
/*
|--------------------------------------------------------------------------
| Log File Permissions
|--------------------------------------------------------------------------
|
| The file system permissions to be applied on newly created log files.
|
| IMPORTANT: This MUST be an integer (no quotes) and you MUST use octal
| integer notation (i.e. 0700, 0644, etc.)
*/
$config['log_file_permissions'] = 0644;
/*
|--------------------------------------------------------------------------
| Date Format for Logs
|--------------------------------------------------------------------------
|
| Each item that is logged has an associated date. You can use PHP date
| codes to set your own date formatting
|
*/
$config['log_date_format'] = 'Y-m-d H:i:s';
/*
|--------------------------------------------------------------------------
| Error Views Directory Path
|--------------------------------------------------------------------------
|
| Leave this BLANK unless you would like to set something other than the default
| application/views/errors/ directory. Use a full server path with trailing slash.
|
*/
$config['error_views_path'] = '';
/*
|--------------------------------------------------------------------------
| Cache Directory Path
|--------------------------------------------------------------------------
|
| Leave this BLANK unless you would like to set something other than the default
| application/cache/ directory. Use a full server path with trailing slash.
|
*/
$config['cache_path'] = '';
/*
|--------------------------------------------------------------------------
| Cache Include Query String
|--------------------------------------------------------------------------
|
| Whether to take the URL query string into consideration when generating
| output cache files. Valid options are:
|
| FALSE = Disabled
| TRUE = Enabled, take all query parameters into account.
| Please be aware that this may result in numerous cache
| files generated for the same page over and over again.
| array('q') = Enabled, but only take into account the specified list
| of query parameters.
|
*/
$config['cache_query_string'] = FALSE;
/*
|--------------------------------------------------------------------------
| Encryption Key
|--------------------------------------------------------------------------
|
| If you use the Encryption class, you must set an encryption key.
| See the user guide for more info.
|
| https://codeigniter.com/user_guide/libraries/encryption.html
|
*/
$config['encryption_key'] = '';
/*
|--------------------------------------------------------------------------
| Session Variables
|--------------------------------------------------------------------------
|
| 'sess_driver'
|
| The storage driver to use: files, database, redis, memcached
|
| 'sess_cookie_name'
|
| The session cookie name, must contain only [0-9a-z_-] characters
|
| 'sess_expiration'
|
| The number of SECONDS you want the session to last.
| Setting to 0 (zero) means expire when the browser is closed.
|
| 'sess_save_path'
|
| The location to save sessions to, driver dependent.
|
| For the 'files' driver, it's a path to a writable directory.
| WARNING: Only absolute paths are supported!
|
| For the 'database' driver, it's a table name.
| Please read up the manual for the format with other session drivers.
|
| IMPORTANT: You are REQUIRED to set a valid save path!
|
| 'sess_match_ip'
|
| Whether to match the user's IP address when reading the session data.
|
| WARNING: If you're using the database driver, don't forget to update
| your session table's PRIMARY KEY when changing this setting.
|
| 'sess_time_to_update'
|
| How many seconds between CI regenerating the session ID.
|
| 'sess_regenerate_destroy'
|
| Whether to destroy session data associated with the old session ID
| when auto-regenerating the session ID. When set to FALSE, the data
| will be later deleted by the garbage collector.
|
| Other session cookie settings are shared with the rest of the application,
| except for 'cookie_prefix' and 'cookie_httponly', which are ignored here.
|
*/
$config['sess_driver'] = 'files';
$config['sess_cookie_name'] = 'ci_session';
$config['sess_expiration'] = 7200;
$config['sess_save_path'] = NULL;
$config['sess_match_ip'] = FALSE;
$config['sess_time_to_update'] = 300;
$config['sess_regenerate_destroy'] = FALSE;
/*
|--------------------------------------------------------------------------
| Cookie Related Variables
|--------------------------------------------------------------------------
|
| 'cookie_prefix' = Set a cookie name prefix if you need to avoid collisions
| 'cookie_domain' = Set to .your-domain.com for site-wide cookies
| 'cookie_path' = Typically will be a forward slash
| 'cookie_secure' = Cookie will only be set if a secure HTTPS connection exists.
| 'cookie_httponly' = Cookie will only be accessible via HTTP(S) (no javascript)
|
| Note: These settings (with the exception of 'cookie_prefix' and
| 'cookie_httponly') will also affect sessions.
|
*/
$config['cookie_prefix'] = '';
$config['cookie_domain'] = '';
$config['cookie_path'] = '/';
$config['cookie_secure'] = FALSE;
$config['cookie_httponly'] = FALSE;
/*
|--------------------------------------------------------------------------
| Standardize newlines
|--------------------------------------------------------------------------
|
| Determines whether to standardize newline characters in input data,
| meaning to replace \r\n, \r, \n occurrences with the PHP_EOL value.
|
| WARNING: This feature is DEPRECATED and currently available only
| for backwards compatibility purposes!
|
*/
$config['standardize_newlines'] = FALSE;
/*
|--------------------------------------------------------------------------
| Global XSS Filtering
|--------------------------------------------------------------------------
|
| Determines whether the XSS filter is always active when GET, POST or
| COOKIE data is encountered
|
| WARNING: This feature is DEPRECATED and currently available only
| for backwards compatibility purposes!
|
*/
$config['global_xss_filtering'] = FALSE;
/*
|--------------------------------------------------------------------------
| Cross Site Request Forgery
|--------------------------------------------------------------------------
| Enables a CSRF cookie token to be set. When set to TRUE, token will be
| checked on a submitted form. If you are accepting user data, it is strongly
| recommended CSRF protection be enabled.
|
| 'csrf_token_name' = The token name
| 'csrf_cookie_name' = The cookie name
| 'csrf_expire' = The number in seconds the token should expire.
| 'csrf_regenerate' = Regenerate token on every submission
| 'csrf_exclude_uris' = Array of URIs which ignore CSRF checks
*/
$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_exclude_uris'] = array();
/*
|--------------------------------------------------------------------------
| Output Compression
|--------------------------------------------------------------------------
|
| Enables Gzip output compression for faster page loads. When enabled,
| the output class will test whether your server supports Gzip.
| Even if it does, however, not all browsers support compression
| so enable only if you are reasonably sure your visitors can handle it.
|
| Only used if zlib.output_compression is turned off in your php.ini.
| Please do not use it together with httpd-level output compression.
|
| VERY IMPORTANT: If you are getting a blank page when compression is enabled it
| means you are prematurely outputting something to your browser. It could
| even be a line of whitespace at the end of one of your scripts. For
| compression to work, nothing can be sent before the output buffer is called
| by the output class. Do not 'echo' any values with compression enabled.
|
*/
$config['compress_output'] = FALSE;
/*
|--------------------------------------------------------------------------
| Master Time Reference
|--------------------------------------------------------------------------
|
| Options are 'local' or any PHP supported timezone. This preference tells
| the system whether to use your server's local time as the master 'now'
| reference, or convert it to the configured one timezone. See the 'date
| helper' page of the user guide for information regarding date handling.
|
*/
$config['time_reference'] = 'local';
/*
|--------------------------------------------------------------------------
| Rewrite PHP Short Tags
|--------------------------------------------------------------------------
|
| If your PHP installation does not have short tag support enabled CI
| can rewrite the tags on-the-fly, enabling you to utilize that syntax
| in your view files. Options are TRUE or FALSE (boolean)
|
| Note: You need to have eval() enabled for this to work.
|
*/
$config['rewrite_short_tags'] = FALSE;
/*
|--------------------------------------------------------------------------
| Reverse Proxy IPs
|--------------------------------------------------------------------------
|
| If your server is behind a reverse proxy, you must whitelist the proxy
| IP addresses from which CodeIgniter should trust headers such as
| HTTP_X_FORWARDED_FOR and HTTP_CLIENT_IP in order to properly identify
| the visitor's IP address.
|
| You can use both an array or a comma-separated list of proxy addresses,
| as well as specifying whole subnets. Here are a few examples:
|
| Comma-separated: '10.0.1.200,192.168.5.0/24'
| Array: array('10.0.1.200', '192.168.5.0/24')
*/
$config['proxy_ips'] = '';

View File

@@ -0,0 +1,94 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
/*
|--------------------------------------------------------------------------
| Display Debug backtrace
|--------------------------------------------------------------------------
|
| If set to TRUE, a backtrace will be displayed along with php errors. If
| error_reporting is disabled, the backtrace will not display, regardless
| of this setting
|
*/
defined('SHOW_DEBUG_BACKTRACE') OR define('SHOW_DEBUG_BACKTRACE', TRUE);
/*
|--------------------------------------------------------------------------
| File and Directory Modes
|--------------------------------------------------------------------------
|
| These prefs are used when checking and setting modes when working
| with the file system. The defaults are fine on servers with proper
| security, but you may wish (or even need) to change the values in
| certain environments (Apache running a separate process for each
| user, PHP under CGI with Apache suEXEC, etc.). Octal values should
| 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);
/*
|--------------------------------------------------------------------------
| File Stream Modes
|--------------------------------------------------------------------------
|
| 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');
/*
|--------------------------------------------------------------------------
| Exit Status Codes
|--------------------------------------------------------------------------
|
| Used to indicate the conditions under which the script is exit()ing.
| While there is no universal standard for error codes, there are some
| broad conventions. Three such conventions are mentioned below, for
| those who wish to make use of them. The CodeIgniter defaults were
| chosen for the least overlap with these conventions, while still
| leaving room for others to be defined in future versions and user
| applications.
|
| The three main conventions used for determining exit status codes
| are as follows:
|
| Standard C/C++ Library (stdlibc):
| http://www.gnu.org/software/libc/manual/html_node/Exit-Status.html
| (This link also contains other GNU-specific conventions)
| BSD sysexits.h:
| http://www.gsp.com/cgi-bin/man.cgi?section=3&topic=sysexits
| Bash scripting:
| 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
define('THE_ADD_SUCCESS_MSG', "The %s has been added successfully");
define('THE_UPDATE_SUCCESS_MSG', "The %s has been updated successfully");
define('THE_DELETE_ALERT_MSG', "Are you sure, you want to delete this %s");
define('THE_DELETE_SUCCESS_MSG', "The %s has been deleted successfully");
define('THE_DELETE_ERROR_MSG', "Oops.. Something went wrong while updating the %s");
define('THE_ADD_ERROR_MSG', "Oops.. Something went wrong while adding the %s");
define('THE_UPDATE_ERROR_MSG', "Oops.. Something went wrong while updating the %s");
define('STUDENT_IMAGE_URL', 'https://dev.ezydemo.com/assets_student/application/');

View File

@@ -0,0 +1,24 @@
<?php
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">',
'xhtml1-strict' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">',
'xhtml1-trans' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">',
'xhtml1-frame' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Frameset//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd">',
'xhtml-basic11' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML Basic 1.1//EN" "http://www.w3.org/TR/xhtml-basic/xhtml-basic11.dtd">',
'html5' => '<!DOCTYPE html>',
'html4-strict' => '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">',
'html4-trans' => '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">',
'html4-frame' => '<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN" "http://www.w3.org/TR/html4/frameset.dtd">',
'mathml1' => '<!DOCTYPE math SYSTEM "http://www.w3.org/Math/DTD/mathml1/mathml.dtd">',
'mathml2' => '<!DOCTYPE math PUBLIC "-//W3C//DTD MathML 2.0//EN" "http://www.w3.org/Math/DTD/mathml2/mathml2.dtd">',
'svg10' => '<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.0//EN" "http://www.w3.org/TR/2001/REC-SVG-20010904/DTD/svg10.dtd">',
'svg11' => '<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">',
'svg11-basic' => '<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1 Basic//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11-basic.dtd">',
'svg11-tiny' => '<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1 Tiny//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11-tiny.dtd">',
'xhtml-math-svg-xh' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1 plus MathML 2.0 plus SVG 1.1//EN" "http://www.w3.org/2002/04/xhtml-math-svg/xhtml-math-svg.dtd">',
'xhtml-math-svg-sh' => '<!DOCTYPE svg:svg PUBLIC "-//W3C//DTD XHTML 1.1 plus MathML 2.0 plus SVG 1.1//EN" "http://www.w3.org/2002/04/xhtml-math-svg/xhtml-math-svg.dtd">',
'xhtml-rdfa-1' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML+RDFa 1.0//EN" "http://www.w3.org/MarkUp/DTD/xhtml-rdfa-1.dtd">',
'xhtml-rdfa-2' => '<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML+RDFa 1.1//EN" "http://www.w3.org/MarkUp/DTD/xhtml-rdfa-2.dtd">'
);

View File

@@ -0,0 +1,114 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
/*
| -------------------------------------------------------------------
| Foreign Characters
| -------------------------------------------------------------------
| This file contains an array of foreign characters for transliteration
| conversion used by the Text helper
|
*/
$foreign_characters = array(
'/ä|æ|ǽ/' => 'ae',
'/ö|œ/' => 'oe',
'/ü/' => 'ue',
'/Ä/' => 'Ae',
'/Ü/' => 'Ue',
'/Ö/' => 'Oe',
'/À|Á|Â|Ã|Ä|Å|Ǻ|Ā|Ă|Ą|Ǎ|Α|Ά|Ả|Ạ|Ầ|Ẫ|Ẩ|Ậ|Ằ|Ắ|Ẵ|Ẳ|Ặ|А/' => 'A',
'/à|á|â|ã|å|ǻ|ā|ă|ą|ǎ|ª|α|ά|ả|ạ|ầ|ấ|ẫ|ẩ|ậ|ằ|ắ|ẵ|ẳ|ặ|а/' => 'a',
'/Б/' => 'B',
'/б/' => 'b',
'/Ç|Ć|Ĉ|Ċ|Č/' => 'C',
'/ç|ć|ĉ|ċ|č/' => 'c',
'/Д|Δ/' => 'D',
'/д|δ/' => 'd',
'/Ð|Ď|Đ/' => 'Dj',
'/ð|ď|đ/' => 'dj',
'/È|É|Ê|Ë|Ē|Ĕ|Ė|Ę|Ě|Ε|Έ|Ẽ|Ẻ|Ẹ|Ề|Ế|Ễ|Ể|Ệ|Е|Э/' => 'E',
'/è|é|ê|ë|ē|ĕ|ė|ę|ě|έ|ε|ẽ|ẻ|ẹ|ề|ế|ễ|ể|ệ|е|э/' => 'e',
'/Ф/' => 'F',
'/ф/' => 'f',
'/Ĝ|Ğ|Ġ|Ģ|Γ|Г|Ґ/' => 'G',
'/ĝ|ğ|ġ|ģ|γ|г|ґ/' => 'g',
'/Ĥ|Ħ/' => 'H',
'/ĥ|ħ/' => 'h',
'/Ì|Í|Î|Ï|Ĩ|Ī|Ĭ|Ǐ|Į|İ|Η|Ή|Ί|Ι|Ϊ|Ỉ|Ị|И|Ы/' => 'I',
'/ì|í|î|ï|ĩ|ī|ĭ|ǐ|į|ı|η|ή|ί|ι|ϊ|ỉ|ị|и|ы|ї/' => 'i',
'/Ĵ/' => 'J',
'/ĵ/' => 'j',
'/Θ/' => 'TH',
'/θ/' => 'th',
'/Ķ|Κ|К/' => 'K',
'/ķ|κ|к/' => 'k',
'/Ĺ|Ļ|Ľ|Ŀ|Ł|Λ|Л/' => 'L',
'/ĺ|ļ|ľ|ŀ|ł|λ|л/' => 'l',
'/М/' => 'M',
'/м/' => 'm',
'/Ñ|Ń|Ņ|Ň|Ν|Н/' => 'N',
'/ñ|ń|ņ|ň|ʼn|ν|н/' => 'n',
'/Ò|Ó|Ô|Õ|Ō|Ŏ|Ǒ|Ő|Ơ|Ø|Ǿ|Ο|Ό|Ω|Ώ|Ỏ|Ọ|Ồ|Ố|Ỗ|Ổ|Ộ|Ờ|Ớ|Ỡ|Ở|Ợ|О/' => 'O',
'/ò|ó|ô|õ|ō|ŏ|ǒ|ő|ơ|ø|ǿ|º|ο|ό|ω|ώ|ỏ|ọ|ồ|ố|ỗ|ổ|ộ|ờ|ớ|ỡ|ở|ợ|о/' => 'o',
'/П/' => 'P',
'/п/' => 'p',
'/Ŕ|Ŗ|Ř|Ρ|Р/' => 'R',
'/ŕ|ŗ|ř|ρ|р/' => 'r',
'/Ś|Ŝ|Ş|Ș|Š|Σ|С/' => 'S',
'/ś|ŝ|ş|ș|š|ſ|σ|ς|с/' => 's',
'/Ț|Ţ|Ť|Ŧ|Τ|Т/' => 'T',
'/ț|ţ|ť|ŧ|τ|т/' => 't',
'/Þ|þ/' => 'th',
'/Ù|Ú|Û|Ũ|Ū|Ŭ|Ů|Ű|Ų|Ư|Ǔ|Ǖ|Ǘ|Ǚ|Ǜ|Ũ|Ủ|Ụ|Ừ|Ứ|Ữ|Ử|Ự|У/' => 'U',
'/ù|ú|û|ũ|ū|ŭ|ů|ű|ų|ư|ǔ|ǖ|ǘ|ǚ|ǜ|υ|ύ|ϋ|ủ|ụ|ừ|ứ|ữ|ử|ự|у/' => 'u',
'/Ƴ|Ɏ|Ỵ|Ẏ|Ӳ|Ӯ|Ў|Ý|Ÿ|Ŷ|Υ|Ύ|Ϋ|Ỳ|Ỹ|Ỷ|Ỵ|Й/' => 'Y',
'/ẙ|ʏ|ƴ|ɏ|ỵ|ẏ|ӳ|ӯ|ў|ý|ÿ|ŷ|ỳ|ỹ|ỷ|ỵ|й/' => 'y',
'/В/' => 'V',
'/в/' => 'v',
'/Ŵ/' => 'W',
'/ŵ/' => 'w',
'/Φ/' => 'F',
'/φ/' => 'f',
'/Χ/' => 'CH',
'/χ/' => 'ch',
'/Ź|Ż|Ž|Ζ|З/' => 'Z',
'/ź|ż|ž|ζ|з/' => 'z',
'/Æ|Ǽ/' => 'AE',
'/ß/' => 'ss',
'/IJ/' => 'IJ',
'/ij/' => 'ij',
'/Œ/' => 'OE',
'/ƒ/' => 'f',
'/Ξ/' => 'KS',
'/ξ/' => 'ks',
'/Π/' => 'P',
'/π/' => 'p',
'/Β/' => 'V',
'/β/' => 'v',
'/Μ/' => 'M',
'/μ/' => 'm',
'/Ψ/' => 'PS',
'/ψ/' => 'ps',
'/Ё/' => 'Yo',
'/ё/' => 'yo',
'/Є/' => 'Ye',
'/є/' => 'ye',
'/Ї/' => 'Yi',
'/Ж/' => 'Zh',
'/ж/' => 'zh',
'/Х/' => 'Kh',
'/х/' => 'kh',
'/Ц/' => 'Ts',
'/ц/' => 'ts',
'/Ч/' => 'Ch',
'/ч/' => 'ch',
'/Ш/' => 'Sh',
'/ш/' => 'sh',
'/Щ/' => 'Shch',
'/щ/' => 'shch',
'/Ъ|ъ|Ь|ь/' => '',
'/Ю/' => 'Yu',
'/ю/' => 'yu',
'/Я/' => 'Ya',
'/я/' => 'ya'
);

View File

@@ -0,0 +1,13 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
/*
| -------------------------------------------------------------------------
| Hooks
| -------------------------------------------------------------------------
| This file lets you define "hooks" to extend CI without hacking the core
| files. Please see the user guide for info:
|
| https://codeigniter.com/user_guide/general/hooks.html
|
*/

View File

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

View File

@@ -0,0 +1,19 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
/*
| -------------------------------------------------------------------------
| Memcached settings
| -------------------------------------------------------------------------
| Your Memcached servers can be specified below.
|
| See: https://codeigniter.com/user_guide/libraries/caching.html#memcached
|
*/
$config = array(
'default' => array(
'hostname' => '127.0.0.1',
'port' => '11211',
'weight' => '1',
),
);

View File

@@ -0,0 +1,84 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
/*
|--------------------------------------------------------------------------
| Enable/Disable Migrations
|--------------------------------------------------------------------------
|
| Migrations are disabled by default for security reasons.
| You should enable migrations whenever you intend to do a schema migration
| and disable it back when you're done.
|
*/
$config['migration_enabled'] = FALSE;
/*
|--------------------------------------------------------------------------
| Migration Type
|--------------------------------------------------------------------------
|
| Migration file names may be based on a sequential identifier or on
| a timestamp. Options are:
|
| 'sequential' = Sequential migration naming (001_add_blog.php)
| 'timestamp' = Timestamp migration naming (20121031104401_add_blog.php)
| Use timestamp format YYYYMMDDHHIISS.
|
| Note: If this configuration value is missing the Migration library
| defaults to 'sequential' for backward compatibility with CI2.
|
*/
$config['migration_type'] = 'timestamp';
/*
|--------------------------------------------------------------------------
| Migrations table
|--------------------------------------------------------------------------
|
| This is the name of the table that will store the current migrations state.
| When migrations runs it will store in a database table which migration
| level the system is at. It then compares the migration level in this
| table to the $config['migration_version'] if they are not the same it
| will migrate up. This must be set.
|
*/
$config['migration_table'] = 'migrations';
/*
|--------------------------------------------------------------------------
| Auto Migrate To Latest
|--------------------------------------------------------------------------
|
| If this is set to TRUE when you load the migrations class and have
| $config['migration_enabled'] set to TRUE the system will auto migrate
| to your latest migration (whatever $config['migration_version'] is
| set to). This way you do not have to call migrations anywhere else
| in your code to have the latest migration.
|
*/
$config['migration_auto_latest'] = FALSE;
/*
|--------------------------------------------------------------------------
| Migrations version
|--------------------------------------------------------------------------
|
| This is used to set migration version that the file system should be on.
| If you run $this->migration->current() this is the version that schema will
| be upgraded / downgraded to.
|
*/
$config['migration_version'] = 0;
/*
|--------------------------------------------------------------------------
| Migrations Path
|--------------------------------------------------------------------------
|
| Path to your migrations folder.
| Typically, it will be within your application path.
| Also, writing permission is required within the migrations path.
|
*/
$config['migration_path'] = APPPATH.'migrations/';

View File

@@ -0,0 +1,184 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
/*
| -------------------------------------------------------------------
| MIME TYPES
| -------------------------------------------------------------------
| This file contains an array of mime types. It is used by the
| Upload class to help identify allowed file types.
|
*/
return array(
'hqx' => array('application/mac-binhex40', 'application/mac-binhex', 'application/x-binhex40', 'application/x-mac-binhex40'),
'cpt' => 'application/mac-compactpro',
'csv' => array('text/x-comma-separated-values', 'text/comma-separated-values', 'application/octet-stream', 'application/vnd.ms-excel', 'application/x-csv', 'text/x-csv', 'text/csv', 'application/csv', 'application/excel', 'application/vnd.msexcel', 'text/plain'),
'bin' => array('application/macbinary', 'application/mac-binary', 'application/octet-stream', 'application/x-binary', 'application/x-macbinary'),
'dms' => 'application/octet-stream',
'lha' => 'application/octet-stream',
'lzh' => 'application/octet-stream',
'exe' => array('application/octet-stream', 'application/x-msdownload'),
'class' => 'application/octet-stream',
'psd' => array('application/x-photoshop', 'image/vnd.adobe.photoshop'),
'so' => 'application/octet-stream',
'sea' => 'application/octet-stream',
'dll' => 'application/octet-stream',
'oda' => 'application/oda',
'pdf' => array('application/pdf', 'application/force-download', 'application/x-download', 'binary/octet-stream'),
'ai' => array('application/pdf', 'application/postscript'),
'eps' => 'application/postscript',
'ps' => 'application/postscript',
'smi' => 'application/smil',
'smil' => 'application/smil',
'mif' => 'application/vnd.mif',
'xls' => array('application/vnd.ms-excel', 'application/msexcel', 'application/x-msexcel', 'application/x-ms-excel', 'application/x-excel', 'application/x-dos_ms_excel', 'application/xls', 'application/x-xls', 'application/excel', 'application/download', 'application/vnd.ms-office', 'application/msword'),
'ppt' => array('application/powerpoint', 'application/vnd.ms-powerpoint', 'application/vnd.ms-office', 'application/msword'),
'pptx' => array('application/vnd.openxmlformats-officedocument.presentationml.presentation', 'application/x-zip', 'application/zip'),
'wbxml' => 'application/wbxml',
'wmlc' => 'application/wmlc',
'dcr' => 'application/x-director',
'dir' => 'application/x-director',
'dxr' => 'application/x-director',
'dvi' => 'application/x-dvi',
'gtar' => 'application/x-gtar',
'gz' => 'application/x-gzip',
'gzip' => 'application/x-gzip',
'php' => array('application/x-httpd-php', 'application/php', 'application/x-php', 'text/php', 'text/x-php', 'application/x-httpd-php-source'),
'php4' => 'application/x-httpd-php',
'php3' => 'application/x-httpd-php',
'phtml' => 'application/x-httpd-php',
'phps' => 'application/x-httpd-php-source',
'js' => array('application/x-javascript', 'text/plain'),
'swf' => 'application/x-shockwave-flash',
'sit' => 'application/x-stuffit',
'tar' => 'application/x-tar',
'tgz' => array('application/x-tar', 'application/x-gzip-compressed'),
'z' => 'application/x-compress',
'xhtml' => 'application/xhtml+xml',
'xht' => 'application/xhtml+xml',
'zip' => array('application/x-zip', 'application/zip', 'application/x-zip-compressed', 'application/s-compressed', 'multipart/x-zip'),
'rar' => array('application/x-rar', 'application/rar', 'application/x-rar-compressed'),
'mid' => 'audio/midi',
'midi' => 'audio/midi',
'mpga' => 'audio/mpeg',
'mp2' => 'audio/mpeg',
'mp3' => array('audio/mpeg', 'audio/mpg', 'audio/mpeg3', 'audio/mp3'),
'aif' => array('audio/x-aiff', 'audio/aiff'),
'aiff' => array('audio/x-aiff', 'audio/aiff'),
'aifc' => 'audio/x-aiff',
'ram' => 'audio/x-pn-realaudio',
'rm' => 'audio/x-pn-realaudio',
'rpm' => 'audio/x-pn-realaudio-plugin',
'ra' => 'audio/x-realaudio',
'rv' => 'video/vnd.rn-realvideo',
'wav' => array('audio/x-wav', 'audio/wave', 'audio/wav'),
'bmp' => array('image/bmp', 'image/x-bmp', 'image/x-bitmap', 'image/x-xbitmap', 'image/x-win-bitmap', 'image/x-windows-bmp', 'image/ms-bmp', 'image/x-ms-bmp', 'application/bmp', 'application/x-bmp', 'application/x-win-bitmap'),
'gif' => 'image/gif',
'jpeg' => array('image/jpeg', 'image/pjpeg'),
'jpg' => array('image/jpeg', 'image/pjpeg'),
'jpe' => array('image/jpeg', 'image/pjpeg'),
'jp2' => array('image/jp2', 'video/mj2', 'image/jpx', 'image/jpm'),
'j2k' => array('image/jp2', 'video/mj2', 'image/jpx', 'image/jpm'),
'jpf' => array('image/jp2', 'video/mj2', 'image/jpx', 'image/jpm'),
'jpg2' => array('image/jp2', 'video/mj2', 'image/jpx', 'image/jpm'),
'jpx' => array('image/jp2', 'video/mj2', 'image/jpx', 'image/jpm'),
'jpm' => array('image/jp2', 'video/mj2', 'image/jpx', 'image/jpm'),
'mj2' => array('image/jp2', 'video/mj2', 'image/jpx', 'image/jpm'),
'mjp2' => array('image/jp2', 'video/mj2', 'image/jpx', 'image/jpm'),
'png' => array('image/png', 'image/x-png'),
'tiff' => 'image/tiff',
'tif' => 'image/tiff',
'css' => array('text/css', 'text/plain'),
'html' => array('text/html', 'text/plain'),
'htm' => array('text/html', 'text/plain'),
'shtml' => array('text/html', 'text/plain'),
'txt' => 'text/plain',
'text' => 'text/plain',
'log' => array('text/plain', 'text/x-log'),
'rtx' => 'text/richtext',
'rtf' => 'text/rtf',
'xml' => array('application/xml', 'text/xml', 'text/plain'),
'xsl' => array('application/xml', 'text/xsl', 'text/xml'),
'mpeg' => 'video/mpeg',
'mpg' => 'video/mpeg',
'mpe' => 'video/mpeg',
'qt' => 'video/quicktime',
'mov' => 'video/quicktime',
'avi' => array('video/x-msvideo', 'video/msvideo', 'video/avi', 'application/x-troff-msvideo'),
'movie' => 'video/x-sgi-movie',
'doc' => array('application/msword', 'application/vnd.ms-office'),
'docx' => array('application/vnd.openxmlformats-officedocument.wordprocessingml.document', 'application/zip', 'application/msword', 'application/x-zip'),
'dot' => array('application/msword', 'application/vnd.ms-office'),
'dotx' => array('application/vnd.openxmlformats-officedocument.wordprocessingml.document', 'application/zip', 'application/msword'),
'xlsx' => array('application/vnd.openxmlformats-officedocument.spreadsheetml.sheet', 'application/zip', 'application/vnd.ms-excel', 'application/msword', 'application/x-zip'),
'word' => array('application/msword', 'application/octet-stream'),
'xl' => 'application/excel',
'eml' => 'message/rfc822',
'json' => array('application/json', 'text/json'),
'pem' => array('application/x-x509-user-cert', 'application/x-pem-file', 'application/octet-stream'),
'p10' => array('application/x-pkcs10', 'application/pkcs10'),
'p12' => 'application/x-pkcs12',
'p7a' => 'application/x-pkcs7-signature',
'p7c' => array('application/pkcs7-mime', 'application/x-pkcs7-mime'),
'p7m' => array('application/pkcs7-mime', 'application/x-pkcs7-mime'),
'p7r' => 'application/x-pkcs7-certreqresp',
'p7s' => 'application/pkcs7-signature',
'crt' => array('application/x-x509-ca-cert', 'application/x-x509-user-cert', 'application/pkix-cert'),
'crl' => array('application/pkix-crl', 'application/pkcs-crl'),
'der' => 'application/x-x509-ca-cert',
'kdb' => 'application/octet-stream',
'pgp' => 'application/pgp',
'gpg' => 'application/gpg-keys',
'sst' => 'application/octet-stream',
'csr' => 'application/octet-stream',
'rsa' => 'application/x-pkcs7',
'cer' => array('application/pkix-cert', 'application/x-x509-ca-cert'),
'3g2' => 'video/3gpp2',
'3gp' => array('video/3gp', 'video/3gpp'),
'mp4' => 'video/mp4',
'm4a' => 'audio/x-m4a',
'f4v' => array('video/mp4', 'video/x-f4v'),
'flv' => 'video/x-flv',
'webm' => 'video/webm',
'aac' => array('audio/x-aac', 'audio/aac'),
'm4u' => 'application/vnd.mpegurl',
'm3u' => 'text/plain',
'xspf' => 'application/xspf+xml',
'vlc' => 'application/videolan',
'wmv' => array('video/x-ms-wmv', 'video/x-ms-asf'),
'au' => 'audio/x-au',
'ac3' => 'audio/ac3',
'flac' => 'audio/x-flac',
'ogg' => array('audio/ogg', 'video/ogg', 'application/ogg'),
'kmz' => array('application/vnd.google-earth.kmz', 'application/zip', 'application/x-zip'),
'kml' => array('application/vnd.google-earth.kml+xml', 'application/xml', 'text/xml'),
'ics' => 'text/calendar',
'ical' => 'text/calendar',
'zsh' => 'text/x-scriptzsh',
'7z' => array('application/x-7z-compressed', 'application/x-compressed', 'application/x-zip-compressed', 'application/zip', 'multipart/x-zip'),
'7zip' => array('application/x-7z-compressed', 'application/x-compressed', 'application/x-zip-compressed', 'application/zip', 'multipart/x-zip'),
'cdr' => array('application/cdr', 'application/coreldraw', 'application/x-cdr', 'application/x-coreldraw', 'image/cdr', 'image/x-cdr', 'zz-application/zz-winassoc-cdr'),
'wma' => array('audio/x-ms-wma', 'video/x-ms-asf'),
'jar' => array('application/java-archive', 'application/x-java-application', 'application/x-jar', 'application/x-compressed'),
'svg' => array('image/svg+xml', 'application/xml', 'text/xml'),
'vcf' => 'text/x-vcard',
'srt' => array('text/srt', 'text/plain'),
'vtt' => array('text/vtt', 'text/plain'),
'ico' => array('image/x-icon', 'image/x-ico', 'image/vnd.microsoft.icon'),
'odc' => 'application/vnd.oasis.opendocument.chart',
'otc' => 'application/vnd.oasis.opendocument.chart-template',
'odf' => 'application/vnd.oasis.opendocument.formula',
'otf' => 'application/vnd.oasis.opendocument.formula-template',
'odg' => 'application/vnd.oasis.opendocument.graphics',
'otg' => 'application/vnd.oasis.opendocument.graphics-template',
'odi' => 'application/vnd.oasis.opendocument.image',
'oti' => 'application/vnd.oasis.opendocument.image-template',
'odp' => 'application/vnd.oasis.opendocument.presentation',
'otp' => 'application/vnd.oasis.opendocument.presentation-template',
'ods' => 'application/vnd.oasis.opendocument.spreadsheet',
'ots' => 'application/vnd.oasis.opendocument.spreadsheet-template',
'odt' => 'application/vnd.oasis.opendocument.text',
'odm' => 'application/vnd.oasis.opendocument.text-master',
'ott' => 'application/vnd.oasis.opendocument.text-template',
'oth' => 'application/vnd.oasis.opendocument.text-web'
);

View File

@@ -0,0 +1,14 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
/*
| -------------------------------------------------------------------------
| Profiler Sections
| -------------------------------------------------------------------------
| This file lets you determine whether or not various sections of Profiler
| data are displayed when the Profiler is enabled.
| Please see the user guide for info:
|
| https://codeigniter.com/user_guide/general/profiling.html
|
*/

View File

@@ -0,0 +1,80 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
/*
| -------------------------------------------------------------------------
| URI ROUTING
| -------------------------------------------------------------------------
| This file lets you re-map URI requests to specific controller functions.
|
| Typically there is a one-to-one relationship between a URL string
| and its corresponding controller class/method. The segments in a
| URL normally follow this pattern:
|
| example.com/class/method/id/
|
| In some instances, however, you may want to remap this relationship
| so that a different class/function is called than the one
| corresponding to the URL.
|
| Please see the user guide for complete details:
|
| https://codeigniter.com/user_guide/general/routing.html
|
| -------------------------------------------------------------------------
| RESERVED ROUTES
| -------------------------------------------------------------------------
|
| There are three reserved routes:
|
| $route['default_controller'] = 'welcome';
|
| This route indicates which controller class should be loaded if the
| URI contains no data. In the above example, the "welcome" class
| would be loaded.
|
| $route['404_override'] = 'errors/page_missing';
|
| This route will tell the Router which controller/method to use if those
| provided in the URL cannot be matched to a valid route.
|
| $route['translate_uri_dashes'] = FALSE;
|
| This is not exactly a route, but allows you to automatically route
| controller and method names that contain dashes. '-' isn't a valid
| class or method name character, so it requires translation.
| When you set this option to TRUE, it will replace ALL dashes in the
| controller and method URI segments.
|
| Examples: my-controller/index -> my_controller/index
| my-controller/my-method -> my_controller/my_method
*/
$route['default_controller'] = 'welcome';
$route['admin'] = 'HmsAdmin/login';
$route['logout'] = 'HmsAdmin/logout';
$route['dashboard'] = 'HmsAdmin/dashboard';
$route['roles'] = 'HmsAdmin/roles';
$route['add-edit-role/(:any)'] = 'HmsAdmin/add_edit_role/$1';
$route['users'] = 'HmsAdmin/users';
$route['add-edit-user/(:any)'] = 'HmsAdmin/add_edit_user/$1';
$route['forgot-password'] = 'HmsAdmin/forgot_password';
$route['reset-password/(:any)'] = 'HmsAdmin/reset_password/$1';
$route['404_override'] = '';
$route['translate_uri_dashes'] = FALSE;
// Routes - Afras Khan
$route['dashboard'] = 'HmsAdmin/dashboard';
$route['blocks'] = 'HmsAdmin/blocks';
$route['floors'] = 'HmsAdmin/floors';
$route['rooms'] = 'HmsAdmin/rooms';
$route['beds'] = 'HmsAdmin/beds';
$route['students'] = 'HmsAdmin/students';
$route['assign-students/(:any)'] = 'HmsAdmin/ae_assign_student/$1';
$route['profile/(:any)'] = 'HmsAdmin/student_profile/$1';
// $routes['delete-block/(:any)'] = 'HmsAdmin/delete_block/$1';

View File

@@ -0,0 +1,64 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
/*
| -------------------------------------------------------------------
| SMILEYS
| -------------------------------------------------------------------
| This file contains an array of smileys for use with the emoticon helper.
| Individual images can be used to replace multiple smileys. For example:
| :-) and :) use the same image replacement.
|
| Please see user guide for more info:
| https://codeigniter.com/user_guide/helpers/smiley_helper.html
|
*/
$smileys = array(
// smiley image name width height alt
':-)' => array('grin.gif', '19', '19', 'grin'),
':lol:' => array('lol.gif', '19', '19', 'LOL'),
':cheese:' => array('cheese.gif', '19', '19', 'cheese'),
':)' => array('smile.gif', '19', '19', 'smile'),
';-)' => array('wink.gif', '19', '19', 'wink'),
';)' => array('wink.gif', '19', '19', 'wink'),
':smirk:' => array('smirk.gif', '19', '19', 'smirk'),
':roll:' => array('rolleyes.gif', '19', '19', 'rolleyes'),
':-S' => array('confused.gif', '19', '19', 'confused'),
':wow:' => array('surprise.gif', '19', '19', 'surprised'),
':bug:' => array('bigsurprise.gif', '19', '19', 'big surprise'),
':-P' => array('tongue_laugh.gif', '19', '19', 'tongue laugh'),
'%-P' => array('tongue_rolleye.gif', '19', '19', 'tongue rolleye'),
';-P' => array('tongue_wink.gif', '19', '19', 'tongue wink'),
':P' => array('raspberry.gif', '19', '19', 'raspberry'),
':blank:' => array('blank.gif', '19', '19', 'blank stare'),
':long:' => array('longface.gif', '19', '19', 'long face'),
':ohh:' => array('ohh.gif', '19', '19', 'ohh'),
':grrr:' => array('grrr.gif', '19', '19', 'grrr'),
':gulp:' => array('gulp.gif', '19', '19', 'gulp'),
'8-/' => array('ohoh.gif', '19', '19', 'oh oh'),
':down:' => array('downer.gif', '19', '19', 'downer'),
':red:' => array('embarrassed.gif', '19', '19', 'red face'),
':sick:' => array('sick.gif', '19', '19', 'sick'),
':shut:' => array('shuteye.gif', '19', '19', 'shut eye'),
':-/' => array('hmm.gif', '19', '19', 'hmmm'),
'>:(' => array('mad.gif', '19', '19', 'mad'),
':mad:' => array('mad.gif', '19', '19', 'mad'),
'>:-(' => array('angry.gif', '19', '19', 'angry'),
':angry:' => array('angry.gif', '19', '19', 'angry'),
':zip:' => array('zip.gif', '19', '19', 'zipper'),
':kiss:' => array('kiss.gif', '19', '19', 'kiss'),
':ahhh:' => array('shock.gif', '19', '19', 'shock'),
':coolsmile:' => array('shade_smile.gif', '19', '19', 'cool smile'),
':coolsmirk:' => array('shade_smirk.gif', '19', '19', 'cool smirk'),
':coolgrin:' => array('shade_grin.gif', '19', '19', 'cool grin'),
':coolhmm:' => array('shade_hmm.gif', '19', '19', 'cool hmm'),
':coolmad:' => array('shade_mad.gif', '19', '19', 'cool mad'),
':coolcheese:' => array('shade_cheese.gif', '19', '19', 'cool cheese'),
':vampire:' => array('vampire.gif', '19', '19', 'vampire'),
':snake:' => array('snake.gif', '19', '19', 'snake'),
':exclaim:' => array('exclaim.gif', '19', '19', 'exclaim'),
':question:' => array('question.gif', '19', '19', 'question')
);

View File

@@ -0,0 +1,216 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
/*
| -------------------------------------------------------------------
| USER AGENT TYPES
| -------------------------------------------------------------------
| This file contains four arrays of user agent data. It is used by the
| User Agent Class to help identify browser, platform, robot, and
| mobile device data. The array keys are used to identify the device
| and the array values are used to set the actual name of the item.
*/
$platforms = array(
'windows nt 10.0' => 'Windows 10',
'windows nt 6.3' => 'Windows 8.1',
'windows nt 6.2' => 'Windows 8',
'windows nt 6.1' => 'Windows 7',
'windows nt 6.0' => 'Windows Vista',
'windows nt 5.2' => 'Windows 2003',
'windows nt 5.1' => 'Windows XP',
'windows nt 5.0' => 'Windows 2000',
'windows nt 4.0' => 'Windows NT 4.0',
'winnt4.0' => 'Windows NT 4.0',
'winnt 4.0' => 'Windows NT',
'winnt' => 'Windows NT',
'windows 98' => 'Windows 98',
'win98' => 'Windows 98',
'windows 95' => 'Windows 95',
'win95' => 'Windows 95',
'windows phone' => 'Windows Phone',
'windows' => 'Unknown Windows OS',
'android' => 'Android',
'blackberry' => 'BlackBerry',
'iphone' => 'iOS',
'ipad' => 'iOS',
'ipod' => 'iOS',
'os x' => 'Mac OS X',
'ppc mac' => 'Power PC Mac',
'freebsd' => 'FreeBSD',
'ppc' => 'Macintosh',
'linux' => 'Linux',
'debian' => 'Debian',
'sunos' => 'Sun Solaris',
'beos' => 'BeOS',
'apachebench' => 'ApacheBench',
'aix' => 'AIX',
'irix' => 'Irix',
'osf' => 'DEC OSF',
'hp-ux' => 'HP-UX',
'netbsd' => 'NetBSD',
'bsdi' => 'BSDi',
'openbsd' => 'OpenBSD',
'gnu' => 'GNU/Linux',
'unix' => 'Unknown Unix OS',
'symbian' => 'Symbian OS'
);
// The order of this array should NOT be changed. Many browsers return
// multiple browser types so we want to identify the sub-type first.
$browsers = array(
'OPR' => 'Opera',
'Flock' => 'Flock',
'Edge' => 'Edge',
'Chrome' => 'Chrome',
// Opera 10+ always reports Opera/9.80 and appends Version/<real version> to the user agent string
'Opera.*?Version' => 'Opera',
'Opera' => 'Opera',
'MSIE' => 'Internet Explorer',
'Internet Explorer' => 'Internet Explorer',
'Trident.* rv' => 'Internet Explorer',
'Shiira' => 'Shiira',
'Firefox' => 'Firefox',
'Chimera' => 'Chimera',
'Phoenix' => 'Phoenix',
'Firebird' => 'Firebird',
'Camino' => 'Camino',
'Netscape' => 'Netscape',
'OmniWeb' => 'OmniWeb',
'Safari' => 'Safari',
'Mozilla' => 'Mozilla',
'Konqueror' => 'Konqueror',
'icab' => 'iCab',
'Lynx' => 'Lynx',
'Links' => 'Links',
'hotjava' => 'HotJava',
'amaya' => 'Amaya',
'IBrowse' => 'IBrowse',
'Maxthon' => 'Maxthon',
'Ubuntu' => 'Ubuntu Web Browser'
);
$mobiles = array(
// legacy array, old values commented out
'mobileexplorer' => 'Mobile Explorer',
// 'openwave' => 'Open Wave',
// 'opera mini' => 'Opera Mini',
// 'operamini' => 'Opera Mini',
// 'elaine' => 'Palm',
'palmsource' => 'Palm',
// 'digital paths' => 'Palm',
// 'avantgo' => 'Avantgo',
// 'xiino' => 'Xiino',
'palmscape' => 'Palmscape',
// 'nokia' => 'Nokia',
// 'ericsson' => 'Ericsson',
// 'blackberry' => 'BlackBerry',
// 'motorola' => 'Motorola'
// Phones and Manufacturers
'motorola' => 'Motorola',
'nokia' => 'Nokia',
'nexus' => 'Nexus',
'palm' => 'Palm',
'iphone' => 'Apple iPhone',
'ipad' => 'iPad',
'ipod' => 'Apple iPod Touch',
'sony' => 'Sony Ericsson',
'ericsson' => 'Sony Ericsson',
'blackberry' => 'BlackBerry',
'cocoon' => 'O2 Cocoon',
'blazer' => 'Treo',
'lg' => 'LG',
'amoi' => 'Amoi',
'xda' => 'XDA',
'mda' => 'MDA',
'vario' => 'Vario',
'htc' => 'HTC',
'samsung' => 'Samsung',
'sharp' => 'Sharp',
'sie-' => 'Siemens',
'alcatel' => 'Alcatel',
'benq' => 'BenQ',
'ipaq' => 'HP iPaq',
'mot-' => 'Motorola',
'playstation portable' => 'PlayStation Portable',
'playstation 3' => 'PlayStation 3',
'playstation vita' => 'PlayStation Vita',
'hiptop' => 'Danger Hiptop',
'nec-' => 'NEC',
'panasonic' => 'Panasonic',
'philips' => 'Philips',
'sagem' => 'Sagem',
'sanyo' => 'Sanyo',
'spv' => 'SPV',
'zte' => 'ZTE',
'sendo' => 'Sendo',
'nintendo dsi' => 'Nintendo DSi',
'nintendo ds' => 'Nintendo DS',
'nintendo 3ds' => 'Nintendo 3DS',
'wii' => 'Nintendo Wii',
'open web' => 'Open Web',
'openweb' => 'OpenWeb',
'meizu' => 'Meizu',
// Operating Systems
'android' => 'Android',
'symbian' => 'Symbian',
'SymbianOS' => 'SymbianOS',
'elaine' => 'Palm',
'series60' => 'Symbian S60',
'windows ce' => 'Windows CE',
// Browsers
'obigo' => 'Obigo',
'netfront' => 'Netfront Browser',
'openwave' => 'Openwave Browser',
'mobilexplorer' => 'Mobile Explorer',
'operamini' => 'Opera Mini',
'opera mini' => 'Opera Mini',
'opera mobi' => 'Opera Mobile',
'fennec' => 'Firefox Mobile',
// Other
'digital paths' => 'Digital Paths',
'avantgo' => 'AvantGo',
'xiino' => 'Xiino',
'novarra' => 'Novarra Transcoder',
'vodafone' => 'Vodafone',
'docomo' => 'NTT DoCoMo',
'o2' => 'O2',
// Fallback
'mobile' => 'Generic Mobile',
'wireless' => 'Generic Mobile',
'j2me' => 'Generic Mobile',
'midp' => 'Generic Mobile',
'cldc' => 'Generic Mobile',
'up.link' => 'Generic Mobile',
'up.browser' => 'Generic Mobile',
'smartphone' => 'Generic Mobile',
'cellphone' => 'Generic Mobile'
);
// There are hundreds of bots but these are the most common.
$robots = array(
'googlebot' => 'Googlebot',
'msnbot' => 'MSNBot',
'baiduspider' => 'Baiduspider',
'bingbot' => 'Bing',
'slurp' => 'Inktomi Slurp',
'yahoo' => 'Yahoo',
'ask jeeves' => 'Ask Jeeves',
'fastcrawler' => 'FastCrawler',
'infoseek' => 'InfoSeek Robot 1.0',
'lycos' => 'Lycos',
'yandex' => 'YandexBot',
'mediapartners-google' => 'MediaPartners Google',
'CRAZYWEBCRAWLER' => 'Crazy Webcrawler',
'adsbot-google' => 'AdsBot Google',
'feedfetcher-google' => 'Feedfetcher Google',
'curious george' => 'Curious George',
'ia_archiver' => 'Alexa Crawler',
'MJ12bot' => 'Majestic-12',
'Uptimebot' => 'Uptimebot'
);

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,25 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
class Welcome extends CI_Controller {
/**
* Index Page for this controller.
*
* Maps to the following URL
* http://example.com/index.php/welcome
* - or -
* http://example.com/index.php/welcome/index
* - or -
* Since this controller is set as the default controller in
* config/routes.php, it's displayed at http://example.com/
*
* So any other public methods not prefixed with an underscore will
* map to /index.php/welcome/<method_name>
* @see https://codeigniter.com/user_guide/general/urls.html
*/
public function index()
{
$this->load->view('welcome_message');
}
}

View File

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

View File

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

View File

@@ -0,0 +1,70 @@
<?php
function urlsafe_b64encode($string)
{
$data = base64_encode($string);
$data = str_replace(array('+','/','='),array('-','_',''),$data);
return $data;
}
function urlsafe_b64decode($string) {
$data = str_replace(array('-','_'),array('+','/'),$string);
$mod4 = strlen($data) % 4;
if ($mod4) {
$data .= substr('====', $mod4);
}
return base64_decode($data);
}
function test_view_array($array) {
echo '<pre>';
print_r($array);
exit();
}
function cuurentNepaliDate($dateObj) {
$date_arr = explode('-', date('Y-m-d'));
list($y, $m, $d) = $date_arr;
// Convert BS to AD.
$datearr = $dateObj->convertAdToBs($y, $m, $d);
extract($datearr);
$string = $year.'-'.$month.'-'.$day;
$date = date_create_from_format('Y-m-d', $string);
return $php_date = date_format($date, 'Y-m-d H:i:s');
}
/*function loggedin_admin_user_permissions()
{
$CI = &get_instance();
$CI->load->model('AdminRule_Model');
$adminRules = $CI->AdminRule_Model->get_admin_rule_details('', "SELECT menu_id FROM admin_rule WHERE role_id=".$CI->session->userdata('role_id'));
return $adminRules;
}*/
function ciSendEmail($data=array())
{
$CI = &get_instance();
$CI->load->library('email');
//$CI->email->clear();
//$config['mailtype'] = 'html';
//$CI->email->initialize($config);
$CI->email->from('nandini@ezydemo.com', 'Erisn Classroom Hostel');
$CI->email->to($data['to']);
//if(isset($data['cc_to']) && $data['cc_to']!='')
//$CI->email->cc($data['cc_to']);
$CI->email->subject($data['subject']);
$CI->email->message($data['message']);
$CI->email->set_mailtype('html');
$res = $CI->email->send();
//echo $res;exit;
return $res;
}
?>

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

@@ -0,0 +1,59 @@
<?php
class classroom_model extends CI_Model
{
public function __construct()
{
parent::__construct();
$this->db = $this->load->database('classroom', TRUE);
}
public function get_table_info($table_name, $where = '', $sqlQry = '', $order = 'DESC', $limit = FALSE, $offset = FALSE)
{
if ($limit)
$this->db->limit($limit, $offset);
if ($where != '')
$this->db->where($where);
$this->db->order_by($table_name . '.id', $order);
$query = $this->db->get($table_name);
if ($sqlQry != '')
$query = $this->db->query($sqlQry);
return $query->result_array();
}
public function get_table_info_row($table_name, $where = '', $sqlQry = '', $order = 'DESC', $limit = FALSE, $offset = FALSE)
{
if ($limit)
$this->db->limit($limit, $offset);
if ($where != '')
$this->db->where($where);
$this->db->order_by($table_name . '.id', $order);
$query = $this->db->get($table_name);
if ($sqlQry != '')
$query = $this->db->query($sqlQry);
return $query->row_array();
}
public function get_logo_from_setting()
{
$this->db->select('*');
$this->db->from('school_settings');
$query = $this->db->get();
return $query->row_array();
}
}
?>

View File

@@ -0,0 +1,461 @@
<?php
class HmsAdmin_Model extends CI_Model
{
/*############################################ START Of Coding By Nandini ############################################*/
public function __construct()
{
$this->load->database();
}
/**************************************** START of Admin Roles - Nandini ************************************/
public function get_hms_admin_roles($where='', $sqlQry='', $limit=FALSE, $offset=FALSE)
{
if($limit)
$this->db->limit($limit, $offset);
if($where!='')
$this->db->where($where);
$this->db->order_by('hms_admin_roles.id', 'DESC');
$query = $this->db->get('hms_admin_roles');
if($sqlQry!='')
$query = $this->db->query($sqlQry);
return $query->result_array();
}
public function check_role_exists($id, $rname)
{
$rId = ($this->input->post('id') !== NULL) ? $this->input->post('id'): $id;
$rName = ($this->input->post('role_name') !== NULL) ? $this->input->post('role_name'): $rname;
$query = $this->db->get_where('hms_admin_roles', array('role_name' => $rName));
if(!empty($query->row_array()))
{
if($rId == 0)
return false; //Duplicate role_name
else
{
if($query->row(0)->id != $rId)
return false; //Duplicate role_name
}
}
return true; //No duplicate
}
function add_edit_admin_role($rId=0, $data)
{
if($rId == 0)
{
$this->db->insert('hms_admin_roles', $data);
if($this->db->affected_rows() > 0){
$insertid = $this->db->insert_id();
return $insertid;
}
else{
return 0;
}
}
else
{
$this->db->where('id', $rId);
$this->db->update('hms_admin_roles', $data);
if($this->db->affected_rows() > 0)
return true;
else
{
if ($this->db->trans_status() === FALSE)
return 0;
return true;
}
}
}
public function delete_admin_role($idVal)
{
$delSqlQry = "DELETE FROM hms_admin_roles WHERE id = $idVal";
$this->db->query($delSqlQry);
return true;
}
/**************************************** ENDDD of Admin Roles - Nandini ************************************/
/**************************************** START of Admin Menu - Nandini ************************************/
public function get_admin_menu_details($where='', $sqlQry='', $limit=FALSE, $offset=FALSE)
{
if ($limit){
$this->db->limit($limit, $offset);
}
if($where!='')
$this->db->where($where);
$this->db->order_by('hms_admin_menu.id', 'DESC');
$query = $this->db->get('hms_admin_menu');
if($sqlQry!='')
$query = $this->db->query($sqlQry);
return $query->result_array();
}
function recursive_menue($parentId = 0)
{
$this->db->where('parent_id', $parentId);
//$this->db->where('is_active', 'Y');
$this->db->order_by('order_number', 'ASC');
$query = $this->db->get('hms_admin_menu');
$result = $query->result_array();
$adminMenu = array();
if(!empty($result))
{
foreach($result as $res)
{
array_push($adminMenu, $res);
}
}
return $adminMenu;
}
function get_admin_menu($parentId = 0)
{
$zeroMenu = $this->recursive_menue(0);
$adminMenu = array();
if(!empty($zeroMenu))
{
foreach($zeroMenu as $zero)
{
$adminMenu[$zero['id']] = $zero;
$oneMenu = $this->recursive_menue($zero['id']);
if(!empty($oneMenu))
{
foreach($oneMenu as $one)
{
$adminMenu[$zero['id']][$zero['id']][$one['id']] = $one;
$twoMenu = $this->recursive_menue($one['id']);
if(!empty($twoMenu))
{
foreach($twoMenu as $two)
{
$adminMenu[$zero['id']][$zero['id']][$one['id']][$one['id']][$two['id']] = $two;
}
}
}
}
}
}
//echo '<pre>';print_r($adminMenu);
return $adminMenu;
}
public function get_hms_admin_role_permissions($where='', $sqlQry='', $limit=FALSE, $offset=FALSE)
{
if($limit)
$this->db->limit($limit, $offset);
if($where!='')
$this->db->where($where);
$this->db->order_by('hms_admin_role_permissions.id', 'DESC');
$query = $this->db->get('hms_admin_role_permissions');
if($sqlQry!='')
$query = $this->db->query($sqlQry);
return $query->result_array();
}
function add_edit_admin_role_permissions($rpId=0, $data)
{
if($rpId == 0)
{
$this->db->insert('hms_admin_role_permissions', $data);
if($this->db->affected_rows() > 0){
$insertid = $this->db->insert_id();
return $insertid;
}
else{
return 0;
}
}
else
{
$this->db->where('id', $rpId);
$this->db->update('hms_admin_role_permissions', $data);
if($this->db->affected_rows() > 0)
return true;
else
{
if ($this->db->trans_status() === FALSE)
return 0;
return true;
}
}
}
/**************************************** END of Admin Menu - Nandini ************************************/
public function check_emailid_exists($id, $email)
{
$uId = ($this->input->post('id') !== NULL) ? $this->input->post('id'): $id;
$eId = ($this->input->post('email') !== NULL) ? $this->input->post('email'): $email;
$query = $this->db->get_where('hms_admin', array('email' => $eId));
if(!empty($query->row_array()))
{
if($uId == 0)
return false; //Duplicate email id
else
{
if($query->row(0)->id != $uId)
return false; //Duplicate email id
}
}
return true; //No duplicate
}
function add_edit_admin_user($uId=0, $data)
{
if($uId == 0)
{
$this->db->insert('hms_admin', $data);
if($this->db->affected_rows() > 0){
$insertid = $this->db->insert_id();
return $insertid;
}
else{
return 0;
}
}
else
{
$this->db->where('id', $uId);
$this->db->update('hms_admin', $data);
if($this->db->affected_rows() > 0)
return true;
else
{
if ($this->db->trans_status() === FALSE)
return 0;
return true;
}
}
}
public function delete_admin_user($idVal)
{
$delSqlQry = "DELETE FROM hms_admin WHERE id = $idVal";
$this->db->query($delSqlQry);
return true;
}
public function get_admin_details($where='', $sqlQry='', $limit=FALSE, $offset=FALSE)
{
if ($limit){
$this->db->limit($limit, $offset);
}
if($where!='')
$this->db->where($where);
$this->db->order_by('hms_admin.id', 'DESC');
$query = $this->db->get('hms_admin');
if($sqlQry!='')
$query = $this->db->query($sqlQry);
return $query->result_array();
}
public function check_is_emailid_valid($email)
{
$query = $this->db->query("SELECT id FROM hms_admin WHERE email='$email'");
if($row = $query->row()){
return TRUE;
}else{
return FALSE;
}
}
/*----------------------------- START of Admin User Login Functionality -----------------------------*/
public function check_login_credentials($email, $encrypt_password)
{
$where = 'email="'.$email.'" AND password="'.$encrypt_password.'"';
$this->db->where($where);
$result = $this->db->get('hms_admin');
if ($result->num_rows() == 1) {
return true;
}else{
return false;
}
}
/*----------------------------- ENDDD of Admin User Login Functionality -----------------------------*/
/*----------------------------- START of Admin User Password Functionality -----------------------------*/
public function reset_admin_password($uId, $new_password)
{
$data = array(
'password' => md5($new_password)
);
$this->db->where('id', $uId);
return $this->db->update('hms_admin', $data);
}
/*----------------------------- ENDDD of Admin User Password Functionality -----------------------------*/
/*############################################ ENDDD Of Coding By Nandini ############################################*/
// ================== Blocks Start - Afras khan - 02-12-2021 ==================
function add_edit_table($table,$id, $data, $update_where = '')
{
if ($id == 0) {
$this->db->insert($table, $data);
if ($this->db->affected_rows() > 0)
return $insert_id = $this->db->insert_id();
else
return 0;
} else {
if($update_where != '')
$this->db->where($update_where);
else
$this->db->where('id', $id);
$this->db->update($table, $data);
if ($this->db->trans_status() === FALSE)
return 0;
return true;
}
}
function update_block_floors($block_id, $data) {
$this->db->trans_start();
$this->db->where('block_id', $block_id);
$this->db->update_batch('hms_floors', $data,'id');
$this->db->trans_complete();
if ($this->db->trans_status() === FALSE)
return 0;
else
return true;
}
function insert_batch_data($table, $data) {
$this->db->trans_start();
$this->db->insert_batch($table, $data);
$this->db->trans_complete();
if ($this->db->trans_status() === FALSE)
return 0;
else
return true;
}
function insert_data($table, $data) {
$this->db->trans_start();
$this->db->insert($table, $data);
$this->db->trans_complete();
if ($this->db->trans_status() === FALSE)
return 0;
else
return true;
}
public function get_table_info($table_name, $where = '', $sqlQry = '', $order = 'DESC', $limit = FALSE, $offset = FALSE)
{
if ($limit)
$this->db->limit($limit, $offset);
if ($where != '')
$this->db->where($where);
$this->db->order_by($table_name . '.id', $order);
$query = $this->db->get($table_name);
if ($sqlQry != '')
$query = $this->db->query($sqlQry);
return $query->result_array();
}
public function get_table_info_row($table_name, $where = '', $sqlQry = '', $order = 'DESC', $limit = FALSE, $offset = FALSE)
{
if ($limit)
$this->db->limit($limit, $offset);
if ($where != '')
$this->db->where($where);
$this->db->order_by($table_name . '.id', $order);
$query = $this->db->get($table_name);
if ($sqlQry != '')
$query = $this->db->query($sqlQry);
return $query->row_array();
}
public function deleteTable($table, $id='', $where='')
{
if($where != '')
$this->db->delete($table, $where);
else
$this->db->delete($table, array('id' => $id));
if ($this->db->affected_rows()) {
return true;
} else {
return false;
}
}
public function check_value_exists($table, $where, $id)
{
$query = $this->db->get_where($table, $where);
if (!empty($query->row_array())) {
if ($id == 0)
return false;
else {
if ($query->row(0)->id != $id)
return false;
}
}
return 1;
}
// ================== Blocks End - Afras khan - 02-12-2021 ==================
// ================== Floors - Afras khan - 03-12-2021 ==================
function update_floor_rooms($floor_id, $data) {
$this->db->trans_start();
$this->db->where('room_floor_id', $floor_id);
$this->db->update_batch('hms_rooms', $data,'id');
$this->db->trans_complete();
if ($this->db->trans_status() === FALSE)
return 0;
else
return true;
}
// ================== Floors End - Afras khan - 03-12-2021 ==================
}
?>

View File

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

View File

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

View File

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

View File

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

View File

@@ -0,0 +1,21 @@
<?php defined('BASEPATH') OR exit('No direct script access allowed'); ?>
An uncaught Exception was encountered
Type: <?php echo get_class($exception), "\n"; ?>
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): ?>
Backtrace:
<?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 ?>

View File

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

View File

@@ -0,0 +1,21 @@
<?php defined('BASEPATH') OR exit('No direct script access allowed'); ?>
A PHP Error was encountered
Severity: <?php echo $severity, "\n"; ?>
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): ?>
Backtrace:
<?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 ?>

View File

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

View File

@@ -0,0 +1,64 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
?><!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>404 Page Not Found</title>
<style type="text/css">
::selection { background-color: #E13300; color: white; }
::-moz-selection { background-color: #E13300; color: white; }
body {
background-color: #fff;
margin: 40px;
font: 13px/20px normal Helvetica, Arial, sans-serif;
color: #4F5155;
}
a {
color: #003399;
background-color: transparent;
font-weight: normal;
}
h1 {
color: #444;
background-color: transparent;
border-bottom: 1px solid #D0D0D0;
font-size: 19px;
font-weight: normal;
margin: 0 0 14px 0;
padding: 14px 15px 10px 15px;
}
code {
font-family: Consolas, Monaco, Courier New, Courier, monospace;
font-size: 12px;
background-color: #f9f9f9;
border: 1px solid #D0D0D0;
color: #002166;
display: block;
margin: 14px 0 14px 0;
padding: 12px 10px 12px 10px;
}
#container {
margin: 10px;
border: 1px solid #D0D0D0;
box-shadow: 0 0 8px #D0D0D0;
}
p {
margin: 12px 15px 12px 15px;
}
</style>
</head>
<body>
<div id="container">
<h1><?php echo $heading; ?></h1>
<?php echo $message; ?>
</div>
</body>
</html>

View File

@@ -0,0 +1,64 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
?><!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Database Error</title>
<style type="text/css">
::selection { background-color: #E13300; color: white; }
::-moz-selection { background-color: #E13300; color: white; }
body {
background-color: #fff;
margin: 40px;
font: 13px/20px normal Helvetica, Arial, sans-serif;
color: #4F5155;
}
a {
color: #003399;
background-color: transparent;
font-weight: normal;
}
h1 {
color: #444;
background-color: transparent;
border-bottom: 1px solid #D0D0D0;
font-size: 19px;
font-weight: normal;
margin: 0 0 14px 0;
padding: 14px 15px 10px 15px;
}
code {
font-family: Consolas, Monaco, Courier New, Courier, monospace;
font-size: 12px;
background-color: #f9f9f9;
border: 1px solid #D0D0D0;
color: #002166;
display: block;
margin: 14px 0 14px 0;
padding: 12px 10px 12px 10px;
}
#container {
margin: 10px;
border: 1px solid #D0D0D0;
box-shadow: 0 0 8px #D0D0D0;
}
p {
margin: 12px 15px 12px 15px;
}
</style>
</head>
<body>
<div id="container">
<h1><?php echo $heading; ?></h1>
<?php echo $message; ?>
</div>
</body>
</html>

View File

@@ -0,0 +1,32 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
?>
<div style="border:1px solid #990000;padding-left:20px;margin:0 0 10px 0;">
<h4>An uncaught Exception was encountered</h4>
<p>Type: <?php echo get_class($exception); ?></p>
<p>Message: <?php echo $message; ?></p>
<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): ?>
<p>Backtrace:</p>
<?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 />
Function: <?php echo $error['function']; ?>
</p>
<?php endif ?>
<?php endforeach ?>
<?php endif ?>
</div>

View File

@@ -0,0 +1,64 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
?><!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Error</title>
<style type="text/css">
::selection { background-color: #E13300; color: white; }
::-moz-selection { background-color: #E13300; color: white; }
body {
background-color: #fff;
margin: 40px;
font: 13px/20px normal Helvetica, Arial, sans-serif;
color: #4F5155;
}
a {
color: #003399;
background-color: transparent;
font-weight: normal;
}
h1 {
color: #444;
background-color: transparent;
border-bottom: 1px solid #D0D0D0;
font-size: 19px;
font-weight: normal;
margin: 0 0 14px 0;
padding: 14px 15px 10px 15px;
}
code {
font-family: Consolas, Monaco, Courier New, Courier, monospace;
font-size: 12px;
background-color: #f9f9f9;
border: 1px solid #D0D0D0;
color: #002166;
display: block;
margin: 14px 0 14px 0;
padding: 12px 10px 12px 10px;
}
#container {
margin: 10px;
border: 1px solid #D0D0D0;
box-shadow: 0 0 8px #D0D0D0;
}
p {
margin: 12px 15px 12px 15px;
}
</style>
</head>
<body>
<div id="container">
<h1><?php echo $heading; ?></h1>
<?php echo $message; ?>
</div>
</body>
</html>

View File

@@ -0,0 +1,33 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
?>
<div style="border:1px solid #990000;padding-left:20px;margin:0 0 10px 0;">
<h4>A PHP Error was encountered</h4>
<p>Severity: <?php echo $severity; ?></p>
<p>Message: <?php echo $message; ?></p>
<p>Filename: <?php echo $filepath; ?></p>
<p>Line Number: <?php echo $line; ?></p>
<?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): ?>
<p style="margin-left:10px">
File: <?php echo $error['file'] ?><br />
Line: <?php echo $error['line'] ?><br />
Function: <?php echo $error['function'] ?>
</p>
<?php endif ?>
<?php endforeach ?>
<?php endif ?>
</div>

View File

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

View File

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

View File

@@ -0,0 +1,200 @@
<style type="text/css">
.bg-dark {
background-color: #032DA1 !important;
}
</style>
<main class="common_margin" id="main">
<div class="main-wrap">
<div class="dashboard-cover">
<div class="subject_r">
<div class="subsec_sec">
<div class="subject_r">
<div class="subject_lsec">
<div class="common-heading">
<h2><?= $title ?></h2>
</div>
<?php
$name=''; $status=''; $desc=''; $permissions=array();
if(isset($details) && !empty($details))
{
$name = $details[0]['role_name'];
$status = $details[0]['status'];
$desc = $details[0]['role_desc'];
//$permissions = $details[0]['admin_role_ids'];
}
if(isset($role_permissions[0]['menu_ids']) && $role_permissions[0]['menu_ids']!='')
$permissions = explode(',', $role_permissions[0]['menu_ids']);
?>
<form action='<?php echo base_url().'add-edit-role/'.$idVal;?>' id="addEditRoleForm" method="post">
<input type='hidden' name='id' id='id' value='<?php echo $idVal;?>' />
<div class="subject_lformarea role_formarea">
<div class="form-group">
<label for="">Role Name<span class="text-danger font-weight-bold">*</span></label>
<input type="text" name="role_name" id="role_name" value='<?php echo $name;?>' class="form-control" >
<label style="display : none" class="form_err" id='role_name_error'></label>
</div>
<div class="form-group">
<label for="">Status<span class="text-danger font-weight-bold">*</span></label>
<select name="status" id="status" class="form-control">
<option value="">Choose Status</option>
<option value="Active" <?php if($status == 'Active'){?>selected<?php } ?>>Active</option>
<option value="Inactive" <?php if($status == 'Inactive'){?>selected<?php } ?>>Inactive</option>
</select>
<label style="display : none" class="form_err" id='status_error'></label>
</div>
<div class="form-group">
<label for=""> Description</label>
<textarea class="form-control" data-altName="Description" name="role_desc" id="role_desc" rows="6" ><?php echo $desc;?></textarea>
</div>
<div class="form-group">
<label for=""> Role Permissions<span class="text-danger font-weight-bold">*</span></label>
<div class="roles_checkbox">
<?php
if(isset($menus) && !empty($menus))
{
foreach($menus as $m)
{
?>
<div class="form-check">
<input class="form-check-input role_perm" type="checkbox" value="<?php echo $m['id'];?>" name="role_permissions[]" <?php if(in_array($m['id'], $permissions)){?>checked<?php } ?> >
<label class="form-check-label" ><?php echo $m['menu_name'];?></label>
</div>
<?php
}
}
?>
</div>
<label style="display : none" class="form_err" id='permissions_error'></label>
</div>
</div>
</form>
<?php if($idVal > 0) { ?>
<button type="button" class="btn bg-dark btn-primary btn-md subject_addbtn" onclick='validate_role_form()'>Update</button>
<?php } else { ?>
<button type="button" class="btn btn-primary btn-md subject_addbtn" onclick='validate_role_form()'>Save</button>
<?php } ?>
&nbsp;&nbsp;
<a href='<?php echo base_url()."roles";?>'>
<button class="btn btn-dark btn-md">Back</button>
</a>
</div>
</div>
</div>
</div>
</div>
</div>
</main>
<!--End right-top side-->
</div>
<!-- <script src="<?php echo base_url(); ?>assets-hms/js/jquery-3.2.1.slim.min.js"></script> -->
<script src="<?php echo base_url(); ?>assets-hms/js/jquery-3.4.1.min.js" ></script>
<script src="<?php echo base_url(); ?>assets-hms/js/popper.min.js"></script>
<script src="<?php echo base_url(); ?>assets-hms/js/bootstrap.min.js"></script>
<script src="https://cdn.datatables.net/1.10.22/js/jquery.dataTables.min.js"></script>
<script defer src="<?php echo base_url(); ?>assets-hms/js/all.js"></script>
<script defer src="<?php echo base_url(); ?>assets-hms/js/main.js"></script>
<script src="<?php echo base_url(); ?>assets-hms/owl-carousel/js/owl.carousel.min.js"></script>
<script>
$(document).ready(function(){
$('.user-drpdown').click(function(){
$('.drpdown-items').toggle();
});
});
//table js
$('#tbl').DataTable( {
"lengthMenu": [[5,10, 25, 50, -1], [5,10, 25, 50, "All"]]
} );
//table js end
</script>
<script type="text/javascript">
var jsAddOrEdit = '<?php echo $idVal;?>';
$(document).ready(function(){
$(document).on('keypress', function(e){
if(e.which==13)
{
validate_role_form();
}
});
});
function hide_all_role_errors()
{
$('#role_name_error').hide();
$('#status_error').hide();
$('#permissions_error').hide();
}
function validate_role_form()
{
hide_all_role_errors();
var errArr = new Array();
var rname = $('#role_name').val().trim();
if(rname=='')
errArr.push('role_name_Sep@Str_Please enter the role name.');
else
{
var alphanumeric = /^[a-z\0-9\-\s]+$/i;
if(!alphanumeric.test(rname)){
errArr.push('role_name_Sep@Str_Please enter only Alphanumeric values.');
} else {
var urltogo = '<?php echo base_url();?>'+'HmsAdmin/ajaxCheckIsRoleAlreadyExists';
var reqdData = 'role_name='+$('#role_name').val()+'&id='+$('#id').val();
$.ajax({
type: "POST",
url: urltogo,
data: reqdData,
async: false,
success: function(result)
{
result = result.trim();
//alert(result);
if(result == 'Duplicate Role')
errArr.push('role_name_Sep@Str_This role name already exists.');
else if(result == 'Insufficient Data')
errArr.push('role_name_Sep@Str_Insufficient Data Sent. Please check again.');
}
});
}
}
var status = $('#status').val().trim();
if(status=='')
errArr.push('status_Sep@Str_Please select the user status.');
var epCnt = 0;
$('.role_perm').each(function(){
if($(this).prop('checked'))
epCnt++;
});
if(epCnt == 0)
errArr.push('permissions_Sep@Str_Please select the role permissions.');
//var errArr = new Array();
if(errArr.length>0)
{
for(i=0; i<errArr.length; i++)
{
var resArr = errArr[i].split("_Sep@Str_");
$("#"+resArr[0]+"_error").html(resArr[1]);;
$("#"+resArr[0]+"_error").show();
}
var xxxVal = errArr[0].split('_Sep@Str_');
$('#'+xxxVal[0]).focus();
return false;
}
else{
$('#addEditRoleForm').submit();
}
}
</script>
</body>
</html>

View File

@@ -0,0 +1,252 @@
<style type="text/css">
.con-pass {
position: absolute;
top: 8px;
right: 8px;
cursor: pointer;
color: #878a8d;
}
.bg-dark {
background-color: #032DA1 !important;
}
</style>
<main class="common_margin" id="main">
<div class="main-wrap">
<div class="dashboard-cover">
<div class="subject_r">
<div class="subsec_sec">
<div class="subject_r">
<div class="subject_lsec">
<div class="common-heading">
<h2><?php echo $title;?></h2>
</div>
<?php
$name=''; $eid=''; $rid=''; $status='';
if(isset($details) && !empty($details))
{
$name = $details[0]['admin_name'];
$eid = $details[0]['email'];
$rid = $details[0]['admin_role_ids'];
$status = $details[0]['status'];
}
?>
<form action='<?php echo base_url().'add-edit-user/'.$idVal;?>' id="addEditUserForm" method="post">
<input type='hidden' name='id' id='id' value='<?php echo $idVal;?>' />
<div class="subject_lformarea role_formarea">
<div class="form-group">
<label for="">Full Name<span class="text-danger font-weight-bold">*</span></label>
<input type="text" name="admin_name" id="admin_name" value='<?php echo $name;?>' class="form-control" >
<label style="display:none" class="form_err" id='admin_name_error'></label>
</div>
<div class="form-group">
<label for="">Email ID<span class="text-danger font-weight-bold">*</span></label>
<input type="email" name="email" id="email" value='<?php echo $eid;?>' class="form-control">
<label style="display:none" class="form_err" id='email_error'></label>
</div>
<?php if($idVal == 0){?>
<div class="form-group">
<label for="">Password<span class="text-danger font-weight-bold">*</span></label>
<div class="password-wrp">
<input type="password" name="password" id="password" class="form-control password_hide" >
<span class="passwrd-icon icon-y"><i class="far fa-eye"></i></span>
</div>
<label style="display:none" class="form_err" id='password_error'></label>
</div>
<div class="form-group">
<label for="">Confirm Password<span class="text-danger font-weight-bold">*</span></label>
<div class="password-wrp">
<input type="password" id="confirm-password" name="confirm_password" class=" form-control password_hide_c" >
<span class="con-pass icon-y"><i class="far fa-eye"></i></span>
</div>
<label style="display:none" class="form_err" id='confirm-password_error'></label>
</div>
<?php } ?>
<div class="form-group">
<label for="">User Role<span class="text-danger font-weight-bold">*</span></label>
<select name="admin_role_ids" id="admin_role_ids" class="form-control">
<option value="">Choose Role</option>
<?php
if(isset($roles) && !empty($roles))
{
foreach($roles as $rs)
{
?>
<option value="<?php echo $rs['id'];?>" <?php if($rs['id'] == $rid){?>selected<?php } ?>><?php echo $rs['role_name'];?></option>
<?php
}
}
?>
</select>
<label style="display:none" class="form_err" id='admin_role_ids_error'></label>
</div>
<div class="form-group">
<label for="">Status<span class="text-danger font-weight-bold">*</span></label>
<select name="status" id="status" class="form-control">
<option value="">Choose Status</option>
<option value="Active" <?php if($status == 'Active'){?>selected<?php } ?>>Active</option>
<option value="Inactive" <?php if($status == 'Inactive'){?>selected<?php } ?>>Inactive</option>
</select>
<label style="display:none" class="form_err" id='status_error'></label>
</div>
</div>
</form>
<button type="button" class="btn bg-dark btn-primary btn-md" type='button' onclick="validate_user_form()" class="subject_addbtn">Save</button>
&nbsp;&nbsp;
<a href='<?php echo base_url()."users";?>'>
<button class="btn btn-dark btn-md">Back</button>
</a>
</div>
</div>
</div>
</div>
</div>
</div>
</main>
<!--End right-top side-->
</div>
<!-- <script src="<?php echo base_url(); ?>assets-hms/js/jquery-3.2.1.slim.min.js"></script> -->
<script src="<?php echo base_url(); ?>assets-hms/js/jquery-3.4.1.min.js" ></script>
<script src="<?php echo base_url(); ?>assets-hms/js/popper.min.js"></script>
<script src="<?php echo base_url(); ?>assets-hms/js/bootstrap.min.js"></script>
<script src="https://cdn.datatables.net/1.10.22/js/jquery.dataTables.min.js"></script>
<script defer src="<?php echo base_url(); ?>assets-hms/js/all.js"></script>
<script defer src="<?php echo base_url(); ?>assets-hms/js/main.js"></script>
<script src="<?php echo base_url(); ?>assets-hms/owl-carousel/js/owl.carousel.min.js"></script>
<script>
$(document).ready(function(){
$('.user-drpdown').click(function(){
$('.drpdown-items').toggle();
});
});
//table js
$('#tbl').DataTable( {
"lengthMenu": [[5,10, 25, 50, -1], [5,10, 25, 50, "All"]]
} );
//table js end
</script>
<script type="text/javascript">
var jsAddOrEdit = '<?php echo $idVal;?>';
$(document).ready(function(){
$(document).on('keypress', function(e){
if(e.which==13)
{
validate_user_form();
}
});
});
function hide_all_user_errors()
{
$('#admin_name_error').hide();
$('#email_error').hide();
if(jsAddOrEdit == 0){
$('#password_error').hide();
$('#confirm-password_error').hide();
}
$('#admin_role_ids_error').hide();
$('#status_error').hide();
}
function validate_user_form()
{
hide_all_user_errors();
var errArr = new Array();
var admin_name = $('#admin_name').val().trim();
if(admin_name==''){
errArr.push('admin_name_Sep@Str_Please enter the full name.');
} else {
var alphanumeric = /^[a-z\0-9\-\s]+$/i;
if(!alphanumeric.test(admin_name)){
errArr.push('admin_name_Sep@Str_Please enter only Alphanumeric values.');
}
}
var email = $('#email').val().trim();
if(email=='')
errArr.push('email_Sep@Str_Please enter the Email Id.');
else
{
var regEmailReg = /^[a-zA-Z0-9._-]+@[a-zA-Z-]+\.[a-zA-Z.]{2,5}$/;
if(!regEmailReg.test($('#email').val()))
errArr.push('email_Sep@Str_Please enter a valid email address.');
else
{
var urltogo = '<?php echo base_url();?>'+'HmsAdmin/ajaxCheckIsUserEmailAlreadyExists';
var reqdData = 'email='+$('#email').val()+'&id='+$('#id').val();
$.ajax({
type: "POST",
url: urltogo,
data: reqdData,
async: false,
success: function(result)
{
result = result.trim();
//alert(result);
if(result == 'Duplicate Email')
errArr.push('email_Sep@Str_This email id already exists.');
else if(result == 'Insufficient Data')
errArr.push('email_Sep@Str_Insufficient Data Sent. Please check again.');
}
});
}
}
if(jsAddOrEdit == 0)
{
var password = $('#password').val().trim();
if(password=='')
errArr.push('password_Sep@Str_Please enter the password.');
else{
var regPwdReg = /(?=.*[a-zA-Z0-9])(?=.*?\W).{6,}/;
if(!regPwdReg.test($('#password').val()))
errArr.push('password_Sep@Str_Password should be minimum 6 characters and should have atleast one special character.');
}
var confirm_password = $('#confirm-password').val().trim();
if(confirm_password=='')
errArr.push('confirm-password_Sep@Str_Please confirm the password.');
if($('#password').val()!='' && $('#confirm-password').val()!='' && ($('#password').val() != $('#confirm-password').val()) )
errArr.push('confirm-password_Sep@Str_Password & confirm Password does not match.');
}
var role_id = $('#admin_role_ids').val().trim();
if(role_id=='')
errArr.push('admin_role_ids_Sep@Str_Please select the user role.');
var status = $('#status').val().trim();
if(status=='')
errArr.push('status_Sep@Str_Please select the user status.');
//var errArr = new Array();
if(errArr.length>0)
{
for(i=0; i<errArr.length; i++)
{
var resArr = errArr[i].split("_Sep@Str_");
$("#"+resArr[0]+"_error").html(resArr[1]);;
$("#"+resArr[0]+"_error").show();
}
var xxxVal = errArr[0].split('_Sep@Str_');
$('#'+xxxVal[0]).focus();
return false;
}
else{
$('#addEditUserForm').submit();
}
}
</script>
</body>
</html>

View File

@@ -0,0 +1,243 @@
<style type="text/css">
#common_err {
color: red;
text-align: center;
}
label.error {
color : red;
}
.field-container {
margin : 0 0 20px !important;
}
.disabledByMe{
pointer-events: none;
}
</style>
<div class="row dash-main-row">
<div class="col-md-10 col-lg-10 p-0">
<div class="mt-3 mb-3">
<h5><?= $option ?></h4>
</div>
<div class="block-head">
<h3 class="dash-tab-head">Assign Rooms</h3>
<div id="common_err"></div>
</div>
<form id="assign-student-form" action="<?php echo base_url() ?>assign-students/<?= $student_id ?>" method="POST">
<div class="row">
<div class="col-md-5">
<?php
if($status == 'Update') {
echo '<input type="hidden" name="hms_student_id" id="hms_student_id">';
}
?>
<div class="field-container">
<label>Block name <span style="color:red">*</span></label>
<select id="block" name="block_id" onChange="getData(this.value,'hms_floors','block_id','#floor','floor_name')" class="form-control assign-select-box">
<option selected value="">Select Block</option>
<?php foreach($blocks as $key => $value) { ?>
<option value="<?= $value['id'] ?>"><?= $value['block_name'] ?></option>
<?php } ?>
</select>
</div>
<div class="field-container">
<label>Room name<span style="color:red">*</span></label>
<select id="rooms" onChange="getData(this.value,'hms_beds','room_id','#beds','bed_name','yes')" name="room_id" class="form-control assign-select-box">
<option selected value="">Select Room</option>
</select>
</div>
<div class="field-container">
<label>Food type<span style="color:red">*</span></label>
<select id="food" readonly name="food_type" class="form-control disabledByMe assign-select-box">
<?php if($food_type == 'Veg') {
echo '<option selected value="Veg">Veg</option>';
echo '<option value="Non-Veg">Non-Veg</option>';
} else {
echo '<option value="Veg">Veg</option>';
echo '<option selected value="Non-Veg">Non-Veg</option>';
} ?>
</select>
</div>
</div>
<div class="col-md-5">
<div class="field-container">
<label>Floor name<span style="color:red">*</span></label>
<select id="floor" onChange="getData(this.value,'hms_rooms','room_floor_id','#rooms','room_name')" name="floor_id" class="form-control assign-select-box">
<option selected value="">Select Floor</option>
</select>
</div>
<div class="field-container">
<label>Bed name<span style="color:red">*</span></label>
<select id="beds" name="bed_id" class="form-control assign-select-box">
<option selected value="">Select Bed</option>
</select>
</div>
</div>
</div>
<div class="mt-3 mb-3">
<?php
if($status == 'Update') { ?>
<button type="submit" class="btn btn-primary student-update-btn">Update</button>
<?php } else { ?>
<button type="submit" class="btn btn-primary student-update-btn">Assign</button>
<?php } ?>
<a href="<?php echo base_url() ?>students" class="btn btn-dark mt-0 ml-2 deleted-btn">Back</a>
</div>
</form>
</div>
</div>
</div>
<script>
const getData = function(val,table,column,displayId,item,bed_clause='') {
$('#common_err').hide();
$.ajax({
url : '<?php echo base_url() ?>' + 'HmsAdmin/ajax_get_rows',
data : {
id : val,
table : table,
column : column,
bed_clause : bed_clause
},
type : 'POST',
async : false,
success: function(data){
if(!data){
$('#common_err').show();
$('#common_err').text('Selected Block has not been fully assigned with Floor or Rooms or Beds');
} else {
data = JSON.parse(data);
console.log(data);
$(data).each(function(index,ele) {
console.log(ele)
if(index == 0) {
$(displayId).empty();
$(displayId).append('<option selected value="">Select Option</option>');
}
$(displayId).append('<option value="'+ele.id+'">'+ele[item]+'</option>')
});
}
}
});
}
const checkOnLoad = function() {
$.ajax({
url : '<?php echo base_url() ?>' + 'HmsAdmin/ajax_get_rows_onready',
data : {
id : '<?php echo $student_id ?>',
},
type : 'POST',
async : false,
success: function(data){
if(data) {
data = JSON.parse(data);
let floors = data.floor;
let rooms = data.rooms;
let beds = data.beds;
let blocks = data.blocks;
let food = data.food_type;
if($('#hms_student_id').length > 0)
$('#hms_student_id').val(data.hms_student_id);
$(floors).each(function(index,ele) {
if(data.floor_name == ele.floor_name) {
$('#floor').append('<option selected value="'+ele.id+'">'+ele.floor_name+'</option>');
} else {
$('#floor').append('<option value="'+ele.id+'">'+ele.floor_name+'</option>')
}
});
$(rooms).each(function(index,ele) {
if(data.room_name == ele.room_name) {
$('#rooms').append('<option selected value="'+ele.id+'">'+ele.room_name+'</option>');
} else {
$('#rooms').append('<option value="'+ele.id+'">'+ele.room_name+'</option>')
}
})
$(beds).each(function(index,ele) {
if(data.bed_name == ele.bed_name) {
$('#beds').append('<option selected value="'+ele.id+'">'+ele.bed_name+'</option>');
} else {
$('#beds').append('<option value="'+ele.id+'">'+ele.bed_name+'</option>')
}
})
$(blocks).each(function(index,ele) {
if(data.block_name == ele.block_name) {
$('#block').append('<option selected value="'+ele.id+'">'+ele.block_name+'</option>');
} else {
$('#block').append('<option value="'+ele.id+'">'+ele.block_name+'</option>')
}
})
$("#food option").each(function(index,ele)
{
if(ele.value == food){
$('#food').val(ele.value);
}
});
}
}
});
}
$(document).ready(function() {
checkOnLoad();
$("#assign-student-form").validate({
ignore: ':hidden',
rules: {
block_id : 'required',
floor_id : 'required',
room_id : 'required',
bed_id : 'required',
food_type : 'required'
},
messages : {
block_id: {
required: "Please select a block",
},
floor_id: {
required: "Please select a floor",
},
room_id: {
required: "Please select a room",
},
bed_id: {
required: "Please select a bed",
},
food_type: {
required: "Please select a food type",
}
},
submitHandler: function(form) {
form.submit();
}
});
})
</script>

View File

@@ -0,0 +1,155 @@
<div class="row dash-main-row">
<div class="col-md-10 col-lg-10 p-0">
<ul class="nav nav-pills mb-3 rooms-sections row" id="pills-tab" role="tablist">
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head " href="<?php echo base_url() ?>blocks" role="tab" aria-controls="pills-blocks" aria-selected="true">Blocks</a>
</li>
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head" href="<?php echo base_url() ?>floors" aria-selected="false">Floors</a>
</li>
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head" href="<?php echo base_url() ?>rooms" aria-selected="false">Rooms</a>
</li>
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head active" href="<?php echo base_url() ?>beds" aria-selected="false">Beds</a>
</li>
</ul>
</div>
</div>
<div class="row dash-main-row">
<div class="col-md-12 col-lg-12 p-0">
<?php if ($this->session->flashdata('success')) { ?>
<div class="alert alert-success alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('success') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
<?php if ($this->session->flashdata('failed')) { ?>
<div class="alert alert-danger alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('failed') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
<table class="table example dash-table mb-3">
<thead>
<tr>
<th scope="col" class="dash-th">SI.No</th>
<th scope="col" class="dash-th rooms-th">Bed Number</th>
<th scope="col" class="dash-th rooms-th">Room No</th>
<th scope="col" class="dash-th rooms-th">Room Type</th>
<th scope="col" class="dash-th rooms-th">Floor Name</th>
<th scope="col" class="dash-th rooms-th">Block</th>
<th scope="col" class="dash-th rooms-th">Status</th>
<th scope="col" class="dash-th-action">Actions</th>
</tr>
</thead>
<tfoot class="text-center">
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tfoot>
<tbody>
<?php if($beds_data) { ?>
<?php foreach ($beds_data as $key => $value) {
$link = $value['student_id'] == NULL ? 'javascript:void(0)' : base_url() . 'profile/'.$value['student_id'];
?>
<tr>
<td ><?= $key + 1 ?></td>
<td class="rooms-td"><?= $value['bed_name'] ?></td>
<td class="rooms-td"><?= $value['room_name'] ?></td>
<td class="rooms-td"><?= $value['room_ac'] ?></td>
<td class="rooms-td"><?= $value['floor_name'] ?></td>
<td class="rooms-td"><?= $value['block_name'] ?></td>
<td class="rooms-td"><?= $value['bed_status'] ?></td>
<td class="preview-img">
<a href="<?= $link ?>">
<img class="mr-1" src="<?php echo base_url() ?>assets-hms/images/dashboard/eye-icon.svg" alt="">
</a>
<img onclick ="beddel(<?php echo $value['id'] ?>)" src="<?= base_url() ?>assets-hms/images/dashboard/delete-icon.svg" alt="" data-toggle="modal" data-target="#DeleteRoomsCenter" data-backdrop="static" data-keyboard="false">
</td>
</tr>
<?php } ?>
<?php } ?>
</tbody>
</table>
</div>
</div>
<!-- Delete Modal -->
<div class="modal fade" id="DeleteRoomsCenter" tabindex="-1" role="dialog" aria-labelledby="DeleteRoomsCenterTitle" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered" role="document">
<div class="modal-content">
<div class="modal-header add-block-header">
<h5 class="modal-title" id="exampleModalLongTitle">Delete Floor</h5>
</div>
<div class="modal-body add-block-body">
<input type="hidden" id="bed_del_id" />
<h6>Are you sure you want to delete ?</h6>
</div>
<div class="modal-footer add-block-footer">
<button type="button" onclick="deletedata($('#bed_del_id').val());" class="btn btn-danger ">Yes</button>
<button type="button" class="btn btn-dark " data-dismiss="modal">No</button>
</div>
</div>
</div>
</div>
</div>
<script>
function beddel(icn){
$('#bed_del_id').val(icn);
}
//
function deletedata(id){
window.location.href = "<?php echo base_url(); ?>HmsAdmin/delete_beds/" + id;
}
$(document).ready(function() {
$('.example').DataTable( {
initComplete: function () {
this.api().columns([1, 2, 3, 4, 5, 6]).every( function () {
var column = this;
var select = $('<select><option value="">Filter</option></select>')
.appendTo( $(column.footer()).empty() )
.on( 'change', function () {
var val = $.fn.dataTable.util.escapeRegex(
$(this).val()
);
column
.search( val ? '^'+val+'$' : '', true, false )
.draw();
} );
column.data().unique().sort().each( function ( d, j ) {
select.append( '<option value="'+d+'">'+d+'</option>' )
} );
} );
}
} );
})
</script>

View File

@@ -0,0 +1,483 @@
<style type="text/css">
label.error {
color : red;
text-align: left;
display: block;
}
.blockNameErr,#floor_name_err,#blockEditNameErr {
color : red
}
</style>
<div class="row dash-main-row">
<div class="col-md-10 col-lg-10 p-0">
<ul class="nav nav-pills mb-3 rooms-sections row" id="pills-tab" role="tablist">
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head active" href="<?php echo base_url() ?>blocks" role="tab" aria-controls="pills-blocks" aria-selected="true">Blocks</a>
</li>
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head" href="<?php echo base_url() ?>floors" aria-selected="false">Floors</a>
</li>
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head" href="<?php echo base_url() ?>rooms" aria-selected="false">Rooms</a>
</li>
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head" href="<?php echo base_url() ?>beds" aria-selected="false">Beds</a>
</li>
</ul>
</div>
</div>
<div class="row dash-main-row">
<div class="col-md-12 col-lg-12 p-0">
<?php if ($this->session->flashdata('success')) { ?>
<div class="alert alert-success alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('success') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
<?php if ($this->session->flashdata('failed')) { ?>
<div class="alert alert-danger alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('failed') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
<div class="block-head">
<div class="block-head-left">
<h3 class="dash-tab-head block-details-head">Block Details</h3>
</div>
<div class="block-head-right">
<button type="button" onClick="set_block_id(0)" class="btn btn-success" data-toggle="modal" data-backdrop="static" data-keyboard="false" data-target="#AddBlockCenter">+ Add Blocks</button>
</div>
</div>
<table class="table example dash-table">
<thead>
<tr>
<th scope="col" class="dash-th">S.No</th>
<th scope="col" class="dash-th">Block</th>
<th scope="col" class="dash-th rooms-th">Floor</th>
<th scope="col" class="dash-th rooms-th">Rooms</th>
<th scope="col" class="dash-th rooms-th">Total Beds</th>
<th scope="col" class="dash-th rooms-th">Total Students</th>
<th scope="col" class="dash-th-action">Actions</th>
</tr>
</thead>
<tfoot class="text-center">
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tfoot>
<tbody>
<?php foreach ($blocks_data as $key => $value) {
$roomCount = $value['room_count'] > 0 ? $value['room_count'] : 0;
?>
<tr>
<td ><?= $key + 1 ?></td>
<td><?= $value['block_name'] ?></td>
<td class="rooms-td"><?= $value['floor_count'] ?></td>
<td class="rooms-td"><?= $roomCount ?></td>
<td class="rooms-td"><?= $value['beds_count'] ?></td>
<td class="rooms-td"><?= $value['student_count'] ?></td>
<td class="preview-img">
<a data-toggle="modal" onClick="set_block_id(<?= $value['id'] ?>)" data-target="#EditBlockCenter" data-backdrop="static" data-keyboard="false">
<img class="action-img" src="<?php echo base_url() ?>assets-hms/images/dashboard/edit-icon.svg" alt="">
</a>
<a data-toggle="modal" onclick ="coursedel(<?php echo $value['id'] ?>)" href="#deleteModal"><img src="<?php echo base_url() ?>assets-hms/images/dashboard/delete-icon.svg" alt="" data-toggle="modal" data-target="#DeleteRoomsCenter" data-backdrop="static" data-keyboard="false"></a>
</td>
</tr>
<?php } ?>
</tbody>
</table>
</div>
</div>
<!-- Add Modal -->
<div class="modal fade" id="AddBlockCenter" tabindex="-1" role="dialog" aria-labelledby="AddBlockCenterTitle" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered" role="document">
<div class="modal-content">
<form action="<?php echo base_url() ?>HmsAdmin/ae_blocks/0" id="block-form" method="post">
<div class="modal-header add-block-header">
<h5 class="modal-title" id="exampleModalLongTitle">Add New Block</h5>
</div>
<div class="modal-body add-block-body">
<p>Block Name<span style="color:red">*</span></p>
<input type="text" name="block_name" class="form-control edit-block-input add-block-input">
<div class="blockNameErr"></div>
<div class="d-flex mt-4 mb-2">
<p>Enter Floor Names</p>
<i class="fas fa-plus add-icon" onclick="addInputField()"></i>
</div>
<div class="add-floors-container">
<div class="add-floor-inputs">
<input type="text" name="floor_names[0]" placeholder="Enter Name" class="add-input form-control add-block-input">
<img class="edit-delete-ico" style="visibility:hidden" src="<?php echo base_url() ?>assets-hms/images/dashboard/delete-icon.svg" alt="">
</div>
<label id="floor_names[0]-error" class="error" for="floor_names[0]"></label>
</div>
</div>
<div class="modal-footer add-block-footer">
<button type="submit" class="btn btn-primary add-block-blue">Add Block</button>
<button type="button" class="btn btn-secondary add-block-cancel" data-dismiss="modal">Cancel</button>
</div>
</form>
</div>
</div>
</div>
<!-- Add Modal Ends -->
<!-- Edit Modal -->
<div class="modal fade" id="EditBlockCenter" tabindex="-1" role="dialog" aria-labelledby="EditBlockCenterTitle" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered" role="document">
<div class="modal-content">
<form id="block-edit-form" method="post">
<div class="modal-header add-block-header">
<h5 class="modal-title" id="exampleModalLongTitle">Edit Block</h5>
</div>
<div class="modal-body add-block-body " id="edit-modal-body">
<p>Block Name<span style="color:red">*</span></p>
<input type="text" name="block_edit_name" id="block-edit-input" class="form-control edit-block-input add-block-input">
<div id="blockEditNameErr"></div>
<div class="d-flex mt-4 mb-2">
<p>Add Floor</p>
<i class="fas fa-plus add-icon" onclick="addInputField()"></i>
</div>
<div class="add-floors-container" id="edit_floors-container">
</div>
<div id="floor_name_err"></div>
</div>
<div class="modal-footer add-block-footer">
<button type="submit" class="btn btn-primary add-block-blue" >Update</button>
<button type="button" class="btn btn-secondary add-block-cancel" data-dismiss="modal">Cancel</button>
</div>
</form>
</div>
</div>
</div>
<!-- Edit Modal Ends -->
<!-- Delete Modal -->
<div class="modal fade" id="DeleteRoomsCenter" tabindex="-1" role="dialog" aria-labelledby="DeleteRoomsCenterTitle" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered" role="document">
<div class="modal-content">
<div class="modal-header add-block-header">
<h5 class="modal-title" id="exampleModalLongTitle">Delete Block</h5>
</div>
<div class="modal-body add-block-body">
<input type="hidden" id="bl_id" />
<h6>Are you sure you want to delete ?</h6>
</div>
<div class="modal-footer add-block-footer">
<button type="button" onclick="deletedata($('#bl_id').val());" class="btn btn-danger ">Yes</button>
<button type="button" class="btn btn-dark " data-dismiss="modal">No</button>
</div>
</div>
</div>
</div>
</div>
<script>
let block_id;
let idCount = 0;
$(document).ready(function() {
$('.example').DataTable( {
initComplete: function () {
this.api().columns([1]).every( function () {
var column = this;
var select = $('<select><option value="">Filter</option></select>')
.appendTo( $(column.footer()).empty() )
.on( 'change', function () {
var val = $.fn.dataTable.util.escapeRegex(
$(this).val()
);
column
.search( val ? '^'+val+'$' : '', true, false )
.draw();
} );
column.data().unique().sort().each( function ( d, j ) {
select.append( '<option value="'+d+'">'+d+'</option>' )
} );
} );
}
} );
// $('#AddBlockCenter').modal('show');
$('.add-input').each(function(index,ele) {
$(ele).attr('name', 'floor_names['+idCount+']');
idCount++;
});
// Add Form validation
$("#block-form").validate({
ignore: ':hidden',
rules: {
<?php for($i = 0; $i <= 20; $i++) {
echo "'floor_names[$i]' : {
required : true,
alphanumeric : true
},";
}?>
block_name: {
required: true,
minlength: 1,
alphanumeric : true
}
},
messages: {
block_name: {
required: "Please provide a block name",
minlength : "Please enter more than 1 Character"
},
},
submitHandler: function(form) {
var inputValue = $("input[name='block_name']",form).val();
inputValue = inputValue.toLowerCase();
let flag = false;
$.ajax({
url : '<?php echo base_url() ?>' + 'HmsAdmin/ajax_validate_block_name',
data : {
value : inputValue,
id : block_id
},
type : 'POST',
async : false,
success: function(data){
console.log(data);
if(data == 'success'){
flag = true
}
}
});
if(flag) {
form.submit();
} else {
$('.blockNameErr').show();
$('.blockNameErr').text('This block name already exists.');
}
}
});
// Edit Form Validation
$("#block-edit-form").validate({
ignore: ':hidden',
rules: {
<?php for($i = 0; $i <= 20; $i++) {
echo "'floor_edit_names[$i]' : {
required : true,
alphanumeric : true
},";
}?>
block_edit_name: {
required: true,
minlength: 1,
alphanumeric : true
}
},
messages: {
block_edit_name: {
required: "Please provide a block name",
minlength : "Please enter more than 1 Character"
},
},
submitHandler: function(form,e) {
$('#floor_name_err').hide();
e.preventDefault();
$(form).attr('action', "<?php echo base_url() ?>HmsAdmin/ae_blocks/"+block_id);
let flag = false;
let dubFlag = false
var inputValue = $("input[name='block_edit_name']",form).val();
inputValue = inputValue.toLowerCase();
let floor_inputs = $('.edit-input');
let floor_names = [];
$(floor_inputs).each(function(index,ele) {
let val = $(ele).val().toLowerCase();
floor_names.push(val);
})
let findDuplicates = arr => arr.filter((item, index) => arr.indexOf(item) != index)
let dubArr = [...new Set(findDuplicates(floor_names))] // Unique duplicates
console.log(dubArr);
if(dubArr.length > 0) {
$('#floor_name_err').show();
$('#floor_name_err').text(dubArr.toString() + ' have been repeated, please change');
} else {
dubFlag = true;
}
$.ajax({
url : '<?php echo base_url() ?>' + 'HmsAdmin/ajax_validate_block_name',
data : {
value : inputValue,
id : block_id,
},
type : 'POST',
async : false,
success: function(data){
$('#blockEditNameErr').hide();
if(data == 'success'){
flag = true;
} else {
$('#blockEditNameErr').show();
$('#blockEditNameErr').text('This block name already exists.');
flag = false;
}
}
});
if(flag && dubFlag) {
form.submit();
}
}
});
});
//
const addInputField = () => {
let checkForAdd = $('.edit-input').length;
let inputContainer;
if(checkForAdd == 0) {
inputContainer = '<div class="add-floor-inputs mt-3"><input type="text" name="floor_names['+idCount+']" placeholder="Enter Floor Name" class="form-control add-input add-block-input"><img onClick="deleteInput(this)" class="edit-delete-ico" src="<?php echo base_url() ?>assets-hms/images/dashboard/delete-icon.svg" alt=""></div><label id="floor_names['+idCount+']-error" class="error" for="floor_names['+idCount+']"></label>';
} else {
inputContainer = '<div class="add-floor-inputs mt-3"><input type="text" name="floor_edit_names['+checkForAdd+']" placeholder="Enter Floor Name" class="edit-input form-control add-input add-block-input"><img onClick="deleteInput(this)" class="edit-delete-ico" src="<?php echo base_url() ?>assets-hms/images/dashboard/delete-icon.svg" alt=""></div><label id="floor_edit_names['+checkForAdd+']-error" class="error" for="floor_edit_names['+checkForAdd+']"></label>';
}
$('.add-floors-container').append(inputContainer);
idCount++;
}
//
const deleteInput = (ele) => {
$(ele).parent().remove();
}
//
const deleteInputFromDb = (ele,floor_id) => {
$.ajax({
url : '<?php echo base_url() ?>' + 'HmsAdmin/ajax_delete_floors',
data : {
id : floor_id
},
type : 'POST',
async : false,
success: function(data){
if(data){
$(ele).parent().remove();
} else {
$('#floor_name_err').text('Floor could not be deleted as it is linked with rooms');
}
}
});
}
//
const set_block_id = (val) => {
block_id = val;
}
//
jQuery.validator.addMethod("alphanumeric", function(value, element) {
return this.optional(element) || /^[a-z0-9\-\s]+$/i.test(value);
}, "Please enter alphanumeric Characters only");
//
function coursedel(icn){
$('#bl_id').val(icn);
}
//
function deletedata(id){
window.location.href = "<?php echo base_url(); ?>HmsAdmin/delete_block/" + id;
}
//
$(".mobileMenu , .hidesidebar").click(function(){
$(".sideMenu").toggle();
});
//
$("#EditBlockCenter").on('show.bs.modal', function(){
$('#floor_name_err').text('')
$('#edit_floors-container').empty();
$.ajax({
url : '<?php echo base_url() ?>' + 'HmsAdmin/ajax_get_block_floor_info',
data : {
id : block_id
},
type : 'POST',
async : false,
success: function(data){
data = JSON.parse(data);
if(!data){
$('#edit-modal-body').empty();
$('#edit-modal-body').append('<p>Data could not be displayed due to some error. Please try again later</p>');
}else{
$('#block-edit-input').val(data.block_name);
$('#edit_floors-container').append(data.floors);
}
}
});
});
</script>

View File

@@ -0,0 +1,12 @@
<!-- <script src="<?php echo base_url(); ?>assets-hms/js/jquery-3.2.1.slim.min.js"></script> -->
<script src="<?php echo base_url(); ?>assets-hms/js/popper.min.js"></script>
<script src="<?php echo base_url(); ?>assets-hms/js/bootstrap.min.js"></script>
<script src="<?php echo base_url(); ?>assets-hms/js/jquery.dataTables.min.js"></script>
<script defer src="<?php echo base_url(); ?>assets-hms/js/dataTables.fixedHeader.min.js"></script>
<script defer src="<?php echo base_url(); ?>assets-hms/js/all.js"></script>
<script defer src="<?php echo base_url(); ?>assets-hms/js/main.js"></script>
</body>
</html>

View File

@@ -0,0 +1,45 @@
<!--right-top side-->
<header id="header" class="dash-main-row">
<div class="user-login-section">
<!--<div class="notification-icon-wrap">
<img src="<?php echo base_url(); ?>assets-hms/images/dashboard/notification.svg">
<span></span>
<div class="notifications-wrap">
<div class="notifications">
<h4>Notifications</h4>
<ul>
<li>
<p>Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor </p>
<i class="fas fa-trash-alt"></i>
</li>
</ul>
</div>
</div>
</div>-->
<?php
$yourName = ''; $namesFirstLetter='';
$linSessData = $_SESSION['hmsAULoginData'];
if(isset($linSessData['hms_lin_name'])){
$yourName = $linSessData['hms_lin_name'];
$namesFirstLetter = substr($yourName, 0, 1);
}
?>
<div class="user-wrap">
<div class="user-login-head">
<div class="profileImage"><?php echo $namesFirstLetter;?></div>
<h5><span class="user-name"><?php echo $yourName;?></span><i class="fa fa-caret-down" aria-hidden="true"></i><i class="fa fa-caret-up" aria-hidden="true"></i></h5>
</div>
<div class="login-wrap-open">
<ul>
<!-- <li><a href=""><span><i class="fa fa-user" aria-hidden="true"></i></span>My Profile</a></li> -->
<li><a href="<?php echo base_url().'logout';?>"><span><i class="fas fa-sign-out-alt"></i></span>Sign Out</a></li>
</ul>
</div>
</div>
</div>
<div class="mobileMenu">
<i class="fas fa-bars"></i>
</div>
</header>

View File

@@ -0,0 +1,169 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title><?= $school_info['school_name']; ?> | Hostel Management | Dashboard</title>
<link rel="icon" type="image/x-icon" href="<?php echo base_url(); ?>assets-hms/fav.png">
<!--styles links-->
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/bootstrap.min.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/font-family.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/all.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/style.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/responsive.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/jquery.dataTables.min.css">
<script src="<?php echo base_url(); ?>assets-hms/js/jquery-3.4.1.min.js" ></script>
<script src="<?php echo base_url(); ?>assets-hms/js/jquery.validate.js"></script>
<style>
.logo-wrap img {
width: 140px !important;
}
</style>
</head>
<body>
<div class="container">
<!--left side content-->
<aside id="mySidebar" class="sideMenu" >
<div class="hidesidebar">
<img class="close-img" src="<?php echo base_url(); ?>assets-hms/images/dashboard/close.png">
</div>
<div class="logo-wrap">
<img src="<?php echo base_url(); ?>assets-hms/<?php echo $school_info['logo']; ?>">
<div class="logo-name">
<!-- <h3>Erisn</h3>
<p>Classrooms</p> -->
</div>
</div>
<ul>
<?php
$linSessData = $_SESSION['hmsAULoginData'];
if(!isset($linSessData['hms_lin_login']))
redirect(base_url().'admin');
//echo '<pre>'; print_r($linSessData);exit;
$currentURL = current_url();
$url = explode(base_url(), $currentURL);
//echo $currentURL;
//echo '<pre>';print_r($url);
$CI = &get_instance();
$CI->load->model('HmsAdmin_Model');
$adminMenuHere = $CI->HmsAdmin_Model->get_admin_menu();
//echo '<pre>'; print_r($adminMenuHere);exit;
$theRoleIds = '';
$adminRolesHere = $CI->HmsAdmin_Model->get_admin_details('', "SELECT admin_role_ids FROM hms_admin WHERE id = ".$linSessData['hms_lin_id']);
if(isset($adminRolesHere[0]['admin_role_ids']) && $adminRolesHere[0]['admin_role_ids']!='')
$theRoleIds = $adminRolesHere[0]['admin_role_ids'];
$adminRolePerms = array();
if($theRoleIds!='')
$adminRolePerms = $CI->HmsAdmin_Model->get_hms_admin_role_permissions("admin_role_ids IN(".$theRoleIds.")");
if(!empty($adminRolePerms))
{
$arpStr = ''; $arpArr = array();
foreach($adminRolePerms as $arp)
{
if($arpStr=='')
$arpStr = $arp['menu_ids'];
else
$arpStr .= ','.$arp['menu_ids'];
}
$arpArr = array_unique(explode(',', $arpStr));
if(!empty($adminMenuHere))
{
foreach($adminMenuHere as $key=>$menuData)
{
if(in_array($key, $arpArr))
{
if(isset($menuData[$key]) && !empty($menuData[$key]))
{
$smPageLinks = array();
foreach($menuData[$key] as $tmactive){
array_push($smPageLinks, $tmactive['page_link']);
}
//echo '<pre>'; print_r($smPageLinks);
//echo $url[0];
$mmmActive = '';
if(in_array($url[1], $smPageLinks))
$mmmActive = 'active';
?>
<li class="list <?php echo $mmmActive;?>">
<a href="javascript:void(0)" id="btn-1" class="dropdown-toggle" data-toggle="collapse" data-target="#<?php echo $menuData['menu_name'].'-submenu';?>" aria-expanded="false">
<img src="<?php echo base_url();?>assets-hms/images/dashboard/<?php echo $menuData['inactive_icon'];?>" class="icon-inactive">
<img src="<?php echo base_url();?>assets-hms/images/dashboard/<?php echo $menuData['active_icon'];?>" class="icon-active">
<span><?php echo $menuData['menu_name'];?></span>
</a>
<div class="nav collapse" id="<?php echo $menuData['menu_name'].'-submenu';?>" role="menu" aria-labelledby="btn-1">
<?php
foreach($menuData[$key] as $subMenu)
{
?>
<a class="dropdown-item <?php if($url[1]==$subMenu['page_link']){?>active<?php } ?>" href="<?php echo base_url().$subMenu['page_link'];?>"><?php echo $subMenu['menu_name'];?></a>
<?php
}
?>
</div>
</li>
<?php
}
else
{
?>
<li class="list <?php if($url[1]==$menuData['page_link']){?>active<?php } ?>">
<a href="<?php echo base_url().$menuData['page_link'];?>" class="dropdown">
<img src="<?php echo base_url();?>assets-hms/images/dashboard/<?php echo $menuData['inactive_icon'];?>" class="icon-inactive">
<img src="<?php echo base_url();?>assets-hms/images/dashboard/<?php echo $menuData['active_icon'];?>" class="icon-active">
<span><?php echo $menuData['menu_name'];?></span>
</a>
</li>
<?php
}
}
}
}
}
?>
</ul>
<!--<ul class="side-list">
<li class="list active">
<a href="dashboard.html">
<img src="<?php echo base_url(); ?>assets-hms/images/dashboard/dashboard-1.svg" class="icon-inactive">
<img src="<?php echo base_url(); ?>assets-hms/images/dashboard/dashboard-2.svg" class="icon-active">
<span>Dashboard</span>
</a>
</li>
<li class="list ">
<a href="manage-rooms.html">
<img src="<?php echo base_url(); ?>assets-hms/images/dashboard/room-1.svg" class="icon-inactive">
<img src="<?php echo base_url(); ?>assets-hms/images/dashboard/room-2.svg" class="icon-active">
<span>Manage Rooms</span>
</a>
</li>
<li class="list ">
<a href="students.html">
<img src="<?php echo base_url(); ?>assets-hms/images/dashboard/student-1.svg" class="icon-inactive">
<img src="<?php echo base_url(); ?>assets-hms/images/dashboard/student-2.svg" class="icon-active">
<span>Students</span>
</a>
</li>
<li class="list">
<a href="javascript:void(0)" id="btn-1" class="dropdown-toggle collapsed" data-toggle="collapse" data-target="#Authorization-submenu" aria-expanded="true">
<img src="http://localhost/erisn-classroom/assets_admin/images/subadmin1.png" class="icon-inactive">
<img src="http://localhost/erisn-classroom/assets_admin/images/subadmin2.png" class="icon-active">
<span>Authorization</span>
</a>
<div class="nav collapse" id="Authorization-submenu" role="menu" aria-labelledby="btn-1" >
<a class="dropdown-item " href="https://ezydemo.com/erisn-hostel-management/assign-rooms.html">Roles</a>
<a class="dropdown-item " href="https://ezydemo.com/erisn-hostel-management/assign-rooms.html">Users</a>
</div>
</li>
</ul>-->
</aside>
<!--End left side content-->

View File

@@ -0,0 +1,86 @@
<div class="row dash-main-row">
<div class="col-md-10 col-lg-10 p-0">
<h3 class="dash-head">DashBoard</h3>
<div class="dashboard-boxes">
<div class=" dashboard-box">
<img class="dash-img dash-student-img" src="<?php echo base_url(); ?>assets-hms/images/dashboard/students.png" alt="">
<h3 class="dash-no"><?= $student_count ?></h3>
<h6 class="dash-name">Total Students</h6>
</div>
<div class=" dashboard-box">
<img class="dash-img dash-room-img" src="<?php echo base_url(); ?>assets-hms/images/dashboard/rooms.png" alt="">
<h3 class="dash-no"><?= $room_count ?></h3>
<h6 class="dash-name">Total Rooms</h6>
</div>
<div class=" dashboard-box">
<img class="dash-img" src="<?php echo base_url(); ?>assets-hms/images/dashboard/bed.svg" alt="">
<h3 class="dash-no"><?= $bed_count ?></h3>
<h6 class="dash-name">Total Beds</h6>
</div>
<div class=" dashboard-box">
<img class="dash-img" src="<?php echo base_url(); ?>assets-hms/images/dashboard/staff.svg" alt="">
<h3 class="dash-no"><?= $staff_count ?></h3>
<h6 class="dash-name">Total Staff</h6>
</div>
</div>
</div>
</div>
<div class="row dash-main-row">
<div class="col-md-10 col-lg-10 p-0">
<h3 class="dash-tab-head">Vacated Rooms</h3>
<table class="table dash-table">
<thead>
<tr>
<th scope="col" class="dash-th">S.No</th>
<th scope="col" class="dash-th">Block</th>
<th scope="col" class="dash-th">Floor</th>
<th scope="col" class="dash-th">Room</th>
<th scope="col" class="dash-th">Bed no</th>
<th scope="col" class="dash-th">Type</th>
</tr>
</thead>
<tbody>
<?php foreach ($beds_data as $key => $value) { ?>
<tr>
<td ><?= $key + 1 ?></td>
<td><?= $value['block_name'] ?></td>
<td><?= $value['floor_name'] ?></td>
<td><?= $value['room_name'] ?></td>
<td><?= $value['bed_name'] ?></td>
<td><?= $value['room_ac'] ?></td>
</tr>
<?php } ?>
</tbody>
</table>
</div>
</div>
</div>
<script src="<?php echo base_url(); ?>assets-hms/js/jquery-3.4.1.min.js"></script>
<script src="<?php echo base_url(); ?>assets-hms/js/popper.min.js"></script>
<script src="<?php echo base_url(); ?>assets-hms/js/bootstrap.min.js"></script>
<script defer src="<?php echo base_url(); ?>assets-hms/js/all.js"></script>
<script>
$(".mobileMenu , .hidesidebar").click(function(){
$(".sideMenu").toggle();
});
</script>
<script>
$('.logo-wrap').click(function() {
window.location.href = '<?php echo base_url().'dashboard';?>';
return false;
});
</script>
</body>
</html>

View File

@@ -0,0 +1,74 @@
<!doctype html>
<body style="background-color:#e2e1e0;font-family: Open Sans, sans-serif;font-size:100%;font-weight:400;line-height:1.4;color:#000;">
<table style=" max-width: 670px;margin:50px auto 10px;background-color:#fff;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px;-webkit-box-shadow:0 1px 3px rgba(0,0,0,.12),0 1px 2px rgba(0,0,0,.24);-moz-box-shadow:0 1px 3px rgba(0,0,0,.12),0 1px 2px rgba(0,0,0,.24);box-shadow:0 1px 3px rgba(0,0,0,.12),0 1px 2px rgba(0,0,0,.24); line-height: 25px;">
<tr>
<td colspan="3">
<table style="padding:20px 30px;padding: 20px 30px;background: #fff;width: 100%;padding: 115px auto 0;">
<tbody>
<tr style="padding: 20px 0;text-align: center;">
<td><img src="<?php echo base_url()?>assets-hms/images/erisn-blue.png"></td>
</tr>
<tr style="text-align: center;">
<td><img src="<?php echo base_url()?>assets-hms/images/mail-image.png" style="margin-top: 20px"></td>
</tr>
<tr>
<td style="font-weight: 800;font-size: 22px;"> Reset Password</td>
</tr>
<tr>
<td style="padding-top: 20px;font-weight: 500;font-size: 16px;"> Dear <?php echo $nameHere;?>,</td>
</tr>
<tr>
<td>
<p style="font-weight: 400;font-size: 16px;">Your Request has been received to reset your password for your Blackboard Hostel Management System Account</p>
</td>
</tr>
<tr style="text-align: center;">
<td>
<a href="<?php echo base_url().'reset-password/'.$emailId;?>" target="_blank" style="color: #ffffff; text-decoration: none;">
<span class="email-temp" style="padding: 1% 2%; border-radius: 4px;border: none; color: #fff;font-weight: 500;font-size: 16px;background-color: #032DA1; cursor:pointer;">Password Reset Link</span>
</a>
</td>
</tr>
<tr>
<td>
<p class="email-temp" style="font-size: 14px; font-weight: 400; margin: 2% 0 0% 0;">Best Regards,</p>
<p class="email-temp" style="font-size: 14px; font-weight: 400; margin: 0% 0 3% 0;">Team Erisn</p>
</td>
</tr>
</tbody>
</table>
</td>
</tr>
<!--<tr>
<td colspan="3">
<table style="width: 100%;background: #fff;color: #032DA1;padding:10px 20px">
<tr style="text-align: center;">
<td colspan="2">
<ul style="list-style-type: none;padding: 0;">
<li style="margin-bottom: 4px;">
<a href="" style="color: #032DA1;text-decoration: none;font-size: 14px;">
<img src="<?php echo base_url()?>assets-lms/images/mail-globe.png" style="width: 20px;margin-right: 10px;vertical-align: middle;">WWW.Erisnclassroom.com</a>
</li>
</ul>
</td>
<td colspan="2">
<ul style="list-style-type: none;padding: 0;">
<li style="margin-bottom: 4px;">
<a href="mailto:erisnclassroom@gmail.com" style="color: #032DA1;text-decoration: none;font-size: 14px;">
<img src="<?php echo base_url()?>assets-lms/images/mail-envelope.png" style="width: 20px;margin-right: 10px;vertical-align: middle;">erisnclassroom@gmail.com</a>
</li>
</ul>
</td>
</tr>
</table>
</td>
</tr>-->
</table>
</body>
</html>

View File

@@ -0,0 +1,353 @@
<style type="text/css">
label.error {
color : red;
text-align: left;
display: block;
}
#room_name_err {
color : red;
text-align: center;
}
</style>
<div class="row dash-main-row">
<div class="col-md-10 col-lg-10 p-0">
<ul class="nav nav-pills mb-3 rooms-sections row" id="pills-tab" role="tablist">
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head " href="<?php echo base_url() ?>blocks" role="tab" aria-controls="pills-blocks" aria-selected="true">Blocks</a>
</li>
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head active" href="<?php echo base_url() ?>floors" aria-selected="false">Floors</a>
</li>
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head" href="<?php echo base_url() ?>rooms" aria-selected="false">Rooms</a>
</li>
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head" href="<?php echo base_url() ?>beds" aria-selected="false">Beds</a>
</li>
</ul>
</div>
</div>
<div class="row dash-main-row">
<div class="col-md-12 col-lg-12 p-0">
<?php if ($this->session->flashdata('success')) { ?>
<div class="alert alert-success alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('success') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
<?php if ($this->session->flashdata('failed')) { ?>
<div class="alert alert-danger alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('failed') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
<table class="table example dash-table mt-3 text-center">
<thead>
<tr>
<th scope="col" class="dash-th">SI.No</th>
<th scope="col" class="dash-th">Floor Name</th>
<th scope="col" class="dash-th rooms-th">Block</th>
<th scope="col" class="dash-th rooms-th">Rooms</th>
<th scope="col" class="dash-th rooms-th">Total Beds</th>
<th scope="col" class="dash-th rooms-th">Total Students</th>
<th scope="col" class="dash-th-action">Actions</th>
</tr>
</thead>
<tfoot class="text-center">
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tfoot>
<tbody>
<?php foreach ($floors_data as $key => $value) { ?>
<tr>
<td ><?php echo $key + 1 ?></td>
<td><?= $value['floor_name'] ?></td>
<td class="rooms-td"><?= $value['block_name'] ?></td>
<td class="rooms-td"><?= $value['room_count'] ?></td>
<td class="rooms-td"><?= $value['beds_count'] ?></td>
<td class="rooms-td"><?= $value['student_count']?></td>
<td class="preview-img">
<img class="action-img" onClick="set_floor_id(<?= $value['id'] ?>)" src="<?= base_url() ?>assets-hms/images/dashboard/edit-icon.svg" data-backdrop="static" data-keyboard="false" data-toggle="modal" data-target="#EditFloorsCenter" alt="">
<a data-toggle="DeleteRoomsCenter" onclick ="floordel(<?php echo $value['id'] ?>)" href="#deleteModal">
<img src="<?= base_url() ?>assets-hms/images/dashboard/delete-icon.svg" alt="" data-toggle="modal" data-target="#DeleteRoomsCenter" data-backdrop="static" data-keyboard="false">
</a>
</td>
</tr>
<?php } ?>
</tbody>
</table>
</div>
</div>
</div>
<!-- Modal -->
<div class="modal fade" id="EditFloorsCenter" tabindex="-1" role="dialog" aria-labelledby=" EditFloorsCenterTitle" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered" role="document">
<div class="modal-content">
<div class="modal-header add-block-header">
<h5 class="modal-title" id="exampleModalLongTitle">Edit Floors</h5>
</div>
<form method="post" id="floor-edit-form">
<div class="modal-body add-block-body room-modal-body">
<p>Block Name</p>
<input type="text" id="block_name" placeholder="1st Block" class="form-control add-block-input" readonly>
<p>Floor Name</p>
<input type="text" id="floor_name" placeholder="1st Floor" class="form-control add-block-input" readonly>
<!-- <input type="hidden" name="floor_id" id="floor_id">
<input type="hidden" name="block_id" id="block_id"> -->
<div class="edit-floor-titles">
<div class="d-flex" style="width: 90%;">
<p>Add Room</p>
<i onclick="addInputField()" class="fas fa-plus add-icon"></i>
</div>
<p>A/C</p>
</div>
<div class="room-container">
<div class="edit-floor-main-div">
<div class="edit-floor-input">
<div class="edit-floor-left">
<input type="text" placeholder="A101" class="form-control add-input edit-floors-input room-names">
</div>
<div class="edit-floor-right">
<input type="checkbox" name="ac[]" class="form-check-input edit-floor-checkbox" id="exampleCheck1">
<img class="edit-delete-icon" onClick="deleteInput(this)" src="<?= base_url() ?>assets-hms/images/dashboard/delete-icon.svg" alt="">
</div>
</div>
<label id="room_names[0]-error" class="error" for="room_names[0]"></label>
</div>
</div>
</div>
<div id="room_name_err"></div>
<div class="modal-footer add-block-footer">
<button type="submit" class="btn btn-primary add-block-blue">Update</button>
<button type="button" class="btn btn-secondary add-block-cancel" data-dismiss="modal">Cancel</button>
</div>
</form>
</div>
</div>
</div>
<!-- Delete Modal -->
<div class="modal fade" id="DeleteRoomsCenter" tabindex="-1" role="dialog" aria-labelledby="DeleteRoomsCenterTitle" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered" role="document">
<div class="modal-content">
<div class="modal-header add-block-header">
<h5 class="modal-title" id="exampleModalLongTitle">Delete Floor</h5>
</div>
<div class="modal-body add-block-body">
<input type="hidden" id="floor_id" />
<h6>Are you sure you want to delete ?</h6>
</div>
<div class="modal-footer add-block-footer">
<button type="button" onclick="deletedata($('#floor_id').val());" class="btn btn-danger ">Yes</button>
<button type="button" class="btn btn-dark " data-dismiss="modal">No</button>
</div>
</div>
</div>
</div>
</div>
<script>
let floor_id;
let idCount = 0;
$(document).ready(function() {
$('.add-input').each(function(index,ele) {
$(ele).attr('name', 'room_names['+idCount+']');
idCount++;
});
$('.example').DataTable( {
initComplete: function () {
this.api().columns([1, 2, 3]).every( function () {
var column = this;
var select = $('<select><option value="">Filter</option></select>')
.appendTo( $(column.footer()).empty() )
.on( 'change', function () {
var val = $.fn.dataTable.util.escapeRegex(
$(this).val()
);
column
.search( val ? '^'+val+'$' : '', true, false )
.draw();
} );
column.data().unique().sort().each( function ( d, j ) {
select.append( '<option value="'+d+'">'+d+'</option>' )
} );
} );
}
} );
})
const set_floor_id = (id) => {
floor_id = id;
}
const addInputField = () => {
let checkForAdd = $('.room-names').length;
let inputContainer = '<div class="edit-floor-main-div"><div class="edit-floor-input mt-3"><div class="edit-floor-left"><input type="text" placeholder="Enter Room Name" name="room_names['+checkForAdd+']" class="form-control room-names add-input edit-floors-input"></div><div class="edit-floor-right"><input type="checkbox" class="form-check-input edit-floor-checkbox" name="ac[]" id="exampleCheck1"><img class="edit-delete-icon" onClick="deleteInput(this)" src="<?= base_url() ?>assets-hms/images/dashboard/delete-icon.svg" alt=""></div></div><label id="room_names['+checkForAdd+']-error" class="error" for="room_names['+checkForAdd+']"></label></div>';
$('.room-container').append(inputContainer);
idCount++;
}
function floordel(icn){
$('#floor_id').val(icn);
}
//
function deletedata(id){
window.location.href = "<?php echo base_url(); ?>HmsAdmin/delete_floors/" + id;
}
const deleteInput = (ele) => {
$(ele).parent().parent().parent().remove();
}
const deleteInputFromDb = (ele,room_id) => {
$(ele).parent().parent().parent().remove();
$.ajax({
url : '<?php echo base_url() ?>' + 'HmsAdmin/ajax_delete_rooms',
data : {
id : room_id
},
type : 'POST',
async : false,
success: function(data){
if(data){
$(ele).parent().remove();
} else {
$('#floor_name_err').text('Floor could not be deleted as it is linked with rooms');
}
}
});
}
// Before Modal Event
$("#EditFloorsCenter").on('show.bs.modal', function(){
$('.room-container').empty();
$.ajax({
url : '<?php echo base_url() ?>' + 'HmsAdmin/ajax_get_floor_rooms_info',
data : {
id : floor_id
},
type : 'POST',
async : false,
success: function(data){
if(!data) {
$('.room-container').empty();
$('.room-container').append('<p>Data could not be displayed due to some error. Please try again later</p>');
} else {
data = JSON.parse(data);
$('#block_name').val(data.block_name);
$('#floor_name').val(data.floor_name);
$('.room-container').append(data.rooms);
}
}
});
});
//
jQuery.validator.addMethod("alphanumeric", function(value, element) {
return this.optional(element) || /^[a-z0-9\-\s]+$/i.test(value);
}, "Please enter alphanumeric Characters only");
// Edit Form Validation
$("#floor-edit-form").validate({
ignore: ':hidden',
rules: {
<?php for($i = 0; $i <= 20; $i++) {
echo "'room_names[$i]' : {
required : true,
alphanumeric : true
},";
}?>
},
submitHandler: function(form,e) {
e.preventDefault();
$(form).attr('action', "<?php echo base_url() ?>HmsAdmin/ae_rooms/"+floor_id);
let flag = false
let room_inputs = $('.room-names');
let room_names = [];
$(room_inputs).each(function(index,ele) {
let val = $(ele).val().toLowerCase();
room_names.push(val);
})
let findDuplicates = arr => arr.filter((item, index) => arr.indexOf(item) != index)
let dubArr = [...new Set(findDuplicates(room_names))] // Unique duplicates
if(dubArr.length > 0) {
$('#room_name_err').text(dubArr.toString() + ' have been repeated, please change');
} else {
flag = true;
}
$('.form-check-input').each(function(index,ele) {
if($(ele).prop('checked')){
$(this).val('A/C');
} else {
$(this).val('NON-A/C');
}
$(ele).prop('checked', true);
})
if(flag) {
form.submit();
}
}
});
</script>

View File

@@ -0,0 +1,160 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Hostel Management | Admin Forgot Password</title>
<link rel="icon" type="image/x-icon" href="<?php echo base_url(); ?>assets-hms/fav.png">
<!--styles links-->
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/bootstrap.min.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/font-family.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/all.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/style.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/responsive.css">
<style>
.error-message p{
font-size:13px !important;
color:red !important;
margin-bottom:2% !important;
}
</style>
</head>
<body>
<div class="containers">
<div class="main-logo">
<img src="<?php echo base_url(); ?>assets-hms/<?php echo $school_info['color_logo']; ?>">
</div>
<?php
$isForgotPasswordSuccess = 'No';
if($this->session->userdata('isForgotPasswordSuccess')){
$isForgotPasswordSuccess = 'Yes';
$this->session->unset_userdata('isForgotPasswordSuccess');
}
?>
<?php
$eid = '';
if(count($_POST) > 0)
{
$eid = $_POST['email'];
}
?>
<div class="containers">
<form action='<?php base_url().'forgot-password';?>' id="forgotPasswordForm" method="post">
<div class="row login-row">
<div class="col-md-7 col-lg-7 login-bg">
<img src="<?php echo base_url(); ?>assets-hms/images/login/login-bg.svg" class="lg-img" alt="">
</div>
<div class="col-md-4 col-lg-4 login-right">
<div class="forgot-box">
<div class="forgot-fields">
<h3>Forgot Password</h3>
<p>
Please enter your registered email address to verify and get link to reset password
</p>
<input type="text" name="email" id="email" value='<?php echo $eid;?>' placeholder="Enter your email address" class="form-control login-input" >
<p class="error-message" id='email_error'></p>
<div class="error-message"><?php echo form_error('email'); ?></div>
<div class="forgot-button">
<button class="forgot-btn" type='button' onclick='validate_fp_form()'>
Submit
</button>
</div>
<div class="forgot-redirection">
<a href="<?php echo base_url().'admin'; ?>">Go back to Login</a>
</div>
</div>
</div>
</div>
</div>
</form>
</div>
</div>
<div class="modal fade" id="passwordChangeModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalCenterTitle" aria-hidden="true" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog modal-dialog-centered" role="document">
<div class="modal-content">
<div class="modal-body">
<img src="<?php echo base_url(); ?>assets-hms/images/login/modal-check.svg" alt="">
<h4>Success</h4>
<p>
An email has been sent to your registered email address which has a link to reset your password.
</p>
</div>
<div class="modal-footer">
<button type="button" class="btn modal-btn" onclick='go_to_admin_login()'>Go to Login</button>
</div>
</div>
</div>
</div>
<script src="<?php echo base_url(); ?>assets-hms/js/jquery-3.4.1.min.js"></script>
<script src="<?php echo base_url(); ?>assets-hms/js/popper.min.js"></script>
<script src="<?php echo base_url(); ?>assets-hms/js/bootstrap.min.js"></script>
<script defer src="<?php echo base_url(); ?>assets-hms/js/all.js"></script>
<script type="text/javascript">
var isForgotPasswordSuccess = '<?php echo $isForgotPasswordSuccess;?>';
if(isForgotPasswordSuccess == 'Yes'){
$('#passwordChangeModal').modal('show');
}
function go_to_admin_login()
{
window.location = '<?php echo base_url()."admin";?>';
}
$(document).ready(function(){
$(document).on('keypress', function(e){
if(e.which==13)
{
validate_fp_form();
}
});
});
function hide_all_fp_errors()
{
$('#email_error').hide();
}
function validate_fp_form()
{
hide_all_fp_errors();
var errArr = new Array();
var lemail = $('#email').val().trim();
var regex = /^([a-zA-Z0-9_\.\-\+])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/;
if(lemail==''){
errArr.push('email_Sep@Str_Please enter your email address.');
}else if(!regex.test(lemail)){
errArr.push('email_Sep@Str_Please enter a valid email address.');
}
if(errArr.length>0)
{
for(i=0; i<errArr.length; i++)
{
var resArr = errArr[i].split("_Sep@Str_");
$("#"+resArr[0]+"_error").html(resArr[1]);;
$("#"+resArr[0]+"_error").show();
}
var xxxVal = errArr[0].split('_Sep@Str_');
$('#'+xxxVal[0]).focus();
return false;
}
else{
$('#forgotPasswordForm').submit();
}
}
</script>
</body>
</html>

View File

@@ -0,0 +1,158 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Hostel Management | Admin Login</title>
<link rel="icon" type="image/x-icon" href="<?php echo base_url(); ?>assets-hms/fav.png">
<!--styles links-->
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/bootstrap.min.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/font-family.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/all.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/style.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/responsive.css">
</head>
<body>
<div class="containers">
<div class="main-logo">
<img src="<?php echo base_url(); ?>assets-hms/<?php echo $school_info['color_logo']; ?>">
</div>
<?php
$uname = ''; $pass = ''; $rme = 'Off';
if(isset($_COOKIE["username"]))
$uname = $_COOKIE["username"];
if(isset($_COOKIE["password"]))
$pass = $_COOKIE["password"];
if(isset($_COOKIE["rem_me"]))
$rme = $_COOKIE["rem_me"];
$checked = isset($_COOKIE["rem_me"]) ? 'checked' : '';
if(count($_POST) > 0)
{
$uname = $_POST['email'];
$pass = $_POST['password'];
if(isset($_POST['remember_me']))
$rme = 'On';
}
?>
<div class="containers">
<form action='<?php echo base_url().'admin';?>' id="loginform" method="post">
<div class="row login-row">
<div class="col-md-7 col-lg-7 login-bg">
<img src="<?php echo base_url(); ?>assets-hms/images/login/login-bg.svg" class="lg-img" alt="">
</div>
<div class="col-md-4 col-lg-4 login-right">
<div class="login-box">
<div class="login-fields">
<h3>Hostel Admin Login</h3>
<?php if($this->session->flashdata('danger')){?>
<div class="alert alert-danger alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('danger') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
<input name="email" id="email" value='<?php echo $uname;?>' placeholder="Enter Your Email ID" class="form-control login-input" >
<p class="error-message" id='email_error'></p>
<div class="error-message"><?php echo form_error('email'); ?></div>
<div class="login-eye-pos">
<input type="password" name="password" id="paswd" value='<?php echo $pass;?>' placeholder="Password" class="form-control login-input">
<span class="login-eye login-eye-icon"><i class="far fa-eye"></i></span>
<p class="error-message" id='paswd_error'></p>
<div class="error-message"><?php echo form_error('password'); ?></div>
<div>
<a href="<?php echo base_url().'forgot-password'; ?>">Forgot Password?</a><br>
<input type="checkbox" <?= $checked ?> id="remember" name="remember_me" value="on">
<label class="remember" for="remember"> Remember me</label><br><br>
<div class="login-button">
<button class="login-btn" type='button' onclick="validate_login_form()">Login</button>
</div>
</div>
</div>
</div>
</div>
</form>
</div>
</div>
<script src="<?php echo base_url(); ?>assets-hms/js/jquery-3.4.1.min.js"></script>
<script src="<?php echo base_url(); ?>assets-hms/js/popper.min.js"></script>
<script src="<?php echo base_url(); ?>assets-hms/js/bootstrap.min.js"></script>
<script defer src="<?php echo base_url(); ?>assets-hms/js/all.js"></script>
<script type="text/javascript">
$(".login-eye").click(function() {
$(".login-eye").toggleClass("login-eye-icon");
var input = $('#paswd');
if (input.attr("type") == "password")
input.attr("type", "text");
else
input.attr("type", "password");
});
$(document).ready(function(){
$(document).on('keypress', function(e){
if(e.which==13)
{
//if(js_status != 'Not Verified')
validate_login_form();
}
});
});
function hide_all_login_errors()
{
$('#email_error').hide();
$('#paswd_error').hide();
}
function validate_login_form()
{
hide_all_login_errors();
var errArr = new Array();
var lemail = $('#email').val().trim();
var regex = /^([a-zA-Z0-9_\.\-\+])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/;
if(lemail==''){
errArr.push('email_Sep@Str_Please enter your email address.');
}else if(!regex.test(lemail)){
errArr.push('email_Sep@Str_Please enter a valid email address.');
}
var lpwd = $('#paswd').val().trim();
if(lpwd==''){
errArr.push('paswd_Sep@Str_Please enter your password.');
}
if(errArr.length>0)
{
for(i=0; i<errArr.length; i++)
{
var resArr = errArr[i].split("_Sep@Str_");
$("#"+resArr[0]+"_error").html(resArr[1]);;
$("#"+resArr[0]+"_error").show();
}
var xxxVal = errArr[0].split('_Sep@Str_');
$('#'+xxxVal[0]).focus();
return false;
}
else{
$('#loginform').submit();
}
}
</script>
</body>
</html>

View File

@@ -0,0 +1,213 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Hostel Management | Admin Forgot Password</title>
<link rel="icon" type="image/x-icon" href="<?php echo base_url(); ?>assets-hms/fav.png">
<!--styles links-->
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/bootstrap.min.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/font-family.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/all.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/style.css">
<link rel="stylesheet" href="<?php echo base_url(); ?>assets-hms/css/responsive.css">
<style>
.error-message p{
font-size:13px !important;
color:red !important;
margin-bottom:2% !important;
}
</style>
</head>
<body>
<div class="containers">
<div class="main-logo">
<img src="<?php echo base_url(); ?>assets-hms/<?php echo $school_info['color_logo']; ?>">
</div>
<?php
$isResetPasswordSuccess = 'No';
if($this->session->userdata('isResetPasswordSuccess')){
$isResetPasswordSuccess = 'Yes';
$this->session->unset_userdata('isResetPasswordSuccess');
}
?>
<?php
$pwd = ''; $conf_pwd = '';
if(count($_POST) > 0)
{
$pwd = $_POST['password'];
$conf_pwd = $_POST['conf_password'];
}
?>
<div class="containers">
<form action="<?php echo base_url().'reset-password/'.$encodedEmailId;?>" id="resetPasswordForm" method="post">
<div class="row login-row">
<div class="col-md-7 col-lg-7 login-bg">
<img src="<?php echo base_url(); ?>assets-hms/images/login/login-bg.svg" class="lg-img" alt="">
</div>
<div class="col-md-4 col-lg-4 login-right">
<div class="forgot-box">
<div class="forgot-fields">
<h3>Forgot Password</h3>
<p>Your email address is verified successfully. You can now reset your password here.</p>
<?php if($this->session->flashdata('danger')){?>
<div class="alert alert-danger alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('danger') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
<div class="rp-eye-pos">
<p class="input-label">New Password*</p>
<input type="password" name="password" id="password" placeholder="Enter new passwod" class="form-control reset-input" >
<span class="rp-eye-one rp-eye-one-icon"><i class="far fa-eye"></i></span>
<p class="error-message" id='password_error'></p>
<span class="error-message"><?php echo form_error('password'); ?></span>
</div>
<div class="rp-eye-pos">
<p class="input-label">Re-type New Password*</p>
<input type="password" name="conf_password" id="conf_password" placeholder="Retype new password" class="form-control reset-input" >
<span class="rp-eye-two rp-eye-two-icon"><i class="far fa-eye"></i></span>
<p class="error-message" id='conf_password_error'></p>
<span class="error-message"><?php echo form_error('conf_password'); ?></span>
</div>
<div class="forgot-button">
<button class="forgot-btn" type='button' onclick='validate_rp_form()'>Reset Password</button>
</div>
<div class="forgot-redirection">
<a href="<?php echo base_url().'admin';?>">Go back to Login</a>
</div>
</div>
</div>
</div>
</div>
</form>
</div>
</div>
<div class="modal fade" id="passwordChangeModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalCenterTitle" aria-hidden="true" data-backdrop="static" data-keyboard="false">
<div class="modal-dialog modal-dialog-centered" role="document">
<div class="modal-content">
<div class="modal-body">
<img src="<?php echo base_url(); ?>assets-hms/images/login/modal-check.svg" alt="">
<h4>Success</h4>
<p>
Your password has been reset successfully. You can now login with new password.
</p>
</div>
<div class="modal-footer">
<button type="button" class="btn modal-btn" onclick='go_to_admin_login()'>Go to Login</button>
</div>
</div>
</div>
</div>
<script src="<?php echo base_url(); ?>assets-hms/js/jquery-3.4.1.min.js"></script>
<script src="<?php echo base_url(); ?>assets-hms/js/popper.min.js"></script>
<script src="<?php echo base_url(); ?>assets-hms/js/bootstrap.min.js"></script>
<script defer src="<?php echo base_url(); ?>assets-hms/js/all.js"></script>
<script defer src="<?php echo base_url(); ?>assets-hms/js/main.js"></script>
<script type="text/javascript">
$(".rp-eye-one").click(function() {
$(".rp-eye-one").toggleClass("rp-eye-one-icon");
var input = $('#password');
if (input.attr("type") == "password")
input.attr("type", "text");
else
input.attr("type", "password");
});
$(".rp-eye-two").click(function() {
$(".rp-eye-two").toggleClass("rp-eye-two-icon");
var input = $('#conf_password');
if (input.attr("type") == "password")
input.attr("type", "text");
else
input.attr("type", "password");
});
var isResetPasswordSuccess = '<?php echo $isResetPasswordSuccess;?>';
if(isResetPasswordSuccess == 'Yes'){
$('#passwordChangeModal').modal('show');
}
function go_to_admin_login()
{
window.location = '<?php echo base_url()."admin";?>';
}
$(document).ready(function(){
$(document).on('keypress', function(e){
if(e.which==13)
{
//if(js_status != 'Not Verified')
validate_rp_form();
}
});
});
function hide_all_rp_errors()
{
$('#password_error').hide();
$('#conf_password_error').hide();
}
function validate_rp_form()
{
hide_all_rp_errors();
var errArr = new Array();
var pwd = $('#password').val().trim();
var conf_password = $('#conf_password').val().trim();
if(pwd==''){
errArr.push('password_Sep@Str_Please enter your new password.');
}
else{
var regPwdReg = /(?=.*[a-zA-Z0-9])(?=.*?\W).{6,}/;
if(!regPwdReg.test($('#password').val()))
errArr.push('password_Sep@Str_Password should be minimum 6 characters and should have atleast one special character.');
}
if(conf_password==''){
errArr.push('conf_password_Sep@Str_Please re-enter your new password.');
}
if($('#password').val()!='' && $('#conf_password').val()!='' && ($('#password').val() != $('#conf_password').val()) )
errArr.push('conf_password_Sep@Str_Password & Retype Password does not match.');
if(errArr.length>0)
{
for(i=0; i<errArr.length; i++)
{
var resArr = errArr[i].split("_Sep@Str_");
$("#"+resArr[0]+"_error").html(resArr[1]);;
$("#"+resArr[0]+"_error").show();
}
var xxxVal = errArr[0].split('_Sep@Str_');
$('#'+xxxVal[0]).focus();
return false;
}
else{
$('#resetPasswordForm').submit();
}
}
</script>
</body>
</html>

View File

@@ -0,0 +1,150 @@
<main class="common_margin" id="main">
<div id="add-btn" class="from-group adding-class form-group_lng form-group_full-width ">
<a href='<?php echo base_url()."add-edit-role/0";?>'><button type="button" class="btn btn-success btn-sm">Add New Role</button></a>
</div>
<div class="main-wrap">
<div class="roles-cover">
<div class="common-heading">
<h2>Roles</h2>
<div class="alert alert-danger" id="errShow" style="display:none;"><strong>Error!</strong> This role has been assigned to one or more users. So it can not be deleted.</div>
<div class="alert alert-success" id="success" style="display:none;"><strong>Success!</strong> The role has been deleted successfully.</div>
<?php if($this->session->flashdata('success')){?>
<div class="alert alert-success alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('success') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
<?php if($this->session->flashdata('danger')){?>
<div class="alert alert-danger alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('danger') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
</div>
<div class="subject_r">
<div class="subject_rsec">
<div class="">
<table id="tbl" class="display user-role dataTable table-responsive">
<thead>
<tr>
<th>Sl No</th>
<th>Role Name</th>
<th>Permission</th>
<th>Status</th>
<th>Actions</th>
</tr>
</thead>
<tbody>
<?php
if(isset($roleList) && !empty($roleList))
{
$slNo=1;
foreach($roleList as $post)
{
?>
<tr>
<td><?php echo $slNo;?></td>
<td><?php echo $post['role_name'];?></td>
<td>
<?php
if($post['permissions']!='')
echo str_replace(',', '<br>', $post['permissions']);
?>
</td>
<td><?php echo $post['status'];?></td>
<td>
<div class="sub_tabbtnsec">
<a href='<?php echo base_url()."add-edit-role/".$post['id'];?>'>
<div class="sub_editbtn"><i class="fas fa-pencil-alt"></i></div>
</a>
<?php if($post['can_delete']=='Yes'){?>
<div class="sub_delbtn" onclick='delete_role(<?php echo $post['id'];?>)'>
<i class="fa fa-trash" aria-hidden="true"></i>
</div>
<?php } ?>
</div>
</td>
</tr>
<?php
$slNo++;
}
}
?>
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
</main>
<!--End right-top side-->
</div>
<script src="assets-hms/js/jquery-3.4.1.min.js" ></script>
<script src="assets-hms/js/popper.min.js"></script>
<script src="assets-hms/js/bootstrap.min.js"></script>
<script src="https://cdn.datatables.net/1.10.22/js/jquery.dataTables.min.js"></script>
<script defer src="assets-hms/js/all.js"></script>
<script defer src="assets-hms/js/main.js"></script>
<script src="assets-hms/owl-carousel/js/owl.carousel.min.js"></script>
<script src="https://unpkg.com/sweetalert/dist/sweetalert.min.js"></script>
<script>
$(document).ready(function(){
$('.user-drpdown').click(function(){
$('.drpdown-items').toggle();
});
});
//table js
$('#tbl').DataTable( {
"lengthMenu": [[5,10, 25, 50, -1], [5,10, 25, 50, "All"]]
} );
//table js end
</script>
<script>
function delete_role(roleId)
{
swal({
title: "Are you sure?",
text: "Once deleted, you will not be able to recover this role!",
icon: "warning",
buttons: true,
dangerMode: true,
})
.then((willDelete) => {
if (willDelete) {
$.ajax({
type: 'post',
url: '<?= base_url(); ?>HmsAdmin/delete_role',
data: {'id' : roleId},
success: function(result){
//alert(result);
if(result=='Success')
{
$('#errShow').hide();
$('#success').show();
setTimeout(() => { location.reload(); }, 2000);
}
else
{
$('#success').hide();
$('#errShow').show();
}
}
});
}
})
}
</script>

View File

@@ -0,0 +1,329 @@
<style>
.bed-input {
background-color: #fff !important;
}
label.error {
color : red;
text-align: left;
display: block;
}
#bed_name_err {
color : red;
text-align: center;
}
</style>
<div class="row dash-main-row">
<div class="col-md-10 col-lg-10 p-0">
<ul class="nav nav-pills mb-3 rooms-sections row" id="pills-tab" role="tablist">
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head " href="<?php echo base_url() ?>blocks" role="tab" aria-controls="pills-blocks" aria-selected="true">Blocks</a>
</li>
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head " href="<?php echo base_url() ?>floors" aria-selected="false">Floors</a>
</li>
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head active" href="<?php echo base_url() ?>rooms" aria-selected="false">Rooms</a>
</li>
<li class="nav-item section-sec col-md-3 p-0">
<a class="nav-link sec-head" href="<?php echo base_url() ?>beds" aria-selected="false">Beds</a>
</li>
</ul>
</div>
</div>
<div class="row dash-main-row mt-4 mb-4">
<div class="col-md-12 col-lg-12 p-0">
<?php if ($this->session->flashdata('success')) { ?>
<div class="alert alert-success alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('success') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
<?php if ($this->session->flashdata('failed')) { ?>
<div class="alert alert-danger alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('failed') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
<table class="example text-center" style="width : 100%" class="table dash-table">
<thead>
<tr>
<th scope="col" class="dash-th">SI.No</th>
<th scope="col" class="dash-th rooms-th">Room No</th>
<th scope="col" class="dash-th rooms-th">Floor Name</th>
<th scope="col" class="dash-th rooms-th">Block</th>
<th scope="col" class="dash-th rooms-th">Room Type</th>
<th scope="col" class="dash-th rooms-th">Total Beds</th>
<th scope="col" class="dash-th-action">Actions</th>
</tr>
</thead>
<tfoot class="text-center">
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tfoot>
<tbody>
<?php foreach ($rooms_data as $key => $value) {
?>
<tr>
<td ><?= $key + 1 ?></td>
<td id="td-room" class="rooms-td"><?= $value['room_name'] ?></td>
<td id="td-floor" class="rooms-td"><?= $value['floor_name'] ?></td>
<td id="td-block" class="rooms-td"><?= $value['block_name'] ?></td>
<td class="rooms-td"><?= $value['room_ac'] ?></td>
<td class="rooms-td"><?= $value['beds_count'] ?></td>
<td class="preview-img">
<img class="action-img" onClick="set_room_id(<?= $value['id'] ?>,this)" src="<?php echo base_url() ?>assets-hms/images/dashboard/edit-icon.svg" data-toggle="modal" data-target="#EditRoomsCenter" alt="" data-backdrop="static" data-keyboard="false">
<img src="<?php echo base_url() ?>assets-hms/images/dashboard/delete-icon.svg" alt="" onclick ="roomdel(<?php echo $value['id'] ?>)" data-toggle="modal" data-target="#DeleteRoomsCenter" data-backdrop="static" data-keyboard="false">
</td>
</tr>
<?php } ?>
</tbody>
</table>
</div>
</div>
<!-- Modal -->
<div class="modal fade" id="EditRoomsCenter" tabindex="-1" role="dialog" aria-labelledby="EditRoomsCenterTitle" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered" role="document">
<div class="modal-content">
<form id="rooms-bed-form" method="post">
<div class="modal-header add-block-header">
<h5 class="modal-title" id="exampleModalLongTitle">Edit Rooms</h5>
</div>
<input type="hidden" name="room_id" id="room_id">
<div class="modal-body add-block-body">
<div class="block-floor-info d-flex justify-content-around mb-4">
<p><b>Block Name: </b><span id="pop_block_name">Block 1</span></p>
<p><b>Floor Name: </b><span id="pop_floor_name">Floor 1</span></p>
</div>
<p>Room Name</p>
<input type="text" value="A101" placeholder="A101" readonly class="room-name form-control add-block-input">
<div class="edit-floor-titles">
<div class="d-flex" style="width: 90%;">
<p>Add Beds</p>
<i onclick="addInputField(this)" class="fas fa-plus add-icon"></i>
</div>
</div>
<div class="beds-container">
</div>
</div>
<div id="bed_name_err"></div>
<div class="modal-footer add-block-footer">
<button type="submit" id="submit-beds" class="btn btn-primary add-block-blue">Update</button>
<button type="button" class="btn btn-secondary add-block-cancel" data-dismiss="modal">Cancel</button>
</div>
</form>
</div>
</div>
</div>
<!-- Delete Modal -->
<div class="modal fade" id="DeleteRoomsCenter" tabindex="-1" role="dialog" aria-labelledby="DeleteRoomsCenterTitle" aria-hidden="true">
<div class="modal-dialog modal-dialog-centered" role="document">
<div class="modal-content">
<div class="modal-header add-block-header">
<h5 class="modal-title" id="exampleModalLongTitle">Delete Room</h5>
</div>
<div class="modal-body add-block-body">
<input type="hidden" id="room_del_id" />
<h6>Are you sure you want to delete ?</h6>
</div>
<div class="modal-footer add-block-footer">
<button type="button" onclick="deletedata($('#room_del_id').val());" class="btn btn-danger ">Yes</button>
<button type="button" class="btn btn-dark " data-dismiss="modal">No</button>
</div>
</div>
</div>
</div>
</div>
<script>
let idCount = 0;
let room_id;
let block_name,floor_name,room_name;
const set_room_id = (id, ele) => {
room_id = id;
let current = ele;
while($(current).prop("tagName") != 'TR' ) {
current = $(current).parent();
}
block_name = $(current).children('#td-block').text();
floor_name = $(current).children('#td-floor').text();
room_name = $(current).children('#td-room').text();
$('#pop_floor_name').text(floor_name);
$('#pop_block_name').text(block_name);
$('.room-name').val(room_name);
}
function roomdel(icn){
$('#room_del_id').val(icn);
}
function deletedata(id){
window.location.href = "<?php echo base_url(); ?>HmsAdmin/delete_room/" + id;
}
const addInputField = (ele) => {
$('#empty-bed-err').hide();
$('#submit-beds').attr('disabled', false);
let roomName = $('.room-name').val();
let checkForAdd = $('.bed-input').length;
let inputContainer = '<div class="edit-rooms-input beds-inner-container mt-3"><input type="text" value="'+(roomName+'-'+(checkForAdd+1))+'" name="bed_names['+(checkForAdd+1)+']" readOnly class="form-control bed-input add-rooms-inputs"><img onClick="deleteInput(this)" class="edit-rooms-ico" src="<?php echo base_url() ?>assets-hms/images/dashboard/delete-icon.svg" alt=""></div>';
$('.beds-container').append(inputContainer);
idCount++;
}
const deleteInput = (ele) => {
$(ele).parent().remove();
}
// Before Modal Event
$("#EditRoomsCenter").on('show.bs.modal', function(e){
$('.beds-container').empty();
$.ajax({
url : '<?php echo base_url() ?>' + 'HmsAdmin/ajax_get_rooms_bed_info',
data : {
id : room_id
},
type : 'POST',
async : false,
success: function(data){
if(data == '') {
$('.beds-container').empty();
$('.beds-container').append('<p id="empty-bed-err" style="color:red" class="mt-2">This Room doesn\'t have any bed</p>');
$('#submit-beds').attr('disabled', true);
} else {
$('.beds-container').append(data);
}
}
});
});
//
jQuery.validator.addMethod("alphanumeric", function(value, element) {
return this.optional(element) || /^[a-z0-9\-\s]+$/i.test(value);
}, "Please enter alphanumeric Characters only");
// Edit Form Validation
$("#rooms-bed-form").validate({
ignore: ':hidden',
rules: {
<?php for($i = 0; $i <= 20; $i++) {
echo "'bed_names[$i]' : {
required : true,
alphanumeric : true
},";
}?>
},
submitHandler: function(form,e) {
e.preventDefault();
$(form).attr('action', "<?php echo base_url() ?>HmsAdmin/ae_beds/"+room_id);
$('#room_id').val(room_id);
form.submit();
}
});
const deleteInputFromDb = (ele,room_id) => {
$.ajax({
url : '<?php echo base_url() ?>' + 'HmsAdmin/ajax_delete_row',
data : {
id : room_id,
table : 'hms_beds'
},
type : 'POST',
async : false,
success: function(data){
if(data){
$(ele).parent().remove();
} else {
$('#bed_name_err').text('Bed could not be deleted as it is linked with rooms');
}
}
});
}
$(document).ready(function() {
$('.example').DataTable( {
initComplete: function () {
this.api().columns([1, 2, 3, 4, 5]).every( function () {
var column = this;
var select = $('<select><option value="">Filter</option></select>')
.appendTo( $(column.footer()).empty() )
.on( 'change', function () {
var val = $.fn.dataTable.util.escapeRegex(
$(this).val()
);
column
.search( val ? '^'+val+'$' : '', true, false )
.draw();
} );
column.data().unique().sort().each( function ( d, j ) {
select.append( '<option value="'+d+'">'+d+'</option>' )
} );
} );
}
} );
})
</script>

View File

@@ -0,0 +1,225 @@
<style type="text/css">
.course-info-fields,.student-info-fields {
margin-top: 10px;
}
</style>
<div class="row dash-main-row ">
<div class="col-md-8 col-lg-8 p-0">
<a href="<?php echo base_url() ?>students" class="btn btn-dark deleted-btn">Back</a>
<div class="block-head">
<h3 class="dash-tab-head">Student Details</h3>
</div>
<ul class="nav nav-pills mb-3 student-sections row" id="pills-tab" role="tablist">
<li class="nav-item section-sec col-md-4 p-0">
<a class="nav-link sec-head active" id="pills-student-tab" data-toggle="pill" href="#pills-student" role="tab" aria-controls="pills-student" aria-selected="true">Student Info</a>
</li>
<li class="nav-item section-sec col-md-4 p-0">
<a class="nav-link sec-head" id="pills-course-tab" data-toggle="pill" href="#pills-course" role="tab" aria-controls="pills-course" aria-selected="false">Course Details</a>
</li>
<li class="nav-item section-sec col-md-4 p-0">
<a class="nav-link sec-head" id="pills-hostel-tab" data-toggle="pill" href="#pills-hostel" role="tab" aria-controls="pills-hostel" aria-selected="false">Hostel Details</a>
</li>
</ul>
</div>
</div>
<div class="tab-content" id="pills-tabContent">
<div class="tab-pane fade show active" id="pills-student" role="tabpanel" aria-labelledby="pills-student-tab">
<div class="row dash-main-row details-row">
<div class="col-md-8 student-info">
<img class="student-info-img" src="<?= STUDENT_IMAGE_URL . '/' . $student['photo'] ?>" alt="">
<div class="student-info-fields mt-4">
<p class="student-fields-left">Student ID:</p>
<p class="student-fields-right"><?= $student['studentId'] ?></p>
</div>
<div class="student-info-fields">
<p class="student-fields-left">Name:</p>
<p class="student-fields-right"><?= $student['name'] ?></p>
</div>
<div class="student-info-fields">
<p class="student-fields-left">Email:</p>
<p class="student-fields-right"><?= $student['email'] ?></p>
</div>
<div class="student-info-fields">
<p class="student-fields-left">Contact number:</p>
<p class="student-fields-right"><?= $student['mobile'] ?></p>
</div>
<div class="student-info-fields">
<p class="student-fields-left">Date of birth:</p>
<p class="student-fields-right"><?= $student['dob'] ?></p>
</div>
<div class="student-info-fields">
<p class="student-fields-left">Gender:</p>
<p class="student-fields-right"><?= $student['gender'] ?></p>
</div>
<h5 class="student-emergency-title">Emergency contacts</h5>
<div class="student-info-fields">
<p class="student-fields-left">Name:</p>
<p class="student-fields-right"><?= $student['emergency_contact_name'] ?></p>
</div>
<div class="student-info-fields">
<p class="student-fields-left">Contact number</p>
<p class="student-fields-right"><?= $student['emergency_contact_number'] ?></p>
</div>
<div class="student-info-fields">
<p class="student-fields-left">Address:</p>
<p class="student-fields-right"><?= $student['address1'] ?></p>
</div>
</div>
</div>
</div>
<div class="tab-pane fade" id="pills-course" role="tabpanel" aria-labelledby="pills-course-tab">
<div class="row dash-main-row">
<div class="col-md-8 course-details">
<div class="course-info-fields">
<p class="course-fields-left">Student ID:</p>
<p class="course-fields-right"><?= $student['studentId'] ?></p>
</div>
<div class="course-info-fields">
<p class="course-fields-left">Level:</p>
<p class="course-fields-right"><?= $student['class'] ?></p>
</div>
<div class="course-info-fields">
<p class="course-fields-left">Batch:</p>
<p class="course-fields-right"><?= $student['startEndDate'] ?></p>
</div>
<div class="course-info-fields">
<p class="course-fields-left">Programme:</p>
<p class="course-fields-right"><?= $student['course_name'] ?></p>
</div>
<div class="course-info-fields">
<p class="course-fields-left">Subjects:</p>
<p class="course-fields-right">
<?php foreach ($student['subjects'] as $key => $value) {
echo $value['subject_name'] . '<br>';
} ?>
</p>
</div>
</div>
</div>
</div>
<div class="tab-pane fade" id="pills-hostel" role="tabpanel" aria-labelledby="pills-hostel-tab">
<div class="row dash-main-row">
<div class="col-md-8 course-details">
<div class="course-info-fields">
<p class="course-fields-left">Joined Date:</p>
<p class="course-fields-right"><?= date('d-m-Y', strtotime($hostel['joined_date'])) ?></p>
</div>
<div class="course-info-fields">
<p class="course-fields-left">Block:</p>
<p class="course-fields-right"><?= $hostel['block_name'] ?></p>
</div>
<div class="course-info-fields">
<p class="course-fields-left">Floor:</p>
<p class="course-fields-right"><?= $hostel['floor_name'] ?></p>
</div>
<div class="course-info-fields">
<p class="course-fields-left">Room No:</p>
<p class="course-fields-right"><?= $hostel['room_name'] ?></p>
</div>
<div class="course-info-fields">
<p class="course-fields-left">Room Type</p>
<p class="course-fields-right"><?= $hostel['room_ac'] ?></p>
</div>
<div class="course-info-fields">
<p class="course-fields-left">Bed No:</p>
<p class="course-fields-right"><?= $hostel['bed_name'] ?></p>
</div>
<div class="course-info-fields">
<p class="course-fields-left">Food Type:</p>
<p class="course-fields-right"><?= $hostel['food_type'] ?></p>
</div>
<h5 class="student-emergency-title">Hostel Fee Details</h5>
<?php if(empty($payments)) {
echo 'Please try again in sometime';
} else {
foreach ($payments as $key => $value) {
$installments = json_decode($value['payment_details']); ?>
<div class="course-info-fields">
<p class="course-fields-left">Total:</p>
<p class="course-fields-right">Rs.<?= $value['amount'] ?></p>
</div>
<div class="course-info-fields">
<p class="course-fields-left">Payment Dates:</p>
<div class="course-fields-right">
<!-- <?php echo '<pre>';print_r($installments) ?> -->
<?php foreach ($installments as $index => $ele) { ?>
<div class="course-fields-right_block">
<div class="fields-right-1">
<p>Rs.<?= $ele->feeamount; ?></p>
</div>
<?php if($ele->payment_status == 'yes') { ?>
<div class="fields-right-2">
<p>Paid on: <?= date('d-m-Y', strtotime($ele->paid_date)) ?></p>
<img class="student-check-img ml-2" src="<?= base_url()?>assets-hms/images/dashboard/check.svg" alt="">
</div>
<?php } else { ?>
<div class="fields-right-2">
<p>Due on: <?= date('d-m-Y', strtotime($ele->due_date)) ?></p>
</div>
<?php } ?>
</div>
<?php } ?>
</div>
<?php } ?>
<?php } ?>
</div>
</div>
</div>
</div>
</div>
</div>
</div>

View File

@@ -0,0 +1,101 @@
<div class="row dash-main-row students-row">
<div class="col-md-12 col-lg-12 p-0">
<div class="block-head">
<h3 class="dash-tab-head">Students</h3>
</div>
<?php if ($this->session->flashdata('success')) { ?>
<div class="alert alert-success alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('success') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
<?php if ($this->session->flashdata('failed')) { ?>
<div class="alert alert-danger alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('failed') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
<table class="table example dash-table mb-3 text-center">
<thead>
<tr>
<th scope="col" class="dash-th">Student ID</th>
<th scope="col" class="dash-th rooms-th">Student Name</th>
<th scope="col" class="dash-th rooms-th">Class</th>
<th scope="col" class="dash-th rooms-th">Room</th>
<th scope="col" class="dash-th rooms-th">Contact</th>
<th scope="col" class="dash-th rooms-th">Student profile</th>
<th scope="col" class="dash-th rooms-th">Room Status</th>
</tr>
</thead>
<tfoot class="text-center">
<tr>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tfoot>
<tbody class="pb-2">
<?php foreach ($students as $key => $value) {
$room = isset($value['room_name']) ? $value['room_name'] : '-';
$assigned = isset($value['room_name']) ? true : false;
?>
<tr>
<td class=""><?= $value['studentId'] ?></td>
<td class="rooms-td"><?= $value['name'] ?></td>
<td class="rooms-td"><?= $value['classroom_name'] ?></td>
<td class="rooms-td"><?= $room ?></td>
<td class="rooms-td"><?= $value['emergency_contact_number'] ?></td>
<td class="student-view"><img src="<?php echo base_url() ?>assets-hms/images/dashboard/user-icon.svg" alt=""><a href="<?php echo base_url() ?>profile/<?= $value['id'] ?>">View</a> </td>
<td class="rooms-td">
<?php if($assigned) { ?>
<a href="<?php echo base_url() ?>assign-students/<?= $value['id'] ?>" class="btn btn-outline-primary student-edit-btn">Edit</a>
<?php } else { ?>
<a href="<?php echo base_url() ?>assign-students/<?= $value['id'] ?>" class="btn btn-primary student-update-btn">Assign</a>
<?php } ?>
</td>
</tr>
<?php } ?>
</tbody>
</table>
</div>
</div>
</div>
<script>
$(document).ready(function(){
$('.example').DataTable( {
initComplete: function () {
this.api().columns([1, 2, 3]).every( function () {
var column = this;
var select = $('<select><option value="">Choose</option></select>')
.appendTo( $(column.footer()).empty() )
.on( 'change', function () {
var val = $.fn.dataTable.util.escapeRegex(
$(this).val()
);
column
.search( val ? '^'+val+'$' : '', true, false )
.draw();
} );
column.data().unique().sort().each( function ( d, j ) {
select.append( '<option value="'+d+'">'+d+'</option>' )
} );
} );
}
} );
})
</script>

View File

@@ -0,0 +1,149 @@
<main class="common_margin" id="main">
<div id="add-btn" class="from-group adding-class form-group_lng form-group_full-width ">
<a href="<?php echo base_url().'add-edit-user/0';?>"><button type="button" class="btn btn-success btn-sm">Add New User</button></a>
</div>
<div class="main-wrap">
<div class="roles-cover">
<div class="common-heading">
<h2>Users</h2>
<div class="alert alert-danger" id="errShow" style="display:none;"><strong>Error!</strong> Oops. Something went wrong.</div>
<div class="alert alert-success" id="success" style="display:none;"><strong>Success!</strong> The user has been deleted successfully.</div>
<?php if($this->session->flashdata('success')){?>
<div class="alert alert-success alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('success') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
<?php if($this->session->flashdata('danger')){?>
<div class="alert alert-danger alert-dismissible fade show" role="alert">
<p><?php echo $this->session->flashdata('danger') ?></p>
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<?php } ?>
</div>
<div class="subject_r">
<div class="subject_rsec">
<div class="">
<table id="tbl" class="display user-role dataTable table-responsive">
<thead>
<tr>
<th>Sl No</th>
<th>Full Name</th>
<th>Email ID</th>
<th>User Role</th>
<th>Status</th>
<th>Actions</th>
</tr>
</thead>
<tbody>
<?php
if(isset($userList) && !empty($userList))
{
$slNo=1;
foreach($userList as $post)
{
?>
<tr>
<td><?php echo $slNo;?></td>
<td><?php echo $post['admin_name'];?></td>
<td><?php echo $post['email'];?></td>
<td><?php echo $post['role_name'];?></td>
<td><?php echo $post['status'];?></td>
<td>
<div class="sub_tabbtnsec">
<a href='<?php echo base_url()."add-edit-user/".$post['id'];?>'>
<div class="sub_editbtn"><i class="fas fa-pencil-alt"></i></div>
</a>
<?php if($post['can_delete']=='Yes'){?>
<div class="sub_delbtn" onclick='delete_user(<?php echo $post['id'];?>)'>
<i class="fa fa-trash" aria-hidden="true"></i>
</div>
<?php } ?>
</div>
</td>
</tr>
<?php
$slNo++;
}
}
?>
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
</main>
<!--End right-top side-->
</div>
<!-- <script src="assets-hms/js/jquery-3.2.1.slim.min.js"></script> -->
<script src="assets-hms/js/jquery-3.4.1.min.js" ></script>
<script src="assets-hms/js/popper.min.js"></script>
<script src="assets-hms/js/bootstrap.min.js"></script>
<script src="https://cdn.datatables.net/1.10.22/js/jquery.dataTables.min.js"></script>
<script defer src="assets-hms/js/all.js"></script>
<script defer src="assets-hms/js/main.js"></script>
<script src="assets-hms/owl-carousel/js/owl.carousel.min.js"></script>
<script src="https://unpkg.com/sweetalert/dist/sweetalert.min.js"></script>
<script>
$(document).ready(function(){
$('.user-drpdown').click(function(){
$('.drpdown-items').toggle();
});
});
//table js
$('#tbl').DataTable( {
"lengthMenu": [[5,10, 25, 50, -1], [5,10, 25, 50, "All"]]
} );
//table js end
</script>
<script>
function delete_user(userId)
{
swal({
title: "Are you sure?",
text: "Once deleted, you will not be able to recover this user!",
icon: "warning",
buttons: true,
dangerMode: true,
})
.then((willDelete) => {
if (willDelete) {
$.ajax({
type: 'post',
url: '<?= base_url(); ?>HmsAdmin/delete_user',
data: {'id' : userId},
success: function(result){
//alert(result);
if(result=='Success')
{
$('#errShow').hide();
$('#success').show();
setTimeout(() => { location.reload(); }, 2000);
}
else
{
$('#success').hide();
$('#errShow').show();
}
}
});
}
})
}
</script>
</body>
</html>

View File

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

View File

@@ -0,0 +1,89 @@
<?php
defined('BASEPATH') OR exit('No direct script access allowed');
?><!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Welcome to CodeIgniter</title>
<style type="text/css">
::selection { background-color: #E13300; color: white; }
::-moz-selection { background-color: #E13300; color: white; }
body {
background-color: #fff;
margin: 40px;
font: 13px/20px normal Helvetica, Arial, sans-serif;
color: #4F5155;
}
a {
color: #003399;
background-color: transparent;
font-weight: normal;
}
h1 {
color: #444;
background-color: transparent;
border-bottom: 1px solid #D0D0D0;
font-size: 19px;
font-weight: normal;
margin: 0 0 14px 0;
padding: 14px 15px 10px 15px;
}
code {
font-family: Consolas, Monaco, Courier New, Courier, monospace;
font-size: 12px;
background-color: #f9f9f9;
border: 1px solid #D0D0D0;
color: #002166;
display: block;
margin: 14px 0 14px 0;
padding: 12px 10px 12px 10px;
}
#body {
margin: 0 15px 0 15px;
}
p.footer {
text-align: right;
font-size: 11px;
border-top: 1px solid #D0D0D0;
line-height: 32px;
padding: 0 10px 0 10px;
margin: 20px 0 0 0;
}
#container {
margin: 10px;
border: 1px solid #D0D0D0;
box-shadow: 0 0 8px #D0D0D0;
}
</style>
</head>
<body>
<div id="container">
<h1>Welcome to CodeIgniter!</h1>
<div id="body">
<p>The page you are looking at is being generated dynamically by CodeIgniter.</p>
<p>If you would like to edit this page you'll find it located at:</p>
<code>application/views/welcome_message.php</code>
<p>The corresponding controller for this page is found at:</p>
<code>application/controllers/Welcome.php</code>
<p>If you are exploring CodeIgniter for the very first time, you should start by reading the <a href="user_guide/">User Guide</a>.</p>
</div>
<p class="footer">Page rendered in <strong>{elapsed_time}</strong> seconds. <?php echo (ENVIRONMENT === 'development') ? 'CodeIgniter Version <strong>' . CI_VERSION . '</strong>' : '' ?></p>
</div>
</body>
</html>