first commit

This commit is contained in:
Nadea Mefira 2025-07-07 12:16:55 +07:00
commit 94d7001ee8
4615 changed files with 1391604 additions and 0 deletions

15
.editorconfig Normal file
View File

@ -0,0 +1,15 @@
# top-most EditorConfig file
root = true
# Unix-style newlines with a newline ending every file
[*]
end_of_line = lf
insert_final_newline = true
# Matches multiple files with brace expansion notation
# Set default charset
[*]
charset = utf-8
# Tab indentation (no size specified)
indent_style = tab

32
.gitignore vendored Normal file
View File

@ -0,0 +1,32 @@
.DS_Store
application/cache/*
!application/cache/index.html
application/logs/*
!application/logs/index.html
!application/*/.htaccess
composer.lock
tests/mocks/database/ci_test.sqlite
user_guide_src/build/*
user_guide_src/cilexer/build/*
user_guide_src/cilexer/dist/*
user_guide_src/cilexer/pycilexer.egg-info/*
/vendor/
# IDE Files
#-------------------------
/nbproject/
.idea/*
## Sublime Text cache files
*.tmlanguage.cache
*.tmPreferences.cache
*.stTheme.cache
*.sublime-workspace
*.sublime-project
/tests/tests/
/tests/results/

4
.htaccess Normal file
View File

@ -0,0 +1,4 @@
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteRule ^(.*)$ index.php/$1 [L]

6
application/.htaccess Normal file
View File

@ -0,0 +1,6 @@
<IfModule authz_core_module>
Require all denied
</IfModule>
<IfModule !authz_core_module>
Deny from all
</IfModule>

10
application/cache/index.html vendored Normal file
View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>

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('session', 'form_validation', 'database', 'email', 'phpmailer_lib', 'Notif');
/*
| -------------------------------------------------------------------
| 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', 'form', 'file', 'security', 'auth', 'text');
/*
| -------------------------------------------------------------------
| 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,538 @@
<?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 to guess the protocol and
| path to 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.
|
*/
$protocol = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) ? "https://" : "http://";
$host = $_SERVER['HTTP_HOST'];
$path = rtrim(dirname($_SERVER['SCRIPT_NAME']), '/\\');
$config['base_url'] = $protocol . $host . $path . '/';
/*
|--------------------------------------------------------------------------
| 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/userguide3/general/urls.html
|
| Note: This option is ignored for CLI requests.
*/
$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/userguide3/general/core_classes.html
| https://codeigniter.com/userguide3/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';
date_default_timezone_set('Asia/Jakarta');
/*
|--------------------------------------------------------------------------
| 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/userguide3/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_samesite'
|
| Session cookie SameSite attribute: Lax (default), Strict or None
|
| '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_samesite'] = 'Lax';
$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)
| 'cookie_samesite' = Cookie's samesite attribute (Lax, Strict or None)
|
| 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;
$config['cookie_samesite'] = 'Lax';
/*
|--------------------------------------------------------------------------
| 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,85 @@
<?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

View File

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

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/userguide3/general/hooks.html
|
*/

View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>

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/userguide3/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,186 @@
<?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',
'heic' => 'image/heic',
'heif' => 'image/heif',
'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', 'image/svg', '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/userguide3/general/profiling.html
|
*/

View File

@ -0,0 +1,56 @@
<?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/userguide3/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'] = 'auth';
$route['404_override'] = '';
$route['translate_uri_dashes'] = FALSE;
$route['admin/chat/(:num)'] = 'Chat/chatAdmin/$1'; // tampilkan chat untuk wali tertentu
$route['admin/sendChat'] = 'Chat/sendChatFromAdmin'; // proses kirim chat dari admin

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/userguide3/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,222 @@
<?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',
'huawei' => 'Huawei',
'xiaomi' => 'Xiaomi',
'oppo' => 'Oppo',
'vivo' => 'Vivo',
'infinix' => 'Infinix',
// 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',
'UptimeRobot' => 'UptimeRobot'
);

View File

@ -0,0 +1,136 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Form_validation $form_validation
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Input $input
* @property CI_Upload $upload
*/
class Admin extends CI_Controller
{
public function __construct()
{
parent::__construct();
is_logged_in();
}
public function index()
{
$data['title'] = 'Profil Admin';
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/admin');
$this->load->view('templates/footer');
}
public function edit()
{
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$data['title'] = 'Edit Profil';
$this->form_validation->set_rules('name', 'Nama lengkap', 'required|trim', [
'required' => 'Nama lengkap wajib diisi!'
]);
if ($this->form_validation->run() == false) {
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/edit', $data);
$this->load->view('templates/footer');
} else {
$name = $this->input->post('name');
$email = $this->input->post('email');
// Cek jika ada gambar yang diupload
$upload_image = $_FILES['image']['name'];
if ($upload_image) {
$config['allowed_types'] = 'gif|jpg|png|';
$config['max_size'] = '2048';
$config['upload_path'] = './assets/img/profile/';
$this->load->library('upload', $config);
}
if ($upload_image) {
$config['allowed_types'] = 'gif|jpg|png';
$config['max_size'] = '2048';
$config['upload_path'] = './assets/img/profile/';
$this->load->library('upload', $config);
if ($this->upload->do_upload('image')) {
$old_image = $data['admin']['image'];
if ($old_image != 'default1.jpg') {
unlink(FCPATH . 'assets/img/profile/' . $old_image);
}
$new_image = $this->upload->data('file_name');
$this->db->set('image', $new_image);
} else {
$this->session->set_flashdata('message', '<div class="alert alert-danger" role="alert">' . $this->upload->display_errors() . '</div>');
redirect('admin/edit');
}
}
$this->db->set('name', $name);
$this->db->where('email', $email);
$this->db->update('admin');
$this->session->set_flashdata('message', '<div class="alert alert-success" role="alert">Profil anda telah diperbarui!</div>');
redirect('admin/edit');
}
}
public function ubahKataSandi()
{
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$data['title'] = 'Ubah Kata Sandi';
$this->form_validation->set_rules('current_password', 'Kata sandi saat ini', 'required|trim', [
'required' => 'Kata sandi saat ini wajib diisi!'
]);
$this->form_validation->set_rules('new_password1', 'Kata sandi baru', 'required|trim|min_length[4]|matches[new_password2]', [
'required' => 'Kata sandi baru wajib diisi!',
'min_length' => 'Kata sandi baru minimal 4 karakter!',
'matches' => 'Kata sandi baru tidak cocok dengan pengulangan kata sandi baru!'
]);
$this->form_validation->set_rules('new_password2', 'Ulangi kata sandi baru', 'required|trim|min_length[4]|matches[new_password1]', [
'required' => 'Ulangi kata sandi baru wajib diisi!',
'min_length' => 'Kata sandi baru minimal 4 karakter!',
'matches' => 'Pengulangan kata sandi baru tidak cocok dengan kata sandi baru!'
]);
if ($this->form_validation->run() == false) {
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/ubahkatasandi', $data);
$this->load->view('templates/footer');
} else {
$current_password = $this->input->post('current_password');
$new_password = $this->input->post('new_password1');
if (!password_verify($current_password, $data['admin']['password'])) {
$this->session->set_flashdata('message', '<div class="alert alert-danger" role="alert">Kata sandi saat ini salah!</div>');
redirect('admin/ubahkatasandi');
} else {
if ($current_password == $new_password) {
$this->session->set_flashdata('message', '<div class="alert alert-danger" role="alert">Kata sandi baru tidak boleh sama dengan kata sandi saat ini!</div>');
redirect('admin/ubahkatasandi');
} else {
$password_hash = password_hash($new_password, PASSWORD_DEFAULT);
$this->db->set('password', $password_hash);
$this->db->where('email', $this->session->userdata('email'));
$this->db->update('admin');
$this->session->set_flashdata('message', '<div class="alert alert-success" role="alert">Kata sandi Anda telah diperbarui!</div>');
redirect('admin/ubahkatasandi');
}
}
}
}
}

View File

@ -0,0 +1,270 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
header("Access-Control-Allow-Origin: *");
header("Content-Type: application/json");
/**
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Form_validation $form_validation
* @property CI_Input $input
* @property CI_Wali_santri_model $wali_santri_model
* @property CI_Santri_model $santri_model
* @property CI_Sejarah_model $sejarah_model
*/
class Api extends CI_Controller
{
public function __construct()
{
parent::__construct();
$this->load->database();
$this->load->model('santri_model'); // ini penting!
$this->load->model('sejarah_model'); // ini penting!
}
public function loginWaliSantri()
{
// Ambil input JSON
$post = json_decode(file_get_contents("php://input"), true);
if (!$post) {
echo json_encode([
"status" => "failed",
"message" => "Data tidak dikirim dengan benar."
]);
return;
}
$email_or_NIS = $post['email_or_NIS'] ?? null;
$password = $post['password'] ?? null;
if (empty($email_or_NIS) || empty($password)) {
echo json_encode([
"status" => "failed",
"message" => "Email/NIS dan password wajib diisi."
]);
return;
}
// JOIN wali dan santri
$this->db->select('tb_wali_santri.*, tb_santri.NIS, tb_santri.nama_santri as nama_santri, tb_santri.*');
$this->db->from('tb_wali_santri');
$this->db->join('tb_santri', 'tb_santri.id_santri = tb_wali_santri.id_santri');
$this->db->group_start();
$this->db->where('tb_wali_santri.email', $email_or_NIS);
$this->db->or_where('tb_santri.NIS', $email_or_NIS);
$this->db->group_end();
$this->db->where('tb_wali_santri.password', $password); // pastikan field password sesuai
$query = $this->db->get();
$result = $query->row();
if ($result) {
$id_santri = $result->id_santri;
// Ambil data terkait santri
$prestasi = $this->db->get_where('tb_prestasi_santri', ['id_santri' => $id_santri])->result();
$pelanggaran = $this->db->get_where('tb_pelanggaran_santri', ['id_santri' => $id_santri])->result();
$spp = $this->db->get_where('tb_informasi_spp_santri', ['id_santri' => $id_santri])->result();
// Data umum
$kegiatan = $this->db->get('tb_kegiatan')->result();
$berita = $this->db->get('tb_berita')->result();
$sejarah = $this->db->get('tb_sejarah')->result();
echo json_encode([
"status" => "success",
"wali_santri" => $result,
"santri" => [
"id_santri" => $result->id_santri,
"NIS" => $result->NIS,
"nama" => $result->nama_santri
],
"prestasi" => $prestasi,
"pelanggaran" => $pelanggaran,
"spp" => $spp,
"kegiatan" => $kegiatan,
"berita" => $berita,
"sejarah" => $sejarah
]);
} else {
echo json_encode([
"status" => "failed",
"message" => "Email/NIS atau password salah."
]);
}
}
public function getDataSantri()
{
$id_santri = $this->input->get('id_santri');
$NIS = $this->input->get('NIS');
$email = $this->input->get('email');
if ($id_santri) {
$data = $this->santri_model->get_data_by_id_santri($id_santri); // pastikan model ini ada
} else if ($NIS) {
$data = $this->santri_model->get_data_by_nis($NIS);
} else if ($email) {
$data = $this->santri_model->get_data_by_email_wali($email);
} else {
echo json_encode([
"status" => false,
"message" => "Parameter id_santri, NIS atau email harus diisi"
]);
return;
}
if ($data) {
echo json_encode([
"status" => true,
"data" => $data
]);
} else {
echo json_encode([
"status" => false,
"message" => "Data tidak ditemukan"
]);
}
}
public function getSejarah()
{
$this->load->model('sejarah_model');
$data = $this->sejarah_model->get_sejarah(); // ambil dari model
if ($data) {
echo json_encode([
'status' => true,
'data' => $data
]);
} else {
echo json_encode([
'status' => false,
'message' => 'Data sejarah tidak ditemukan'
]);
}
}
public function getKegiatan()
{
$query = $this->db->get('tb_kegiatan');
if ($query->num_rows() > 0) {
$data = $query->result();
echo json_encode([
'status' => true,
'data' => $data
]);
} else {
echo json_encode([
'status' => false,
'message' => 'Tidak ada kegiatan ditemukan'
]);
}
}
public function getBerita()
{
$this->db->select('judul, tanggal, gambar, deskripsi');
$this->db->from('tb_berita');
$this->db->order_by('tanggal', 'DESC');
$query = $this->db->get();
if ($query->num_rows() > 0) {
$data = $query->result();
// Tambahkan base URL agar Glide di Android bisa load gambarnya
foreach ($data as &$row) {
$row->gambar = base_url('assets/img/berita/' . $row->gambar);
}
echo json_encode([
'status' => true,
'data' => $data
]);
} else {
echo json_encode([
'status' => false,
'message' => 'Data berita tidak ditemukan'
]);
}
}
// Kirim chat dari Android
public function sendChat()
{
header('Content-Type: application/json');
$sender = $this->input->post('sender'); // 'wali' atau 'admin'
$id_wali_santri = $this->input->post('id_wali_santri');
$message = $this->input->post('message');
if (!$sender || !$id_wali_santri || !$message) {
echo json_encode([
'status' => false,
'message' => 'Semua field wajib diisi.'
]);
return;
}
$data = [
'sender' => $sender,
'id_wali_santri' => $id_wali_santri,
'message' => $message
];
$this->db->insert('chat', $data);
echo json_encode([
'status' => true,
'message' => 'Pesan berhasil dikirim.'
]);
}
// Ambil chat berdasarkan wali santri (untuk Android)
public function getChatByWali($id_wali_santri)
{
$this->db->select('chat.*, tb_wali_santri.nama_wali_santri, tb_santri.nama_santri');
$this->db->from('chat');
$this->db->join('tb_wali_santri', 'tb_wali_santri.id_wali_santri = chat.id_wali_santri');
$this->db->join('tb_santri', 'tb_santri.id_santri = tb_wali_santri.id_santri');
$this->db->where('chat.id_wali_santri', $id_wali_santri);
$this->db->order_by('chat.timestamp', 'ASC');
$query = $this->db->get();
$result = $query->result();
echo json_encode([
'status' => true,
'data' => $result
]);
}
public function saveToken()
{
$input = json_decode(file_get_contents("php://input"), true);
$id_wali_santri = $input['id_wali_santri'];
$token = $input['token'];
if ($id_wali_santri && $token) {
$data = [
'id_wali_santri' => $id_wali_santri,
'token' => $token,
'created_at' => date('Y-m-d H:i:s')
];
// Jika sudah ada token, update
$existing = $this->db->get_where('fcm_tokens', ['id_wali_santri' => $id_wali_santri])->row();
if ($existing) {
$this->db->where('id_wali_santri', $id_wali_santri)->update('fcm_tokens', $data);
} else {
$this->db->insert('fcm_tokens', $data);
}
echo json_encode(['status' => 'success']);
} else {
echo json_encode(['status' => 'failed']);
}
}
}

View File

@ -0,0 +1,325 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
use PHPMailer\PHPMailer\PHPMailer;
use PHPMailer\PHPMailer\Exception;
/**
* @property CI_Form_validation $form_validation
* @property CI_Input $input
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Email $email
*/
class Auth extends CI_Controller
{
/** @var Phpmailer_lib */
public $phpmailer_lib;
public function __construct()
{
parent::__construct();
$this->load->library('form_validation');
$this->load->library('phpmailer_lib'); // Load library PHPMailer
}
public function index()
{
$this->form_validation->set_rules('email', 'Email', 'trim|required|valid_email', [
'required' => 'Email harus diisi!',
'valid_email' => 'Email tidak valid!'
]);
$this->form_validation->set_rules('password', 'Password', 'trim|required', [
'required' => 'Kata sandi harus diisi!'
]);
if ($this->form_validation->run() == FALSE) {
$data['title'] = 'Halaman Login';
$this->load->view('templates/auth_header', $data);
$this->load->view('auth/login');
$this->load->view('templates/auth_footer');
} else {
// Validasi sukses
$this->_login();
}
}
private function _login()
{
$email = $this->input->post('email');
$password = $this->input->post('password');
$admin = $this->db->get_where('admin', ['email' => $email])->row_array();
// Jika usernya ada
if ($admin) {
// Jika usernya aktif
if ($admin['is_active'] == 1) {
// Cek password
if (password_verify($password, $admin['password'])) {
$data = [
'email' => $admin['email']
];
$this->session->set_userdata($data);
redirect('dashboard'); // langsung ke dashboard tanpa cek role_id
} else {
$this->session->set_flashdata('message', '<div class="alert alert-danger" role="alert">Kata sandi salah!</div>');
redirect('auth');
}
} else {
$this->session->set_flashdata('message', '<div class="alert alert-danger" role="alert">Email ini belum diaktifkan!</div>');
redirect('auth');
}
} else {
$this->session->set_flashdata('message', '<div class="alert alert-danger" role="alert">Email belum terdaftar!</div>');
redirect('auth');
}
}
public function registration()
{
$this->form_validation->set_rules('name', 'Name', 'required|trim', [
'required' => 'Nama wajib diisi!'
]);
$this->form_validation->set_rules('email', 'Email', 'required|trim|valid_email|is_unique[admin.email]', [
'required' => 'Email wajib diisi!',
'is_unique' => 'Email ini sudah terdaftar!',
]);
$this->form_validation->set_rules('password1', 'Password', 'required|trim|min_length[3]|matches[password2]', [
'required' => 'Kata sandi wajib diisi!',
'matches' => 'Kata sandi tidak cocok!',
'min_length' => 'Kata sandi terlalu pendek!'
]);
$this->form_validation->set_rules('password2', 'Password', 'required|trim|matches[password1]', [
'matches' => 'Kata sandi tidak cocok!'
]);
if ($this->form_validation->run() == false) {
$data['title'] = 'Halaman Pendaftaran';
$this->load->view('templates/auth_header', $data);
$this->load->view('auth/registration');
$this->load->view('templates/auth_footer');
} else {
$email = $this->input->post('email', true);
$data = [
'name' => htmlspecialchars($this->input->post('name', true)),
'email' => htmlspecialchars($email),
'image' => 'default1.jpg',
'password' => password_hash($this->input->post('password1'), PASSWORD_DEFAULT),
'is_active' => 0,
'date_created' => time()
];
// siapkan token
$token = base64_encode(random_bytes(32));
$admin_token = [
'email' => $email,
'token' => $token,
'date_created' => time()
];
$this->db->insert('admin', $data);
$this->db->insert('admin_token', $admin_token);
$this->_sendEmail($token, 'verify');
$this->session->set_flashdata('message', '<div class="alert alert-success" role="alert">Selamat! Akun Anda telah dibuat. Silakan aktivasi akun Anda.</div>');
redirect('auth');
}
}
public function verify()
{
$email = $this->input->get('email');
$token = $this->input->get('token');
$admin = $this->db->get_where('admin', ['email' => $email])->row_array();
if ($admin) {
$admin_token = $this->db->get_where('admin_token', ['token' => $token])->row_array();
if ($admin) {
if (time() - $admin_token['date_created'] < (60 * 60 * 24)) {
$this->db->set('is_active', 1);
$this->db->where('email', $email);
$this->db->update('admin');
$this->db->delete('admin_token', ['email' => $email]);
$this->session->set_flashdata('message', '<div class="alert alert-success" role="alert">' . $email . ' telah diaktifkan. Silakan login!</div>');
redirect('auth');
} else {
$this->db->delete('admin', ['email' => $email]);
$this->db->delete('admin_token', ['email' => $email]);
$this->session->set_flashdata('message', '<div class="alert alert-danger" role="alert">Verifikasi akun gagal! Token kadaluarsa.</div>');
redirect('auth');
}
} else {
$this->session->set_flashdata('message', '<div class="alert alert-danger" role="alert">Verifikasi akun gagal! Token salah.</div>');
redirect('auth');
}
} else {
$this->session->set_flashdata('message', '<div class="alert alert-danger" role="alert">Verifikasi akun gagal! Email salah.</div>');
redirect('auth');
}
}
private function _sendEmail($token, $type)
{
$this->load->library('phpmailer_lib');
$mail = $this->phpmailer_lib->load(); // Mengembalikan objek PHPMailer
try {
$mail->isSMTP();
$mail->Host = 'smtp.gmail.com';
$mail->SMTPAuth = true;
$mail->Username = 'ratnaantika386@gmail.com';
$mail->Password = 'swpf wnxp avvn aukc';
$mail->SMTPSecure = PHPMailer::ENCRYPTION_SMTPS;
$mail->Port = 465;
$mail->setFrom('ratnaantika386@gmail.com');
$mail->addAddress($this->input->post('email'));
if ($type == 'verify') {
$mail->Subject = 'Verifikasi Akun';
$mail->isHTML(true);
$mail->Body = 'Klik tautan ini untuk memverifikasi akun Anda:
<a href="' . base_url() . 'auth/verify?email=' . $this->input->post('email') . '&token=' . urlencode($token) . '">Aktivasi</a>';
} else if ($type == 'forgot') {
$mail->Subject = 'Atur Ulang Kata Sandi';
$mail->isHTML(true);
$mail->Body = 'Klik tautan ini untuk mengatur ulang kata sandi Anda:
<a href="' . base_url() . 'auth/resetpassword?email=' . $this->input->post('email') . '&token=' . urlencode($token) . '">Atur Ulang Kata Sandi</a>';
}
$mail->send();
} catch (Exception $e) {
echo "Pesan gagal dikirim. Error: {$mail->ErrorInfo}";
die;
}
}
public function logout()
{
$this->session->unset_userdata('email');
$this->session->unset_userdata('role_id');
$this->session->set_flashdata('message', '<div class="alert alert-success" role="alert">Anda telah keluar!</div>');
redirect('auth');
}
public function blocked()
{
$this->load->view('auth/blocked');
}
public function forgotPassword()
{
$this->form_validation->set_rules('email', 'Email', 'required|trim|valid_email', [
'required' => 'Email harus diisi!',
'valid_email' => 'Email tidak valid!'
]);
if ($this->form_validation->run() == false) {
$data['title'] = 'Lupa Kata Sandi';
$this->load->view('templates/auth_header', $data);
$this->load->view('auth/forgot-password');
$this->load->view('templates/auth_footer');
} else {
$email = $this->input->post('email');
$admin = $this->db->get_where('admin', ['email' => $email])->row_array();
if ($admin) {
$token = base64_encode(random_bytes('32'));
$admin_token = [
'email' => $email,
'token' => $token,
'date_created' => time(),
];
$this->db->insert('admin_token', $admin_token);
$this->_sendEmail($token, 'forgot');
$this->session->set_flashdata('message', '<div class="alert alert-success" role="alert">Silakan cek email Anda untuk mengatur ulang kata sandi Anda!</div>');
redirect('auth/forgotpassword');
} else {
$this->session->set_flashdata('message', '<div class="alert alert-danger" role="alert">Email belum terdaftar!</div>');
redirect('auth/forgotpassword');
}
}
}
public function resetPassword()
{
$email = $this->input->get('email');
$token = $this->input->get('token');
$admin = $this->db->get_where('admin', ['email' => $email])->row_array();
if ($admin) {
$admin_token = $this->db->get_where('admin_token', ['token' => $token])->row_array();
if ($admin_token) {
// Cek apakah token masih berlaku (5 menit)
if (time() - $admin_token['date_created'] < 300) { // 300 detik = 5 menit
$this->session->set_userdata('reset_email', $email);
$this->changePassword(); // Panggil fungsi untuk mengubah password
} else {
// Hapus token dan user jika token kadaluarsa
$this->db->delete('admin_token', ['email' => $email]);
$this->session->set_flashdata('message', '<div class="alert alert-danger" role="alert">Atur ulang kata sandi gagal! Token kadaluarsa.</div>');
redirect('auth');
}
} else {
$this->session->set_flashdata('message', '<div class="alert alert-danger" role="alert">Atur ulang kata sandi gagal! Token salah.</div>');
redirect('auth');
}
} else {
$this->session->set_flashdata('message', '<div class="alert alert-danger" role="alert">Atur ulang kata sandi gagal! Email salah.</div>');
redirect('auth');
}
}
public function changePassword()
{
if (!$this->session->userdata('reset_email')) {
redirect('auth');
}
$this->form_validation->set_rules('password1', 'Password', 'required|trim|min_length[4]|matches[password2]', [
'required' => 'Kata sandi harus diisi!',
'min_length' => 'Kata sandi terlalu pendek!',
'matches' => 'Kata sandi tidak cocok!',
]);
$this->form_validation->set_rules('password2', 'Password', 'required|trim|min_length[4]|matches[password1]', [
'required' => 'Ulangi kata sandi harus diisi!',
'min_length' => 'Kata sandi terlalu pendek!',
'matches' => 'Kata sandi tidak cocok!',
]);
if ($this->form_validation->run() == false) {
$data['title'] = 'Ubah Kata Sandi';
$this->load->view('templates/auth_header', $data);
$this->load->view('auth/change-password');
$this->load->view('templates/auth_footer');
} else {
$password = password_hash($this->input->post('password1'), PASSWORD_DEFAULT);
$email = $this->session->userdata('reset_email');
$this->db->set('password', $password);
$this->db->where('email', $email);
$this->db->update('admin');
$this->session->unset_userdata('reset_email');
$this->session->set_flashdata('message', '<div class="alert alert-success" role="alert">Kata sandi sudah berubah! Silakan login.</div>');
redirect('auth');
}
}
}

View File

