summaryrefslogtreecommitdiff
path: root/src/web/core/component.php
blob: 376e24dc5fdb1152c8cf776243a5aeaa4132d04d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
<?php /* Copyright (c) 2024 Freya Murphy */

/**
 * Gives access to imporant
 * needed utility functions for
 * accessing everything else!
 */
abstract class Component extends Core {

	// keep track of what has been loaded
	private static array $loaded = array();

// ============================= LOADABLE OBJECTS ==

	/**
	 * Loads a $type of object from a $dir with a given $name
	 * @param string $name - the name of the object to load
	 * @param string $dir - the directory theese objects are stored in
	 * @param string $type - the type of the object
	 */
	private function load_type($name, $dir, $type): object|NULL
	{

		$path = $dir . '/' . $name . '.php';

		// dont reload an ohject
		if (array_key_exists($path, Component::$loaded))
			return Component::$loaded[$path];

		// only load a object if it exists
		if (!file_exists($path))
			return NULL;


		$parts = explode('/', $name);
		$part = end($parts);
		$class = ucfirst($part) . '_' . $type;
		require($path);

		$ref = NULL;
		try {
			$ref = new ReflectionClass($class);
		} catch (Exception $_e) {}

		if ($ref === NULL)
			return NULL;

		$obj = $ref->newInstance();
		Component::$loaded[$path] = $obj;

		return $obj;
	}

	/**
	 * Loads a model
	 * @param string $name - the name of the model to load
	 */
	protected function load_model($name): Model|NULL
	{
		$dir = WEB_ROOT . '/_model';
		return $this->load_type($name, $dir, 'model');
	}

	/**
	 * Loads a controller
	 * @param string $name - the name of the controller to load
	 */
	public function load_controller($name): Controller|NULL
	{
		$dir = WEB_ROOT . '/_controller';
		return $this->load_type($name, $dir, 'controller');
	}

// ========================================= LANG ==

	/**
	 * Loads a php lang file into the lang array
	 */
	private static function load_lang_file(string $file): void
	{
		$lang = $GLOBALS['__lang'];
		require($file);
		$GLOBALS['__lang'] = $lang;
	}

	/**
	 * Loads each php file lang strings in a directory
	 */
	private static function load_lang_dir(string $dir): void
	{
		if ($handle = opendir($dir)) {
			while (false !== ($entry = readdir($handle))) {
				if ($entry === '.' || $entry === '..')
					continue;
				Component::load_lang_file($entry);
			}
		}
	}

	/**
	 * Loads the given common lang
	 */
	protected static function load_lang(string ...$langs): void
	{
		$root = WEB_ROOT . '/lang';

		foreach ($langs as $lang) {
			$file = "{$root}/{$lang}.php";
			$dir = "{$root}/{$lang}";

			if (file_exists($file))
				Component::load_lang_file($file);
			else if (is_dir($dir))
				Component::load_lang_dir($dir);

		}
	}

}