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; return true;
} }
public function search( $table, $column, $param ) { public function searchColumn( $table, $column, $param ) {
return $this->action( 'SELECT *', $table, [$column, 'LIKE', '%' . $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. * Selects data from the database.
* *

View File

@ -17,8 +17,9 @@ use TheTempusProject\Bedrock\Functions\Check;
use TheTempusProject\Bedrock\Bedrock; use TheTempusProject\Bedrock\Bedrock;
class DatabaseModel extends Model { class DatabaseModel extends Model {
public $databaseMatrix;
public $tableName; public $tableName;
public $databaseMatrix;
public $searchFields;
public function __construct() { public function __construct() {
parent::__construct(); parent::__construct();
@ -190,4 +191,19 @@ class DatabaseModel extends Model {
} }
return $this->filter( $data->results() ); 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} * @return {bool}
*/ */
public static function imageUpload( $imageName ) { public static function imageUpload( $imageName ) {
if ( !Config::getValue( 'uploads/images' ) ) { if ( ! Config::getValue( 'uploads/images' ) ) {
self::addUserError( 'Image uploads are disabled.' ); self::addUserError( 'Image uploads are disabled.' );
return false; return false;
} }
if ( !isset( $_FILES[$imageName] ) ) { if ( ! isset( $_FILES[ $imageName ] ) ) {
self::addUserError( 'File not found.', $imageName ); self::addUserError( 'File not found.', $imageName );
return false; 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. 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.** **Notice: This Library is provided as is, please use at your own risk.**
## Installation and Use ## 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": { "require": {
"TheTempusProject/Bedrock": "*", "TheTempusProject/Bedrock": "*",
}, },
"autoload": { "autoload": {
"psr-4": { "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 - [ ] Expansion of PDO to allow different database types
- [ ] template stuff should really only be called from template/controllers - [ ] Updates for configs and models to re-build based on a delta model, to make version changes simpler. (Migration system)
- [ ] Update installer to account for updates. - [ ] Implement better uniformity in terms of error reporting, exceptions, logging.
- [ ] Implement uniformity in terms of error reporting, exceptions, logging.