@ -0,0 +1,283 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Form_validation $form_validation
* @property CI_Input $input
* @property CI_Berita_model $berita_model
* @property CI_Upload $upload
*/
class Berita extends CI_Controller
{
public function __construct()
{
parent::__construct();
$this->load->model('berita_model');
is_logged_in();
}
public function index()
{
$data['title'] = 'Berita';
$data['berita'] = $this->berita_model->get_data('tb_berita')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/berita');
$this->load->view('templates/footer');
}
public function tambah()
{
$data['title'] = 'Tambah Berita';
$data['berita'] = $this->berita_model->get_data('tb_berita')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/tambah_berita', $data);
$this->load->view('templates/footer');
}
public function tambah_aksi()
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->tambah();
} else {
// Konfigurasi upload
$config['upload_path'] = './assets/img/berita/';
$config['allowed_types'] = 'jpg|jpeg|png|gif';
$config['max_size'] = 2048; // 2MB
$this->load->library('upload', $config);
if (!$this->upload->do_upload('gambar')) {
// Jika upload gagal
$this->session->set_flashdata('pesan', '<div class="alert alert-danger">Gagal mengunggah gambar!</div>');
redirect('berita/tambah');
} else {
$gambar = $this->upload->data('file_name');
$tanggal_input = $this->input->post('tanggal');
$tanggal_formatted = date('Y-m-d H:i:s', strtotime(str_replace('/', '-', $tanggal_input)));
$data = array(
'gambar' => $gambar,
'judul' => $this->input->post('judul'),
'deskripsi' => $this->input->post('deskripsi'),
'tanggal' => $tanggal_formatted
);
$this->berita_model->insert_data($data, 'tb_berita');
$this->load->library('Notif');
$notif = new Notif();
$title = 'Nufaku - Berita Terkini';
$body = $this->input->post('judul');
$host = $_SERVER['HTTP_HOST'];
if (strpos($host, 'localhost') !== false || strpos($host, '127.0.0.1') !== false) {
$host = '192.168.0.80:8080'; // Ganti dengan IP kamu
}
$gambar_url = 'http://' . $host . '/admin-nufa/assets/img/berita/' . $gambar;
$dataPayload = [
'type' => 'berita',
'judul' => $this->input->post('judul'),
'gambar' => $gambar_url,
'tanggal' => $tanggal_formatted,
'deskripsi' => $this->input->post('deskripsi'),
'from_notif' => 'true'
];
$tokens = $this->db->get('fcm_tokens')->result();
foreach ($tokens as $row) {
$token = $row->token;
if (!empty($token)) {
$response = $notif->send($token, $title, $body, $dataPayload);
log_message('debug', 'RESPON FCM: ' . print_r($response, true));
}
}
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil ditambahkan!
<button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span></button></div>');
redirect('berita');
}
}
}
public function edit($id_berita)
{
$this->form_validation->set_rules('judul', 'Judul', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('deskripsi', 'Deskripsi', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('tanggal', 'Tanggal', 'required', array(
'required' => '%s harus diisi!!'
));
if ($this->form_validation->run() == FALSE) {
$this->index();
} else {
$judul = $this->input->post('judul');
$deskripsi = $this->input->post('deskripsi');
$tanggal_input = $this->input->post('tanggal');
$tanggal_formatted = date('Y-m-d H:i:s', strtotime(str_replace('/', '-', $tanggal_input)));
// Ambil gambar lama, bahkan jika tidak upload gambar baru
$berita_lama = $this->berita_model->get_data_by_id($id_berita);
$gambar_lama = $berita_lama ? $berita_lama->gambar : '';
$upload_gambar = $_FILES['gambar']['name'];
if ($upload_gambar) {
$config['upload_path'] = 'assets/img/berita/';
$config['allowed_types'] = 'jpg|jpeg|png|gif';
$config['max_size'] = 2048;
$config['encrypt_name'] = TRUE;
$this->load->library('upload', $config);
if ($this->upload->do_upload('gambar')) {
// Ambil gambar lama
$berita_lama = $this->berita_model->get_data_by_id($id_berita); // kamu harus buat fungsi ini kalau belum ada
$gambar_lama = $berita_lama->gambar;
// Hapus gambar lama jika bukan default
if ($gambar_lama && file_exists(FCPATH . 'assets/img/berita/' . $gambar_lama)) {
unlink(FCPATH . 'assets/img/berita/' . $gambar_lama);
}
// Simpan nama gambar baru
$gambar_baru = $this->upload->data('file_name');
} else {
$this->session->set_flashdata('pesan', '<div class="alert alert-danger">' . $this->upload->display_errors() . '</div>');
redirect('berita');
}
}
// Data array
$data = array(
'id_berita' => $id_berita,
'judul' => $judul,
'deskripsi' => $deskripsi,
'tanggal' => $tanggal_formatted,
);
// Jika upload gambar baru, tambahkan ke data
if (!empty($gambar_baru)) {
$data['gambar'] = $gambar_baru;
}
$this->berita_model->update_data($data, 'tb_berita');
$this->load->library('Notif');
$notif = new Notif();
$title = 'Nufaku - Pembaruan Berita';
$body = $this->input->post('judul');
$gambar = !empty($gambar_baru) ? $gambar_baru : $gambar_lama;
// Dapatkan host
$host = $_SERVER['HTTP_HOST'];
// Jika localhost, ganti ke IP lokal kamu (ganti dengan IP sesuai hasil ipconfig)
$host = $_SERVER['HTTP_HOST']; // bisa jadi 'localhost:8080'
if (strpos($host, 'localhost') !== false || strpos($host, '127.0.0.1') !== false) {
$host = '192.168.0.80:8080'; // Ganti dengan IP kamu
}
// Buat URL gambar yang bisa diakses Android
$gambar_url = 'http://' . $host . '/admin-nufa/assets/img/berita/' . $gambar;
// Payload untuk notifikasi
$dataPayload = [
'type' => 'berita',
'judul' => $judul,
'gambar' => $gambar_url,
'tanggal' => $tanggal_formatted,
'deskripsi' => $deskripsi,
'from_notif' => 'true'
];
log_message('debug', 'URL GAMBAR: ' . $gambar_url);
$tokens = $this->db->get('fcm_tokens')->result();
foreach ($tokens as $row) {
$token = $row->token;
if (!empty($token)) {
$response = $notif->send($token, $title, $body, $dataPayload);
log_message('debug', 'RESPON FCM: ' . print_r($response, true));
}
}
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil diubah! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('berita');
}
}
public function view($id_berita)
{
// Load model jika belum diload
$this->load->model('berita_model');
// Ambil data wali santri berdasarkan id_santri dari model
$data['berita'] = $this->berita_model->get_berita_by_id($id_berita);
// Periksa apakah data ditemukan
if ($data['berita']) {
// Kirim data ke view untuk ditampilkan dalam modal
$this->load->view('berita', $data);
} else {
// Jika data tidak ditemukan, redirect ke halaman utama dengan pesan error
$this->session->set_flashdata('pesan', 'Berita tidak ditemukan');
redirect('berita'); // Ubah sesuai route halaman utama Anda
}
}
public function _rules()
{
$this->form_validation->set_rules('judul', 'Judul', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('deskripsi', 'Deskripsi', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('tanggal', 'Tanggal', 'required', array(
'required' => '%s harus diisi!!'
));
// Validasi manual untuk file
if (empty($_FILES['gambar']['name'])) {
$this->form_validation->set_rules('gambar', 'Gambar', 'required', array(
'required' => '%s harus diisi!!'
));
}
}
public function delete($id)
{
$where = array('id_berita' => $id);
$this->berita_model->delete($where, 'tb_berita');
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Data berhasil dihapus! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('berita');
}
}

View File

@ -0,0 +1,85 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Form_validation $form_validation
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Input $input
* @property CI_Upload $upload
* @property CI_Wali_santri_model $wali_santri_model
* @property CI_Santri_model $santri_model
* @property CI_Chat_model $chat_model
*/
class Chat extends CI_Controller
{
public function __construct()
{
parent::__construct();
is_logged_in();
$this->load->model('chat_model');
$this->load->model('wali_santri_model'); // Untuk relasi nama wali jika diperlukan
}
// ✅ Fungsi kirim chat (digunakan oleh aplikasi Android misalnya)
public function sendChat()
{
$id_wali_santri = $this->input->post('id_wali_santri');
$sender = $this->input->post('sender');
$message = $this->input->post('message');
if ($id_wali_santri && $sender && $message) {
$this->chat_model->insertChat($id_wali_santri, $sender, $message);
echo json_encode(['status' => 'success', 'message' => 'Chat sent']);
} else {
echo json_encode(['status' => 'error', 'message' => 'Missing required data']);
}
}
// ✅ Ambil riwayat chat berdasarkan id_wali_santri
public function getChatByWali($id_wali_santri)
{
$chat = $this->chat_model->getChatByWali($id_wali_santri);
echo json_encode(['status' => 'success', 'data' => $chat]);
}
// ✅ Halaman admin untuk melihat dan membalas chat
public function chatAdmin($id_wali_santri = null)
{
$data['title'] = 'Pesan';
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$data['chat'] = $this->chat_model->getChatByWali($id_wali_santri);
$data['id_wali_santri'] = $id_wali_santri;
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/chat_admin', $data);
$this->load->view('templates/footer');
}
// ✅ Proses kirim chat dari sisi admin (form di web)
public function sendChatFromAdmin()
{
$id_wali_santri = $this->input->post('id_wali_santri');
$message = $this->input->post('message');
$sender = 'admin';
if ($id_wali_santri && $message) {
$this->chat_model->insertChat($id_wali_santri, $sender, $message);
// Tambahkan flashdata sebelum redirect
$this->session->set_flashdata('pesan', '
<div class="alert alert-success alert-dismissible fade show" role="alert">
Pesan berhasil dikirim!
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
');
redirect('chat/chatadmin/' . $id_wali_santri);
} else {
show_error('Input tidak lengkap!');
}
}
}

View File

@ -0,0 +1,27 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Db $db
* @property CI_Session $session
*/
class Dashboard extends CI_Controller
{
public function __construct()
{
parent::__construct();
is_logged_in();
}
public function index()
{
$data['title'] = 'Dashboard';
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('dashboard');
$this->load->view('templates/footer');
}
}

View File

@ -0,0 +1,37 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Form_validation $form_validation
* @property CI_Input $input
* @property CI_Wali_santri_model $wali_santri_model
* @property CI_Santri_model $santri_model
* @property CI_Sejarah_model $sejarah_model
*/
class FCM extends CI_Controller
{
public function saveToken()
{
$json = json_decode(file_get_contents('php://input'), true);
$id = $json['id_wali_santri'];
$token = $json['token'];
// Cek jika token sudah ada untuk wali yang sama
$this->db->where('id_wali_santri', $id);
$exist = $this->db->get('fcm_tokens')->row();
if ($exist) {
$this->db->where('id_wali_santri', $id);
$this->db->update('fcm_tokens', ['token' => $token]);
} else {
$this->db->insert('fcm_tokens', [
'id_wali_santri' => $id,
'token' => $token
]);
}
echo json_encode(['status' => true, 'message' => 'Token berhasil disimpan']);
}
}

View File

@ -0,0 +1,159 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Form_validation $form_validation
* @property CI_Input $input
* @property CI_InformasiSPP_model $informasispp_model
*/
class InformasiSPP extends CI_Controller
{
public function __construct()
{
parent::__construct();
$this->load->model('informasispp_model');
is_logged_in();
}
public function index()
{
$data['title'] = 'SPP';
// $data['informasispp'] = $this->informasispp_model->get_data('tb_informasispp')->result();
$data['informasispp'] = $this->informasispp_model->get_informasispp();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/informasi_spp');
$this->load->view('templates/footer');
}
public function tambah()
{
$data['title'] = 'Tambah Waktu Pembayaran';
$data['informasispp'] = $this->informasispp_model->get_data('tb_informasispp')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/tambah_informasi_spp', $data);
$this->load->view('templates/footer');
}
public function tambah_aksi()
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->tambah();
} else {
$bulan = $this->input->post('bulan');
$tahun = $this->input->post('tahun');
// Cek apakah kombinasi bulan & tahun sudah ada
$cek = $this->db->get_where('tb_informasispp', [
'bulan' => $bulan,
'tahun' => $tahun
])->num_rows();
if ($cek > 0) {
// Jika data sudah ada, tampilkan pesan error
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Informasi SPP di bulan dan tahun tersebut sudah pernah ditambahkan!
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button></div>');
redirect('informasispp/tambah');
} else {
// Jika belum ada, lanjutkan menyimpan data
$data = array(
'bulan' => $bulan,
'tahun' => $tahun,
'jumlah_pembayaran' => $this->input->post('jumlah_pembayaran'),
'jatuh_tempo' => $this->input->post('jatuh_tempo')
);
$this->informasispp_model->insert_data($data, 'tb_informasispp');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil ditambahkan! <button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span></button></div>');
redirect('informasispp');
}
}
}
public function edit($id_spp)
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->index();
} else {
$bulan = $this->input->post('bulan');
$tahun = $this->input->post('tahun');
// Cek apakah kombinasi bulan dan tahun sudah ada di data lain (bukan data yang sedang diedit)
$this->db->where('bulan', $bulan);
$this->db->where('tahun', $tahun);
$this->db->where('id_spp !=', $id_spp); // pengecualian untuk data yang sedang diedit
$cek = $this->db->get('tb_informasispp')->num_rows();
if ($cek > 0) {
// Jika kombinasi bulan & tahun sudah ada di data lain, tampilkan pesan
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Informasi SPP di bulan dan tahun tersebut sudah pernah ditambahkan!
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button></div>');
redirect('informasispp');
} else {
// Jika aman, lanjut update
$data = array(
'id_spp' => $id_spp,
'bulan' => $bulan,
'tahun' => $tahun,
'jumlah_pembayaran' => $this->input->post('jumlah_pembayaran'),
'jatuh_tempo' => $this->input->post('jatuh_tempo')
);
$this->informasispp_model->update_data($data, 'tb_informasispp');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil diubah! <button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span></button></div>');
redirect('informasispp');
}
}
}
public function _rules()
{
$this->form_validation->set_rules('bulan', 'Bulan', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('tahun', 'Tahun', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('jumlah_pembayaran', 'Jumlah Pembayaran', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('jatuh_tempo', 'Jatuh Tempo', 'required', array(
'required' => '%s harus diisi!!'
));
}
public function delete($id)
{
$where = array('id_spp' => $id);
$this->informasispp_model->delete($where, 'tb_informasispp');
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Data berhasil dihapus! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('informasispp');
}
}

View File

@ -0,0 +1,237 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Form_validation $form_validation
* @property CI_Input $input
* @property CI_InformasiSPPSantri_model $informasi_spp_santri_model
*/
class InformasiSPPSantri extends CI_Controller
{
public function __construct()
{
parent::__construct();
$this->load->model('informasi_spp_santri_model');
is_logged_in();
}
public function index()
{
$data['title'] = 'SPP Santri';
// $data['informasispp'] = $this->informasispp_model->get_data('tb_informasispp')->result();
$data['informasisppsantri'] = $this->informasi_spp_santri_model->get_informasispp();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/informasi_spp_santri');
$this->load->view('templates/footer');
}
public function tambah()
{
$data['title'] = 'Tambah Data SPP Santri';
$data['informasisppsantri'] = $this->informasi_spp_santri_model->get_data('tb_informasi_spp_santri')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/tambah_informasi_spp_santri', $data);
$this->load->view('templates/footer');
}
public function tambah_aksi()
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->tambah();
} else {
$id_santri = $this->input->post('id_santri');
$bulan = $this->input->post('bulan');
$tahun = $this->input->post('tahun');
// Cek apakah data sudah ada
$cek = $this->db->get_where('tb_informasi_spp_santri', [
'id_santri' => $id_santri,
'bulan' => $bulan,
'tahun' => $tahun
])->num_rows();
if ($cek > 0) {
// Data duplikat ditemukan
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Data untuk santri ini di bulan dan tahun tersebut sudah pernah ditambahkan!
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button></div>');
redirect('informasisppsantri/tambah');
} else {
// Data aman untuk disimpan
$tanggal_input = $this->input->post('jatuh_tempo');
$tanggal_formatted = date('Y-m-d', strtotime(str_replace('/', '-', $tanggal_input)));
$data = array(
'id_santri' => $id_santri,
'NIS' => $this->input->post('NIS'),
'nama_santri' => $this->input->post('nama_santri'),
'kelas_diniyah' => intval($this->input->post('kelas_diniyah')),
'bulan' => $bulan,
'tahun' => $tahun,
'jumlah_pembayaran' => $this->input->post('jumlah_pembayaran'),
'jatuh_tempo' => $tanggal_formatted,
'keterangan' => $this->input->post('keterangan')
);
$this->informasi_spp_santri_model->insert_data($data, 'tb_informasi_spp_santri');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil ditambahkan!
<button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('informasisppsantri');
}
}
}
public function get_nis_autocomplete()
{
$term = $this->input->get('term');
$this->db->like('NIS', $term);
$this->db->or_like('nama_santri', $term);
$query = $this->db->get('tb_santri');
$result = [];
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
foreach ($query->result() as $row) {
$kelas_diniyah_text = isset($kelas_diniyah[$row->kelas_diniyah]) ? $kelas_diniyah[$row->kelas_diniyah] : 'Tidak Diketahui';
$result[] = [
'label' => $row->NIS . ' - ' . $row->nama_santri . ' (' . $kelas_diniyah_text . ')',
'value' => $row->NIS,
'nama_santri' => $row->nama_santri,
'id_santri' => $row->id_santri,
'kelas_diniyah' => $kelas_diniyah_text, // Kirim teksnya ke JS, bukan angkanya
'kelas_diniyah_id' => $row->kelas_diniyah // untuk disimpan ke DB
];
}
echo json_encode($result);
}
public function view($id_santri)
{
$data['title'] = 'Informasi SPP Santri';
$data['santri'] = $this->db->get_where('tb_santri', ['id_santri' => $id_santri])->row();
$data['informasisppsantri'] = $this->informasi_spp_santri_model->get_informasi_spp_by_santri($id_santri);
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header');
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/detail_informasi_spp_santri', $data);
$this->load->view('templates/footer');
}
public function edit($id_spp_santri)
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->index();
} else {
$id_santri = $this->input->post('id_santri');
$bulan = $this->input->post('bulan');
$tahun = $this->input->post('tahun');
// Cek apakah data dengan id_santri, bulan, tahun sudah ada, tapi dengan id_spp_santri yang berbeda
$this->db->where('id_santri', $id_santri);
$this->db->where('bulan', $bulan);
$this->db->where('tahun', $tahun);
$this->db->where('id_spp_santri !=', $id_spp_santri); // pengecualian untuk record ini
$cek = $this->db->get('tb_informasi_spp_santri')->row();
if ($cek) {
// Jika sudah ada data lain dengan kombinasi itu
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Data untuk santri tersebut pada bulan dan tahun ini sudah ada! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span></button></div>');
redirect('informasisppsantri');
} else {
// Aman, lanjut update
$tanggal_input = $this->input->post('jatuh_tempo');
$tanggal_formatted = date('Y-m-d', strtotime(str_replace('/', '-', $tanggal_input)));
$data = array(
'id_spp_santri' => $id_spp_santri,
'NIS' => $this->input->post('NIS'),
'nama_santri' => $this->input->post('nama_santri'),
'kelas_diniyah' => $this->input->post('kelas_diniyah'),
'bulan' => $bulan,
'tahun' => $tahun,
'jumlah_pembayaran' => $this->input->post('jumlah_pembayaran'),
'jatuh_tempo' => $tanggal_formatted,
'keterangan' => $this->input->post('keterangan')
);
$this->db->where('id_spp_santri', $id_spp_santri);
$this->db->update('tb_informasi_spp_santri', $data);
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil diubah! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span></button></div>');
redirect('informasisppsantri');
}
}
}
public function _rules()
{
$this->form_validation->set_rules('NIS', 'NIS', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('nama_santri', 'Nama Santri', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('kelas_diniyah', 'Kelas Diniyah', 'required|numeric|greater_than[0]', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('bulan', 'Bulan', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('tahun', 'Tahun', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('jumlah_pembayaran', 'Jumlah Pembayaran', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('jatuh_tempo', 'Jatuh Tempo', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('keterangan', 'Keterangan', 'required', array(
'required' => '%s harus diisi!!'
));
}
public function delete($id)
{
$where = array('id_spp_santri' => $id);
$this->informasi_spp_santri_model->delete($where, 'tb_informasi_spp_santri');
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Data berhasil dihapus! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('informasispp');
}
}

View File

@ -0,0 +1,114 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Form_validation $form_validation
* @property CI_Input $input
* @property CI_Kegiatan_santri_model $kegiatan_santri_model
*/
class KegiatanSantri extends CI_Controller
{
public function __construct()
{
parent::__construct();
$this->load->model('kegiatan_santri_model');
is_logged_in();
}
public function index()
{
$data['title'] = 'Kegiatan Santri';
$data['kegiatan'] = $this->kegiatan_santri_model->get_data('tb_kegiatan')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/kegiatan_santri');
$this->load->view('templates/footer');
}
public function tambah()
{
$data['title'] = 'Tambah Kegiatan Santri';
$data['kegiatan'] = $this->kegiatan_santri_model->get_data('tb_kegiatan')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
// $data['id_santri'] = $this->db->select_max('id_santri')->get('tb_kegiatan')->row()->id_santri + 1;
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/tambah_kegiatan', $data);
$this->load->view('templates/footer');
}
public function tambah_aksi()
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->tambah();
} else {
$data = array(
'hari' => $this->input->post('hari'),
'nama_kegiatan' => $this->input->post('nama_kegiatan'),
'waktu' => $this->input->post('waktu')
);
$this->kegiatan_santri_model->insert_data($data, 'tb_kegiatan');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil ditambahkan! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('kegiatansantri');
}
}
public function edit($id_kegiatan)
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->index();
} else {
$data = array(
'id_kegiatan' => $id_kegiatan,
'hari' => $this->input->post('hari'),
'nama_kegiatan' => $this->input->post('nama_kegiatan'),
'waktu' => $this->input->post('waktu')
);
$this->kegiatan_santri_model->update_data($data, 'tb_kegiatan');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil diubah! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('kegiatansantri');
}
}
public function _rules()
{
$this->form_validation->set_rules('hari', 'Hari', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('nama_kegiatan', 'Nama Kegiatan', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('waktu', 'Waktu', 'required', array(
'required' => '%s harus diisi!!'
));
}
public function delete($id)
{
$where = array('id_kegiatan' => $id);
$this->kegiatan_santri_model->delete($where, 'tb_kegiatan');
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Data berhasil dihapus! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('kegiatansantri');
}
}

View File

@ -0,0 +1,107 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Form_validation $form_validation
* @property CI_Input $input
* @property CI_Pelanggaran_model $pelanggaran_model
*/
class Pelanggaran extends CI_Controller
{
public function __construct()
{
parent::__construct();
$this->load->model('pelanggaran_model');
is_logged_in();
}
public function index()
{
$data['title'] = 'Kategori Pelanggaran';
$data['pelanggaran'] = $this->pelanggaran_model->get_data('tb_pelanggaran')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/pelanggaran');
$this->load->view('templates/footer');
}
public function tambah()
{
$data['title'] = 'Tambah Kategori Pelanggaran';
$data['pelanggaran'] = $this->pelanggaran_model->get_data('tb_pelanggaran')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/tambah_kategori_pelanggaran', $data);
$this->load->view('templates/footer');
}
public function tambah_aksi()
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->tambah();
} else {
$data = array(
'pelanggaran' => $this->input->post('pelanggaran'),
'sanksi' => $this->input->post('sanksi')
);
$this->pelanggaran_model->insert_data($data, 'tb_pelanggaran');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil ditambahkan! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('pelanggaran');
}
}
public function edit($id_pelanggaran)
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->index();
} else {
$data = array(
'id_pelanggaran' => $id_pelanggaran,
'pelanggaran' => $this->input->post('pelanggaran'),
'sanksi' => $this->input->post('sanksi')
);
$this->pelanggaran_model->update_data($data, 'tb_pelanggaran');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil diubah! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('pelanggaran');
}
}
public function _rules()
{
$this->form_validation->set_rules('pelanggaran', 'Pelanggaran', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('sanksi', 'Sanksi', 'required', array(
'required' => '%s harus diisi!!'
));
}
public function delete($id)
{
$where = array('id_pelanggaran' => $id);
$this->pelanggaran_model->delete($where, 'tb_pelanggaran');
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Data berhasil dihapus! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('pelanggaran');
}
}

View File

@ -0,0 +1,420 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Form_validation $form_validation
* @property CI_Input $input
* @property CI_Pelanggaran_santri_model $pelanggaran_santri_model
*/
use Dompdf\Dompdf;
use Dompdf\Options;
class PelanggaranSantri extends CI_Controller
{
public function __construct()
{
parent::__construct();
$this->load->model('pelanggaran_santri_model');
$this->load->library('notif'); // load library Notif
is_logged_in();
}
public function index()
{
$data['title'] = 'Pelanggaran Santri';
$data['pelanggaransantri'] = $this->pelanggaran_santri_model->get_data('tb_pelanggaran_santri')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/pelanggaran_santri');
$this->load->view('templates/footer');
}
public function tambah()
{
$data['title'] = 'Tambah Pelanggaran Santri';
$data['pelanggaransantri'] = $this->pelanggaran_santri_model->get_data('tb_pelanggaran_santri')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/tambah_pelanggaran_santri', $data);
$this->load->view('templates/footer');
}
public function print()
{
// Ambil input dari form
$start_input = $this->input->get('start_date');
$end_input = $this->input->get('end_date');
// Ubah format dari dd/mm/yyyy ke Y-m-d
if (!empty($start_input) && !empty($end_input)) {
$start = date('Y-m-d', strtotime(str_replace('/', '-', $start_input)));
$end = date('Y-m-d', strtotime(str_replace('/', '-', $end_input)));
// Filter berdasarkan tanggal
$data['pelanggaransantri'] = $this->pelanggaran_santri_model->get_filtered_data($start, $end);
} else {
// Ambil semua data jika tidak ada filter
$data['pelanggaransantri'] = $this->db->get('tb_pelanggaran_santri')->result();
}
$this->load->view('admin/print_pelanggaran_santri', $data);
}
public function pdf()
{
$options = new Options();
$options->set('isHtml5ParserEnabled', true);
$dompdf = new Dompdf($options);
// Ambil input tanggal dari GET
$tanggal_awal_input = $this->input->get('start_date');
$tanggal_akhir_input = $this->input->get('end_date');
// Format ulang dari dd/mm/yyyy ke Y-m-d
if (!empty($tanggal_awal_input) && !empty($tanggal_akhir_input)) {
$tgl_awal = date('Y-m-d', strtotime(str_replace('/', '-', $tanggal_awal_input)));
$tgl_akhir = date('Y-m-d', strtotime(str_replace('/', '-', $tanggal_akhir_input)));
// Filter berdasarkan tanggal yang sudah diformat
$this->db->where('tanggal >=', $tgl_awal);
$this->db->where('tanggal <=', $tgl_akhir);
}
$data['pelanggaransantri'] = $this->db->get('tb_pelanggaran_santri')->result();
$html = $this->load->view('admin/data_pelanggaran_santri', $data, true);
$dompdf->setPaper('A4', 'portrait');
$dompdf->loadHtml($html);
$dompdf->render();
$dompdf->stream('pelanggaran_santri.pdf', array("Attachment" => 0));
}
public function tambah_aksi()
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->tambah();
} else {
$tanggal_input = $this->input->post('tanggal');
$tanggal_formatted = date('Y-m-d', strtotime(str_replace('/', '-', $tanggal_input)));
$data = array(
'id_santri' => $this->input->post('id_santri'),
'NIS' => $this->input->post('NIS'),
'nama_santri' => $this->input->post('nama_santri'),
'kelas_diniyah' => intval($this->input->post('kelas_diniyah')),
'pelanggaran' => $this->input->post('pelanggaran'),
'tanggal' => $tanggal_formatted,
'sanksi' => $this->input->post('sanksi'),
'keterangan' => $this->input->post('keterangan')
);
$this->pelanggaran_santri_model->insert_data($data, 'tb_pelanggaran_santri');
$id_santri = $this->input->post('id_santri');
$namaSantri = $this->input->post('nama_santri');
// Kirim notifikasi FCM ke wali santri jika token tersedia
$wali = $this->db->get_where('tb_wali_santri', ['id_santri' => $id_santri])->row();
if ($wali) {
$token = $this->db->get_where('fcm_tokens', ['id_wali_santri' => $wali->id_wali_santri])->row('token');
if ($token) {
$title = 'Nufaku - Pelanggaran Baru';
$body = $namaSantri . ' melakukan pelanggaran baru';
$host = $_SERVER['HTTP_HOST'];
if (strpos($host, 'localhost') !== false || strpos($host, '127.0.0.1') !== false) {
$host = '192.168.0.80:8080'; // Ganti sesuai IP kamu
}
$this->load->library('notif');
$notif = new Notif();
$title = 'Nufaku - Pelanggaran Baru';
$body = $namaSantri . ' melakukan pelanggaran baru';
// Tambahkan payload
$dataPayload = [
'type' => 'pelanggaran',
'id_santri' => $id_santri,
'nama_santri' => $namaSantri,
'kelas_diniyah' => $this->input->post('kelas_diniyah'),
'pelanggaran' => $this->input->post('pelanggaran'),
'tanggal' => $tanggal_formatted,
'sanksi' => $this->input->post('sanksi'),
'keterangan' => $this->input->post('keterangan'),
'from_notif' => 'true'
];
$response = $notif->send($token, $title, $body, $dataPayload);
log_message('debug', 'RESPON FCM: ' . print_r($response, true));
}
}
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil ditambahkan! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('pelanggaransantri');
}
}
public function get_nis_autocomplete()
{
$term = $this->input->get('term');
$this->db->like('NIS', $term);
$this->db->or_like('nama_santri', $term);
$query = $this->db->get('tb_santri');
$result = [];
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
foreach ($query->result() as $row) {
$kelas_diniyah_text = isset($kelas_diniyah[$row->kelas_diniyah]) ? $kelas_diniyah[$row->kelas_diniyah] : 'Tidak Diketahui';
$result[] = [
'label' => $row->NIS . ' - ' . $row->nama_santri . ' (' . $kelas_diniyah_text . ')',
'value' => $row->NIS,
'nama_santri' => $row->nama_santri,
'id_santri' => $row->id_santri,
'kelas_diniyah' => $kelas_diniyah_text, // Kirim teksnya ke JS, bukan angkanya
'kelas_diniyah_id' => $row->kelas_diniyah // untuk disimpan ke DB
];
}
echo json_encode($result);
}
public function view($id_santri)
{
$data['title'] = 'Pelanggaran Santri';
$data['santri'] = $this->db->get_where('tb_santri', ['id_santri' => $id_santri])->row();
$data['pelanggaransantri'] = $this->pelanggaran_santri_model->get_pelanggaran_by_santri($id_santri);
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header');
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/detail_pelanggaran_santri', $data);
$this->load->view('templates/footer');
}
public function edit($id_pelanggaran_santri)
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->index();
} else {
$tanggal_input = $this->input->post('tanggal');
$tanggal_formatted = date('Y-m-d', strtotime(str_replace('/', '-', $tanggal_input)));
$data = array(
'id_pelanggaran_santri' => $id_pelanggaran_santri,
'NIS' => $this->input->post('NIS'),
'nama_santri' => $this->input->post('nama_santri'),
'kelas_diniyah' => $this->input->post('kelas_diniyah'),
'pelanggaran' => $this->input->post('pelanggaran'),
'tanggal' => $tanggal_formatted,
'sanksi' => $this->input->post('sanksi'),
'keterangan' => $this->input->post('keterangan')
);
$this->pelanggaran_santri_model->update_data($data, 'tb_pelanggaran_santri');
$id_santri = $this->input->post('id_santri');
$namaSantri = $this->input->post('nama_santri');
// Kirim notifikasi FCM ke wali santri jika token tersedia
$wali = $this->db->get_where('tb_wali_santri', ['id_santri' => $id_santri])->row();
if ($wali) {
$token = $this->db->get_where('fcm_tokens', ['id_wali_santri' => $wali->id_wali_santri])->row('token');
log_message('debug', 'TOKEN FCM DITEMUKAN: ' . $token);
if ($token) {
$title = 'Nufaku - Pelanggaran Baru';
$body = $namaSantri . ' melakukan pelanggaran baru';
$host = $_SERVER['HTTP_HOST'];
$protocol = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off' || $_SERVER['SERVER_PORT'] == 443) ? "https://" : "http://";
// URL backend (digunakan misal dalam notifikasi FCM yang arahkan ke web)
$baseUrl = $protocol . $host . base_url(); // base_url() sudah dinamis jika config-nya sudah benar
// Jika butuh URL API manual (misalnya untuk disisipkan dalam payload FCM), contoh:
$urlApi = $protocol . $host . '/admin-nufa/api/';
$this->load->library('notif');
$notif = new Notif();
$title = 'Nufaku - Pembaruan Pelanggaran';
$body = 'Data pelanggaran milik ' . $namaSantri . ' telah diperbarui';
// Tambahkan payload
$dataPayload = [
'type' => 'pelanggaran',
'id_santri' => $id_santri,
'login_key' => 'id_santri',
'login_value' => $id_santri,
'nama_santri' => $namaSantri,
'kelas_diniyah' => $this->input->post('kelas_diniyah'),
'pelanggaran' => $this->input->post('pelanggaran'),
'tanggal' => $tanggal_formatted,
'sanksi' => $this->input->post('sanksi'),
'keterangan' => $this->input->post('keterangan'),
'from_notif' => 'true',
'detail_url' => $baseUrl . 'pelanggaransantri/detail/' . $id_santri, // misal untuk Android nanti
'api_url' => $urlApi . 'getDataSantri?id_santri=' . $id_santri
];
$response = $notif->send($token, $title, $body, $dataPayload);
log_message('debug', 'RESPON FCM: ' . print_r($response, true));
}
}
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil diubah! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('pelanggaransantri');
}
}
public function rekap()
{
$data['title'] = 'Rekap Pelanggaran Santri';
// Ambil semua data pelanggaran
$pelanggaransantri = $this->pelanggaran_santri_model->get_data('tb_pelanggaran_santri')->result();
// Proses pengelompokan
$rekap = [];
foreach ($pelanggaransantri as $row) {
$nis = $row->NIS;
if (!isset($rekap[$nis])) {
$rekap[$nis] = [
'NIS' => $row->NIS,
'nama_santri' => $row->nama_santri,
'kelas_diniyah' => $row->kelas_diniyah,
'jumlah_pelanggaran' => 0,
'sanksi_ada' => [],
'sanksi_kosong' => []
];
}
$rekap[$nis]['jumlah_pelanggaran']++;
if (!empty($row->sanksi)) {
$rekap[$nis]['sanksi_ada'][] = $row->sanksi;
} else {
$rekap[$nis]['sanksi_kosong'][] = $row->pelanggaran;
}
}
$data['rekap'] = $rekap;
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
// Load tampilan rekap
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/rekap_pelanggaran', $data);
$this->load->view('templates/footer');
}
public function rekap_pdf()
{
$options = new Options();
$options->set('isHtml5ParserEnabled', true);
$dompdf = new Dompdf($options);
// Ambil data pelanggaran dan rekap
$pelanggaransantri = $this->pelanggaran_santri_model->get_data('tb_pelanggaran_santri')->result();
$rekap = [];
foreach ($pelanggaransantri as $row) {
$nis = $row->NIS;
if (!isset($rekap[$nis])) {
$rekap[$nis] = [
'NIS' => $row->NIS,
'nama_santri' => $row->nama_santri,
'kelas_diniyah' => $row->kelas_diniyah,
'jumlah_pelanggaran' => 0,
'sanksi_ada' => [],
'sanksi_kosong' => []
];
}
$rekap[$nis]['jumlah_pelanggaran']++;
if (strtolower(trim($row->keterangan)) == 'sudah disanksi') {
$rekap[$nis]['sanksi_ada'][] = $row->sanksi;
} else {
$rekap[$nis]['sanksi_kosong'][] = $row->sanksi;
}
}
$data['rekap'] = $rekap;
// Load HTML view sebagai string
$html = $this->load->view('admin/rekap_pelanggaran', $data, true);
$dompdf->setPaper('A4', 'landscape');
$dompdf->loadHtml($html);
$dompdf->render();
$dompdf->stream('rekap_pelanggaran_santri.pdf', array("Attachment" => false));
}
public function _rules()
{
$this->form_validation->set_rules('NIS', 'NIS', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('nama_santri', 'Nama Santri', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('kelas_diniyah', 'Kelas Diniyah', 'required|numeric|greater_than[0]', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('pelanggaran', 'Pelanggaran', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('tanggal', 'Tanggal', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('sanksi', 'Sanksi', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('keterangan', 'Keterangan', 'required', array(
'required' => '%s harus diisi!!'
));
}
public function delete($id)
{
$where = array('id_pelanggaran_santri' => $id);
$this->pelanggaran_santri_model->delete($where, 'tb_pelanggaran_santri');
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Data berhasil dihapus! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('pelanggaransantri');
}
}

View File

@ -0,0 +1,112 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Form_validation $form_validation
* @property CI_Input $input
* @property CI_Perlombaan_model $perlombaan_model
*/
class Perlombaan extends CI_Controller
{
public function __construct()
{
parent::__construct();
$this->load->model('perlombaan_model');
is_logged_in();
}
public function index()
{
$data['title'] = 'Halaman Perlombaan';
$data['perlombaan'] = $this->perlombaan_model->get_data('tb_perlombaan')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/perlombaan');
$this->load->view('templates/footer');
}
public function tambah()
{
$data['title'] = 'Tambah Perlombaan Santri';
$data['perlombaan'] = $this->perlombaan_model->get_data('tb_perlombaan')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/tambah_perlombaan', $data);
$this->load->view('templates/footer');
}
public function tambah_aksi()
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->tambah();
} else {
$data = array(
'agenda' => $this->input->post('agenda'),
'perlombaan' => $this->input->post('perlombaan'),
'tanggal' => $this->input->post('tanggal')
);
$this->perlombaan_model->insert_data($data, 'tb_perlombaan');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil ditambahkan! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('perlombaan');
}
}
public function edit($id_perlombaan)
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->index();
} else {
$data = array(
'id_perlombaan' => $id_perlombaan,
'agenda' => $this->input->post('agenda'),
'perlombaan' => $this->input->post('perlombaan'),
'tanggal' => $this->input->post('tanggal')
);
$this->perlombaan_model->update_data($data, 'tb_perlombaan');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil diubah! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('perlombaan');
}
}
public function _rules()
{
$this->form_validation->set_rules('agenda', 'Agenda', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('perlombaan', 'Perlombaan', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('tanggal', 'Tanggal', 'required', array(
'required' => '%s harus diisi!!'
));
}
public function delete($id)
{
$where = array('id_perlombaan' => $id);
$this->perlombaan_model->delete($where, 'tb_perlombaan');
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Data berhasil dihapus! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('perlombaan');
}
}

View File

@ -0,0 +1,308 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Form_validation $form_validation
* @property CI_Input $input
* @property CI_Prestasi_santri_model $prestasi_santri_model
*/
use Dompdf\Dompdf;
use Dompdf\Options;
class PrestasiSantri extends CI_Controller
{
public function __construct()
{
parent::__construct();
$this->load->model('prestasi_santri_model');
is_logged_in();
}
public function index()
{
$data['title'] = 'Prestasi Santri';
$data['prestasisantri'] = $this->prestasi_santri_model->get_data('tb_prestasi_santri')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/prestasi_santri');
$this->load->view('templates/footer');
}
public function tambah()
{
$data['title'] = 'Tambah Prestasi Santri';
$data['prestasisantri'] = $this->prestasi_santri_model->get_data('tb_prestasi_santri')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/tambah_prestasi_santri', $data);
$this->load->view('templates/footer');
}
public function print()
{
// Ambil input dari form
$start_input = $this->input->get('start_date');
$end_input = $this->input->get('end_date');
// Ubah format dari dd/mm/yyyy ke Y-m-d
if (!empty($start_input) && !empty($end_input)) {
$start = date('Y-m-d', strtotime(str_replace('/', '-', $start_input)));
$end = date('Y-m-d', strtotime(str_replace('/', '-', $end_input)));
// Filter berdasarkan tanggal
$data['prestasisantri'] = $this->prestasi_santri_model->get_filtered_data($start, $end);
} else {
// Ambil semua data jika tidak ada filter
$data['prestasisantri'] = $this->db->get('tb_prestasi_santri')->result();
}
$this->load->view('admin/print_prestasi_santri', $data);
}
public function pdf()
{
$options = new Options();
$options->set('isHtml5ParserEnabled', true);
$dompdf = new Dompdf($options);
// Ambil input tanggal dari GET
$tanggal_awal_input = $this->input->get('start_date');
$tanggal_akhir_input = $this->input->get('end_date');
// Format ulang dari dd/mm/yyyy ke Y-m-d
if (!empty($tanggal_awal_input) && !empty($tanggal_akhir_input)) {
$tgl_awal = date('Y-m-d', strtotime(str_replace('/', '-', $tanggal_awal_input)));
$tgl_akhir = date('Y-m-d', strtotime(str_replace('/', '-', $tanggal_akhir_input)));
// Filter berdasarkan tanggal yang sudah diformat
$this->db->where('tanggal >=', $tgl_awal);
$this->db->where('tanggal <=', $tgl_akhir);
}
$data['prestasisantri'] = $this->db->get('tb_prestasi_santri')->result();
$html = $this->load->view('admin/data_prestasi_santri', $data, true);
$dompdf->setPaper('A4', 'portrait');
$dompdf->loadHtml($html);
$dompdf->render();
$dompdf->stream('prestasi_santri.pdf', array("Attachment" => 0));
}
public function tambah_aksi()
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->tambah();
} else {
$bukti = $this->input->post('bukti_prestasi');
$valid = false;
if (strpos($bukti, '/d/') !== false) {
$parts = explode('/d/', $bukti);
if (count($parts) > 1 && strpos($parts[1], '/') !== false) {
$valid = true;
}
} elseif (strpos($bukti, 'id=') !== false) {
$parsedUrl = parse_url($bukti);
if (isset($parsedUrl['query'])) {
parse_str($parsedUrl['query'], $queryParams);
if (isset($queryParams['id']) && !empty($queryParams['id'])) {
$valid = true;
}
}
}
if (!$valid && !empty($bukti)) {
$this->session->set_flashdata('pesan', '
<div class="alert alert-danger alert-dismissible fade show" role="alert">
Link file tidak valid! Pastikan menggunakan format Google Drive seperti
<code>https://drive.google.com/file/d/FILE_ID/view</code> atau <code>?id=FILE_ID</code>.
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>');
redirect('prestasisantri/tambah');
return;
}
// Lanjut simpan jika valid
$tanggal_input = $this->input->post('tanggal');
$tanggal_formatted = date('Y-m-d', strtotime(str_replace('/', '-', $tanggal_input)));
$data = array(
'id_santri' => $this->input->post('id_santri'),
'NIS' => $this->input->post('NIS'),
'nama_santri' => $this->input->post('nama_santri'),
'kelas_diniyah' => $this->input->post('kelas_diniyah'),
'prestasi' => $this->input->post('prestasi'),
'perlombaan' => $this->input->post('perlombaan'),
'agenda' => $this->input->post('agenda'),
'tanggal' => $tanggal_formatted,
'bukti_prestasi' => $bukti,
);
$this->prestasi_santri_model->insert_data($data, 'tb_prestasi_santri');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil ditambahkan! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('prestasisantri');
}
}
public function get_nis_autocomplete()
{
$term = $this->input->get('term');
$this->db->like('NIS', $term);
$this->db->or_like('nama_santri', $term);
$query = $this->db->get('tb_santri');
$result = [];
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
foreach ($query->result() as $row) {
$kelas_diniyah_text = isset($kelas_diniyah[$row->kelas_diniyah]) ? $kelas_diniyah[$row->kelas_diniyah] : 'Tidak Diketahui';
$result[] = [
'label' => $row->NIS . ' - ' . $row->nama_santri . ' (' . $kelas_diniyah_text . ')',
'value' => $row->NIS,
'nama_santri' => $row->nama_santri,
'id_santri' => $row->id_santri,
'kelas_diniyah' => $kelas_diniyah_text, // Kirim teksnya ke JS, bukan angkanya
'kelas_diniyah_id' => $row->kelas_diniyah // untuk disimpan ke DB
];
}
echo json_encode($result);
}
public function view($id_santri)
{
$data['title'] = 'Prestasi Santri';
$data['santri'] = $this->db->get_where('tb_santri', ['id_santri' => $id_santri])->row();
$data['prestasisantri'] = $this->prestasi_santri_model->get_prestasi_by_santri($id_santri);
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header');
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/detail_prestasi_santri', $data);
$this->load->view('templates/footer');
}
public function edit($id_prestasi_santri)
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->index();
} else {
$bukti = $this->input->post('bukti_prestasi');
$valid = false;
if (strpos($bukti, '/d/') !== false) {
$parts = explode('/d/', $bukti);
if (count($parts) > 1 && strpos($parts[1], '/') !== false) {
$valid = true;
}
} elseif (strpos($bukti, 'id=') !== false) {
$parsedUrl = parse_url($bukti);
if (isset($parsedUrl['query'])) {
parse_str($parsedUrl['query'], $queryParams);
if (isset($queryParams['id']) && !empty($queryParams['id'])) {
$valid = true;
}
}
}
if (!$valid && !empty($bukti)) {
$this->session->set_flashdata('pesan', '
<div class="alert alert-danger alert-dismissible fade show" role="alert">
Link file tidak valid! Pastikan menggunakan format Google Drive seperti
<code>https://drive.google.com/file/d/FILE_ID/view</code> atau <code>?id=FILE_ID</code>.
<button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>');
redirect('prestasisantri');
return;
}
$tanggal_input = $this->input->post('tanggal');
$tanggal_formatted = date('Y-m-d', strtotime(str_replace('/', '-', $tanggal_input))); // Format aman untuk MySQL
$data = array(
'id_prestasi_santri' => $id_prestasi_santri,
'NIS' => $this->input->post('NIS'),
'nama_santri' => $this->input->post('nama_santri'),
'kelas_diniyah' => $this->input->post('kelas_diniyah'),
'prestasi' => $this->input->post('prestasi'),
'perlombaan' => $this->input->post('perlombaan'),
'agenda' => $this->input->post('agenda'),
'tanggal' => $tanggal_formatted, // Sudah diformat dengan aman
'bukti_prestasi' => $bukti
);
$this->prestasi_santri_model->update_data($data, 'tb_prestasi_santri');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil diubah! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('prestasisantri');
}
}
public function _rules()
{
$this->form_validation->set_rules('NIS', 'NIS', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('nama_santri', 'Nama Santri', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('kelas_diniyah', 'Kelas Diniyah', 'required|numeric|greater_than[0]', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('prestasi', 'Prestasi', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('agenda', 'Agenda', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('perlombaan', 'Perlombaan', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('tanggal', 'Tanggal', 'required', array(
'required' => '%s harus diisi!!'
));
}
public function delete($id)
{
$where = array('id_prestasi_santri' => $id);
$this->prestasi_santri_model->delete($where, 'tb_prestasi_santri');
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Data berhasil dihapus! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('prestasisantri');
}
}

View File

@ -0,0 +1,224 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Form_validation $form_validation
* @property CI_Input $input
* @property CI_Santri_model $santri_model
*/
use Dompdf\Dompdf;
use Dompdf\Options;
class Santri extends CI_Controller
{
public function __construct()
{
parent::__construct();
$this->load->model('santri_model');
is_logged_in();
}
public function index()
{
$data['title'] = 'Santri';
$data['santri'] = $this->santri_model->get_data('tb_santri')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/santri', $data);
$this->load->view('templates/footer');
}
public function tambah()
{
$data['title'] = 'Tambah Santri';
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
// Pastikan $data['id_santri'] memiliki nilai unik, misalnya berdasarkan jumlah santri yang sudah ada
$data['id_santri'] = $this->db->select_max('id_santri')->get('tb_santri')->row()->id_santri + 1;
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/tambah_santri', $data);
$this->load->view('templates/footer');
}
public function print()
{
$data['santri'] = $this->santri_model->get_data('tb_santri')->result();
$this->load->view('admin/print_santri', $data);
}
public function pdf()
{
// Buat instance baru Dompdf dan set opsi jika diperlukan
$options = new Options();
$options->set('isHtml5ParserEnabled', true); // Mengaktifkan parser HTML5
$dompdf = new Dompdf($options);
// Ambil data santri dari model
$data['santri'] = $this->santri_model->get_data('tb_santri')->result();
// Load view laporan_santri dan simpan output HTML ke dalam variabel
$html = $this->load->view('admin/laporan_santri', $data, true);
// Atur ukuran kertas dan orientasi
$dompdf->setPaper('legal', 'portrait'); // Pilih 'portrait' atau 'landscape'
// Muat konten HTML ke dalam Dompdf
$dompdf->loadHtml($html);
// Render konten HTML menjadi PDF
$dompdf->render();
// Stream atau unduh file PDF
$dompdf->stream('laporan_santri.pdf', array("Attachment" => 0)); // Attachment=0 untuk menampilkan di browser
}
public function tambah_aksi()
{
// Ambil NIS dari input form
$NIS = $this->input->post('NIS');
// Cek apakah NIS sudah ada di database
if ($this->santri_model->check_nis_exists($NIS)) {
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
NIS sudah pernah ditambahkan! <button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span></button></div>');
redirect('santri/tambah');
}
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->tambah();
} else {
$tanggal_input = $this->input->post('tanggal_lahir');
$tanggal_formatted = date('Y-m-d', strtotime(str_replace('/', '-', $tanggal_input)));
$data = array(
'NIS' => $this->input->post('NIS'),
'nama_santri' => $this->input->post('nama_santri'),
'kelas_diniyah' => $this->input->post('kelas_diniyah'),
'status_santri' => $this->input->post('status_santri'),
'kondisi_kesehatan' => $this->input->post('kondisi_kesehatan'),
'tahun_masuk' => $this->input->post('tahun_masuk'),
'tahun_keluar' => $this->input->post('tahun_keluar'),
'keterangan_keluar' => $this->input->post('keterangan_keluar'),
'tempat_lahir' => $this->input->post('tempat_lahir'),
'tanggal_lahir' => $tanggal_formatted,
'alamat_santri' => $this->input->post('alamat_santri'),
);
$this->santri_model->insert_data($data, 'tb_santri');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil ditambahkan! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('santri');
}
}
public function edit($id_santri)
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->index();
} else {
$tanggal_input = $this->input->post('tanggal_lahir');
$tanggal_formatted = date('Y-m-d', strtotime(str_replace('/', '-', $tanggal_input)));
// Ambil nilai dari form
$id_santri = $this->input->post('id_santri');
$namaSantri = $this->input->post('nama_santri');
$kondisi_kesehatan = $this->input->post('kondisi_kesehatan');
$data = array(
'id_santri' => $id_santri,
'NIS' => $this->input->post('NIS'),
'nama_santri' => $namaSantri,
'kelas_diniyah' => $this->input->post('kelas_diniyah'),
'status_santri' => $this->input->post('status_santri'),
'kondisi_kesehatan' => $kondisi_kesehatan,
'tahun_masuk' => $this->input->post('tahun_masuk'),
'tahun_keluar' => $this->input->post('tahun_keluar'),
'keterangan_keluar' => $this->input->post('keterangan_keluar'),
'tempat_lahir' => $this->input->post('tempat_lahir'),
'tanggal_lahir' => $tanggal_formatted,
'alamat_santri' => $this->input->post('alamat_santri'),
);
// Update data santri
$this->santri_model->update_data($data, 'tb_santri');
// Jika kondisi_kesehatan = sehat atau sakit, kirim notifikasi ke wali
if ($kondisi_kesehatan == "Dalam Kondisi Sehat" || $kondisi_kesehatan == "Dalam Kondisi Sakit") {
$wali = $this->db->get_where('tb_wali_santri', ['id_santri' => $id_santri])->row();
if ($wali) {
$token = $this->db->get_where('fcm_tokens', ['id_wali_santri' => $wali->id_wali_santri])->row('token');
if ($token) {
$title = 'Kondisi Kesehatan';
$body = $namaSantri . ' ' . $kondisi_kesehatan;
// Load dan kirim notifikasi
$this->load->library('notif');
$notif = new Notif();
$response = $notif->send($token, $title, $body);
log_message('debug', 'RESPON FCM: ' . print_r($response, true));
}
}
}
// Flash pesan berhasil
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil diubah! <button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span></button></div>');
redirect('santri');
}
}
public function _rules()
{
$this->form_validation->set_rules('NIS', 'NIS', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('nama_santri', 'Nama Santri', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('kelas_diniyah', 'Kelas Diniyah', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('status_santri', 'Status Santri', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('kondisi_kesehatan', 'Kondisi Kesehatan', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('tahun_masuk', 'Tahun Masuk', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('tempat_lahir', 'Tempat Lahir', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('tanggal_lahir', 'Tanggal Lahir', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('alamat_santri', 'Alamat Santri', 'required', array(
'required' => '%s harus diisi!!'
));
}
public function delete($id)
{
$where = array('id_santri' => $id);
$this->santri_model->delete($where, 'tb_santri');
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Data berhasil dihapus! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('santri');
}
}

View File

@ -0,0 +1,88 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Form_validation $form_validation
* @property CI_Input $input
* @property CI_Sejarah_model $sejarah_model
*/
class Sejarah extends CI_Controller
{
public function __construct()
{
parent::__construct();
$this->load->model('sejarah_model');
is_logged_in();
}
public function index()
{
$data['title'] = 'Sejarah';
$data['sejarah'] = $this->sejarah_model->get_data('tb_sejarah')->result();
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/sejarah');
$this->load->view('templates/footer');
}
public function tambah_aksi()
{
$this->_rules();
if ($this->form_validation->run() == TRUE) {
$data = array(
'sejarah' => $this->input->post('sejarah'),
);
$this->sejarah_model->insert_data($data, 'tb_sejarah');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil ditambahkan! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('sejarah');
}
}
public function edit($id_sejarah)
{
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->index();
} else {
$data = array(
'id_sejarah' => $id_sejarah,
'sejarah' => $this->input->post('sejarah'),
);
$this->sejarah_model->update_data($data, 'tb_sejarah');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil diubah! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('sejarah');
}
}
public function _rules()
{
$this->form_validation->set_rules('sejarah', 'Sejarah', 'required', array(
'required' => '%s harus diisi!!'
));
}
public function delete($id)
{
$where = array('id_sejarah' => $id);
$this->sejarah_model->delete($where, 'tb_sejarah');
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Data berhasil dihapus! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('sejarah');
}
}

View File

@ -0,0 +1,256 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
/**
* @property CI_Db $db
* @property CI_Session $session
* @property CI_Form_validation $form_validation
* @property CI_Input $input
* @property CI_Wali_santri_model $wali_santri_model
* @property CI_Santri_model $santri_model
* @property CI_Chat_model $chat_model
*/
class WaliSantri extends CI_Controller
{
public function __construct()
{
parent::__construct();
$this->load->model('wali_santri_model');
$this->load->model('santri_model');
$this->load->model('chat_model');
is_logged_in();
}
public function index()
{
$data['title'] = 'Wali Santri';
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$data['santri'] = $this->wali_santri_model->get_all_santri(); // Tambahkan data santri
$data['santri'] = $this->db->select('tb_santri.id_santri, tb_santri.NIS, tb_santri.nama_santri, tb_wali_santri.id_wali_santri, tb_wali_santri.nama_wali_santri, tb_wali_santri.alamat, tb_wali_santri.no_telepon, tb_wali_santri.email, tb_wali_santri.password, tb_wali_santri.pekerjaan')
->from('tb_santri')
->join('tb_wali_santri', 'tb_santri.id_santri = tb_wali_santri.id_santri', 'left')
->get()
->result();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/wali_santri', $data); // Pastikan data santri dikirim ke view wali_santri
$this->load->view('templates/footer');
}
public function get_all_santri()
{
$this->db->select('tb_wali_santri.nama_wali_santri, tb_santri.nama_santri, tb_wali_santri.alamat, tb_wali_santri.no_telepon, tb_santri.id_santri');
$this->db->from('tb_wali_santri');
$this->db->join('tb_santri', 'tb_santri.id_santri = tb_wali_santri.id_santri');
return $this->db->get()->result();
}
public function tambah($id_santri = null)
{
// Set judul halaman
$data['title'] = 'Tambah Wali Santri';
// Periksa apakah id_santri ada dan valid
if ($id_santri && is_numeric($id_santri)) {
// Ambil data santri berdasarkan id_santri dari model
$santri = $this->santri_model->get_santri_by_id($id_santri);
if ($santri) {
$data['santri'] = $santri; // Berikan data santri jika ditemukan
} else {
$data['santri'] = null; // Set null jika data tidak ditemukan
$this->session->set_flashdata('error', 'Data santri tidak ditemukan');
}
} else {
$data['santri'] = null; // Set null jika id_santri tidak ada atau tidak valid
}
// Load view dengan data santri
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/tambah_wali_santri', $data); // Kirim data ke view
$this->load->view('templates/footer');
}
public function tambah_aksi()
{
$id_santri = $this->input->post('id_santri');
// Cek apakah wali santri dengan username ini sudah ada untuk santri tersebut
if ($this->wali_santri_model->check_wali_exists($id_santri)) {
$this->session->set_flashdata('pesan', '<div class="alert alert-danger alert-dismissible fade show" role="alert">
Wali santri sudah pernah ditambahkan! <button type="button" class="close" data-dismiss="alert" aria-label="Close">
<span aria-hidden="true">&times;</span></button></div>');
redirect('santri');
}
$this->_rules();
if ($this->form_validation->run() == FALSE) {
$this->tambah();
} else {
// Cek apakah id_santri kosong
$id_santri = $this->input->post('id_santri');
if (empty($id_santri)) {
$this->session->set_flashdata('error', 'Kesalahan: id_santri tidak boleh kosong!');
redirect('walisantri');
return;
}
$data = array(
'email' => $this->input->post('email'),
'password' => $this->input->post('password'),
'nama_wali_santri' => $this->input->post('nama_wali_santri'),
'id_santri' => $id_santri,
// 'no_ktp' => $this->input->post('no_ktp'),
// 'tempat_lahir' => $this->input->post('tempat_lahir'),
// 'tanggal_lahir' => $this->input->post('tanggal_lahir'),
'alamat' => $this->input->post('alamat'),
'no_telepon' => $this->input->post('no_telepon'),
'pekerjaan' => $this->input->post('pekerjaan'),
);
$this->wali_santri_model->insert_data($data, 'tb_wali_santri');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil ditambahkan! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('walisantri');
}
}
public function edit($id_wali_santri = null)
{
$this->_rules();
if ($id_wali_santri === null) {
redirect('walisantri');
} else {
$data = array(
'id_wali_santri' => $id_wali_santri,
'email' => $this->input->post('email'),
'password' => $this->input->post('password'),
'nama_wali_santri' => $this->input->post('nama_wali_santri'),
'id_santri' => $this->input->post('id_santri'),
// 'no_ktp' => $this->input->post('no_ktp'),
// 'tempat_lahir' => $this->input->post('tempat_lahir'),
// 'tanggal_lahir' => $this->input->post('tanggal_lahir'),
'alamat' => $this->input->post('alamat'),
'no_telepon' => $this->input->post('no_telepon'),
'pekerjaan' => $this->input->post('pekerjaan'),
);
$this->wali_santri_model->update_data($data, 'tb_wali_santri');
$this->session->set_flashdata('pesan', '<div class="alert alert-success alert-dismissible fade show" role="alert">
Data berhasil diubah! <button type="button" class="close" data-dismiss="alert" aria-label="Close"> <span aria-hidden="true">&times;</span>
</button></div>');
redirect('walisantri');
}
}
public function view($id_santri)
{
// Load model jika belum diload
$this->load->model('wali_santri_model');
// Ambil data wali santri berdasarkan id_santri dari model
$data['santri'] = $this->wali_santri_model->get_santri_by_id($id_santri);
// Periksa apakah data ditemukan
if ($data['santri']) {
// Kirim data ke view untuk ditampilkan dalam modal
$this->load->view('wali_santri', $data);
} else {
// Jika data tidak ditemukan, redirect ke halaman utama dengan pesan error
$this->session->set_flashdata('pesan', 'Data wali santri tidak ditemukan');
redirect('admin/santri'); // Ubah sesuai route halaman utama Anda
}
}
private function _rules()
{
$this->form_validation->set_rules('email', 'Email', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('password', 'Password', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('nama_wali_santri', 'Nama Wali Santri', 'required', array(
'required' => '%s harus diisi!!'
));
// $this->form_validation->set_rules('no_ktp', 'No KTP', 'required', array(
// 'required' => '%s harus diisi!!'
// ));
// $this->form_validation->set_rules('tempat_lahir', 'Tempat Lahir', 'required', array(
// 'required' => '%s harus diisi!!'
// ));
// $this->form_validation->set_rules('tanggal_lahir', 'Tanggal Lahir', 'required', array(
// 'required' => '%s harus diisi!!'
// ));
$this->form_validation->set_rules('alamat', 'Alamat', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('no_telepon', 'No Telepon', 'required', array(
'required' => '%s harus diisi!!'
));
$this->form_validation->set_rules('pekerjaan', 'Pekerjaan', 'required', array(
'required' => '%s harus diisi!!'
));
}
public function chatAdmin($id_wali_santri = null)
{
$data['title'] = 'Halaman Pesan';
$data['admin'] = $this->db->get_where('admin', ['email' => $this->session->userdata('email')])->row_array();
$data['chat'] = $this->chat_model->getChatByWali($id_wali_santri);
$data['id_wali_santri'] = $id_wali_santri;
$this->load->view('templates/header', $data);
$this->load->view('templates/sidebar', $data);
$this->load->view('admin/chat_admin', $data);
$this->load->view('templates/footer');
}
public function sendChatFromAdmin()
{
$id_wali_santri = $this->input->post('id_wali_santri');
$message = $this->input->post('message');
$sender = 'admin';
if ($id_wali_santri && $message) {
$this->chat_model->insertChat($id_wali_santri, $sender, $message);
redirect('chat/chatadmin/' . $id_wali_santri);
} else {
show_error('Input tidak lengkap!');
}
}
public function saveToken()
{
$input = json_decode(file_get_contents("php://input"), true);
$id_wali_santri = $input['id_wali_santri'];
$token = $input['token'];
if ($id_wali_santri && $token) {
$data = [
'id_wali_santri' => $id_wali_santri,
'token' => $token,
'created_at' => date('Y-m-d H:i:s')
];
// Jika sudah ada token, update
$existing = $this->db->get_where('fcm_tokens', ['id_wali_santri' => $id_wali_santri])->row();
if ($existing) {
$this->db->where('id_wali_santri', $id_wali_santri)->update('fcm_tokens', $data);
} else {
$this->db->insert('fcm_tokens', $data);
}
echo json_encode(['status' => 'success']);
} else {
echo json_encode(['status' => 'failed']);
}
}
}

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/userguide3/general/urls.html
*/
public function index()
{
$this->load->view('welcome_message');
}
}

View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>

View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>

View File

@ -0,0 +1,31 @@
<?php
function check_user_role($required_role)
{
$ci = get_instance();
$role_id = $ci->session->userdata('role_id');
if ($role_id != $required_role) {
redirect('auth/blocked');
}
}
function is_logged_in()
{
$ci = get_instance();
if (!$ci->session->userdata('email')) {
redirect('auth');
}
}
function check_access($role_id, $menu_id)
{
$ci = get_instance();
$ci->db->where('role_id', $role_id);
$ci->db->where('menu_id', $menu_id);
$result = $ci->db->get('user_access_menu');
if ($result->num_rows() > 0) {
return "checked='checked'";
}
}

View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>

View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>

10
application/index.html Normal file
View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>

View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>

View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>

View File

@ -0,0 +1,35 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
use Kreait\Firebase\Factory;
use Kreait\Firebase\Messaging\CloudMessage;
class Notif
{
private $messaging;
public function __construct()
{
$firebase = (new Factory)
->withServiceAccount(FCPATH . 'firebase/firebase-credentials.json');
$this->messaging = $firebase->createMessaging();
}
public function send($token, $title, $body, $data = [])
{
$message = CloudMessage::withTarget('token', $token)
->withData(array_merge([
'title' => $title,
'body' => $body
], $data)); // kirim semua sebagai data
try {
$this->messaging->send($message);
return true;
} catch (\Kreait\Firebase\Exception\MessagingException $e) {
log_message('error', 'FCM Error: ' . $e->getMessage());
return false;
}
}
}

View File

@ -0,0 +1,20 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
use PHPMailer\PHPMailer\PHPMailer;
use PHPMailer\PHPMailer\Exception;
class Phpmailer_lib
{
public function __construct()
{
// Pastikan autoload Composer di-load
require_once APPPATH . '../vendor/autoload.php';
}
public function load()
{
$mail = new PHPMailer(true);
return $mail;
}
}

View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>

View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>

View File

@ -0,0 +1,33 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class Berita_model extends CI_Model
{
public function get_data($table)
{
return $this->db->get($table);
}
public function insert_data($data, $table)
{
$this->db->insert($table, $data);
}
public function update_data($data, $table)
{
$this->db->where('id_berita', $data['id_berita']);
$this->db->update($table, $data);
}
public function get_data_by_id($id)
{
return $this->db->get_where('tb_berita', ['id_berita' => $id])->row();
}
public function delete($where, $table)
{
$this->db->where($where);
$this->db->delete($table);
}
}

View File

@ -0,0 +1,33 @@
<?php
class Chat_model extends CI_Model
{
public function get_all_chats()
{
$this->db->select('chat.*, tb_wali_santri.nama_wali_santri, tb_santri.nama_santri');
$this->db->from('chat');
$this->db->join('tb_wali_santri', 'tb_wali_santri.id_wali_santri = chat.id_wali_santri');
$this->db->join('tb_santri', 'tb_santri.id_santri = tb_wali_santri.id_santri');
$this->db->order_by('chat.timestamp', 'ASC');
return $this->db->get()->result();
}
public function insertChat($id_wali_santri, $sender, $message)
{
$data = [
'id_wali_santri' => $id_wali_santri,
'sender' => $sender,
'message' => $message,
'timestamp' => date('Y-m-d H:i:s')
];
return $this->db->insert('chat', $data);
}
public function getChatByWali($id_wali_santri)
{
$this->db->where('id_wali_santri', $id_wali_santri);
$this->db->order_by('timestamp', 'ASC');
$query = $this->db->get('chat');
return $query->result_array();
}
}

View File

@ -0,0 +1,38 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class InformasiSPP_model extends CI_Model
{
public function get_data($table)
{
return $this->db->get($table);
}
public function get_informasispp()
{
$this->db->order_by('bulan', 'ASC');
return $this->db->get('tb_informasispp')->result();
}
public function insert_data($data, $table)
{
$this->db->insert($table, $data);
}
public function update_data($data, $table)
{
$this->db->where('id_spp', $data['id_spp']);
$this->db->update($table, $data);
}
public function get_data_by_id($id_spp)
{
return $this->db->get_where('tb_informasispp', array('id_spp' => $id_spp))->row();
}
public function delete($where, $table)
{
$this->db->where($where);
$this->db->delete($table);
}
}

View File

@ -0,0 +1,43 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class Informasi_SPP_santri_model extends CI_Model
{
public function get_data($table)
{
return $this->db->get($table);
}
public function get_informasispp()
{
$this->db->order_by('bulan', 'ASC');
return $this->db->get('tb_informasi_spp_santri')->result();
}
public function get_informasi_spp_by_santri($id_santri)
{
return $this->db->get_where('tb_informasi_spp_santri', ['id_santri' => $id_santri])->result();
}
public function insert_data($data, $table)
{
$this->db->insert($table, $data);
}
public function update_data($data, $table)
{
$this->db->where('id_spp_santri', $data['id_spp_santri']);
$this->db->update($table, $data);
}
public function get_data_by_id($id_spp_santri)
{
return $this->db->get_where('tb_informasi_spp_santri', array('id_spp' => $id_spp_santri))->row();
}
public function delete($where, $table)
{
$this->db->where($where);
$this->db->delete($table);
}
}

View File

@ -0,0 +1,27 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class Kegiatan_santri_model extends CI_Model
{
public function get_data($table)
{
return $this->db->get($table);
}
public function insert_data($data, $table)
{
$this->db->insert($table, $data);
}
public function update_data($data, $table)
{
$this->db->where('id_kegiatan', $data['id_kegiatan']);
$this->db->update($table, $data);
}
public function delete($where, $table)
{
$this->db->where($where);
$this->db->delete($table);
}
}

View File

@ -0,0 +1,27 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class Pelanggaran_model extends CI_Model
{
public function get_data($table)
{
return $this->db->get($table);
}
public function insert_data($data, $table)
{
$this->db->insert($table, $data);
}
public function update_data($data, $table)
{
$this->db->where('id_pelanggaran', $data['id_pelanggaran']);
$this->db->update($table, $data);
}
public function delete($where, $table)
{
$this->db->where($where);
$this->db->delete($table);
}
}

View File

@ -0,0 +1,42 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class Pelanggaran_santri_model extends CI_Model
{
public function get_data($table)
{
return $this->db->get($table);
}
public function insert_data($data, $table)
{
$this->db->insert($table, $data);
}
public function get_pelanggaran_by_santri($id_santri)
{
return $this->db->get_where('tb_pelanggaran_santri', ['id_santri' => $id_santri])->result();
}
public function update_data($data, $table)
{
$this->db->where('id_pelanggaran_santri', $data['id_pelanggaran_santri']);
$this->db->update($table, $data);
}
public function get_filtered_data($start = null, $end = null)
{
if (!empty($start) && !empty($end)) {
$this->db->where('tanggal >=', $start);
$this->db->where('tanggal <=', $end);
}
return $this->db->get('tb_pelanggaran_santri')->result();
}
public function delete($where, $table)
{
$this->db->where($where);
$this->db->delete($table);
}
}

View File

@ -0,0 +1,27 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class Perlombaan_model extends CI_Model
{
public function get_data($table)
{
return $this->db->get($table);
}
public function insert_data($data, $table)
{
$this->db->insert($table, $data);
}
public function update_data($data, $table)
{
$this->db->where('id_perlombaan', $data['id_perlombaan']);
$this->db->update($table, $data);
}
public function delete($where, $table)
{
$this->db->where($where);
$this->db->delete($table);
}
}

View File

@ -0,0 +1,41 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class Prestasi_santri_model extends CI_Model
{
public function get_data($table)
{
return $this->db->get($table);
}
public function insert_data($data, $table)
{
$this->db->insert($table, $data);
}
public function get_prestasi_by_santri($id_santri)
{
return $this->db->get_where('tb_prestasi_santri', ['id_santri' => $id_santri])->result();
}
public function update_data($data, $table)
{
$this->db->where('id_prestasi_santri', $data['id_prestasi_santri']);
$this->db->update($table, $data);
}
public function get_filtered_data($start = null, $end = null)
{
if (!empty($start) && !empty($end)) {
$this->db->where('tanggal >=', $start);
$this->db->where('tanggal <=', $end);
}
return $this->db->get('tb_prestasi_santri')->result();
}
public function delete($where, $table)
{
$this->db->where($where);
$this->db->delete($table);
}
}

View File

@ -0,0 +1,276 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class Santri_model extends CI_Model
{
public function get_data($table)
{
return $this->db->get($table);
}
public function insert_data($data, $table)
{
$this->db->insert($table, $data);
}
public function check_nis_exists($nis)
{
$this->db->where('NIS', $nis);
$query = $this->db->get('tb_santri');
return $query->num_rows() > 0;
}
public function update_data($data, $table)
{
$this->db->where('id_santri', $data['id_santri']);
$this->db->update($table, $data);
}
public function get_data_by_id($id_santri)
{
return $this->db->get_where('tb_santri', array('id_santri' => $id_santri))->row();
}
public function get_santri_by_id($id_santri)
{
$this->db->where('id_santri', $id_santri);
$query = $this->db->get('tb_santri');
return $query->row(); // Mengembalikan satu baris data
}
public function get_data_by_id_santri($id_santri)
{
$this->db->where('id_santri', $id_santri);
$santri = $this->db->get('tb_santri')->row_array();
if ($santri) {
// tambahkan pelanggaran juga kalau dibutuhkan
$this->db->where('id_santri', $id_santri);
$pelanggaran = $this->db->get('tb_pelanggaran_santri')->result_array();
return [
"santri" => $santri,
"pelanggaran_santri" => $pelanggaran
];
}
return null;
}
public function get_data_by_nis($NIS)
{
// Ambil data santri dan wali
$this->db->select('
tb_santri.*,
tb_wali_santri.id_wali_santri,
tb_wali_santri.nama_wali_santri,
tb_wali_santri.alamat AS alamat_wali,
tb_wali_santri.no_telepon,
tb_wali_santri.pekerjaan,
tb_wali_santri.email AS email_wali,
tb_wali_santri.password AS password_wali
');
$this->db->from('tb_santri');
$this->db->join('tb_wali_santri', 'tb_wali_santri.id_santri = tb_santri.id_santri', 'left');
$this->db->where('tb_santri.NIS', $NIS);
$result = $this->db->get()->row();
if (!$result) {
return null;
}
$santri_data = [
'santri' => [
'id_santri' => $result->id_santri,
'NIS' => $result->NIS,
'nama_santri' => $result->nama_santri,
'kelas_diniyah' => $result->kelas_diniyah,
'status_santri' => $result->status_santri,
'kondisi_kesehatan' => $result->kondisi_kesehatan,
'alamat_santri' => $result->alamat_santri,
'tempat_lahir' => $result->tempat_lahir,
'tanggal_lahir' => $result->tanggal_lahir,
'tahun_masuk' => $result->tahun_masuk,
'tahun_keluar' => $result->tahun_keluar,
'keterangan_keluar' => $result->keterangan_keluar,
],
'wali_santri' => [
'id_wali_santri' => $result->id_wali_santri,
'nama_wali_santri' => $result->nama_wali_santri,
'alamat' => $result->alamat_wali,
'no_telepon' => $result->no_telepon,
'pekerjaan' => $result->pekerjaan,
'email' => $result->email_wali,
'password' => $result->password_wali
],
'prestasi_santri' => [],
'pelanggaran_santri' => [],
'informasi_spp_santri' => []
];
// Ambil prestasi
$this->db->select('*');
$this->db->from('tb_prestasi_santri');
$this->db->where('id_santri', $result->id_santri);
$prestasi = $this->db->get()->result();
foreach ($prestasi as $row) {
$santri_data['prestasi_santri'][] = [
'nama_santri' => $row->nama_santri,
'prestasi' => $row->prestasi,
'agenda' => $row->agenda,
'perlombaan' => $row->perlombaan,
'tanggal' => $row->tanggal,
'bukti_prestasi' => $row->bukti_prestasi,
];
}
// Ambil pelanggaran
$this->db->select('nama_santri, pelanggaran, tanggal, sanksi, keterangan AS keterangan_pelanggaran');
$this->db->from('tb_pelanggaran_santri');
$this->db->where('id_santri', $result->id_santri);
$pelanggaran = $this->db->get()->result();
foreach ($pelanggaran as $row) {
$santri_data['pelanggaran_santri'][] = [
'nama_santri' => $row->nama_santri,
'pelanggaran' => $row->pelanggaran,
'tanggal' => $row->tanggal,
'sanksi' => $row->sanksi,
'keterangan' => $row->keterangan_pelanggaran
];
}
// Ambil informasi spp
$this->db->select('nama_santri, bulan, tahun, jumlah_pembayaran, jatuh_tempo, keterangan AS keterangan_spp');
$this->db->from('tb_informasi_spp_santri');
$this->db->where('id_santri', $result->id_santri);
$spp_result = $this->db->get()->result();
foreach ($spp_result as $row) {
$santri_data['informasi_spp_santri'][] = [
'nama_santri' => $row->nama_santri,
'bulan' => $row->bulan,
'tahun' => $row->tahun,
'jumlah_pembayaran' => $row->jumlah_pembayaran,
'jatuh_tempo' => $row->jatuh_tempo,
'keterangan' => $row->keterangan_spp
];
}
return $santri_data;
}
public function get_data_by_email_wali($email)
{
// Ambil data santri dan wali
$this->db->select('
tb_santri.*,
tb_wali_santri.id_wali_santri,
tb_wali_santri.nama_wali_santri,
tb_wali_santri.alamat AS alamat_wali,
tb_wali_santri.no_telepon,
tb_wali_santri.pekerjaan,
tb_wali_santri.email AS email_wali,
tb_wali_santri.password AS password_wali
');
$this->db->from('tb_santri');
$this->db->join('tb_wali_santri', 'tb_wali_santri.id_santri = tb_santri.id_santri', 'left');
$this->db->where('tb_wali_santri.email', $email);
$result = $this->db->get()->row();
// echo $this->db->last_query();
if (!$result) {
return null;
}
$santri_data = [
'santri' => [
'id_santri' => $result->id_santri,
'NIS' => $result->NIS,
'nama_santri' => $result->nama_santri,
'kelas_diniyah' => $result->kelas_diniyah,
'status_santri' => $result->status_santri,
'kondisi_kesehatan' => $result->kondisi_kesehatan,
'alamat_santri' => $result->alamat_santri,
'tempat_lahir' => $result->tempat_lahir,
'tanggal_lahir' => $result->tanggal_lahir,
'tahun_masuk' => $result->tahun_masuk,
'tahun_keluar' => $result->tahun_keluar,
'keterangan_keluar' => $result->keterangan_keluar,
],
'wali_santri' => [
'id_wali_santri' => $result->id_wali_santri,
'nama_wali_santri' => $result->nama_wali_santri,
'alamat' => $result->alamat_wali,
'no_telepon' => $result->no_telepon,
'pekerjaan' => $result->pekerjaan,
'email' => $result->email_wali,
'password' => $result->password_wali
],
'prestasi_santri' => [],
'pelanggaran_santri' => [],
'informasi_spp_santri' => []
];
// Ambil prestasi
$this->db->select('*');
$this->db->from('tb_prestasi_santri');
$this->db->where('id_santri', $result->id_santri);
$prestasi = $this->db->get()->result();
foreach ($prestasi as $row) {
$santri_data['prestasi_santri'][] = [
'nama_santri' => $row->nama_santri,
'prestasi' => $row->prestasi,
'agenda' => $row->agenda,
'perlombaan' => $row->perlombaan,
'tanggal' => $row->tanggal,
'bukti_prestasi' => $row->bukti_prestasi,
];
}
// Ambil pelanggaran
$this->db->select('nama_santri, pelanggaran, tanggal, sanksi, keterangan AS keterangan_pelanggaran');
$this->db->from('tb_pelanggaran_santri');
$this->db->where('id_santri', $result->id_santri);
$pelanggaran = $this->db->get()->result();
foreach ($pelanggaran as $row) {
$santri_data['pelanggaran_santri'][] = [
'nama_santri' => $row->nama_santri,
'pelanggaran' => $row->pelanggaran,
'tanggal' => $row->tanggal,
'sanksi' => $row->sanksi,
'keterangan' => $row->keterangan_pelanggaran
];
}
// Ambil informasi spp
$this->db->select('nama_santri, bulan, tahun, jumlah_pembayaran, jatuh_tempo, keterangan AS keterangan_spp');
$this->db->from('tb_informasi_spp_santri');
$this->db->where('id_santri', $result->id_santri);
$spp_result = $this->db->get()->result();
foreach ($spp_result as $row) {
$santri_data['informasi_spp_santri'][] = [
'nama_santri' => $row->nama_santri,
'bulan' => $row->bulan,
'tahun' => $row->tahun,
'jumlah_pembayaran' => $row->jumlah_pembayaran,
'jatuh_tempo' => $row->jatuh_tempo,
'keterangan' => $row->keterangan_spp
];
}
return $santri_data;
}
public function delete($where, $table)
{
$this->db->where($where);
$this->db->delete($table);
}
}

View File

@ -0,0 +1,31 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class Sejarah_model extends CI_Model
{
public function get_data($table)
{
return $this->db->get($table);
}
public function get_sejarah()
{
$this->db->select('sejarah');
$this->db->from('tb_sejarah');
$query = $this->db->get();
return $query->result(); // Mengembalikan semua baris sejarah
}
public function update_data($data, $table)
{
$this->db->where('id_sejarah', $data['id_sejarah']);
$this->db->update($table, $data);
}
public function delete($where, $table)
{
$this->db->where($where);
$this->db->delete($table);
}
}

View File

@ -0,0 +1,51 @@
<?php
defined('BASEPATH') or exit('No direct script access allowed');
class wali_santri_model extends CI_Model
{
public function get_data($table)
{
return $this->db->get($table);
}
public function insert_data($data, $table)
{
$this->db->insert($table, $data);
}
public function get_santri_by_id($id_santri)
{
return $this->db->get_where('santri', array('id_santri' => $id_santri))->row();
}
// Di dalam wali_santri_model.php
public function get_data_by_id($id_wali_santri)
{
$this->db->where('id_wali_santri', $id_wali_santri);
return $this->db->get('tb_wali_santri')->row();
}
public function get_all_santri()
{
// Mengambil data dari tabel tb_wali_santri dan menggabungkannya dengan tb_santri
$this->db->select('tb_wali_santri.nama_wali_santri, tb_santri.nama_santri, tb_wali_santri.alamat, tb_wali_santri.no_telepon, tb_santri.id_santri');
$this->db->from('tb_wali_santri');
$this->db->join('tb_santri', 'tb_santri.id_santri = tb_wali_santri.id_santri');
return $this->db->get()->result(); // Mengembalikan hasil query
}
public function update_data($data, $table)
{
$this->db->where('id_wali_santri', $data['id_wali_santri']);
$this->db->update($table, $data);
}
public function check_wali_exists($id_santri)
{
$this->db->where('id_santri', $id_santri);
$query = $this->db->get('tb_wali_santri');
return $query->num_rows() > 0;
}
}

View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>

10
application/third_party/index.html vendored Normal file
View File

@ -0,0 +1,10 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>403 Forbidden</title>
</head>
<body>
<p>Directory access is forbidden.</p>
</body>

View File

@ -0,0 +1,25 @@
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Profil Admin</h3>
</div>
<div class="row">
<div class="col-lg-5">
<?= $this->session->flashdata('message'); ?>
</div>
</div>
<div class="card mb-3 col-lg-5 mt-4 ml-4 mb-4">
<div class="row no-gutters">
<div class="col-md-4">
<img src="<?= base_url('assets/img/profile/') . $admin['image']; ?>" style="width: 179px; height: 185px;">
</div>
<div class="col-md-8">
<div class="card-body">
<h5 class="card-title"><?= $admin['name'] ?></h5>
<p class="card-text"><?= $admin['email'] ?></p>
<p class="card-text"><small class="text-muted">Member since <?= date('d F Y', $admin['date_created']) ?></small></p>
</div>
</div>
</div>
</div>
</div>

View File

@ -0,0 +1,250 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Berita</h3>
<div class="ml-auto">
<a href="<?= base_url('Berita/tambah') ?>" class="btn btn-success btn-sm custom-button">
Tambah Berita
</a>
</div>
</div>
<!-- /.card-header -->
<div class="card-body">
<table id="tb_santri" class="table table-bordered table-striped">
<thead>
<tr class="text-center">
<th>Gambar</th>
<th>Judul Berita</th>
<th>Deskripsi Singkat</th>
<th>Tanggal</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
<?php
foreach ($berita as $bta) : ?>
<tr class="text-center">
<td><img src="<?= base_url('assets/img/berita/' . $bta->gambar) ?>" width="100"></td>
<td><?= $bta->judul ?></td>
<td><?= character_limiter($bta->deskripsi, 50) ?></td>
<td><?= date('d/m/Y H:i:s', strtotime($bta->tanggal)) ?></td>
<td>
<button data-toggle="modal" data-target="#edit<?= $bta->id_berita ?>" class="btn btn-warning btn-sm"><i class="fas fa-edit"></i></button>
<!-- <button data-toggle="modal" data-target="#view<?= $bta->id_berita ?>" class="btn btn-success btn-sm"><i class="fas fa-newspaper"></i></button> -->
<a href="<?= base_url('Berita/delete/' . $bta->id_berita) ?>" class="btn btn-danger btn-sm" onclick="return confirm('Apakah anda yakin menghapus data ini?')"><i class="fas fa-trash"></i></a>
</td>
</tr>
<?php endforeach ?>
</tbody>
</table>
</div>
</div>
<!-- Modal View -->
<?php foreach ($berita as $bta) { ?>
<div class="modal fade" id="view<?= $bta->id_berita ?>" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Detail Berita</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<form action="<?= base_url('Berita/view/') ?>" method="POST" enctype="multipart/form-data">
<input type="hidden" name="id_berita" value="<?= $bta->id_berita ?>" data-default="<?= $bta->id_berita ?>">
<div class="form-group">
<label>Gambar</label><br>
<!-- Tampilkan gambar lama -->
<img src="<?= base_url('assets/img/berita/' . $bta->gambar) ?>" width="150" class="mb-2" alt="Gambar Sebelumnya">
</div>
<div class="form-group">
<label>Judul Berita</label>
<textarea name="judul" class="form-control" readonly><?= $bta->judul ?></textarea>
<?= form_error('judul', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Deskripsi Singkat</label>
<textarea name="deskripsi" class="form-control" readonly><?= $bta->deskripsi ?></textarea>
<?= form_error('deskripsi', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tanggal</label>
<input type="datetime-local" name="tanggal" class="form-control" value="<?= $bta->tanggal ?>" readonly>
<?= form_error('tanggal', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</div>
</form>
</div>
</div>
</div>
</div>
<?php } ?>
<!-- Modal Edit -->
<?php foreach ($berita as $bta) { ?>
<div class="modal fade" id="edit<?= $bta->id_berita ?>" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Edit Berita</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<form action="<?= base_url('Berita/edit/' . $bta->id_berita) ?>" method="POST" enctype="multipart/form-data">
<input type="hidden" name="id_berita" value="<?= $bta->id_berita ?>" data-default="<?= $bta->id_berita ?>">
<div class="form-group">
<label>Gambar</label><br>
<!-- Tampilkan gambar lama -->
<img src="<?= base_url('assets/img/berita/' . $bta->gambar) ?>" width="150" class="mb-2" alt="Gambar Sebelumnya">
<!-- Input file untuk upload gambar baru -->
<input type="file" class="form-control" id="gambar" name="gambar">
</div>
<div class="form-group">
<label>Judul Berita</label>
<textarea name="judul" class="form-control"><?= $bta->judul ?></textarea>
<?= form_error('judul', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Deskripsi Singkat</label>
<textarea name="deskripsi" class="form-control"><?= $bta->deskripsi ?></textarea>
<?= form_error('deskripsi', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tanggal</label>
<input type="text" id="tanggal" name="tanggal" class="form-control"
value="<?= date('d/m/Y H:i:s', strtotime($bta->tanggal)) ?>">
<?= form_error('tanggal', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</div>
</form>
</div>
</div>
</div>
</div>
<?php } ?>
<script src="https://cdn.jsdelivr.net/npm/flatpickr"></script>
<script>
flatpickr("#tanggal", {
enableTime: true,
dateFormat: "d/m/Y H:i:S", // hasil: 2025/06/15 14:30
time_24hr: true,
enableSeconds: true
});
</script>
<style>
/* CSS untuk mengubah background dan border <th> dan <td> */
/* Ubah warna border tabel menjadi hijau */
table.table-bordered {
border: 2px solid green;
/* Border luar tabel */
}
/* Ubah warna background dan border header tabel */
table.table-bordered th {
background-color: #e0f7e0;
/* Hijau muda untuk header */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Ubah warna background dan border sel tabel */
table.table-bordered td {
background-color: #f0fff0;
/* Hijau sangat muda untuk sel */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
.form-control:not([size]):not([multiple]) {
background-image: none !important;
/* Menghilangkan panah bawaan Bootstrap */
}
.custom-button {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 6px 13px;
/* Sesuaikan padding agar proporsional */
}
.custom-btn {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 4px 10px;
/* Sesuaikan padding agar proporsional */
}
/* Override panah sorting ganda */
/* Hapus panah sorting bawaan template atau Bootstrap */
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
display: none !important;
}
</style>
<script>
$(document).ready(function() {
$('#tb_santri').DataTable({
"paging": true, // Enable pagination
"lengthChange": true, // Allow user to change number of rows shown
"searching": true, // Enable search
"ordering": true, // Enable column sorting
"info": true, // Show table info
"autoWidth": false, // Disable auto column width adjustment
});
});
document.addEventListener("DOMContentLoaded", function() {
document.querySelectorAll(".reset-btn").forEach(button => {
button.addEventListener("click", function() {
var id = this.getAttribute("data-id");
var form = document.getElementById("formEdit" + id);
if (form) {
form.reset(); // Reset semua input di form
// Handle input yang memiliki value dari PHP agar benar-benar kosong
form.querySelectorAll("input:not([readonly]), textarea").forEach(input => {
input.value = "";
});
// **Kembalikan nilai id_santri agar tidak kosong!**
var idKegiatanSantriInput = form.querySelector("input[name='id_kegiatan']");
if (idKegiatanSantriInput) {
idKegiatanSantriInput.value = idKegiatanSantriInput.getAttribute("data-default");
}
}
});
});
});
</script>

View File

@ -0,0 +1,46 @@
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Mengirim Pesan</h3>
</div>
<div class="row">
<div class="col-lg-6 mt-4 ml-4">
<div class="card-body">
<div class="chat-box" style="max-height: 400px; overflow-y: auto;">
<?php foreach ($chats as $chat): ?>
<div class="mb-3">
<strong>
<?= $chat->nama_wali ?> (<?= $chat->nama_santri ?>)
<?= $chat->sender == 'admin' ? '[Admin]' : '' ?>
</strong><br>
<span><?= $chat->message ?></span><br>
<small class="text-muted"><?= date('d M Y H:i', strtotime($chat->timestamp)) ?></small>
</div>
<?php endforeach; ?>
</div>
<!-- Form kirim pesan -->
<form action="<?= base_url('chat/send') ?>" method="post">
<input type="hidden" name="sender" value="admin">
<div class="form-group">
<label for="id_wali_santri">Pilih Wali Santri:</label>
<select name="id_wali_santri" class="form-control" required>
<?php
$wali_santri_list = $this->db->get('tb_wali_santri')->result();
foreach ($wali_santri_list as $wali):
?>
<option value="<?= $wali->id_wali_santri ?>"><?= $wali->nama_wali_santri ?></option>
<?php endforeach; ?>
</select>
</div>
<div class="form-group">
<label for="message">Pesan:</label>
<textarea name="message" class="form-control" rows="2" required></textarea>
</div>
<button type="submit" class="btn btn-primary">Kirim</button>
</form>
</div>
</div>
</div>
</div>

View File

@ -0,0 +1,51 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Mengirim dan Melihat Pesan</h3>
</div>
<div class="row no-gutters px-4 py-3">
<!-- Kolom kiri: Form Kirim Pesan -->
<div class="col-lg-6 d-flex flex-column pr-3">
<h5 class="mb-3">Pesan</h5>
<div>
<form id="formPesan" method="POST" action="<?= base_url('chat/sendChatFromAdmin') ?>">
<input type="hidden" name="id_wali_santri" value="<?= $id_wali_santri ?>">
<input type="hidden" name="sender" value="admin">
<div class="form-group">
<textarea name="message" class="form-control" rows="4" placeholder="Tulis pesan sebagai admin..." required></textarea>
</div>
</form>
</div>
<!-- Tombol Aksi -->
<div class="mt-3">
<a href="<?= base_url('walisantri') ?>" class="btn btn-danger btn-sm">
<i class="fas fa-solid fa-angle-left"></i> Kembali
</a>
<button type="submit" class="btn btn-primary btn-sm" form="formPesan">Kirim</button>
</div>
</div>
<!-- Kolom kanan: Riwayat Chat -->
<div class="col-lg-6 d-flex flex-column pl-3">
<h5 class="mb-3">Riwayat Pesan</h5>
<div class="card flex-fill">
<div class="card-body" style="background-color: #f8f9fa; max-height: 400px; overflow-y: auto;">
<?php if ($chat): ?>
<?php foreach ($chat as $c): ?>
<div class="mb-3 p-2 <?= ($c['sender'] === 'admin') ? 'bg-light border-left border-primary' : 'bg-white border-left border-success' ?>">
<strong><?= ($c['sender'] === 'admin') ? '🧑‍💼 Admin' : '👤 Wali' ?>:</strong>
<p class="mb-1"><?= htmlspecialchars($c['message']) ?></p>
<small class="text-muted"><?= date('d M Y H:i', strtotime($c['timestamp'])) ?></small>
</div>
<?php endforeach; ?>
<?php else: ?>
<p class="text-muted">Belum ada pesan.</p>
<?php endif; ?>
</div>
</div>
</div>
</div>
</div>

View File

@ -0,0 +1,63 @@
<!DOCTYPE html>
<html lang="en">
<head>
<title>Data Pelanggaran Santri</title>
<style>
table,
th,
td {
border: 1px solid black;
border-collapse: collapse;
}
th,
td {
padding: 6px;
}
</style>
</head>
<body>
<table>
<tr>
<th>No</th>
<th>NIS</th>
<th>Nama Santri</th>
<th>Kelas Diniyah</th>
<th>Pelanggaran</th>
<th>Tanggal</th>
<th>Sanksi</th>
<th>Keterangan</th>
</tr>
<?php $no = 1;
foreach ($pelanggaransantri as $pgnstr) :
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
]; ?>
<tr>
<td><?= $no++ ?></td>
<td><?= $pgnstr->NIS ?></td>
<td><?= $pgnstr->nama_santri ?></td>
<td><?= $kelas_diniyah[$pgnstr->kelas_diniyah] ?? 'Kelas Diniyah Tidak Valid' ?></td>
<td><?= $pgnstr->pelanggaran ?></td>
<td><?= date('d/m/Y', strtotime($pgnstr->tanggal)) ?></td>
<td><?= $pgnstr->sanksi ?></td>
<td><?= $pgnstr->keterangan ?></td>
</tr>
<?php endforeach ?>
</table>
</body>
</html>

View File

@ -0,0 +1,63 @@
<!DOCTYPE html>
<html lang="en">
<head>
<title>Data Prestasi Santri</title>
<style>
table,
th,
td {
border: 1px solid black;
border-collapse: collapse;
}
th,
td {
padding: 6px;
}
</style>
</head>
<body>
<table>
<tr>
<th>No</th>
<th>NIS</th>
<th>Nama Santri</th>
<th>Kelas Diniyah</th>
<th>Prestasi</th>
<th>Perlombaan</th>
<th>Agenda</th>
<th>Tanggal</th>
</tr>
<?php $no = 1;
foreach ($prestasisantri as $ptistr) :
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
]; ?>
<tr>
<td><?= $no++ ?></td>
<td><?= $ptistr->NIS ?></td>
<td><?= $ptistr->nama_santri ?></td>
<td><?= $kelas_diniyah[$ptistr->kelas_diniyah] ?? 'Kelas Diniyah Tidak Valid' ?></td>
<td><?= $ptistr->prestasi ?></td>
<td><?= $ptistr->perlombaan ?></td>
<td><?= $ptistr->agenda ?></td>
<td><?= date('d/m/Y', strtotime($ptistr->tanggal)) ?></td>
</tr>
<?php endforeach ?>
</table>
</body>
</html>

View File

@ -0,0 +1,156 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Informasi SPP Santri</h3>
<div class="ml-auto">
<a href="<?= base_url('santri') ?>" class="btn btn-danger btn-sm custom-button">
<i class="fas fa-solid fa-angle-left"></i> Kembali
</a>
</div>
</div>
<!-- /.card-header -->
<?php
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
$nama_bulan = [
1 => 'Januari',
2 => 'Februari',
3 => 'Maret',
4 => 'April',
5 => 'Mei',
6 => 'Juni',
7 => 'Juli',
8 => 'Agustus',
9 => 'September',
10 => 'Oktober',
11 => 'November',
12 => 'Desember'
];
?>
<div class="card-body">
<table id="tb_santri" class="table table-bordered table-striped">
<thead>
<tr class="text-center">
<th>No</th>
<th>NIS</th>
<th>Nama Santri</th>
<th>Kelas Diniyah</th>
<th>Bulan</th>
<th>Tahun</th>
<th>Jumlah Pembayaran</th>
<th>Jatuh Tempo</th>
<th>Keterangan</th>
</tr>
</thead>
<tbody>
<?php $no = 1;
foreach ($informasisppsantri as $sppstr) : ?>
<tr class="text-center">
<td><?= $no++ ?></td>
<td><?= $sppstr->NIS ?></td>
<td><?= $sppstr->nama_santri ?></td>
<td><?= $kelas_diniyah[$sppstr->kelas_diniyah] ?? 'Kelas Diniyah Tidak Valid' ?></td>
<td><?= $nama_bulan[$sppstr->bulan] ?? 'Bulan Tidak Valid' ?></td>
<td><?= $sppstr->tahun ?></td>
<td><?= $sppstr->jumlah_pembayaran ?></td>
<td><?= $sppstr->jatuh_tempo ?></td>
<td><?= $sppstr->keterangan ?></td>
</tr>
<?php endforeach ?>
</tbody>
</table>
</div>
</div>
<style>
/* CSS untuk mengubah background dan border <th> dan <td> */
/* Ubah warna border tabel menjadi hijau */
table.table-bordered {
border: 2px solid green;
/* Border luar tabel */
}
/* Ubah warna background dan border header tabel */
table.table-bordered th {
background-color: #e0f7e0;
/* Hijau muda untuk header */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Ubah warna background dan border sel tabel */
table.table-bordered td {
background-color: #f0fff0;
/* Hijau sangat muda untuk sel */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
.form-control:not([size]):not([multiple]) {
background-image: none !important;
/* Menghilangkan panah bawaan Bootstrap */
}
.custom-button {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 6px 13px;
/* Sesuaikan padding agar proporsional */
}
.custom-btn {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 4px 10px;
/* Sesuaikan padding agar proporsional */
}
/* Override panah sorting ganda */
/* Hapus panah sorting bawaan template atau Bootstrap */
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
display: none !important;
}
</style>
<script>
$(document).ready(function() {
$('#tb_santri').DataTable({
"paging": true, // Enable pagination
"lengthChange": true, // Allow user to change number of rows shown
"searching": true, // Enable search
"ordering": true, // Enable column sorting
"info": true, // Show table info
"autoWidth": false, // Disable auto column width adjustment
});
});
</script>

View File

@ -0,0 +1,140 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Pelanggaran Santri</h3>
<div class="ml-auto">
<a href="<?= base_url('santri') ?>" class="btn btn-danger btn-sm custom-button">
<i class="fas fa-solid fa-angle-left"></i> Kembali
</a>
</div>
</div>
<!-- /.card-header -->
<?php
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
?>
<div class="card-body">
<table id="tb_santri" class="table table-bordered table-striped">
<thead>
<tr class="text-center">
<th>No</th>
<th>NIS</th>
<th>Nama Santri</th>
<th>Kelas Diniyah</th>
<th>Pelanggaran</th>
<th>Tanggal</th>
<th>Sanksi</th>
<th>Keterangan</th>
</tr>
</thead>
<tbody>
<?php $no = 1;
foreach ($pelanggaransantri as $pgnstr) : ?>
<tr class="text-center">
<td><?= $no++ ?></td>
<td><?= $pgnstr->NIS ?></td>
<td><?= $pgnstr->nama_santri ?></td>
<td><?= $kelas_diniyah[$pgnstr->kelas_diniyah] ?? 'Kelas Diniyah Tidak Valid' ?></td>
<td><?= $pgnstr->pelanggaran ?></td>
<td><?= $pgnstr->tanggal ?></td>
<td><?= $pgnstr->sanksi ?></td>
<td><?= $pgnstr->keterangan ?></td>
</tr>
<?php endforeach ?>
</tbody>
</table>
</div>
</div>
<style>
/* CSS untuk mengubah background dan border <th> dan <td> */
/* Ubah warna border tabel menjadi hijau */
table.table-bordered {
border: 2px solid green;
/* Border luar tabel */
}
/* Ubah warna background dan border header tabel */
table.table-bordered th {
background-color: #e0f7e0;
/* Hijau muda untuk header */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Ubah warna background dan border sel tabel */
table.table-bordered td {
background-color: #f0fff0;
/* Hijau sangat muda untuk sel */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
.form-control:not([size]):not([multiple]) {
background-image: none !important;
/* Menghilangkan panah bawaan Bootstrap */
}
.custom-button {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 6px 13px;
/* Sesuaikan padding agar proporsional */
}
.custom-btn {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 4px 10px;
/* Sesuaikan padding agar proporsional */
}
/* Override panah sorting ganda */
/* Hapus panah sorting bawaan template atau Bootstrap */
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
display: none !important;
}
</style>
<script>
$(document).ready(function() {
$('#tb_santri').DataTable({
"paging": true, // Enable pagination
"lengthChange": true, // Allow user to change number of rows shown
"searching": true, // Enable search
"ordering": true, // Enable column sorting
"info": true, // Show table info
"autoWidth": false, // Disable auto column width adjustment
});
});
</script>

View File

@ -0,0 +1,141 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Prestasi Santri</h3>
<div class="ml-auto">
<a href="<?= base_url('santri') ?>" class="btn btn-danger btn-sm custom-button">
<i class="fas fa-solid fa-angle-left"></i> Kembali
</a>
</div>
</div>
<!-- /.card-header -->
<?php
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
?>
<div class="card-body">
<table id="tb_santri" class="table table-bordered table-striped">
<thead>
<tr class="text-center">
<th>No</th>
<th>NIS</th>
<th>Nama Santri</th>
<th>Kelas Diniyah</th>
<th>Prestasi</th>
<th>Perlombaan</th>
<th>Agenda</th>
<th>Tanggal</th>
</tr>
</thead>
<tbody>
<?php $no = 1;
foreach ($prestasisantri as $ptistr) : ?>
<tr class="text-center">
<td><?= $no++ ?></td>
<td><?= $ptistr->NIS ?></td>
<td><?= $ptistr->nama_santri ?></td>
<td><?= $kelas_diniyah[$ptistr->kelas_diniyah] ?? 'Kelas Diniyah Tidak Valid' ?></td>
<td><?= $ptistr->prestasi ?></td>
<td><?= $ptistr->perlombaan ?></td>
<td><?= $ptistr->agenda ?></td>
<td><?= $ptistr->tanggal ?></td>
</tr>
<?php endforeach ?>
</tbody>
</table>
</div>
</div>
<style>
/* CSS untuk mengubah background dan border <th> dan <td> */
/* Ubah warna border tabel menjadi hijau */
table.table-bordered {
border: 2px solid green;
/* Border luar tabel */
}
/* Ubah warna background dan border header tabel */
table.table-bordered th {
background-color: #e0f7e0;
/* Hijau muda untuk header */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Ubah warna background dan border sel tabel */
table.table-bordered td {
background-color: #f0fff0;
/* Hijau sangat muda untuk sel */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
.form-control:not([size]):not([multiple]) {
background-image: none !important;
/* Menghilangkan panah bawaan Bootstrap */
}
.custom-button {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 6px 13px;
/* Sesuaikan padding agar proporsional */
}
.custom-btn {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 4px 10px;
/* Sesuaikan padding agar proporsional */
}
/* Override panah sorting ganda */
/* Hapus panah sorting bawaan template atau Bootstrap */
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
display: none !important;
}
</style>
<script>
$(document).ready(function() {
$('#tb_santri').DataTable({
"paging": true, // Enable pagination
"lengthChange": true, // Allow user to change number of rows shown
"searching": true, // Enable search
"ordering": true, // Enable column sorting
"info": true, // Show table info
"autoWidth": false, // Disable auto column width adjustment
});
});
</script>

View File

@ -0,0 +1,52 @@
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Edit Profil Admin</h3>
</div>
<div class="row">
<div class="col-lg-8 mt-4 ml-4">
<?= form_open_multipart('admin/edit'); ?>
<div class="form-group row">
<label for="email" class="col-sm-2 col-form-label" style="font-weight: normal;">Email</label>
<div class="col-sm-10">
<input type="text" class="form-control" id="email" name="email" value="<?= $admin['email']; ?>" readonly>
</div>
</div>
<div class="form-group row">
<label for="email" class="col-sm-2 col-form-label" style="font-weight: normal;">Nama Lengkap</label>
<div class="col-sm-10">
<input type="text" class="form-control" id="name" name="name" value="<?= $admin['name']; ?>">
<?= form_error('name', '<small class="text-danger pl-3">', '</small>'); ?>
</div>
</div>
<div class="form-group row">
<div class="col-sm-2">Picture</div>
<div class="col-sm-10">
<div class="row">
<div class="col-sm-3">
<img src="<?= base_url('assets/img/profile/') . $admin['image']; ?>" class="img-thumbnail">
</div>
<div class="col-sm-9">
<div class="custom-file">
<input type="file" class="custom-file-input" id="image" name="image">
<label class="custom-file-label" for="image">Pilih gambar gif/jpg/png</label>
</div>
</div>
</div>
</div>
</div>
<div class="form-group row justify-content-end">
<div class="col-sm-10">
<button type="submit" class="btn btn-primary">Edit</button>
</div>
</div>
</form>
</div>
</div>
</div>
<script>
$(document).on('change', '.custom-file-input', function() {
let fileName = $(this).val().split("\\").pop(); // Ambil nama file
$(this).next('.custom-file-label').html(fileName); // Update label
});
</script>

View File

@ -0,0 +1,196 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Data SPP</h3>
<div class="ml-auto">
<a href="<?= base_url('InformasiSPP/tambah') ?>" class="btn btn-success btn-sm custom-button">
Tambah Waktu Pembayaran
</a>
</div>
</div>
<!-- /.card-header -->
<?php
$nama_bulan = [
1 => 'Januari',
2 => 'Februari',
3 => 'Maret',
4 => 'April',
5 => 'Mei',
6 => 'Juni',
7 => 'Juli',
8 => 'Agustus',
9 => 'September',
10 => 'Oktober',
11 => 'November',
12 => 'Desember'
];
?>
<div class="card-body">
<table id="tb_santri" class="table table-bordered table-striped">
<thead>
<tr class="text-center">
<th>Bulan</th>
<th>Tahun</th>
<th>Jumlah Pembayaran</th>
<th>Jatuh Tempo</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
<?php
foreach ($informasispp as $spp) : ?>
<tr class="text-center">
<td><?= $nama_bulan[$spp->bulan] ?? 'Bulan Tidak Valid' ?></td>
<td><?= $spp->tahun ?></td>
<td><?= $spp->jumlah_pembayaran ?></td>
<td><?= $spp->jatuh_tempo ?></td>
<td>
<button data-toggle="modal" data-target="#edit<?= $spp->id_spp ?>" class="btn btn-warning btn-sm"><i class="fas fa-edit"></i></button>
<a href="<?= base_url('InformasiSPP/delete/' . $spp->id_spp) ?>" class="btn btn-danger btn-sm" onclick="return confirm('Apakah anda yakin menghapus data ini?')"><i class="fas fa-trash"></i></a>
</td>
</tr>
<?php endforeach ?>
</tbody>
</table>
</div>
</div>
<!-- Modal Edit -->
<?php foreach ($informasispp as $spp) { ?>
<div class="modal fade" id="edit<?= $spp->id_spp ?>" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Edit Informasi SPP</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<form action="<?= base_url('InformasiSPP/edit/' . $spp->id_spp) ?>" method="POST">
<input type="hidden" name="id_spp" value="<?= $spp->id_spp ?>" data-default="<?= $spp->id_spp ?>">
<div class="form-group">
<label>Bulan</label>
<select class="custom-select" id="inputGroupSelect02" name="bulan">
<option value="">Pilih Bulan</option>
<option value="1" <?= ($spp->bulan == 1) ? 'selected' : '' ?>>Januari</option>
<option value="2" <?= ($spp->bulan == 2) ? 'selected' : '' ?>>Februari</option>
<option value="3" <?= ($spp->bulan == 3) ? 'selected' : '' ?>>Maret</option>
<option value="4" <?= ($spp->bulan == 4) ? 'selected' : '' ?>>April</option>
<option value="5" <?= ($spp->bulan == 5) ? 'selected' : '' ?>>Mei</option>
<option value="6" <?= ($spp->bulan == 6) ? 'selected' : '' ?>>Juni</option>
<option value="7" <?= ($spp->bulan == 7) ? 'selected' : '' ?>>Juli</option>
<option value="8" <?= ($spp->bulan == 8) ? 'selected' : '' ?>>Agustus</option>
<option value="9" <?= ($spp->bulan == 9) ? 'selected' : '' ?>>September</option>
<option value="10" <?= ($spp->bulan == 10) ? 'selected' : '' ?>>Oktober</option>
<option value="11" <?= ($spp->bulan == 11) ? 'selected' : '' ?>>November</option>
<option value="12" <?= ($spp->bulan == 12) ? 'selected' : '' ?>>Desember</option>
</select>
<?= form_error('bulan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tahun</label>
<input type="text" name="tahun" class="form-control" value="<?= $spp->tahun ?>">
<?= form_error('tahun', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Jumlah Pembayaran</label>
<input type="text" name="jumlah_pembayaran" class="form-control" value="<?= $spp->jumlah_pembayaran ?>">
<?= form_error('jumlah_pembayaran', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Jatuh Tempo</label>
<input type="date" name="jatuh_tempo" class="form-control" value="<?= $spp->jatuh_tempo ?>">
<?= form_error('jatuh_tempo', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</div>
</form>
</div>
</div>
</div>
</div>
<?php } ?>
<style>
/* CSS untuk mengubah background dan border <th> dan <td> */
/* Ubah warna border tabel menjadi hijau */
table.table-bordered {
border: 2px solid green;
/* Border luar tabel */
}
/* Ubah warna background dan border header tabel */
table.table-bordered th {
background-color: #e0f7e0;
/* Hijau muda untuk header */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Ubah warna background dan border sel tabel */
table.table-bordered td {
background-color: #f0fff0;
/* Hijau sangat muda untuk sel */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
.form-control:not([size]):not([multiple]) {
background-image: none !important;
/* Menghilangkan panah bawaan Bootstrap */
}
.custom-button {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 6px 13px;
/* Sesuaikan padding agar proporsional */
}
.custom-btn {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 4px 10px;
/* Sesuaikan padding agar proporsional */
}
/* Override panah sorting ganda */
/* Hapus panah sorting bawaan template atau Bootstrap */
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
display: none !important;
}
</style>
<script>
$(document).ready(function() {
$('#tb_informasispp').DataTable({
"paging": true, // Enable pagination
"lengthChange": true, // Allow user to change number of rows shown
"searching": true, // Enable search
"ordering": false, // Enable column sorting
"serverSide": true,
"info": true, // Show table info
"autoWidth": false, // Disable auto column width adjustment
});
});
</script>

View File

@ -0,0 +1,276 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Data SPP Santri</h3>
<div class="ml-auto">
<a href="<?= base_url('InformasiSPPSantri/tambah') ?>" class="btn btn-success btn-sm custom-button">
Tambah Data SPP Santri
</a>
</div>
</div>
<!-- /.card-header -->
<?php
$nama_bulan = [
1 => 'Januari',
2 => 'Februari',
3 => 'Maret',
4 => 'April',
5 => 'Mei',
6 => 'Juni',
7 => 'Juli',
8 => 'Agustus',
9 => 'September',
10 => 'Oktober',
11 => 'November',
12 => 'Desember'
];
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
?>
<div class="card-body">
<table id="tb_santri" class="table table-bordered table-striped">
<thead>
<tr class="text-center">
<th>No</th>
<th>NIS</th>
<th>Nama Santri</th>
<th>Kelas Diniah</th>
<th>Bulan</th>
<th>Tahun</th>
<th>Jumlah Pembayaran</th>
<th>Jatuh Tempo</th>
<th>Keterangan</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
<?php $no = 1;
foreach ($informasisppsantri as $sppstr) : ?>
<tr class="text-center">
<td><?= $no++ ?></td>
<td><?= $sppstr->NIS ?></td>
<td><?= $sppstr->nama_santri ?></td>
<td><?= $kelas_diniyah[$sppstr->kelas_diniyah] ?? 'Kelas Diniyah Tidak Valid' ?></td>
<td><?= $nama_bulan[$sppstr->bulan] ?? 'Bulan Tidak Valid' ?></td>
<td><?= $sppstr->tahun ?></td>
<td><?= $sppstr->jumlah_pembayaran ?></td>
<td><?= date('d/m/Y', strtotime($sppstr->jatuh_tempo)) ?></td>
<td><?= $sppstr->keterangan ?></td>
<td>
<button data-toggle="modal" data-target="#edit<?= $sppstr->id_spp_santri ?>" class="btn btn-warning btn-sm"><i class="fas fa-edit"></i></button>
<a href="<?= base_url('InformasiSPPSantri/delete/' . $sppstr->id_spp_santri) ?>" class="btn btn-danger btn-sm" onclick="return confirm('Apakah anda yakin menghapus data ini?')"><i class="fas fa-trash"></i></a>
</td>
</tr>
<?php endforeach ?>
</tbody>
</table>
</div>
</div>
<!-- Modal Edit -->
<?php foreach ($informasisppsantri as $sppstr) {
$list_kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
$kelas_terpilih = isset($sppstr->kelas_diniyah) ? $sppstr->kelas_diniyah : set_value('kelas_diniyah');
?>
<div class="modal fade" id="edit<?= $sppstr->id_spp_santri ?>" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Edit Informasi SPP Santri</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<form action="<?= base_url('InformasiSPPSantri/edit/' . $sppstr->id_spp_santri) ?>" method="POST">
<input type="hidden" name="id_spp_santri" value="<?= $sppstr->id_spp_santri ?>" data-default="<?= $sppstr->id_spp_santri ?>">
<input type="hidden" name="id_santri" value="<?= $sppstr->id_santri ?>">
<div class="form-group">
<label>NIS</label>
<input type="text" name="NIS" class="form-control" value="<?= $sppstr->NIS ?>">
<?= form_error('NIS', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Nama Santri</label>
<input type="text" name="nama_santri" class="form-control" value="<?= $sppstr->nama_santri ?>">
<?= form_error('nama_santri', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Kelas Diniyah</label>
<select class="custom-select" name="kelas_diniyah">
<option value="">Pilih Kelas Diniyah</option>
<?php foreach ($list_kelas_diniyah as $key => $label): ?>
<option value="<?= $key ?>" <?= ($kelas_terpilih == $key) ? 'selected' : '' ?>>
<?= $label ?>
</option>
<?php endforeach; ?>
</select>
<?= form_error('kelas_diniyah', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Bulan</label>
<select class="custom-select" id="inputGroupSelect02" name="bulan">
<option value="">Pilih Bulan</option>
<option value="1" <?= ($sppstr->bulan == 1) ? 'selected' : '' ?>>Januari</option>
<option value="2" <?= ($sppstr->bulan == 2) ? 'selected' : '' ?>>Februari</option>
<option value="3" <?= ($sppstr->bulan == 3) ? 'selected' : '' ?>>Maret</option>
<option value="4" <?= ($sppstr->bulan == 4) ? 'selected' : '' ?>>April</option>
<option value="5" <?= ($sppstr->bulan == 5) ? 'selected' : '' ?>>Mei</option>
<option value="6" <?= ($sppstr->bulan == 6) ? 'selected' : '' ?>>Juni</option>
<option value="7" <?= ($sppstr->bulan == 7) ? 'selected' : '' ?>>Juli</option>
<option value="8" <?= ($sppstr->bulan == 8) ? 'selected' : '' ?>>Agustus</option>
<option value="9" <?= ($sppstr->bulan == 9) ? 'selected' : '' ?>>September</option>
<option value="10" <?= ($sppstr->bulan == 10) ? 'selected' : '' ?>>Oktober</option>
<option value="11" <?= ($sppstr->bulan == 11) ? 'selected' : '' ?>>November</option>
<option value="12" <?= ($sppstr->bulan == 12) ? 'selected' : '' ?>>Desember</option>
</select>
<?= form_error('bulan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tahun</label>
<input type="text" name="tahun" class="form-control" value="<?= $sppstr->tahun ?>">
<?= form_error('tahun', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Jumlah Pembayaran</label>
<input type="text" name="jumlah_pembayaran" class="form-control" value="<?= $sppstr->jumlah_pembayaran ?>">
<?= form_error('jumlah_pembayaran', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Jatuh Tempo</label>
<input type="text" id="jatuh_tempo" name="jatuh_tempo" class="form-control"
value="<?= date('d/m/Y', strtotime($sppstr->jatuh_tempo)) ?>">
<?= form_error('jatuh_tempo', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Keterangan</label>
<select name="keterangan" class="form-control">
<option value="">-- Pilih Keterangan --</option>
<option value="Belum Lunas" <?= ($sppstr->keterangan == 'Belum Lunas') ? 'selected' : '' ?>>Belum Lunas</option>
<option value="Sudah Lunas" <?= ($sppstr->keterangan == 'Sudah Lunas') ? 'selected' : '' ?>>Sudah Lunas</option>
</select>
<?= form_error('keterangan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</div>
</form>
</div>
</div>
</div>
</div>
<?php } ?>
<script src="https://cdn.jsdelivr.net/npm/flatpickr"></script>
<script>
flatpickr("#jatuh_tempo", {
dateFormat: "d/m/Y" // yyyy/mm/dd
});
</script>
<style>
/* CSS untuk mengubah background dan border <th> dan <td> */
/* Ubah warna border tabel menjadi hijau */
table.table-bordered {
border: 2px solid green;
/* Border luar tabel */
}
/* Ubah warna background dan border header tabel */
table.table-bordered th {
background-color: #e0f7e0;
/* Hijau muda untuk header */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Ubah warna background dan border sel tabel */
table.table-bordered td {
background-color: #f0fff0;
/* Hijau sangat muda untuk sel */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
.form-control:not([size]):not([multiple]) {
background-image: none !important;
/* Menghilangkan panah bawaan Bootstrap */
}
.custom-button {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 6px 13px;
/* Sesuaikan padding agar proporsional */
}
.custom-btn {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 4px 10px;
/* Sesuaikan padding agar proporsional */
}
/* Override panah sorting ganda */
/* Hapus panah sorting bawaan template atau Bootstrap */
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
display: none !important;
}
</style>
<script>
$(document).ready(function() {
$('#tb_informasispp').DataTable({
"paging": true, // Enable pagination
"lengthChange": true, // Allow user to change number of rows shown
"searching": true, // Enable search
"ordering": false, // Enable column sorting
"serverSide": true,
"info": true, // Show table info
"autoWidth": false, // Disable auto column width adjustment
});
});
</script>

View File

@ -0,0 +1,158 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Kegiatan Santri</h3>
<div class="ml-auto">
<a href="<?= base_url('KegiatanSantri/tambah') ?>" class="btn btn-success btn-sm custom-button">
Tambah Kegiatan
</a>
</div>
</div>
<!-- /.card-header -->
<div class="card-body">
<table id="tb_santri" class="table table-bordered table-striped">
<thead>
<tr class="text-center">
<th>Hari</th>
<th>Nama Kegiatan</th>
<th>Waktu</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
<?php
foreach ($kegiatan as $kgn) : ?>
<tr class="text-center">
<td><?= $kgn->hari ?></td>
<td><?= $kgn->nama_kegiatan ?></td>
<td><?= $kgn->waktu ?></td>
<td>
<button data-toggle="modal" data-target="#edit<?= $kgn->id_kegiatan ?>" class="btn btn-warning btn-sm"><i class="fas fa-edit"></i></button>
<a href="<?= base_url('KegiatanSantri/delete/' . $kgn->id_kegiatan) ?>" class="btn btn-danger btn-sm" onclick="return confirm('Apakah anda yakin menghapus data ini?')"><i class="fas fa-trash"></i></a>
</td>
</tr>
<?php endforeach ?>
</tbody>
</table>
</div>
</div>
<!-- Modal Edit -->
<?php foreach ($kegiatan as $kgn) { ?>
<div class="modal fade" id="edit<?= $kgn->id_kegiatan ?>" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Edit Kegiatan Santri</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<form id="editKegiatanSantriForm<?= $kgn->id_kegiatan ?>" action="<?= base_url('KegiatanSantri/edit/' . $kgn->id_kegiatan) ?>" method="POST">
<input type="hidden" name="id_kegiatan" value="<?= $kgn->id_kegiatan ?>" data-default="<?= $kgn->id_kegiatan ?>">
<div class="form-group">
<label>Hari</label>
<input type="text" name="hari" class="form-control" value="<?= $kgn->hari ?>">
<?= form_error('hari', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Nama Kegiatan</label>
<input type="text" name="nama_kegiatan" class="form-control" value="<?= $kgn->nama_kegiatan ?>">
<?= form_error('nama_kegiatan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Waktu</label>
<input type="text" name="waktu" class="form-control" value="<?= $kgn->waktu ?>">
<?= form_error('waktu', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</div>
</form>
</div>
</div>
</div>
</div>
<?php } ?>
<style>
/* CSS untuk mengubah background dan border <th> dan <td> */
/* Ubah warna border tabel menjadi hijau */
table.table-bordered {
border: 2px solid green;
/* Border luar tabel */
}
/* Ubah warna background dan border header tabel */
table.table-bordered th {
background-color: #e0f7e0;
/* Hijau muda untuk header */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Ubah warna background dan border sel tabel */
table.table-bordered td {
background-color: #f0fff0;
/* Hijau sangat muda untuk sel */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
.form-control:not([size]):not([multiple]) {
background-image: none !important;
/* Menghilangkan panah bawaan Bootstrap */
}
.custom-button {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 6px 13px;
/* Sesuaikan padding agar proporsional */
}
.custom-btn {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 4px 10px;
/* Sesuaikan padding agar proporsional */
}
/* Override panah sorting ganda */
/* Hapus panah sorting bawaan template atau Bootstrap */
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
display: none !important;
}
</style>
<script>
$(document).ready(function() {
$('#tb_santri').DataTable({
"paging": true, // Enable pagination
"lengthChange": true, // Allow user to change number of rows shown
"searching": true, // Enable search
"ordering": false, // Enable column sorting
"info": true, // Show table info
"autoWidth": false, // Disable auto column width adjustment
});
});
</script>

View File

@ -0,0 +1,78 @@
<!DOCTYPE html>
<html lang="en">
<head>
<title>Laporan Santri</title>
<style>
table {
width: 100%;
border-collapse: collapse;
font-size: 12px;
/* kecilkan jika diperlukan */
}
th,
td {
border: 1px solid #000;
padding: 5px;
text-align: left;
word-wrap: break-word;
}
th {
background-color: #f2f2f2;
}
</style>
</head>
<body>
<?php
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
?>
<table>
<tr>
<th>No</th>
<th>NIS</th>
<th>Nama Santri</th>
<th>Kelas Diniah</th>
<th>Status Santri</th>
<th>Tahun Masuk</th>
<th>Tahun Keluar</th>
<th>Keterangan Keluar</th>
<th>Tempat Lahir</th>
<th>Tanggal Lahir</th>
<th>Alamat</th>
</tr>
<?php $no = 1;
foreach ($santri as $str) : ?>
<tr>
<td><?= $no++ ?> </td>
<td><?= $str->NIS ?> </td>
<td><?= $str->nama_santri ?></td>
<td><?= $kelas_diniyah[$str->kelas_diniyah] ?? 'Kelas Diniyah Tidak Valid' ?></td>
<td><?= $str->status_santri ?></td>
<td><?= $str->tahun_masuk ?></td>
<td><?= $str->tahun_keluar ?></td>
<td><?= $str->keterangan_keluar ?></td>
<td><?= $str->tempat_lahir ?></td>
<td><?= date('d/m/Y', strtotime($str->tanggal_lahir)) ?></td>
<td><?= $str->alamat_santri ?></td>
</tr>
<?php endforeach ?>
</table>
</body>
</html>

View File

@ -0,0 +1,151 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Kategori Pelanggaran</h3>
<div class="ml-auto">
<a href="<?= base_url('Pelanggaran/tambah') ?>" class="btn btn-success btn-sm custom-button">
Tambah Kategori Pelanggaran
</a>
</div>
</div>
<!-- /.card-header -->
<div class="card-body">
<table id="tb_santri" class="table table-bordered table-striped">
<thead>
<tr class="text-center">
<th>Kategori Pelanggaran</th>
<th>Sanksi</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
<?php
foreach ($pelanggaran as $pgn) : ?>
<tr class="text-center">
<td><?= $pgn->pelanggaran ?></td>
<td><?= $pgn->sanksi ?></td>
<td>
<button data-toggle="modal" data-target="#edit<?= $pgn->id_pelanggaran ?>" class="btn btn-warning btn-sm"><i class="fas fa-edit"></i></button>
<a href="<?= base_url('Pelanggaran/delete/' . $pgn->id_pelanggaran) ?>" class="btn btn-danger btn-sm" onclick="return confirm('Apakah anda yakin menghapus data ini?')"><i class="fas fa-trash"></i></a>
</td>
</tr>
<?php endforeach ?>
</tbody>
</table>
</div>
</div>
<!-- Modal Edit -->
<?php foreach ($pelanggaran as $pgn) { ?>
<div class="modal fade" id="edit<?= $pgn->id_pelanggaran ?>" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Edit Pelanggaran Santri</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<form action="<?= base_url('Pelanggaran/edit/' . $pgn->id_pelanggaran) ?>" method="POST">
<input type="hidden" name="id_pelanggaran" value="<?= $pgn->id_pelanggaran ?>" data-default="<?= $pgn->id_pelanggaran ?>">
<div class="form-group">
<label>Pelanggaran</label>
<input type="text" name="pelanggaran" class="form-control" value="<?= $pgn->pelanggaran ?>">
<?= form_error('Pelanggaran', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Sanksi</label>
<input type="text" name="sanksi" class="form-control" value="<?= $pgn->sanksi ?>">
<?= form_error('Sanksi', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</div>
</form>
</div>
</div>
</div>
</div>
<?php } ?>
<style>
/* CSS untuk mengubah background dan border <th> dan <td> */
/* Ubah warna border tabel menjadi hijau */
table.table-bordered {
border: 2px solid green;
/* Border luar tabel */
}
/* Ubah warna background dan border header tabel */
table.table-bordered th {
background-color: #e0f7e0;
/* Hijau muda untuk header */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Ubah warna background dan border sel tabel */
table.table-bordered td {
background-color: #f0fff0;
/* Hijau sangat muda untuk sel */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
.form-control:not([size]):not([multiple]) {
background-image: none !important;
/* Menghilangkan panah bawaan Bootstrap */
}
.custom-button {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 6px 13px;
/* Sesuaikan padding agar proporsional */
}
.custom-btn {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 4px 10px;
/* Sesuaikan padding agar proporsional */
}
/* Override panah sorting ganda */
/* Hapus panah sorting bawaan template atau Bootstrap */
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
display: none !important;
}
</style>
<script>
$(document).ready(function() {
$('#tb_santri').DataTable({
"paging": true, // Enable pagination
"lengthChange": true, // Allow user to change number of rows shown
"searching": true, // Enable search
"ordering": true, // Enable column sorting
"info": true, // Show table info
"autoWidth": false, // Disable auto column width adjustment
});
});
</script>

View File

@ -0,0 +1,326 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Pelanggaran Santri</h3>
<div class="ml-auto">
<a href="<?= base_url('PelanggaranSantri/tambah') ?>" class="btn btn-success btn-sm custom-button">
Tambah Pelanggaran Santri
</a>
<button class="btn btn-info btn-sm custom-button" data-toggle="modal" data-target="#modalFilterPrintPelanggaran">
<i class="fas fa-print"></i> Print
</button>
<button class="btn btn-success btn-sm custom-button" data-toggle="modal" data-target="#modalFilterPdfPelanggaran">
<i class="fas fa-file"></i> Cetak PDF
</button>
<a href="<?= base_url('PelanggaranSantri/rekap_pdf') ?>" class="btn btn-info btn-sm custom-button">
Rekap Pelanggaran
</a>
</div>
</div>
<!-- /.card-header -->
<?php
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
?>
<div class="card-body">
<table id="tb_santri" class="table table-bordered table-striped">
<thead>
<tr class="text-center">
<th>No</th>
<th>NIS</th>
<th>Nama Santri</th>
<th>Kelas Diniah</th>
<th>Kategori Pelanggaran</th>
<th>Tanggal</th>
<th>Sanksi</th>
<th>Keterangan</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
<?php $no = 1;
foreach ($pelanggaransantri as $pgnstr) : ?>
<tr class="text-center">
<td><?= $no++ ?></td>
<td><?= $pgnstr->NIS ?></td>
<td><?= $pgnstr->nama_santri ?></td>
<td><?= $kelas_diniyah[$pgnstr->kelas_diniyah] ?? 'Kelas Diniyah Tidak Valid' ?></td>
<td><?= $pgnstr->pelanggaran ?></td>
<td><?= date('d/m/Y', strtotime($pgnstr->tanggal)) ?></td>
<td><?= $pgnstr->sanksi ?></td>
<td><?= $pgnstr->keterangan ?></td>
<td>
<button data-toggle="modal" data-target="#edit<?= $pgnstr->id_pelanggaran_santri ?>" class="btn btn-warning btn-sm"><i class="fas fa-edit"></i></button>
<a href="<?= base_url('PelanggaranSantri/delete/' . $pgnstr->id_pelanggaran_santri) ?>" class="btn btn-danger btn-sm" onclick="return confirm('Apakah anda yakin menghapus data ini?')"><i class="fas fa-trash"></i></a>
</td>
</tr>
<?php endforeach ?>
</tbody>
</table>
</div>
</div>
<!-- Modal Filter Print Pelanggaran -->
<div class="modal fade" id="modalFilterPrintPelanggaran" tabindex="-1" role="dialog" aria-labelledby="modalLabel" aria-hidden="true">
<div class="modal-dialog" role="document">
<form method="GET" action="<?= base_url('PelanggaranSantri/print') ?>" target="_blank">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="modalLabel">Filter Tanggal Pelanggaran</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Tutup">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<div class="form-group">
<label for="start_date">Dari Tanggal</label>
<input type="text" id="start_date" name="start_date" class="form-control" placeholder="dd/mm/yyyy" required>
</div>
<div class="form-group">
<label for="end_date">Sampai Tanggal</label>
<input type="text" id="end_date" name="end_date" class="form-control" placeholder="dd/mm/yyyy" required>
</div>
</div>
<div class="modal-footer">
<!-- Tombol print semua data tanpa filter -->
<a href="<?= base_url('PelanggaranSantri/print') ?>" target="_blank" class="btn btn-primary">
Print Semua
</a>
<!-- Tombol filter print berdasarkan tanggal -->
<button type="submit" class="btn btn-info">Print Sesuai Filter</button>
<button type="button" class="btn btn-secondary" data-dismiss="modal">Batal</button>
</div>
</div>
</form>
</div>
</div>
<!-- Modal Filter Pdf Pelanggaran -->
<div class="modal fade" id="modalFilterPdfPelanggaran" tabindex="-1" role="dialog" aria-labelledby="modalLabel" aria-hidden="true">
<div class="modal-dialog" role="document">
<form method="GET" action="<?= base_url('PelanggaranSantri/pdf') ?>" target="_blank">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="modalLabel">Filter Tanggal Pelanggaran</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Tutup">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<div class="form-group">
<label for="start_date">Dari Tanggal</label>
<input type="text" id="start_date" name="start_date" class="form-control" placeholder="dd/mm/yyyy" required>
</div>
<div class="form-group">
<label for="end_date">Sampai Tanggal</label>
<input type="text" id="end_date" name="end_date" class="form-control" placeholder="dd/mm/yyyy" required>
</div>
</div>
<div class="modal-footer">
<!-- Tombol print semua data tanpa filter -->
<a href="<?= base_url('PelanggaranSantri/pdf') ?>" target="_blank" class="btn btn-primary">
Cetak PDF Semua
</a>
<!-- Tombol filter print berdasarkan tanggal -->
<button type="submit" class="btn btn-info">Cetak PDF Sesuai Filter</button>
<button type="button" class="btn btn-secondary" data-dismiss="modal">Batal</button>
</div>
</div>
</form>
</div>
</div>
<!-- Modal Edit -->
<?php foreach ($pelanggaransantri as $pgnstr) {
$list_kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
$kelas_terpilih = isset($pgnstr->kelas_diniyah) ? $pgnstr->kelas_diniyah : set_value('kelas_diniyah');
?>
<div class="modal fade" id="edit<?= $pgnstr->id_pelanggaran_santri ?>" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Edit Pelanggaran Santri</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<form id="editPelanggaranSantriForm<?= $pgnstr->id_pelanggaran_santri ?>" action="<?= base_url('PelanggaranSantri/edit/' . $pgnstr->id_pelanggaran_santri) ?>" method="POST">
<input type="hidden" name="id_kegiatan" value="<?= $pgnstr->id_pelanggaran_santri ?>" data-default="<?= $pgnstr->id_pelanggaran_santri ?>">
<input type="hidden" name="id_santri" value="<?= $pgnstr->id_santri ?>"> <!-- ini penting -->
<div class="form-group">
<label>NIS</label>
<input type="text" name="NIS" class="form-control" value="<?= $pgnstr->NIS ?>">
<?= form_error('NIS', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Nama Santri</label>
<input type="text" name="nama_santri" class="form-control" value="<?= $pgnstr->nama_santri ?>">
<?= form_error('nama_santri', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Kelas Diniyah</label>
<select class="custom-select" name="kelas_diniyah">
<option value="">Pilih Kelas Diniah</option>
<?php foreach ($list_kelas_diniyah as $key => $label): ?>
<option value="<?= $key ?>" <?= ($kelas_terpilih == $key) ? 'selected' : '' ?>>
<?= $label ?>
</option>
<?php endforeach; ?>
</select>
<?= form_error('kelas_diniyah', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Pelanggaran</label>
<input type="text" name="pelanggaran" class="form-control" value="<?= $pgnstr->pelanggaran ?>">
<?= form_error('pelanggaran', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tanggal</label>
<input type="text" id="tanggal" name="tanggal" class="form-control"
value="<?= date('d/m/Y', strtotime($pgnstr->tanggal)) ?>">
<?= form_error('tanggal', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Sanksi</label>
<input type="text" name="sanksi" class="form-control" value="<?= $pgnstr->sanksi ?>">
<?= form_error('sanksi', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Keterangan</label>
<select name="keterangan" class="form-control">
<option value="">-- Pilih Keterangan --</option>
<option value="Belum Disanksi" <?= ($pgnstr->keterangan == 'Belum Disanksi') ? 'selected' : '' ?>>Belum Disanksi</option>
<option value="Sudah Disanksi" <?= ($pgnstr->keterangan == 'Sudah Disanksi') ? 'selected' : '' ?>>Sudah Disanksi</option>
</select>
<?= form_error('keterangan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</div>
</form>
</div>
</div>
</div>
</div>
<?php } ?>
<script src="https://cdn.jsdelivr.net/npm/flatpickr"></script>
<script>
flatpickr("#tanggal", {
dateFormat: "d/m/Y" // Menampilkan dalam format dd/mm/yyyy
});
flatpickr("#start_date", {
dateFormat: "d/m/Y" // Menampilkan dalam format dd/mm/yyyy
});
flatpickr("#end_date", {
dateFormat: "d/m/Y" // Menampilkan dalam format dd/mm/yyyy
});
</script>
<style>
/* CSS untuk mengubah background dan border <th> dan <td> */
/* Ubah warna border tabel menjadi hijau */
table.table-bordered {
border: 2px solid green;
/* Border luar tabel */
}
/* Ubah warna background dan border header tabel */
table.table-bordered th {
background-color: #e0f7e0;
/* Hijau muda untuk header */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Ubah warna background dan border sel tabel */
table.table-bordered td {
background-color: #f0fff0;
/* Hijau sangat muda untuk sel */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
.form-control:not([size]):not([multiple]) {
background-image: none !important;
/* Menghilangkan panah bawaan Bootstrap */
}
.custom-button {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 6px 13px;
/* Sesuaikan padding agar proporsional */
}
.custom-btn {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 4px 10px;
/* Sesuaikan padding agar proporsional */
}
/* Override panah sorting ganda */
/* Hapus panah sorting bawaan template atau Bootstrap */
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
display: none !important;
}
</style>
<script>
$(document).ready(function() {
$('#tb_santri').DataTable({
"paging": true, // Enable pagination
"lengthChange": true, // Allow user to change number of rows shown
"searching": true, // Enable search
"ordering": true, // Enable column sorting
"info": true, // Show table info
"autoWidth": false, // Disable auto column width adjustment
});
});
</script>

View File

@ -0,0 +1,158 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Perlombaan Santri</h3>
<div class="ml-auto">
<a href="<?= base_url('perlombaan/tambah') ?>" class="btn btn-success btn-sm custom-button">
Tambah Perlombaan
</a>
</div>
</div>
<!-- /.card-header -->
<div class="card-body">
<table id="tb_santri" class="table table-bordered table-striped">
<thead>
<tr class="text-center">
<th>Agenda</th>
<th>Perlombaan</th>
<th>Tanggal</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
<?php
foreach ($perlombaan as $plb) : ?>
<tr class="text-center">
<td><?= $plb->agenda ?></td>
<td><?= $plb->perlombaan ?></td>
<td><?= $plb->tanggal ?></td>
<td>
<button data-toggle="modal" data-target="#edit<?= $plb->id_perlombaan ?>" class="btn btn-warning btn-sm"><i class="fas fa-edit"></i></button>
<a href="<?= base_url('perlombaan/delete/' . $plb->id_perlombaan) ?>" class="btn btn-danger btn-sm" onclick="return confirm('Apakah anda yakin menghapus data ini?')"><i class="fas fa-trash"></i></a>
</td>
</tr>
<?php endforeach ?>
</tbody>
</table>
</div>
</div>
<!-- Modal Edit -->
<?php foreach ($perlombaan as $plb) { ?>
<div class="modal fade" id="edit<?= $plb->id_perlombaan ?>" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Edit Perlombaan Santri</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<form action="<?= base_url('Perlombaan/edit/' . $plb->id_perlombaan) ?>" method="POST">
<input type="hidden" name="id_kegiatan" value="<?= $plb->id_perlombaan ?>" data-default="<?= $plb->id_perlombaan ?>">
<div class="form-group">
<label>Agenda</label>
<input type="text" name="agenda" class="form-control" value="<?= $plb->agenda ?>">
<?= form_error('Agenda', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Perlombaan</label>
<input type="text" name="perlombaan" class="form-control" value="<?= $plb->perlombaan ?>">
<?= form_error('Perlombaan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tanggal</label>
<input type="date" name="tanggal" class="form-control" value="<?= $plb->tanggal ?>">
<?= form_error('Tanggal', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</div>
</form>
</div>
</div>
</div>
</div>
<?php } ?>
<style>
/* CSS untuk mengubah background dan border <th> dan <td> */
/* Ubah warna border tabel menjadi hijau */
table.table-bordered {
border: 2px solid green;
/* Border luar tabel */
}
/* Ubah warna background dan border header tabel */
table.table-bordered th {
background-color: #e0f7e0;
/* Hijau muda untuk header */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Ubah warna background dan border sel tabel */
table.table-bordered td {
background-color: #f0fff0;
/* Hijau sangat muda untuk sel */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
.form-control:not([size]):not([multiple]) {
background-image: none !important;
/* Menghilangkan panah bawaan Bootstrap */
}
.custom-button {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 6px 13px;
/* Sesuaikan padding agar proporsional */
}
.custom-btn {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 4px 10px;
/* Sesuaikan padding agar proporsional */
}
/* Override panah sorting ganda */
/* Hapus panah sorting bawaan template atau Bootstrap */
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
display: none !important;
}
</style>
<script>
$(document).ready(function() {
$('#tb_santri').DataTable({
"paging": true, // Enable pagination
"lengthChange": true, // Allow user to change number of rows shown
"searching": true, // Enable search
"ordering": true, // Enable column sorting
"info": true, // Show table info
"autoWidth": false, // Disable auto column width adjustment
});
});
</script>

View File

@ -0,0 +1,331 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Prestasi Santri</h3>
<div class="ml-auto">
<a href="<?= base_url('PrestasiSantri/tambah') ?>" class="btn btn-success btn-sm custom-button">
Tambah Prestasi
</a>
<button class="btn btn-info btn-sm custom-button" data-toggle="modal" data-target="#modalFilterPrintPerlombaan">
<i class="fas fa-print"></i> Print
</button>
<button class="btn btn-success btn-sm custom-button" data-toggle="modal" data-target="#modalFilterPdfPerlombaan">
<i class="fas fa-print"></i> Cetak PDF
</button>
</div>
</div>
<!-- /.card-header -->
<?php
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
?>
<div class="card-body">
<table id="tb_santri" class="table table-bordered table-striped">
<thead>
<tr class="text-center">
<th>No</th>
<th>NIS</th>
<th>Nama Santri</th>
<th>Kelas Diniah</th>
<th>Prestasi</th>
<th>Perlombaan</th>
<th>Agenda</th>
<th>Tanggal</th>
<th>Bukti Prestasi</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
<?php $no = 1;
foreach ($prestasisantri as $ptistr) : ?>
<tr class="text-center">
<td><?= $no++ ?></td>
<td><?= $ptistr->NIS ?></td>
<td><?= $ptistr->nama_santri ?></td>
<td><?= $kelas_diniyah[$ptistr->kelas_diniyah] ?? 'Kelas Diniyah Tidak Valid' ?></td>
<td><?= $ptistr->prestasi ?></td>
<td><?= $ptistr->perlombaan ?></td>
<td><?= $ptistr->agenda ?></td>
<td><?= date('d/m/Y', strtotime($ptistr->tanggal)) ?></td>
<td>
<?php if (!empty($ptistr->bukti_prestasi)): ?>
<a href="<?= $ptistr->bukti_prestasi ?>" target="_blank" class="btn btn-primary btn-sm">Lihat File</a>
<?php else: ?>
<span class="text-muted">Tidak Ada File</span>
<?php endif; ?>
</td>
<td>
<button data-toggle="modal" data-target="#edit<?= $ptistr->id_prestasi_santri ?>" class="btn btn-warning btn-sm"><i class="fas fa-edit"></i></button>
<a href="<?= base_url('PrestasiSantri/delete/' . $ptistr->id_prestasi_santri) ?>" class="btn btn-danger btn-sm" onclick="return confirm('Apakah anda yakin menghapus data ini?')"><i class="fas fa-trash"></i></a>
</td>
</tr>
<?php endforeach ?>
</tbody>
</table>
</div>
</div>
<!-- Modal Filter Print Prestasi Santri -->
<div class="modal fade" id="modalFilterPrintPerlombaan" tabindex="-1" role="dialog" aria-labelledby="modalLabel" aria-hidden="true">
<div class="modal-dialog" role="document">
<form method="GET" action="<?= base_url('PrestasiSantri/print') ?>" target="_blank">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="modalLabel">Filter Tanggal Perlombaan</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Tutup">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<div class="form-group">
<label for="start_date">Dari Tanggal</label>
<input type="text" id="start_date" name="start_date" class="form-control" placeholder="dd/mm/yyyy" required>
</div>
<div class="form-group">
<label for="end_date">Sampai Tanggal</label>
<input type="text" id="end_date" name="end_date" class="form-control" placeholder="dd/mm/yyyy" required>
</div>
</div>
<div class="modal-footer">
<!-- Tombol print semua data tanpa filter -->
<a href="<?= base_url('PrestasiSantri/print') ?>" target="_blank" class="btn btn-primary">
Print Semua
</a>
<!-- Tombol filter print berdasarkan tanggal -->
<button type="submit" class="btn btn-info">Print Sesuai Filter</button>
<button type="button" class="btn btn-secondary" data-dismiss="modal">Batal</button>
</div>
</div>
</form>
</div>
</div>
<!-- Modal Filter Pdf Prestasi -->
<div class="modal fade" id="modalFilterPdfPerlombaan" tabindex="-1" role="dialog" aria-labelledby="modalLabel" aria-hidden="true">
<div class="modal-dialog" role="document">
<form method="GET" action="<?= base_url('PrestasiSantri/pdf') ?>" target="_blank">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="modalLabel">Filter Tanggal Perlombaan</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Tutup">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<div class="form-group">
<label for="start_date">Dari Tanggal</label>
<input type="text" id="start_date" name="start_date" class="form-control" placeholder="dd/mm/yyyy" required>
</div>
<div class="form-group">
<label for="end_date">Sampai Tanggal</label>
<input type="text" id="end_date" name="end_date" class="form-control" placeholder="dd/mm/yyyy" required>
</div>
</div>
<div class="modal-footer">
<!-- Tombol print semua data tanpa filter -->
<a href="<?= base_url('PrestasiSantri/pdf') ?>" target="_blank" class="btn btn-primary">
Cetak PDF Semua
</a>
<!-- Tombol filter print berdasarkan tanggal -->
<button type="submit" class="btn btn-info">Cetak PDF Sesuai Filter</button>
<button type="button" class="btn btn-secondary" data-dismiss="modal">Batal</button>
</div>
</div>
</form>
</div>
</div>
<!-- Modal Edit -->
<?php foreach ($prestasisantri as $ptistr) {
$list_kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
$kelas_terpilih = isset($ptistr->kelas_diniyah) ? $ptistr->kelas_diniyah : set_value('kelas_diniyah');
?>
<div class="modal fade" id="edit<?= $ptistr->id_prestasi_santri ?>" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Edit Prestasi Santri</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<form id="editPrestasiSantriForm<?= $ptistr->id_prestasi_santri ?>" action="<?= base_url('PrestasiSantri/edit/' . $ptistr->id_prestasi_santri) ?>" method="POST">
<input type="hidden" name="id_kegiatan" value="<?= $ptistr->id_prestasi_santri ?>" data-default="<?= $ptistr->id_prestasi_santri ?>">
<div class="form-group">
<label>NIS</label>
<input type="text" name="NIS" class="form-control" value="<?= $ptistr->NIS ?>">
<?= form_error('NIS', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Nama Santri</label>
<input type="text" name="nama_santri" class="form-control" value="<?= $ptistr->nama_santri ?>">
<?= form_error('nama_santri', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Kelas Diniyah</label>
<select class="custom-select" name="kelas_diniyah">
<option value="">Pilih Kelas Diniah</option>
<?php foreach ($list_kelas_diniyah as $key => $label): ?>
<option value="<?= $key ?>" <?= ($kelas_terpilih == $key) ? 'selected' : '' ?>>
<?= $label ?>
</option>
<?php endforeach; ?>
</select>
<?= form_error('kelas_diniyah', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Prestasi</label>
<input type="text" name="prestasi" class="form-control" value="<?= $ptistr->prestasi ?>">
<?= form_error('prestasi', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Perlombaan</label>
<input type="text" name="perlombaan" class="form-control" value="<?= $ptistr->perlombaan ?>">
<?= form_error('Perlombaan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Agenda</label>
<input type="text" name="agenda" class="form-control" value="<?= $ptistr->agenda ?>">
<?= form_error('Agenda', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tanggal</label>
<input type="text" id="tanggal" name="tanggal" class="form-control"
value="<?= date('d/m/Y', strtotime($ptistr->tanggal)) ?>">
<?= form_error('Tanggal', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Bukti Prestasi</label>
<input type="text" name="bukti_prestasi" class="form-control" value="<?= $ptistr->bukti_prestasi ?>">
<?= form_error('bukti_prestasi', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</div>
</form>
</div>
</div>
</div>
</div>
<?php } ?>
<script src="https://cdn.jsdelivr.net/npm/flatpickr"></script>
<script>
flatpickr("#tanggal", {
dateFormat: "d/m/Y" // Menampilkan dalam format dd/mm/yyyy
});
flatpickr("#start_date", {
dateFormat: "d/m/Y" // Menampilkan dalam format dd/mm/yyyy
});
flatpickr("#end_date", {
dateFormat: "d/m/Y" // Menampilkan dalam format dd/mm/yyyy
});
</script>
<style>
/* CSS untuk mengubah background dan border <th> dan <td> */
/* Ubah warna border tabel menjadi hijau */
table.table-bordered {
border: 2px solid green;
/* Border luar tabel */
}
/* Ubah warna background dan border header tabel */
table.table-bordered th {
background-color: #e0f7e0;
/* Hijau muda untuk header */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Ubah warna background dan border sel tabel */
table.table-bordered td {
background-color: #f0fff0;
/* Hijau sangat muda untuk sel */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
.form-control:not([size]):not([multiple]) {
background-image: none !important;
/* Menghilangkan panah bawaan Bootstrap */
}
.custom-button {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 6px 13px;
/* Sesuaikan padding agar proporsional */
}
.custom-btn {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 4px 10px;
/* Sesuaikan padding agar proporsional */
}
/* Override panah sorting ganda */
/* Hapus panah sorting bawaan template atau Bootstrap */
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
display: none !important;
}
</style>
<script>
$(document).ready(function() {
$('#tb_santri').DataTable({
"paging": true, // Enable pagination
"lengthChange": true, // Allow user to change number of rows shown
"searching": true, // Enable search
"ordering": true, // Enable column sorting
"info": true, // Show table info
"autoWidth": false, // Disable auto column width adjustment
});
});
</script>

View File

@ -0,0 +1,69 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Print Pelanggaran Santri</title>
<style>
table,
th,
td {
border: 1px solid black;
border-collapse: collapse;
}
th,
td {
padding: 6px;
}
</style>
</head>
<body>
<table>
<tr>
<th>No</th>
<th>NIS</th>
<th>Nama Santri</th>
<th>Kelas Diniyah</th>
<th>Pelanggaran</th>
<th>Tanggal</th>
<th>Sanksi</th>
<th>Keterangan</th>
</tr>
<?php $no = 1;
foreach ($pelanggaransantri as $pgnstr) :
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
]; ?>
<tr>
<td><?= $no++ ?></td>
<td><?= $pgnstr->NIS ?></td>
<td><?= $pgnstr->nama_santri ?></td>
<td><?= $kelas_diniyah[$pgnstr->kelas_diniyah] ?? 'Kelas Diniyah Tidak Valid' ?></td>
<td><?= $pgnstr->pelanggaran ?></td>
<td><?= date('d/m/Y', strtotime($pgnstr->tanggal)) ?></td>
<td><?= $pgnstr->sanksi ?></td>
<td><?= $pgnstr->keterangan ?></td>
</tr>
<?php endforeach ?>
</table>
<script type="text/javascript">
window.print();
</script>
</body>
</html>

View File

@ -0,0 +1,69 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Print Prestasi Santri</title>
<style>
table,
th,
td {
border: 1px solid black;
border-collapse: collapse;
}
th,
td {
padding: 6px;
}
</style>
</head>
<body>
<table>
<tr>
<th>No</th>
<th>NIS</th>
<th>Nama Santri</th>
<th>Kelas Diniyah</th>
<th>Prestasi</th>
<th>Perlombaan</th>
<th>Agenda</th>
<th>Tanggal</th>
</tr>
<?php $no = 1;
foreach ($prestasisantri as $ptistr) :
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
]; ?>
<tr>
<td><?= $no++ ?></td>
<td><?= $ptistr->NIS ?></td>
<td><?= $ptistr->nama_santri ?></td>
<td><?= $kelas_diniyah[$ptistr->kelas_diniyah] ?? 'Kelas Diniyah Tidak Valid' ?></td>
<td><?= $ptistr->prestasi ?></td>
<td><?= $ptistr->perlombaan ?></td>
<td><?= $ptistr->agenda ?></td>
<td><?= date('d/m/Y', strtotime($ptistr->tanggal)) ?></td>
</tr>
<?php endforeach ?>
</table>
<script type="text/javascript">
window.print();
</script>
</body>
</html>

View File

@ -0,0 +1,84 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Print Data Santri</title>
<style>
table {
width: 100%;
border-collapse: collapse;
font-size: 12px;
/* kecilkan jika diperlukan */
}
th,
td {
border: 1px solid #000;
padding: 5px;
text-align: left;
word-wrap: break-word;
}
th {
background-color: #f2f2f2;
}
</style>
</head>
<body>
<?php
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
?>
<table>
<tr>
<th>No</th>
<th>NIS</th>
<th>Nama Santri</th>
<th>Kelas Diniah</th>
<th>Status Santri</th>
<th>Tahun Masuk</th>
<th>Tahun Keluar</th>
<th>Keterangan Keluar</th>
<th>Tempat Lahir</th>
<th>Tanggal Lahir</th>
<th>Alamat</th>
</tr>
<?php $no = 1;
foreach ($santri as $str) : ?>
<tr>
<td><?= $no++ ?> </td>
<td><?= $str->NIS ?></td>
<td><?= $str->nama_santri ?></td>
<td><?= $kelas_diniyah[$str->kelas_diniyah] ?? 'Kelas Diniyah Tidak Valid' ?></td>
<td><?= $str->status_santri ?></td>
<td><?= $str->tahun_masuk ?></td>
<td><?= $str->tahun_keluar ?></td>
<td><?= $str->keterangan_keluar ?></td>
<td><?= $str->tempat_lahir ?></td>
<td><?= date('d/m/Y', strtotime($str->tanggal_lahir)) ?></td>
<td><?= $str->alamat_santri ?></td>
</tr>
<?php endforeach ?>
</table>
<script type="text/javascript">
window.print();
</script>
</body>
</html>

View File

@ -0,0 +1,70 @@
<!DOCTYPE html>
<html lang="en">
<head>
<title>Data Pelanggaran Santri</title>
<style>
table,
th,
td {
border: 1px solid black;
border-collapse: collapse;
}
th,
td {
padding: 6px;
}
</style>
</head>
<body>
<table>
<tr>
<th>No</th>
<th>NIS</th>
<th>Nama Santri</th>
<th>Kelas Diniyah</th>
<th>Jumlah Pelanggaran</th>
<th>Keterangan</th>
</tr>
<?php
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
$no = 1;
foreach ($rekap as $r) : ?>
<tr>
<td><?= $no++ ?></td>
<td><?= $r['NIS'] ?></td>
<td><?= $r['nama_santri'] ?></td>
<td><?= $kelas_diniyah[$r['kelas_diniyah']] ?? 'Tidak Diketahui' ?></td>
<td><?= $r['jumlah_pelanggaran'] ?> pelanggaran</td>
<td>
<?php if (!empty($r['sanksi_ada'])): ?>
Sudah Disanksi: <?= implode(', ', $r['sanksi_ada']) ?><br>
<?php endif; ?>
<?php if (!empty($r['sanksi_kosong'])): ?>
Belum Disanksi: <?= implode(', ', $r['sanksi_kosong']) ?>
<?php endif; ?>
</td>
</tr>
<?php endforeach; ?>
</table>
</body>
</html>

View File

@ -0,0 +1,399 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Data Diri Santri</h3>
<div class="ml-auto">
<a href="<?= base_url('santri/tambah') ?>" class="btn btn-success btn-sm custom-button">
Tambah Santri
</a>
<a href="<?= base_url('santri/print') ?>" class="btn btn-info btn-sm custom-button">
<i class="fas fa-print"></i> Print
</a>
<a href="<?= base_url('santri/pdf') ?>" class="btn btn-success btn-sm custom-button">
<i class="fas fa-file"></i> Cetak PDF
</a>
</div>
</div>
<!-- /.card-header -->
<?php
$kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
?>
<div class="card-body">
<table id="tb_santri" class="table table-bordered table-striped">
<thead>
<tr class="text-center">
<th>No</th>
<th>NIS</th>
<th>Nama Santri</th>
<th>Kelas Diniah</th>
<th>Status Santri</th>
<th>Kondisi Kesehatan</th>
<th>Detail</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
<?php $no = 1;
foreach ($santri as $str) : ?>
<tr class="text-center">
<td><?= $no++ ?></td>
<td><?= $str->NIS ?></td>
<td><?= $str->nama_santri ?></td>
<td><?= $kelas_diniyah[$str->kelas_diniyah] ?? 'Kelas Diniyah Tidak Valid' ?></td>
<td><?= $str->status_santri ?></td>
<td><?= $str->kondisi_kesehatan ?></td>
<td>
<button data-toggle="modal" data-target="#view<?= $str->id_santri ?>" class="btn btn-info btn-sm"><i class="fas fa-user"></i></button>
<a href="<?= base_url('prestasisantri/view/' . $str->id_santri) ?>" class="btn btn-success btn-sm"><i class="fas fa-award"></i></a>
<a href="<?= base_url('pelanggaransantri/view/' . $str->id_santri) ?>" class="btn btn-danger btn-sm"><i class="fas fa-user-xmark"></i></a>
<a href="<?= base_url('informasisppsantri/view/' . $str->id_santri) ?>" class="btn btn-success btn-sm"><i class="fas fa-sack-dollar"></i></a>
</td>
<td>
<a href="<?= base_url('walisantri/tambah/' . $str->id_santri) ?>" class="btn btn-success btn-sm custom-btn"><i class="fas fa-plus"></i> Wali Santri</a>
<button data-toggle="modal" data-target="#edit<?= $str->id_santri ?>" class="btn btn-warning btn-sm"><i class="fas fa-edit"></i></button>
<a href="<?= base_url('santri/delete/' . $str->id_santri) ?>" class="btn btn-danger btn-sm" onclick="return confirm('Apakah anda yakin menghapus data ini?')"><i class="fas fa-trash"></i></a>
</td>
</tr>
<?php endforeach ?>
</tbody>
</table>
</div>
</div>
<?php foreach ($santri as $str) { ?>
<!-- Modal View-->
<?php
$kelas_diniyah = [
1 => "Al-Wadhih Banin",
2 => "Al-Wadhih Banat",
3 => "Al-Jurūmiyyah Banin",
4 => "Al-Jurūmiyyah Banat",
5 => "Al-'Imriti Banin",
6 => "Al-'Imriti Banat",
7 => "Alfiyah Ula Banin",
8 => "Alfiyah Ula Banat",
9 => "Alfiyah Tsani Banin",
10 => "Alfiyah Tsani Banat",
11 => "Alfiyah Tsalits Banin",
12 => "Alfiyah Tsalits Banat"
];
$kelas_diniyah = isset($kelas_diniyah[$str->kelas_diniyah]) ? $kelas_diniyah[$str->kelas_diniyah] : '-';
?>
<div class="modal fade" id="view<?= $str->id_santri ?>" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Detail Santri</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<form action="<?= base_url('WaliSantri/view') ?>" method="POST">
<div class="form-group">
<label>NIS</label>
<input type="text" name="NIS" class="form-control" value="<?= $str->NIS ?>" readonly>
</div>
<div class="form-group">
<label>Nama Santri</label>
<input type="text" name="nama_santri" class="form-control" value="<?= $str->nama_santri ?>" readonly>
</div>
<div class="form-group">
<label>Kelas Diniah</label>
<input type="text" name="kelas_diniyah" class="form-control" value="<?= $kelas_diniyah ?>" readonly>
</div>
<div class="form-group">
<label>Status Santri</label>
<input type="text" name="status_santri" class="form-control" value="<?= $str->status_santri ?>" readonly>
</div>
<div class="form-group">
<label>Kondisi Kesehatan</label>
<input type="text" name="kondisi_kesehatan" class="form-control" value="<?= $str->kondisi_kesehatan ?>" readonly>
</div>
<div class="form-group">
<label>Tahun Masuk</label>
<input type="text" name="tahun_masuk" class="form-control" value="<?= $str->tahun_masuk ?>" readonly>
</div>
<div class="form-group">
<label>Tahun Keluar</label>
<input type="text" name="tahun_keluar" class="form-control" value="<?= $str->tahun_keluar ?>" readonly>
</div>
<div class="form-group">
<label>Keterangan Keluar</label>
<input type="text" name="keterangan_keluar" class="form-control" value="<?= $str->keterangan_keluar ?>" readonly>
</div>
<div class="form-group">
<label>Tempat Lahir</label>
<input type="text" name="tempat_lahir" class="form-control" value="<?= $str->tempat_lahir ?>" readonly>
</div>
<div class="form-group">
<label>Tanggal Lahir</label>
<input type="text" id="tanggal_lahir" name="tanggal_lahir" class="form-control"
value="<?= date('d/m/Y', strtotime($str->tanggal_lahir)) ?>" readonly>
</div>
<div class="form-group">
<label>Alamat</label>
<textarea name="alamat_santri" class="form-control" readonly><?= $str->alamat_santri ?></textarea>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-danger" data-dismiss="modal">Tutup</button>
</div>
</form>
</div>
</div>
</div>
</div>
<?php } ?>
<!-- Modal Edit -->
<?php foreach ($santri as $str) {
$list_kelas_diniyah = [
1 => 'Al-Wadhih Banin',
2 => 'Al-Wadhih Banat',
3 => 'Al-Jurūmiyyah Banin',
4 => 'Al-Jurūmiyyah Banat',
5 => 'Al-Imriti Banin',
6 => 'Al-Imriti Banat',
7 => 'Alfiyah Ula Banin',
8 => 'Alfiyah Ula Banat',
9 => 'Alfiyah Tsani Banin',
10 => 'Alfiyah Tsani Banat',
11 => 'Alfiyah Tsalits Banin',
12 => 'Alfiyah Tsalits Banat'
];
$kelas_terpilih = isset($str->kelas_diniyah) ? $str->kelas_diniyah : set_value('kelas_diniyah');
?>
<div class="modal fade" id="edit<?= $str->id_santri ?>" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Edit Santri</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<form id="editSantriForm<?= $str->id_santri ?>" action="<?= base_url('santri/edit/' . $str->id_santri) ?>" method="POST">
<input type="hidden" name="id_santri" value="<?= $str->id_santri ?>" data-default="<?= $str->id_santri ?>">
<div class="form-group">
<label>NIS</label>
<input type="text" name="NIS" class="form-control" value="<?= $str->NIS ?>">
<?= form_error('NIS', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Nama Santri</label>
<input type="text" name="nama_santri" class="form-control" value="<?= $str->nama_santri ?>">
<?= form_error('nama_santri', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<?php
$kelas_diniyah = isset($str->kelas_diniyah) ? $str->kelas_diniyah : set_value('kelas_diniyah');
?>
<div class="form-group">
<label>Kelas Diniyah</label>
<select class="custom-select" name="kelas_diniyah">
<option value="">Pilih Kelas Diniah</option>
<?php foreach ($list_kelas_diniyah as $key => $label): ?>
<option value="<?= $key ?>" <?= ($kelas_terpilih == $key) ? 'selected' : '' ?>>
<?= $label ?>
</option>
<?php endforeach; ?>
</select>
<?= form_error('kelas_diniyah', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Status Santri</label>
<select name="status_santri" class="form-control">
<option value="">-- Pilih Status Santri --</option>
<option value="Santri Aktif" <?= ($str->status_santri == 'Santri Aktif') ? 'selected' : '' ?>>Santri Aktif</option>
<option value="Alumni" <?= ($str->status_santri == 'Alumni') ? 'selected' : '' ?>>Alumni</option>
</select>
<?= form_error('keterangan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Kondisi Kesehatan</label>
<select name="kondisi_kesehatan" class="form-control">
<option value="">-- Pilih Kondisi Kesehatan --</option>
<option value="Dalam Kondisi Sehat" <?= ($str->kondisi_kesehatan == 'Dalam Kondisi Sehat') ? 'selected' : '' ?>>Dalam Kondisi Sehat</option>
<option value="Dalam Kondisi Sakit" <?= ($str->kondisi_kesehatan == 'Dalam Kondisi Sakit') ? 'selected' : '' ?>>Dalam Kondisi Sakit</option>
</select>
<?= form_error('keterangan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tahun Masuk</label>
<input type="text" name="tahun_masuk" class="form-control" value="<?= $str->tahun_masuk ?>">
<?= form_error('tahun_masuk', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tahun Keluar</label>
<input type="text" name="tahun_keluar" class="form-control" value="<?= $str->tahun_keluar ?>">
</div>
<div class="form-group">
<label>Keterangan Keluar</label>
<select name="keterangan_keluar" class="form-control">
<option value="">-- Pilih Keterangan Keluar --</option>
<option value="Lulus MTs" <?= ($str->keterangan_keluar == 'Lulus MTs') ? 'selected' : '' ?>>Lulus MTs</option>
<option value="Lulus MAN" <?= ($str->keterangan_keluar == 'Lulus MAN') ? 'selected' : '' ?>>Lulus MAN</option>
<option value="Berhenti Atas Pertimbangan Tertentu" <?= ($str->keterangan_keluar == 'Berhenti Atas Pertimbangan Tertentu') ? 'selected' : '' ?>>Berhenti Atas Pertimbangan Tertentu</option>
</select>
<?= form_error('keterangan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tempat Lahir</label>
<input type="text" name="tempat_lahir" class="form-control" value="<?= $str->tempat_lahir ?>">
<?= form_error('tempat_lahir', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tanggal Lahir</label>
<input type="text" id="tanggal_lahir" name="tanggal_lahir" class="form-control"
value="<?= date('d/m/Y', strtotime($str->tanggal_lahir)) ?>">
<?= form_error('tanggal_lahir', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Alamat Santri</label>
<textarea name="alamat_santri" class="form-control"><?= $str->alamat_santri ?></textarea>
<?= form_error('alamat_santri', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</div>
</form>
</div>
</div>
</div>
</div>
<?php } ?>
<script src="https://cdn.jsdelivr.net/npm/flatpickr"></script>
<script>
flatpickr("#tanggal_lahir", {
dateFormat: "d/m/Y" // Menampilkan dalam format dd/mm/yyyy
});
</script>
<style>
/* CSS untuk mengubah background dan border <th> dan <td> */
/* Ubah warna border tabel menjadi hijau */
table.table-bordered {
border: 2px solid green;
/* Border luar tabel */
}
/* Ubah warna background dan border header tabel */
table.table-bordered th {
background-color: #e0f7e0;
/* Hijau muda untuk header */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Ubah warna background dan border sel tabel */
table.table-bordered td {
background-color: #f0fff0;
/* Hijau sangat muda untuk sel */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
.form-control:not([size]):not([multiple]) {
background-image: none !important;
/* Menghilangkan panah bawaan Bootstrap */
}
.custom-button {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 6px 13px;
/* Sesuaikan padding agar proporsional */
}
.custom-btn {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 4px 10px;
/* Sesuaikan padding agar proporsional */
}
/* Override panah sorting ganda */
/* Hapus panah sorting bawaan template atau Bootstrap */
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
display: none !important;
}
</style>
<!-- DataTables Initialization -->
<script>
$(document).ready(function() {
$('#tb_santri').DataTable({
"paging": true, // Enable pagination
"lengthChange": true, // Allow user to change number of rows shown
"searching": true, // Enable search
"ordering": true, // Enable column sorting
"info": true, // Show table info
"autoWidth": false, // Disable auto column width adjustment
});
});
document.addEventListener("DOMContentLoaded", function() {
document.querySelectorAll(".reset-btn").forEach(button => {
button.addEventListener("click", function() {
var id = this.getAttribute("data-id");
var form = document.getElementById("editSantriForm" + id);
if (form) {
form.reset(); // Reset semua input di form
// Reset input dan textarea secara manual jika form reset tidak bekerja
form.querySelectorAll("input:not([readonly]), textarea").forEach(input => {
input.value = "";
});
// Kosongkan datepicker juga
var dateInput = form.querySelector(".datepicker");
if (dateInput) {
dateInput.value = "";
}
// Kembalikan nilai id_santri agar tidak kosong
var idSantriInput = form.querySelector("input[name='id_santri']");
if (idSantriInput) {
idSantriInput.value = idSantriInput.getAttribute("data-default");
}
}
});
});
});
</script>

View File

@ -0,0 +1,151 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Sejarah Pondok Pesantren</h3>
</div>
<!-- /.card-header -->
<div class="card-body">
<table id="tb_santri" class="table table-bordered table-striped">
<thead>
<tr class="text-center">
<th>Sejarah Singkat</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
<?php
foreach ($sejarah as $sjr) : ?>
<tr>
<td><?php
$paragraf = explode("\n", $sjr->sejarah);
foreach ($paragraf as $p) {
if (trim($p) != '') {
echo '<p style="text-align: justify; text-indent: 40px;">' . $p . '</p>';
}
}
?></td>
<td style="width: 100px;" class="text-center">
<button data-toggle="modal" data-target="#edit<?= $sjr->id_sejarah ?>" class="btn btn-warning btn-sm">
<i class="fas fa-edit"></i>
</button>
<!-- <a href="<?= base_url('Sejarah/delete/' . $sjr->id_sejarah) ?>" class="btn btn-danger btn-sm" onclick="return confirm('Apakah anda yakin menghapus data ini?')">
<i class="fas fa-trash"></i>
</a> -->
</td>
</tr>
<?php endforeach ?>
</tbody>
</table>
</div>
</div>
<!-- Modal Edit -->
<?php foreach ($sejarah as $sjr) { ?>
<div class="modal fade" id="edit<?= $sjr->id_sejarah ?>" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Edit Sejarah</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<form id="editSejarahForm<?= $sjr->id_sejarah ?>" action="<?= base_url('Sejarah/edit/' . $sjr->id_sejarah) ?>" method="POST">
<input type="hidden" name="id_kegiatan" value="<?= $sjr->id_sejarah ?>" data-default="<?= $sjr->id_sejarah ?>">
<div class="form-group">
<label>Sejarah Singkat</label>
<textarea name="sejarah" class="form-control"><?= $sjr->sejarah ?></textarea>
<?= form_error('sejarah', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</div>
</form>
</div>
</div>
</div>
</div>
<?php } ?>
<style>
/* CSS untuk mengubah background dan border <th> dan <td> */
/* Ubah warna border tabel menjadi hijau */
table.table-bordered {
border: 2px solid green;
/* Border luar tabel */
}
/* Ubah warna background dan border header tabel */
table.table-bordered th {
background-color: #e0f7e0;
/* Hijau muda untuk header */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Ubah warna background dan border sel tabel */
table.table-bordered td {
background-color: #f0fff0;
/* Hijau sangat muda untuk sel */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
.form-control:not([size]):not([multiple]) {
background-image: none !important;
/* Menghilangkan panah bawaan Bootstrap */
}
.custom-button {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 6px 13px;
/* Sesuaikan padding agar proporsional */
}
.custom-btn {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 4px 10px;
/* Sesuaikan padding agar proporsional */
}
/* Override panah sorting ganda */
/* Hapus panah sorting bawaan template atau Bootstrap */
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
display: none !important;
}
</style>
<!-- <script>
$(document).ready(function() {
$('#tb_santri').DataTable({
"paging": true, // Enable pagination
"lengthChange": true, // Allow user to change number of rows shown
"searching": true, // Enable search
"ordering": true, // Enable column sorting
"info": true, // Show table info
"autoWidth": false, // Disable auto column width adjustment
});
});
</script> -->

View File

@ -0,0 +1,44 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Tambah Berita</h3>
</div>
<div class="col-lg-6 mt-2 ml-2 mb-4">
<form action="<?= base_url('Berita/tambah_aksi') ?>" method="POST" enctype="multipart/form-data">
<div class="form-group">
<label>Gambar</label>
<input type="file" name="gambar" class="form-control" value="<?= set_value('gambar') ?>">
<?= form_error('gambar', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Judul</label>
<textarea name="judul" class="form-control" value="<?= set_value('judul') ?>" placeholder="Input Judul"></textarea>
<?= form_error('judul', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Deskripsi Singkat</label>
<textarea name="deskripsi" class="form-control" value="<?= set_value('deskripsi') ?>" placeholder="Input Deskripsi"></textarea>
<?= form_error('deskripsi', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tanggal</label>
<input type="text" id="tanggal" name="tanggal" class="form-control" value="<?= set_value('tanggal') ?>" placeholder="Input Tanggal">
<?= form_error('tanggal', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<a href="<?= base_url('berita') ?>" class="btn btn-danger btn-sm">
<i class="fas fa-solid fa-angle-left"></i> Kembali
</a>
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</form>
</div>
</div>
<script src="https://cdn.jsdelivr.net/npm/flatpickr"></script>
<script>
flatpickr("#tanggal", {
enableTime: true,
dateFormat: "d/m/Y H:i:S", // hasil: 2025/06/15 14:30
time_24hr: true,
enableSeconds: true
});
</script>

View File

@ -0,0 +1,48 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Tambah Waktu Pembayaran</h3>
</div>
<div class="col-lg-6 mt-2 ml-2 mb-4">
<form action="<?= base_url('InformasiSPP/tambah_aksi') ?>" method="POST">
<div class="form-group">
<label>Bulan</label>
<select class="custom-select" id="inputGroupSelect02" name="bulan">
<option selected>Pilih Bulan</option>
<option value="1" <?= set_select('bulan', '1'); ?>>Januari</option>
<option value="2" <?= set_select('bulan', '2'); ?>>Februari</option>
<option value="3" <?= set_select('bulan', '3'); ?>>Maret</option>
<option value="4" <?= set_select('bulan', '4'); ?>>April</option>
<option value="5" <?= set_select('bulan', '5'); ?>>Mei</option>
<option value="6" <?= set_select('bulan', '6'); ?>>Juni</option>
<option value="7" <?= set_select('bulan', '7'); ?>>Juli</option>
<option value="8" <?= set_select('bulan', '8'); ?>>Agustus</option>
<option value="9" <?= set_select('bulan', '9'); ?>>September</option>
<option value="10" <?= set_select('bulan', '10'); ?>>Oktober</option>
<option value="11" <?= set_select('bulan', '11'); ?>>November</option>
<option value="12" <?= set_select('bulan', '12'); ?>>Desember</option>
</select>
<?= form_error('bulan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tahun</label>
<input type="text" name="tahun" class="form-control" value="<?= set_value('tahun') ?>" placeholder="Input Tahun">
<?= form_error('tahun', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Jumlah Pembayaran</label>
<input type="text" name="jumlah_pembayaran" class="form-control" value="<?= set_value('jumlah_pembayaran') ?>" placeholder="Input Jumlah Pembayaran">
<?= form_error('jumlah_pembayaran', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Jatuh Tempo</label>
<input type="date" name="jatuh_tempo" class="form-control" value="<?= set_value('jatuh_tempo') ?>" placeholder="Pilih Tanggal Jatuh Tempo">
<?= form_error('jatuh_tempo', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<a href="<?= base_url('InformasiSPP') ?>" class="btn btn-danger btn-sm">
<i class="fas fa-solid fa-angle-left"></i> Kembali
</a>
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</form>
</div>
</div>

View File

@ -0,0 +1,83 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Tambah Data SPP Santri</h3>
</div>
<div class="col-lg-6 mt-2 ml-2 mb-4">
<form action="<?= base_url('informasisppsantri/tambah_aksi') ?>" method="POST">
<input type="hidden" id="id_santri" name="id_santri">
<div class="form-group">
<label>NIS</label>
<input type="text" id="NIS" name="NIS" class="form-control" data-url="<?= base_url('informasisppsantri/get_nis_autocomplete') ?>" value="<?= set_value('NIS') ?>" placeholder="Input NIS">
<?= form_error('NIS', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Nama Santri</label>
<input type="text" id="nama_santri" name="nama_santri" class="form-control" data-url="<?= base_url('informasisppsantri/get_nis_autocomplete') ?>" value="<?= set_value('nama_santri') ?>" placeholder="Input Nama Santri" readonly>
<?= form_error('nama_santri', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Kelas Diniyah</label>
<!-- Tampilkan ke user (teks kelas, misal: "Al-Wadhih Banat") -->
<input type="text" id="kelas_diniyah_display" class="form-control" value="<?= set_value('kelas_diniyah_display') ?>" placeholder="Kelas Diniyah" readonly>
<!-- Disimpan ke database (berupa angka: 1, 2, 3, dst) -->
<input type="hidden" name="kelas_diniyah" id="kelas_diniyah" value="<?= set_value('kelas_diniyah') ?>">
<?= form_error('kelas_diniyah', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Bulan</label>
<select class="custom-select" id="inputGroupSelect02" name="bulan">
<option selected>Pilih Bulan</option>
<option value="1" <?= set_select('bulan', '1'); ?>>Januari</option>
<option value="2" <?= set_select('bulan', '2'); ?>>Februari</option>
<option value="3" <?= set_select('bulan', '3'); ?>>Maret</option>
<option value="4" <?= set_select('bulan', '4'); ?>>April</option>
<option value="5" <?= set_select('bulan', '5'); ?>>Mei</option>
<option value="6" <?= set_select('bulan', '6'); ?>>Juni</option>
<option value="7" <?= set_select('bulan', '7'); ?>>Juli</option>
<option value="8" <?= set_select('bulan', '8'); ?>>Agustus</option>
<option value="9" <?= set_select('bulan', '9'); ?>>September</option>
<option value="10" <?= set_select('bulan', '10'); ?>>Oktober</option>
<option value="11" <?= set_select('bulan', '11'); ?>>November</option>
<option value="12" <?= set_select('bulan', '12'); ?>>Desember</option>
</select>
<?= form_error('bulan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tahun</label>
<input type="text" name="tahun" class="form-control" value="<?= set_value('tahun') ?>" placeholder="Input Tahun">
<?= form_error('tahun', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Jumlah Pembayaran</label>
<input type="text" name="jumlah_pembayaran" class="form-control" value="<?= set_value('jumlah_pembayaran') ?>" placeholder="Input Jumlah Pembayaran">
<?= form_error('jumlah_pembayaran', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Jatuh Tempo</label>
<input type="text" id="jatuh_tempo" name="jatuh_tempo" class="form-control" value="<?= set_value('jatuh_tempo') ?>" placeholder="Pilih Tanggal Jatuh Tempo">
<?= form_error('jatuh_tempo', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Keterangan</label>
<select name="keterangan" class="form-control">
<option value="">-- Pilih Keterangan --</option>
<option value="Sudah Lunas" <?= set_select('keterangan', 'Sudah Lunas') ?>>Sudah Lunas</option>
<option value="Belum Lunas" <?= set_select('keterangan', 'Belum Lunas') ?>>Belum Lunas</option>
</select>
<?= form_error('keterangan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<a href="<?= base_url('informasisppsantri') ?>" class="btn btn-danger btn-sm">
<i class="fas fa-solid fa-angle-left"></i> Kembali
</a>
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</form>
</div>
</div>
<script src="https://cdn.jsdelivr.net/npm/flatpickr"></script>
<script>
flatpickr("#jatuh_tempo", {
dateFormat: "d/m/Y" // yyyy/mm/dd
});
</script>

View File

@ -0,0 +1,24 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Tambah Kategori Pelanggaran</h3>
</div>
<div class="col-lg-6 mt-2 ml-2 mb-4">
<form action="<?= base_url('Pelanggaran/tambah_aksi') ?>" method="POST">
<div class="form-group">
<label>Pelanggaran</label>
<input type="text" name="pelanggaran" class="form-control" value="<?= set_value('pelanggaran') ?>" placeholder="Input Kategori Pelanggaran">
<?= form_error('pelanggaran', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Sanksi</label>
<input type="text" name="sanksi" class="form-control" value="<?= set_value('sanksi') ?>" placeholder="Input Sanksi">
<?= form_error('sanksi', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<a href="<?= base_url('pelanggaran') ?>" class="btn btn-danger btn-sm">
<i class="fas fa-solid fa-angle-left"></i> Kembali
</a>
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</form>
</div>
</div>

View File

@ -0,0 +1,29 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Tambah Kegiatan Santri</h3>
</div>
<div class="col-lg-6 mt-2 ml-2 mb-4">
<form action="<?= base_url('kegiatansantri/tambah_aksi') ?>" method="POST">
<div class="form-group">
<label>Hari</label>
<input type="text" name="hari" class="form-control" value="<?= set_value('hari'); ?>" placeholder="Input Hari">
<?= form_error('hari', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Nama Kegiatan</label>
<input type="text" name="nama_kegiatan" class="form-control" value="<?= set_value('nama_kegiatan'); ?>" placeholder="Input Nama Kegiatan">
<?= form_error('nama_kegiatan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Waktu</label>
<input type="text" name="waktu" class="form-control" value="<?= set_value('waktu'); ?>" placeholder="Input Waktu">
<?= form_error('waktu', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<a href="<?= base_url('kegiatansantri') ?>" class="btn btn-danger btn-sm">
<i class="fas fa-solid fa-angle-left"></i> Kembali
</a>
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</form>
</div>
</div>

View File

@ -0,0 +1,64 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Tambah Pelanggaran Santri</h3>
</div>
<div class="col-lg-6 mt-2 ml-2 mb-4">
<form action="<?= base_url('pelanggaransantri/tambah_aksi') ?>" method="POST">
<input type="hidden" id="id_santri" name="id_santri">
<div class="form-group">
<label>NIS</label>
<input type="text" id="NIS" name="NIS" class="form-control" data-url="<?= base_url('pelanggaransantri/get_nis_autocomplete') ?>" value="<?= set_value('NIS') ?>" placeholder="Input NIS">
<?= form_error('NIS', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Nama Santri</label>
<input type="text" id="nama_santri" name="nama_santri" class="form-control" data-url="<?= base_url('pelanggaransantri/get_nis_autocomplete') ?>" value="<?= set_value('nama_santri') ?>" placeholder="Input Nama Santri" readonly>
<?= form_error('nama_santri', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Kelas Diniah</label>
<!-- Tampilkan ke user (teks kelas, misal: "Al-Wadhih Banat") -->
<input type="text" id="kelas_diniyah_display" class="form-control" value="<?= set_value('kelas_diniyah_display') ?>" placeholder="Kelas Diniyah" readonly>
<!-- Disimpan ke database (berupa angka: 1, 2, 3, dst) -->
<input type="hidden" name="kelas_diniyah" id="kelas_diniyah" value="<?= set_value('kelas_diniyah') ?>">
<?= form_error('kelas_diniyah', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Pelanggaran</label>
<input type="text" name="pelanggaran" class="form-control" value="<?= set_value('pelanggaran') ?>" placeholder="Input Pelanggaran">
<?= form_error('pelanggaran', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tanggal</label>
<input type="text" id="tanggal" name="tanggal" class="form-control" value="<?= set_value('tanggal') ?>" placeholder="Input Tanggal">
<?= form_error('tanggal', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Sanksi</label>
<input type="text" name="sanksi" class="form-control" value="<?= set_value('sanksi') ?>" placeholder="Input Sanksi">
<?= form_error('sanksi', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Keterangan</label>
<select name="keterangan" class="form-control">
<option value="">-- Pilih Keterangan --</option>
<option value="Sudah Disanksi" <?= set_select('keterangan', 'Sudah Disanksi') ?>>Sudah Disanksi</option>
<option value="Belum Disanksi" <?= set_select('keterangan', 'Belum Disanksi') ?>>Belum Disanksi</option>
</select>
<?= form_error('keterangan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<a href="<?= base_url('pelanggaransantri') ?>" class="btn btn-danger btn-sm">
<i class="fas fa-solid fa-angle-left"></i> Kembali
</a>
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</form>
</div>
</div>
<script src="https://cdn.jsdelivr.net/npm/flatpickr"></script>
<script>
flatpickr("#tanggal", {
dateFormat: "d/m/Y" // Menampilkan dalam format dd/mm/yyyy
});
</script>

View File

@ -0,0 +1,29 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Tambah Perlombaan Santri</h3>
</div>
<div class="col-lg-6 mt-2 ml-2 mb-4">
<form action="<?= base_url('perlombaan/tambah_aksi') ?>" method="POST">
<div class="form-group">
<label>Agenda</label>
<input type="text" name="agenda" class="form-control" value="<?= set_value('agenda'); ?>" placeholder="Input Agenda">
<?= form_error('agenda', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Perlombaan</label>
<input type="text" name="perlombaan" class="form-control" value="<?= set_value('perlombaan'); ?>" placeholder="Input Perlombaan">
<?= form_error('perlombaan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tanggal</label>
<input type="text" name="tanggal" class="form-control" value="<?= set_value('tanggal'); ?>" placeholder="Input Tanggal">
<?= form_error('tanggal', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<a href="<?= base_url('perlombaan') ?>" class="btn btn-danger btn-sm">
<i class="fas fa-solid fa-angle-left"></i> Kembali
</a>
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</form>
</div>
</div>

View File

@ -0,0 +1,65 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Tambah Prestasi Santri</h3>
</div>
<div class="col-lg-6 mt-2 ml-2 mb-4">
<form action="<?= base_url('prestasisantri/tambah_aksi') ?>" method="POST">
<input type="hidden" id="id_santri" name="id_santri">
<div class="form-group">
<label>NIS</label>
<input type="text" id="NIS" name="NIS" class="form-control" data-url="<?= base_url('prestasisantri/get_nis_autocomplete') ?>" value="<?= set_value('NIS') ?>" placeholder="Input NIS">
<?= form_error('NIS', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Nama Santri</label>
<input type="text" id="nama_santri" name="nama_santri" class="form-control" data-url="<?= base_url('prestasisantri/get_nis_autocomplete') ?>" value="<?= set_value('nama_santri') ?>" placeholder="Input Nama Santri" readonly>
<?= form_error('nama_santri', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Kelas Diniah</label>
<!-- Tampilkan ke user (teks kelas, misal: "Al-Wadhih Banat") -->
<input type="text" id="kelas_diniyah_display" class="form-control" value="<?= set_value('kelas_diniyah_display') ?>" placeholder="Kelas Diniyah" readonly>
<!-- Disimpan ke database (berupa angka: 1, 2, 3, dst) -->
<input type="hidden" name="kelas_diniyah" id="kelas_diniyah" value="<?= set_value('kelas_diniyah') ?>">
<?= form_error('kelas_diniyah', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Prestasi</label>
<input type="text" name="prestasi" class="form-control" value="<?= set_value('prestasi'); ?>" placeholder="Input Prestasi">
<?= form_error('prestasi', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Perlombaan</label>
<input type="text" name="perlombaan" class="form-control" value="<?= set_value('perlombaan'); ?>" placeholder="Input Perlombaan">
<?= form_error('perlombaan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Agenda</label>
<input type="text" name="agenda" class="form-control" value="<?= set_value('agenda'); ?>" placeholder="Input Agenda">
<?= form_error('agenda', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tanggal</label>
<input type="text" id="tanggal" name="tanggal" class="form-control"
value="<?= set_value('tanggal'); ?>" placeholder="dd/mm/yyyy">
<?= form_error('tanggal', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Bukti Prestasi</label>
<input type="text" name="bukti_prestasi" class="form-control" value="<?= set_value('bukti_prestasi'); ?>" placeholder="Input Link Drive Bukti Prestasi">
</div>
<a href="<?= base_url('prestasisantri') ?>" class="btn btn-danger btn-sm">
<i class="fas fa-solid fa-angle-left"></i> Kembali
</a>
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</form>
</div>
</div>
<script src="https://cdn.jsdelivr.net/npm/flatpickr"></script>
<script>
flatpickr("#tanggal", {
dateFormat: "d/m/Y" // Menampilkan dalam format dd/mm/yyyy
});
</script>

View File

@ -0,0 +1,102 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Tambah Santri</h3>
</div>
<div class="col-lg-6 mt-2 ml-2 mb-4">
<form action="<?= base_url('santri/tambah_aksi') ?>" method="POST">
<div class="form-group">
<label>NIS</label>
<input type="text" name="NIS" class="form-control" value="<?= set_value('NIS'); ?>" placeholder="Input NIS">
<?= form_error('NIS', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Nama Santri</label>
<input type="text" name="nama_santri" class="form-control" value="<?= set_value('nama_santri'); ?>" placeholder="Input Nama Santri">
<?= form_error('nama_santri', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Kelas Diniyah</label>
<select class="custom-select" id="inputGroupSelect" name="kelas_diniyah">
<option selected>Pilih Kelas Diniah</option>
<option value="1" <?= set_select('kelas_diniyah', '1'); ?>>Al-Wadhih Banin</option>
<option value="2" <?= set_select('kelas_diniyah', '2'); ?>>Al-Wadhih Banat</option>
<option value="3" <?= set_select('kelas_diniyah', '3'); ?>>Al-Jurūmiyyah Banin</option>
<option value="4" <?= set_select('kelas_diniyah', '4'); ?>>Al-Jurūmiyyah Banat</option>
<option value="5" <?= set_select('kelas_diniyah', '5'); ?>>Al-'Imriti Banin</option>
<option value="6" <?= set_select('kelas_diniyah', '6'); ?>>Al-'Imriti Banat</option>
<option value="7" <?= set_select('kelas_diniyah', '7'); ?>>Alfiyah Ula Banin</option>
<option value="8" <?= set_select('kelas_diniyah', '8'); ?>>Alfiyah Ula Banat</option>
<option value="9" <?= set_select('kelas_diniyah', '9'); ?>>Alfiyah Tsani Banin</option>
<option value="10" <?= set_select('kelas_diniyah', '10'); ?>>Alfiyah Tsani Banat</option>
<option value="11" <?= set_select('kelas_diniyah', '11'); ?>>Alfiyah Tsalits Banin</option>
<option value="12" <?= set_select('kelas_diniyah', '12'); ?>>Alfiyah Tsalits Banat</option>
</select>
<?= form_error('kelas_diniyah', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Status Santri</label>
<select name="status_santri" class="form-control">
<option value="">-- Pilih Status Santri --</option>
<option value="Santri Aktif" <?= set_select('status_santri', 'Santri Aktif') ?>>Santri Aktif</option>
<option value="Alumni" <?= set_select('status_santri', 'Alumni') ?>>Alumni</option>
</select>
<?= form_error('status_santri', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Kondisi Kesehatan</label>
<select name="kondisi_kesehatan" class="form-control">
<option value="">-- Pilih Kondisi Kesehatan --</option>
<option value="Dalam Kondisi Sehat" <?= set_select('kondisi_kesehatan', 'Dalam Kondisi Sehat') ?>>Dalam Kondisi Sehat</option>
<option value="Dalam Kondisi Sakit" <?= set_select('kondisi_kesehatan', 'Alumni') ?>>Dalam Kondisi Sakit</option>
</select>
<?= form_error('kondisi_kesehatan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tahun Masuk</label>
<input type="text" name="tahun_masuk" class="form-control" value="<?= set_value('tahun_masuk'); ?>" placeholder="Input Tahun Masuk">
<?= form_error('tahun_masuk', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tahun Keluar</label>
<input type="text" name="tahun_keluar" class="form-control" value="<?= set_value('tahun_keluar'); ?>" placeholder="Input Tahun Keluar">
</div>
<div class="form-group">
<label>Keterangan Keluar</label>
<select name="keterangan_keluar" class="form-control">
<option value="">-- Pilih Keterangan Keluar --</option>
<option value="Lulus MTs" <?= set_select('keterangan_keluar', 'Lulus MTs') ?>>Lulus MTs</option>
<option value="Lulus MAN" <?= set_select('keterangan_keluar', 'Lulus MAN') ?>>Lulus MAN</option>
<option value="Berhenti Atas Pertimbangan Tertentu" <?= set_select('keterangan_keluar', 'Berhenti Atas Pertimbangan Tertentu') ?>>Berhenti Atas Pertimbangan Tertentu</option>
</select>
<?= form_error('keterangan_keluar', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tempat Lahir</label>
<input type="text" name="tempat_lahir" class="form-control" value="<?= set_value('tempat_lahir'); ?>" placeholder="Input Tempat Lahir">
<?= form_error('tempat_lahir', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tanggal Lahir</label>
<input type="text" id="tanggal_lahir" name="tanggal_lahir" class="form-control" value="<?= set_value('tanggal_lahir'); ?>" placeholder="Pilih Tanggal">
<?= form_error('tanggal_lahir', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Alamat Santri</label>
<textarea name="alamat_santri" class="form-control" placeholder="Input Alamat Santri"><?= set_value('alamat_santri'); ?></textarea>
<?= form_error('alamat_santri', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<a href="<?= base_url('santri') ?>" class="btn btn-danger btn-sm">
<i class="fas fa-solid fa-angle-left"></i> Kembali
</a>
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</form>
</div>
</div>
<script src="https://cdn.jsdelivr.net/npm/flatpickr"></script>
<script>
flatpickr("#tanggal_lahir", {
dateFormat: "d/m/Y" // Menampilkan dalam format dd/mm/yyyy
});
</script>

View File

@ -0,0 +1,73 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Tambah Wali Santri</h3>
</div>
<div class="col-lg-6 mt-2 ml-2 mb-4">
<form action="<?= base_url('walisantri/tambah_aksi') ?>" method="POST">
<!-- Tambahkan input hidden untuk id_santri -->
<input type="hidden" name="id_santri" value="<?= isset($santri) ? $santri->id_santri : '' ?>">
<div class="form-group">
<label>Email</label>
<input type="text" name="email" class="form-control" value="<?= set_value('email'); ?>" placeholder="Input Email">
<?= form_error('email', '<div class="text-small text-danger">', '</div>') ?>
</div>
<div class="form-group">
<label>Password</label>
<input type="text" name="password" class="form-control" value="<?= set_value('NIS', isset($santri) ? $santri->NIS : '') ?>">
<?= form_error('password', '<div class="text-small text-danger">', '</div>') ?>
</div>
<div class="form-group">
<label>Nama Wali Santri</label>
<input type="text" name="nama_wali_santri" class="form-control" value="<?= set_value('nama_wali_santri'); ?>" placeholder="Input Nama Wali Santri">
<?= form_error('nama_wali_santri', '<div class="text-small text-danger">', '</div>') ?>
</div>
<div class="form-group">
<label>Nama Santri</label>
<input type="text" name="nama_santri" class="form-control"
value="<?= set_value('nama_santri', isset($santri) ? $santri->nama_santri : '') ?>" readonly>
<?= form_error('nama_santri', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>NIS</label>
<input type="text" name="NIS" class="form-control"
value="<?= set_value('NIS', isset($santri) ? $santri->NIS : '') ?>" readonly>
<?= form_error('NIS', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<!-- <div class="form-group">
<label>No KTP</label>
<input type="text" name="no_ktp" class="form-control" value="<?= set_value('no_ktp'); ?>" placeholder="Input No KTP">
<?= form_error('no_ktp', '<div class="text-small text-danger">', '</div>') ?>
</div>
<div class="form-group">
<label>Tempat Lahir</label>
<input type="text" name="tempat_lahir" class="form-control" value="<?= set_value('tempat_lahir'); ?>" placeholder="Input Tempat Lahir">
<?= form_error('tempat_lahir', '<div class="text-small text-danger">', '</div>') ?>
</div>
<div class="form-group">
<label>Tanggal Lahir</label>
<input type="date" name="tanggal_lahir" class="form-control" value="<?= set_value('tanggal_lahir'); ?>" placeholder="Pilih Tanggal">
<?= form_error('tanggal_lahir', '<div class="text-small text-danger">', '</div>') ?>
</div> -->
<div class="form-group">
<label>Alamat</label>
<textarea name="alamat" class="form-control" placeholder="Input Alamat"><?= set_value('alamat'); ?></textarea>
<?= form_error('alamat', '<div class="text-small text-danger">', '</div>') ?>
</div>
<div class="form-group">
<label>No Telepon</label>
<input type="text" name="no_telepon" class="form-control" value="<?= set_value('no_telepon'); ?>" placeholder="Input No Telepon">
<?= form_error('no_telepon', '<div class="text-small text-danger">', '</div>') ?>
</div>
<div class="form-group">
<label>Pekerjaan</label>
<input type="text" name="pekerjaan" class="form-control" value="<?= set_value('tempat_lahir'); ?>" placeholder="Input Pekerjaan">
<?= form_error('pekerjaan', '<div class="text-small text-danger">', '</div>') ?>
</div>
<a href="<?= base_url('santri') ?>" class="btn btn-danger btn-sm">
<i class="fas fa-solid fa-angle-left"></i> Kembali
</a>
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</form>
</div>
</div>

View File

@ -0,0 +1,30 @@
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Ubah Kata Sandi Admin</h3>
</div>
<div class="row">
<div class="col-lg-6 mt-4 ml-4">
<?= $this->session->flashdata('message'); ?>
<form action="<?= base_url('admin/ubahkatasandi'); ?>" method="post">
<div class="form-group">
<label for="current_password" style="font-weight: normal;">Kata sandi saat ini</label>
<input type="password" class="form-control" id="current_password" name="current_password">
<?= form_error('current_password', '<small class="text-danger pl-3">', '</small>'); ?>
</div>
<div class="form-group">
<label for="new_password1" style="font-weight: normal;">Kata sandi baru</label>
<input type="password" class="form-control" id="new_password1" name="new_password1">
<?= form_error('new_password1', '<small class="text-danger pl-3">', '</small>'); ?>
</div>
<div class="form-group">
<label for="new_password2" style="font-weight: normal;">Ulangi kata sandi baru</label>
<input type="password" class="form-control" id="new_password2" name="new_password2">
<?= form_error('new_password2', '<small class="text-danger pl-3">', '</small>'); ?>
</div>
<div class="form-group">
<button type="submit" class="btn btn-primary">Ubah kata sandi</button>
</div>
</form>
</div>
</div>
</div>

View File

@ -0,0 +1,298 @@
<?= $this->session->flashdata('pesan'); ?>
<div class="card">
<div class="card-header d-flex justify-content-between align-items-center w-100">
<h3 class="card-title mb-1" style="margin-top: 5px;">Halaman Data Wali Santri</h3>
<!-- <div class="ml-auto">
<a href="<?= base_url('santri/print') ?>" class="btn btn-info btn-sm custom-button"><i class="fas fa-print"></i> Print </a>
<a href="<?= base_url('santri/pdf') ?>" class="btn btn-success btn-sm custom-button"><i class="fas fa-file"></i> Cetak PDF </a>
</div> -->
</div>
<!-- /.card-header -->
<div class="card-body">
<table id="tb_santri" class="table table-bordered table-striped">
<thead>
<tr class="text-center">
<th>No</th>
<th>Nama Wali Santri</th>
<th>Nama Santri</th>
<th>No Telepon</th>
<th>Alamat</th>
<th>Aksi</th>
</tr>
</thead>
<tbody>
<?php $no = 1;
foreach ($santri as $str) : ?>
<tr class="text-center">
<td><?= $no++ ?></td>
<td><?= $str->nama_wali_santri ?></td>
<td><?= $str->nama_santri ?></td>
<td><?= $str->no_telepon ?></td>
<td><?= $str->alamat ?></td>
<td>
<button data-toggle="modal" data-target="#view<?= $str->id_santri ?>" class="btn btn-success btn-sm"><i class="fas fa-user"></i></button>
<button data-toggle="modal" data-target="#edit<?= $str->id_santri ?>" class="btn btn-warning btn-sm"><i class="fas fa-edit"></i></button>
<!-- <a href="<?= base_url('WaliSantri/delete/' . $str->id_santri) ?>" class="btn btn-danger btn-sm" onclick="return confirm('Apakah anda yakin menghapus data ini?')"><i class="fas fa-trash"></i></a> -->
<a href="<?= base_url('walisantri/chatadmin/' . $str->id_wali_santri) ?>" class="btn btn-sm btn-info"><i class="fas fa-message"></i></a>
</td>
</tr>
<?php endforeach ?>
</tbody>
</table>
</div>
</div>
<?php foreach ($santri as $str) { ?>
<!-- Modal View-->
<div class="modal fade" id="view<?= $str->id_santri ?>" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Detail Wali Santri</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<form action="<?= base_url('WaliSantri/view') ?>" method="POST">
<!-- Tambahkan input hidden untuk id_santri -->
<div class="form-group">
<label>Email</label>
<input type="text" name="email" class="form-control" value="<?= $str->email ?>" readonly>
</div>
<div class="form-group">
<label>Password</label>
<input type="text" name="password" class="form-control" value="<?= $str->password ?>" readonly>
</div>
<div class="form-group">
<label>Nama Wali Santri</label>
<input type="text" name="nama_wali_santri" class="form-control" value="<?= $str->nama_wali_santri ?>" readonly>
</div>
<div class="form-group">
<label>Nama Santri</label>
<input type="text" name="nama_santri" class="form-control" value="<?= $str->nama_santri ?>" readonly>
</div>
<!-- <div class="form-group">
<label>NIS</label>
<input type="text" name="NIS" class="form-control" value="<?= $str->NIS ?>" readonly>
</div>
<div class="form-group">
<label>No KTP</label>
<input type="text" name="no_ktp" class="form-control" value="<?= $str->no_ktp ?>" readonly>
</div>
<div class="form-group">
<label>Tempat Lahir</label>
<input type="text" name="tempat_lahir" class="form-control" value="<?= $str->tempat_lahir ?>" readonly>
</div>
<div class="form-group">
<label>Tanggal Lahir</label>
<input type="date" name="tanggal_lahir" class="form-control" value="<?= $str->tanggal_lahir ?>" readonly>
</div> -->
<div class="form-group">
<label>No Telepon</label>
<input type="text" name="no_telepon" class="form-control" value="<?= $str->no_telepon ?>" readonly>
</div>
<div class="form-group">
<label>Alamat</label>
<textarea name="alamat" class="form-control" readonly><?= $str->alamat ?></textarea>
</div>
<div class="form-group">
<label>Pekerjaan</label>
<input type="text" name="pekerjaan" class="form-control" value="<?= $str->pekerjaan ?>" readonly>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-danger" data-dismiss="modal">Tutup</button>
</div>
</form>
<!-- <script>
$(document).ready(function() {
$('.datepicker').datepicker({
format: 'yyyy-mm-dd',
autoclose: true,
todayHighlight: true
});
});
</script> -->
</div>
</div>
</div>
</div>
<?php } ?>
<!-- Modal Edit-->
<?php foreach ($santri as $str) { ?>
<div class="modal fade" id="edit<?= $str->id_santri ?>" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<h5 class="modal-title" id="exampleModalLabel">Edit Wali Santri</h5>
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span>
</button>
</div>
<div class="modal-body">
<form id="formEdit<?= $str->id_santri ?>" action="<?= base_url('walisantri/edit/' . $str->id_wali_santri) ?>" method="POST">
<?php if (is_object($str)) : ?>
<input type="hidden" name="id_santri" value="<?= $str->id_santri ?>" data-default="<?= $str->id_santri ?>">
<?php endif; ?>
<div class="form-group">
<label>Email</label>
<input type="text" name="email" class="form-control form-control-user" value="<?= $str->email ?>">
<?= form_error('email', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Password</label>
<input type="text" name="password" class="form-control" value="<?= $str->password ?>">
<?= form_error('password', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Nama Wali Santri</label>
<input type="text" name="nama_wali_santri" class="form-control" value="<?= $str->nama_wali_santri ?>">
<?= form_error('nama_wali_santri', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Nama Santri</label>
<input type="text" name="nama_santri" class="form-control" value="<?= $str->nama_santri ?>" readonly>
</div>
<!-- <div class="form-group">
<label>NIS</label>
<input type="text" name="NIS" class="form-control" value="<?= $str->NIS ?>" readonly>
</div>
<div class="form-group">
<label>No KTP</label>
<input type="text" name="no_ktp" class="form-control" value="<?= $str->no_ktp ?>">
<?= form_error('no_ktp', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tempat Lahir</label>
<input type="text" name="tempat_lahir" class="form-control" value="<?= $str->tempat_lahir ?>">
<?= form_error('tempat_lahir', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Tanggal Lahir</label>
<input type="date" name="tanggal_lahir" class="form-control" value="<?= $str->tanggal_lahir ?>">
<?= form_error('tanggal_lahir', '<div class="text-small text-danger">', '</div>'); ?>
</div> -->
<div class="form-group">
<label>No Telepon</label>
<input type="text" name="no_telepon" class="form-control" value="<?= $str->no_telepon ?>">
<?= form_error('no_telepon', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Alamat</label>
<textarea name="alamat" class="form-control"><?= $str->alamat ?></textarea>
<?= form_error('alamat', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="form-group">
<label>Pekerjaan</label>
<input type="text" name="pekerjaan" class="form-control" value="<?= $str->pekerjaan ?>">
<?= form_error('pekerjaan', '<div class="text-small text-danger">', '</div>'); ?>
</div>
<div class="modal-footer">
<button type="submit" class="btn btn-primary btn-sm"><i class="fas fa-save"></i> Simpan </button>
</div>
</form>
</div>
</div>
</div>
</div>
<?php } ?>
<!-- CSS untuk mengubah background dan border <th> dan <td> -->
<style>
/* Ubah warna border tabel menjadi hijau */
table.table-bordered {
border: 2px solid green;
/* Border luar tabel */
}
/* Ubah warna background dan border header tabel */
table.table-bordered th {
background-color: #e0f7e0;
/* Hijau muda untuk header */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Ubah warna background dan border sel tabel */
table.table-bordered td {
background-color: #f0fff0;
/* Hijau sangat muda untuk sel */
border: 1px solid green;
/* Warna border hijau */
color: #333;
/* Warna teks */
}
/* Hapus panah sorting bawaan template atau Bootstrap */
table.dataTable thead .sorting:after,
table.dataTable thead .sorting_asc:after,
table.dataTable thead .sorting_desc:after {
display: none !important;
}
.form-control:not([size]):not([multiple]) {
background-image: none !important;
/* Menghilangkan panah bawaan Bootstrap */
}
.custom-button {
font-family: inherit;
/* Mengikuti font dari parent */
font-size: 0.9rem;
/* Sesuaikan dengan font pada h3 */
font-weight: bold;
/* Jika judul pakai bold, tombol juga dibuat bold */
text-transform: capitalize;
/* Mengikuti format teks di judul */
padding: 6px 13px;
/* Sesuaikan padding agar proporsional */
}
</style>
<!-- DataTables Initialization -->
<script>
$(document).ready(function() {
$('#tb_santri').DataTable({
"paging": true, // Enable pagination
"lengthChange": true, // Allow user to change number of rows shown
"searching": true, // Enable search
"ordering": true, // Enable column sorting
"info": true, // Show table info
"autoWidth": false, // Disable auto column width adjustment
});
});
document.addEventListener("DOMContentLoaded", function() {
document.querySelectorAll(".reset-btn").forEach(button => {
button.addEventListener("click", function() {
var id = this.getAttribute("data-id");
var form = document.getElementById("formEdit" + id);
if (form) {
form.reset(); // Reset semua input di form
// Handle input yang memiliki value dari PHP agar benar-benar kosong
form.querySelectorAll("input:not([readonly]), textarea").forEach(input => {
input.value = "";
});
// Jika ada datepicker, kosongkan juga
var dateInput = form.querySelector(".datepicker");
if (dateInput) {
dateInput.value = "";
}
// **Kembalikan nilai id_santri agar tidak kosong!**
var idSantriInput = form.querySelector("input[name='id_santri']");
if (idSantriInput) {
idSantriInput.value = idSantriInput.getAttribute("data-default");
}
}
});
});
});
</script>

Some files were not shown because too many files have changed in this diff Show More