Compare commits
4 Commits
Author | SHA1 | Date | |
---|---|---|---|
ddb17cc473 | |||
62e1e8f338 | |||
0501718421 | |||
0f00069165 |
@ -1,6 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "itguild/forms",
|
"name": "itguild/forms",
|
||||||
"type": "library",
|
"type": "library",
|
||||||
|
"license": "MIT",
|
||||||
"autoload": {
|
"autoload": {
|
||||||
"psr-4": {
|
"psr-4": {
|
||||||
"itguild\\forms\\": "src/"
|
"itguild\\forms\\": "src/"
|
||||||
@ -8,9 +9,11 @@
|
|||||||
},
|
},
|
||||||
"authors": [
|
"authors": [
|
||||||
{
|
{
|
||||||
"name": "Kavalar"
|
"name": "Kavalar",
|
||||||
|
"email": "apuc06@mail.ru"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
"minimum-stability": "dev",
|
||||||
"require": {
|
"require": {
|
||||||
"twbs/bootstrap": "5.0.2",
|
"twbs/bootstrap": "5.0.2",
|
||||||
"itguild/php-cg-select-v2": "^0.1.0",
|
"itguild/php-cg-select-v2": "^0.1.0",
|
||||||
|
@ -3,7 +3,7 @@ require_once __DIR__ . "/vendor/autoload.php";
|
|||||||
|
|
||||||
$form = new \itguild\forms\ActiveForm();
|
$form = new \itguild\forms\ActiveForm();
|
||||||
$form->beginForm("/some_action");
|
$form->beginForm("/some_action");
|
||||||
$form->field(class: \itguild\forms\inputs\TextInput::class, name: "login", params: [
|
$form->field(class: \itguild\forms\inputs\File::class, name: "login", params: [
|
||||||
'class' => "form-control",
|
'class' => "form-control",
|
||||||
'placeholder' => 'Логин',
|
'placeholder' => 'Логин',
|
||||||
])
|
])
|
||||||
|
@ -4,11 +4,12 @@ require_once __DIR__ . "/vendor/autoload.php";
|
|||||||
|
|
||||||
$form = new \itguild\forms\ActiveForm();
|
$form = new \itguild\forms\ActiveForm();
|
||||||
$form->beginForm("/some_action");
|
$form->beginForm("/some_action");
|
||||||
$form->field(class: \itguild\forms\inputs\TextInput::class, name: "login", params: [
|
$form->field(class: \itguild\forms\inputs\File::class, name: "login", params: [
|
||||||
'class' => "form-control",
|
'class' => "form-control",
|
||||||
'placeholder' => 'Логин',
|
'placeholder' => 'Файл',
|
||||||
])
|
])
|
||||||
->setLabel("Логин")
|
->setLabel("Файл")
|
||||||
->render();
|
->setMultiple()
|
||||||
|
->render();
|
||||||
|
|
||||||
$form->endForm();
|
$form->endForm();
|
@ -4,6 +4,7 @@ namespace itguild\forms;
|
|||||||
|
|
||||||
use itguild\forms\builders\ButtonBuilder;
|
use itguild\forms\builders\ButtonBuilder;
|
||||||
use itguild\forms\builders\CheckBoxBuilder;
|
use itguild\forms\builders\CheckBoxBuilder;
|
||||||
|
use itguild\forms\builders\FileBuilder;
|
||||||
use itguild\forms\builders\HiddenBuilder;
|
use itguild\forms\builders\HiddenBuilder;
|
||||||
use itguild\forms\builders\RadioButtonBuilder;
|
use itguild\forms\builders\RadioButtonBuilder;
|
||||||
use itguild\forms\builders\SelectBuilder;
|
use itguild\forms\builders\SelectBuilder;
|
||||||
@ -13,6 +14,7 @@ use itguild\forms\debug\Debug;
|
|||||||
use itguild\forms\inputs\BaseInput;
|
use itguild\forms\inputs\BaseInput;
|
||||||
use itguild\forms\inputs\Button;
|
use itguild\forms\inputs\Button;
|
||||||
use itguild\forms\inputs\Checkbox;
|
use itguild\forms\inputs\Checkbox;
|
||||||
|
use itguild\forms\inputs\File;
|
||||||
use itguild\forms\inputs\Hidden;
|
use itguild\forms\inputs\Hidden;
|
||||||
use itguild\forms\inputs\RadioButton;
|
use itguild\forms\inputs\RadioButton;
|
||||||
use itguild\forms\inputs\Select;
|
use itguild\forms\inputs\Select;
|
||||||
@ -29,9 +31,9 @@ class ActiveForm
|
|||||||
* @param string $action
|
* @param string $action
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function beginForm(string $action): void
|
public function beginForm(string $action, string $enctype = 'application/x-www-form-urlencoded'): void
|
||||||
{
|
{
|
||||||
echo "<form method='POST' action='$action'>";
|
echo "<form method='POST' action='$action' enctype='$enctype'>";
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -43,7 +45,7 @@ class ActiveForm
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function field($class, string $name, array $params = [])
|
public function field($class, string $name, array $params = []): static
|
||||||
{
|
{
|
||||||
if ($class === Select::class){
|
if ($class === Select::class){
|
||||||
$this->fieldObject = SelectBuilder::build($name, $params);
|
$this->fieldObject = SelectBuilder::build($name, $params);
|
||||||
@ -66,10 +68,12 @@ class ActiveForm
|
|||||||
elseif ($class === Hidden::class){
|
elseif ($class === Hidden::class){
|
||||||
$this->fieldObject = HiddenBuilder::build($name, $params);
|
$this->fieldObject = HiddenBuilder::build($name, $params);
|
||||||
}
|
}
|
||||||
|
elseif ($class === File::class){
|
||||||
|
$this->fieldObject = FileBuilder::build($name, $params);
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
$this->fieldObject = new $class($name, $params);
|
$this->fieldObject = new $class($name, $params);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -94,6 +98,13 @@ class ActiveForm
|
|||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function setMultiple(): self
|
||||||
|
{
|
||||||
|
$this->fieldObject->setMultiple();
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function render()
|
public function render()
|
||||||
{
|
{
|
||||||
$this->fieldObject->create();
|
$this->fieldObject->create();
|
||||||
|
15
src/builders/FileBuilder.php
Normal file
15
src/builders/FileBuilder.php
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace itguild\forms\builders;
|
||||||
|
|
||||||
|
use itguild\forms\debug\Debug;
|
||||||
|
use itguild\forms\inputs\BaseInput;
|
||||||
|
use itguild\forms\inputs\File;
|
||||||
|
|
||||||
|
class FileBuilder implements Builder
|
||||||
|
{
|
||||||
|
public static function build(string $name, array $params = []): BaseInput
|
||||||
|
{
|
||||||
|
return new File(name: $name, paramsArray: $params);
|
||||||
|
}
|
||||||
|
}
|
60
src/inputs/File.php
Normal file
60
src/inputs/File.php
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace itguild\forms\inputs;
|
||||||
|
|
||||||
|
use itguild\forms\inputs\BaseInput;
|
||||||
|
use itguild\forms\templates\Simple\SimpleTemplate;
|
||||||
|
use itguild\forms\traits\CreateParams;
|
||||||
|
|
||||||
|
class File extends BaseInput
|
||||||
|
{
|
||||||
|
use CreateParams;
|
||||||
|
private string $name;
|
||||||
|
private array $paramsArray;
|
||||||
|
private string $multiple;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $name
|
||||||
|
* @param array $paramsArray
|
||||||
|
*/
|
||||||
|
|
||||||
|
public function __construct(string $name, array $paramsArray = [])
|
||||||
|
{
|
||||||
|
$this->name = $name;
|
||||||
|
$this->paramsArray = $paramsArray;
|
||||||
|
$this->inputTemplate = new SimpleTemplate();
|
||||||
|
$this->multiple = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return self
|
||||||
|
*/
|
||||||
|
public function create(): self
|
||||||
|
{
|
||||||
|
$paramsString = $this->createParams($this->paramsArray);
|
||||||
|
$input = "<input type='file' name='$this->name' $this->multiple $paramsString >";
|
||||||
|
|
||||||
|
$this->createLabel();
|
||||||
|
|
||||||
|
$this->html = str_replace('{input}', $input, $this->inputTemplate->getInputTemplate());
|
||||||
|
$this->html = str_replace('{label}', $this->labelString, $this->html);
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $name
|
||||||
|
* @param array $paramsArray
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public static function build(string $name, array $paramsArray = []): void
|
||||||
|
{
|
||||||
|
$input = new self($name, $paramsArray);
|
||||||
|
$input->create()->render();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function setMultiple(): void
|
||||||
|
{
|
||||||
|
$this->multiple = 'multiple';
|
||||||
|
}
|
||||||
|
}
|
@ -73,9 +73,9 @@ class Select extends BaseInput
|
|||||||
* @param $options
|
* @param $options
|
||||||
* @return $this
|
* @return $this
|
||||||
*/
|
*/
|
||||||
public function setOptions($options)
|
public function setOptions($options): static
|
||||||
{
|
{
|
||||||
$this->options = array_merge($options, $this->options);
|
$this->options = $options + $this->options;
|
||||||
|
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user