mirror of
				https://github.com/slawkens/myaac.git
				synced 2025-11-04 09:46:23 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			132 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			132 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
/**
 | 
						|
 * CHANGELOG modifier
 | 
						|
 *
 | 
						|
 * @package   MyAAC
 | 
						|
 * @author    Slawkens <slawkens@gmail.com>
 | 
						|
 * @author    Lee
 | 
						|
 * @copyright 2020 MyAAC
 | 
						|
 * @link      https://my-aac.org
 | 
						|
 */
 | 
						|
 | 
						|
use MyAAC\Changelog;
 | 
						|
use MyAAC\Models\Changelog as ModelsChangelog;
 | 
						|
 | 
						|
defined('MYAAC') or die('Direct access not allowed!');
 | 
						|
 | 
						|
$title = 'Changelog';
 | 
						|
 | 
						|
csrfProtect();
 | 
						|
 | 
						|
if (!hasFlag(FLAG_CONTENT_PAGES) && !superAdmin()) {
 | 
						|
	echo 'Access denied.';
 | 
						|
	return;
 | 
						|
}
 | 
						|
 | 
						|
$use_datatable = true;
 | 
						|
const CL_LIMIT = 600; // maximum changelog body length
 | 
						|
 | 
						|
$id = $_GET['id'] ?? 0;
 | 
						|
 | 
						|
if(!empty($action) && isRequestMethod('post'))
 | 
						|
{
 | 
						|
	$id = $_POST['id'] ?? null;
 | 
						|
	$body = isset($_POST['body']) ? stripslashes($_POST['body']) : null;
 | 
						|
	$create_date = isset($_POST['createdate']) ? (int)strtotime($_POST['createdate'] ): null;
 | 
						|
	$player_id = isset($_POST['player_id']) ? (int)$_POST['player_id'] : null;
 | 
						|
	$type = isset($_POST['type']) ? (int)$_POST['type'] : null;
 | 
						|
	$where = isset($_POST['where']) ? (int)$_POST['where'] : null;
 | 
						|
 | 
						|
	$errors = array();
 | 
						|
 | 
						|
	if($action == 'new') {
 | 
						|
 | 
						|
		if(isset($body) && Changelog::add($body, $type, $where, $player_id, $create_date, $errors)) {
 | 
						|
			$body = '';
 | 
						|
			$type = $where = $player_id = $create_date = 0;
 | 
						|
 | 
						|
			success('Added successful.');
 | 
						|
		}
 | 
						|
	}
 | 
						|
	else if($action == 'delete') {
 | 
						|
		if (Changelog::delete($id, $errors)) {
 | 
						|
			success('Deleted successful.');
 | 
						|
		}
 | 
						|
	}
 | 
						|
	else if($action == 'edit')
 | 
						|
	{
 | 
						|
		if(isset($id) && !isset($body)) {
 | 
						|
			$cl = Changelog::get($id);
 | 
						|
			$body = $cl['body'];
 | 
						|
			$type = $cl['type'];
 | 
						|
			$where = $cl['where'];
 | 
						|
			$create_date = $cl['date'];
 | 
						|
			$player_id = $cl['player_id'];
 | 
						|
		}
 | 
						|
		else {
 | 
						|
			if(Changelog::update($id, $body, $type, $where, $player_id, $create_date,$errors)) {
 | 
						|
				$action = $body = '';
 | 
						|
				$type = $where = $player_id = $create_date = 0;
 | 
						|
 | 
						|
				success('Updated successful.');
 | 
						|
			}
 | 
						|
		}
 | 
						|
	}
 | 
						|
	else if($action == 'hide') {
 | 
						|
		if (Changelog::toggleHide($id, $errors, $status)) {
 | 
						|
			success(($status == 1 ? 'Hide' : 'Show') . ' successful.');
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	if(!empty($errors))
 | 
						|
		error(implode(", ", $errors));
 | 
						|
}
 | 
						|
 | 
						|
$changelogs = ModelsChangelog::orderBy('id')->get()->toArray();
 | 
						|
 | 
						|
$i = 0;
 | 
						|
 | 
						|
$log_type = [
 | 
						|
	['id' => 1, 'icon' => 'added'],
 | 
						|
	['id' => 2, 'icon' => 'removed'],
 | 
						|
	['id' => 3, 'icon' => 'changed'],
 | 
						|
	['id' => 4, 'icon' => 'fixed'],
 | 
						|
];
 | 
						|
 | 
						|
$log_where = [
 | 
						|
	['id' => 1, 'icon' => 'server'],
 | 
						|
	['id' => 2, 'icon' => 'website'],
 | 
						|
];
 | 
						|
 | 
						|
foreach($changelogs as $key => &$log)
 | 
						|
{
 | 
						|
	$log['type'] = getChangelogType($log['type']);
 | 
						|
	$log['where'] = getChangelogWhere($log['where']);
 | 
						|
}
 | 
						|
 | 
						|
if($action == 'edit' || $action == 'new') {
 | 
						|
	if($action == 'edit') {
 | 
						|
		$player = new OTS_Player();
 | 
						|
		$player->load($player_id);
 | 
						|
	}
 | 
						|
 | 
						|
	$account_players = $account_logged->getPlayersList();
 | 
						|
	$account_players->orderBy('group_id', POT::ORDER_DESC);
 | 
						|
	$twig->display('admin.changelog.form.html.twig', array(
 | 
						|
		'action' => $action,
 | 
						|
		'cl_link_form' => constant('ADMIN_URL').'?p=changelog',
 | 
						|
		'cl_id' => $id ?? null,
 | 
						|
		'body' => isset($body) ? escapeHtml($body) : '',
 | 
						|
		'create_date' => $create_date ?? '',
 | 
						|
		'player_id' => $player_id ?? null,
 | 
						|
		'account_players' => $account_players,
 | 
						|
		'type' => $type ?? 0,
 | 
						|
		'where' => $where ?? 0,
 | 
						|
		'log_type' => $log_type,
 | 
						|
		'log_where' => $log_where,
 | 
						|
	));
 | 
						|
}
 | 
						|
$twig->display('admin.changelog.html.twig', array(
 | 
						|
	'changelogs' => $changelogs,
 | 
						|
));
 |