2 Commits

Author SHA1 Message Date
795784f02e Improved Search Functionality 2025-01-30 18:13:12 -05:00
b1e74f9652 Readme update 2025-01-27 22:54:56 -05:00
4 changed files with 71 additions and 15 deletions

View File

@ -637,10 +637,29 @@ class Database {
return true;
}
public function search( $table, $column, $param ) {
public function searchColumn( $table, $column, $param ) {
return $this->action( 'SELECT *', $table, [$column, 'LIKE', '%' . $param . '%'] );
}
public function search( $table, $columns, $param ) {
if ( empty( $columns ) || ! is_array( $columns ) ) {
Debug::log( 'No columns provided for search' );
return [];
}
$conditions = [];
foreach ( $columns as $column ) {
$conditions[] = $column;
$conditions[] = 'LIKE';
$conditions[] = '%' . $param . '%';
$conditions[] = 'OR';
}
array_pop( $conditions );
return $this->action( 'SELECT *', $table, $conditions );
// return $this->action( 'SELECT ' . implode( ',', $columns ), $table, $conditions ); // need to find a way to casually make this the default....
}
/**
* Selects data from the database.
*

View File

@ -17,8 +17,9 @@ use TheTempusProject\Bedrock\Functions\Check;
use TheTempusProject\Bedrock\Bedrock;
class DatabaseModel extends Model {
public $databaseMatrix;
public $tableName;
public $databaseMatrix;
public $searchFields;
public function __construct() {
parent::__construct();
@ -190,4 +191,19 @@ class DatabaseModel extends Model {
}
return $this->filter( $data->results() );
}
public function search($param) {
if (empty($this->searchFields)) {
Debug::log('searchFields is empty');
return [];
}
$result = self::$db->search($this->tableName, $this->searchFields, $param);
if ( $result->count() ) {
return $this->filter( $result->results() );
}
return [];
}
}

View File

@ -99,11 +99,11 @@ class Check {
* @return {bool}
*/
public static function imageUpload( $imageName ) {
if ( !Config::getValue( 'uploads/images' ) ) {
if ( ! Config::getValue( 'uploads/images' ) ) {
self::addUserError( 'Image uploads are disabled.' );
return false;
}
if ( !isset( $_FILES[$imageName] ) ) {
if ( ! isset( $_FILES[ $imageName ] ) ) {
self::addUserError( 'File not found.', $imageName );
return false;
}

View File

@ -1,31 +1,52 @@
# Tempus Project Core
###### Developer(s): Joey Kimsey
Bedrock is the core functionality used by [The Tempus Project](https://github.com/TheTempusProject/TheTempusProject) a rapid prototyping framework. This Library can be utilized outside of the TempusProject, but the functionality has not been tested well as a stand alone library.
# Bedrock
## Developer(s): Joey Kimsey
This library utilizes the MVC architecture in addition to a custom templating engine designed to make building web applications fast and simple.
Bedrock is the core functionality used by [The Tempus Project](https://github.com/TheTempusProject/TheTempusProject) a rapid prototyping framework. It provides database support, configuration, base models, and base controller functionality a in addition to a host of other integrated functions.
This Library can be utilized outside of TheTempusProject, but the functionality has not been tested well as a stand-alone library.
**Notice: This Library is provided as is, please use at your own risk.**
## Installation and Use
The easiest way to use Bedrock in your application is to install and initialize it via composer.
```
The easiest way to use Bedrock in your application is to install it via composer and extend the main app inside of the bin folder.
`Composer.json`
```json
"require": {
"TheTempusProject/Bedrock": "*",
},
"autoload": {
"psr-4": {
"Bedrock\": "vendor/TheTempusProject/Bedrock"
"TheTempusProject\\Bedrock\\": "vendor/thetempusproject/bedrock",
}
}
```
If you prefer to handle auto-loading via other means, you can simply clone this repository wherever you need it. Please note, you will need to install and load the [TempusDebugger](https://github.com/thetempusproject/TempusDebugger) library in order to utilize the debug to console options.
`app.php`
```php
<?php
namespace MyApp;
use TheTempusProject\Bedrock\Bin\Bedrock;
class MyApp extends Bedrock {
// Stuff and Things
}
?>
```
If you prefer to handle auto-loading via other means, you can simply clone this repository wherever you need it.
### To-Do
### WIP:
- [ ] Expansion of PDO to allow different database types
- [ ] template stuff should really only be called from template/controllers
- [ ] Update installer to account for updates.
- [ ] Implement uniformity in terms of error reporting, exceptions, logging.
- [ ] Updates for configs and models to re-build based on a delta model, to make version changes simpler. (Migration system)
- [ ] Implement better uniformity in terms of error reporting, exceptions, logging.