Form renderer for Nette Forms - TwitterBootstrap v5 and v4
Version | PHP | Recommended Nette | Description |
---|---|---|---|
dev-master | >= 7.1 | Nette 3.0 (Nette\SmartObject) | DEV |
1.1.x | >= 7.1 | Nette 3.0 (Nette\SmartObject) | Add TBv5 |
1.0.x | >= 7.1 | Nette 3.0 (Nette\SmartObject) | Only TBv4 |
Install with composer:
composer require venca-x/nette-form-renderer
composer require venca-x/nette-form-renderer:dev-master
Types of orientation form
- Vertical
- Horizontal
- Inline
Vertical form orientation is default.
$form = new Form;
$form->setRenderer(new VencaX\NetteFormRenderer\BootstrapRendererV5());
$form->addEmail('exampleInputEmail1', 'Email address:')
->setHtmlAttribute('placeholder', 'Enter email')
->setOption('description', 'We\'ll never share your email with anyone else.');
$form->addPassword('exampleInputPassword1', 'Password')
->setHtmlAttribute('placeholder', 'Password');
$form->addCheckbox('checkbox', 'Check me out');
$form->addCheckbox('checkbox2', 'Check me out2');
$form->addRadioList('country', 'Country', [
'cz' => 'Česká republika',
'sk' => 'Slovensko',
'eu' => 'EU',
]);
$form->addEmail('exampleInputEmail2', 'Email address')
->setHtmlAttribute('placeholder', '[email protected]');
$form->addSelect('exampleSelect', 'Example select', [
'1',
'2',
'3',
'4',
'5', ]);
$form->addMultiSelect('exampleMultipleSelect', 'Example multiple select', [
'1',
'2',
'3',
'4',
'5', ]);
$form->addTextArea('textarea', 'Example textarea');
$form->addUpload('upload', 'Example upload');
$form->addMultiUpload('multiUpload', 'Example multiUpload');
//sizes
$form->addEmail('formControlLg', '.form-control-lg')
->setHtmlAttribute('class', 'form-control-lg')
->setHtmlAttribute('placeholder', '.form-control-lg');
$form->addEmail('formControl', '.form-control')
->setHtmlAttribute('placeholder', 'Default input');
$form->addEmail('formControlSm', '.form-control-sm')
->setHtmlAttribute('class', 'form-control-sm')
->setHtmlAttribute('placeholder', '.form-control-sm');
//sizes select
$form->addSelect('largeSelect', 'Large select', ['Large select'])
->setHtmlAttribute('class', 'form-control-lg');
$form->addSelect('defaultSelect', ' Default select', ['Default select']);
$form->addSelect('smallSelect', 'Small select', ['Small select'])
->setHtmlAttribute('class', 'form-control-sm');
//disables
$form->addText('disabled', 'Disabled:')
->setHtmlAttribute('placeholder', 'Disabled input here…')
->setDisabled(true);
$form->addSubmit('submit', 'Submit')->setHtmlAttribute('class', 'btn btn-primary');
return $form;
$form = new Form;
$form->setRenderer(new VencaX\NetteFormRenderer\BootstrapRendererV5());
$form->addCheckbox('mondayCheckbox', 'Monday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addCheckbox('tuesdayCheckbox', 'Tuesday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addCheckbox('wednesdayCheckbox', 'Wednesday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addCheckbox('thurstdayCheckbox', 'Thurstday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addCheckbox('fridayCheckbox', 'Friday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addCheckbox('saturdayCheckbox', 'Saturday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addCheckbox('sundayCheckbox', 'Sunday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addRadioList('weekRadionline', 'Week radio 2', [
'monday' => 'Monday',
'tuesday' => 'Tuesday',
'wednesday' => 'Wednesday',
'thurstday' => 'Thurstday',
'friday' => 'Friday',
'saturday' => 'Saturday',
'sunday' => 'Sunday',
])->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addSubmit('submit', 'Submit')->setHtmlAttribute('class', 'btn btn-primary');
return $form;
$form = new Form;
$form->setRenderer(new VencaX\NetteFormRenderer\BootstrapRendererV5());
//horizontal form
$renderer = $form->getRenderer();
$renderer->setFormHorizontalOrientation();
//$renderer->setFormControlLabelWidth('col-sm-6');
//$renderer->setFormControlContainerWidth('col-sm-6');
$form->addEmail('exampleInputEmail1', 'Email address:')
->setHtmlAttribute('placeholder', 'Enter email')
->setOption('description', 'We\'ll never share your email with anyone else.');
$form->addPassword('exampleInputPassword1', 'Password')
->setHtmlAttribute('placeholder', 'Password');
$form->addCheckbox('checkbox', 'Check me out');
$form->addCheckbox('checkbox2', 'Check me out2');
$form->addRadioList('country', 'Country', [
'cz' => 'Česká republika',
'sk' => 'Slovensko',
'eu' => 'EU',
]);
$form->addEmail('exampleInputEmail2', 'Email address')
->setHtmlAttribute('placeholder', '[email protected]');
$form->addSelect('exampleSelect', 'Example select', [
'1',
'2',
'3',
'4',
'5', ]);
$form->addMultiSelect('exampleMultipleSelect', 'Example multiple select', [
'1',
'2',
'3',
'4',
'5', ]);
$form->addTextArea('textarea', 'Example textarea');
$form->addUpload('upload', 'Example upload');
$form->addMultiUpload('multiUpload', 'Example multiUpload');
//sizes
$form->addEmail('formControlLg', '.form-control-lg')
->setHtmlAttribute('class', 'form-control-lg')
->setHtmlAttribute('placeholder', '.form-control-lg');
$form->addEmail('formControl', '.form-control')
->setHtmlAttribute('placeholder', 'Default input');
$form->addEmail('formControlSm', '.form-control-sm')
->setHtmlAttribute('class', 'form-control-sm')
->setHtmlAttribute('placeholder', '.form-control-sm');
//sizes select
$form->addSelect('largeSelect', 'Large select', ['Large select'])
->setHtmlAttribute('class', 'form-control-lg');
$form->addSelect('defaultSelect', ' Default select', ['Default select']);
$form->addSelect('smallSelect', 'Small select', ['Small select'])
->setHtmlAttribute('class', 'form-control-sm');
//disables
$form->addText('disabled', 'Disabled:')
->setHtmlAttribute('placeholder', 'Disabled input here…')
->setDisabled(true);
$form->addSubmit('submit', 'Submit')->setHtmlAttribute('class', 'btn btn-primary');
return $form;
It is not possible to place checkboxes on one line, only radios inline.
$form = new Form;
$form->setRenderer(new VencaX\NetteFormRenderer\BootstrapRendererV5());
//horizontal form
$renderer = $form->getRenderer();
$renderer->setFormHorizontalOrientation();
//$renderer->setFormControlLabelWidth('col-sm-6');
//$renderer->setFormControlContainerWidth('col-sm-6');
//!!!!!!!!! this orientation **don't work** !!!!!!!!!!!!!!!!!
$form->addCheckbox('mondayCheckbox', 'Monday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addCheckbox('tuesdayCheckbox', 'Tuesday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addCheckbox('wednesdayCheckbox', 'Wednesday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addCheckbox('thurstdayCheckbox', 'Thurstday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addCheckbox('fridayCheckbox', 'Friday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addCheckbox('saturdayCheckbox', 'Saturday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addCheckbox('sundayCheckbox', 'Sunday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addRadioList('weekRadionline', 'Week radio 2', [
'monday' => 'Monday',
'tuesday' => 'Tuesday',
'wednesday' => 'Wednesday',
'thurstday' => 'Thurstday',
'friday' => 'Friday',
'saturday' => 'Saturday',
'sunday' => 'Sunday',
])->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV5::FORM_CHECK_INLINE);
$form->addSubmit('submit', 'Submit')->setHtmlAttribute('class', 'btn btn-primary');
return $form;
$form = new Form;
$form->setRenderer(new VencaX\NetteFormRenderer\BootstrapRendererV5());
//inline form
$renderer = $form->getRenderer();
$renderer->setFormInline();
$form->addEmail('loginemail', 'E-mail address:')
->setHtmlAttribute('placeholder', 'Enter e-mail');
$form->addPassword('password', 'Password')
->setHtmlAttribute('placeholder', 'Password');
$form->addCheckbox('checkbox', 'Check me out');
$form->addSubmit('submit', 'Submit')->setHtmlAttribute('class', 'btn btn-primary');
return $form;
$form = new Form;
$form->setRenderer(new VencaX\NetteFormRenderer\BootstrapRendererV4());
$form->addEmail('exampleInputEmail1', 'Email address:')
->setHtmlAttribute('placeholder', 'Enter email')
->setOption('description', 'We\'ll never share your email with anyone else.');
$form->addPassword('exampleInputPassword1', 'Password')
->setHtmlAttribute('placeholder', 'Password');
$form->addCheckbox('checkbox', 'Check me out');
$form->addCheckbox('checkbox2', 'Check me out2');
$form->addRadioList('country', 'Country', [
'cz' => 'Česká republika',
'sk' => 'Slovensko',
'eu' => 'EU',
]);
$form->addEmail('exampleInputEmail2', 'Email address')
->setHtmlAttribute('placeholder', '[email protected]');
$form->addSelect('exampleSelect', 'Example select', [
'1',
'2',
'3',
'4',
'5', ]);
$form->addMultiSelect('exampleMultipleSelect', 'Example multiple select', [
'1',
'2',
'3',
'4',
'5', ]);
$form->addTextArea('textarea', 'Example textarea');
$form->addUpload('upload', 'Example upload');
$form->addMultiUpload('multiUpload', 'Example multiUpload');
//sizes
$form->addEmail('formControlLg', '.form-control-lg')
->setHtmlAttribute('class', 'form-control-lg')
->setHtmlAttribute('placeholder', '.form-control-lg');
$form->addEmail('formControl', '.form-control')
->setHtmlAttribute('placeholder', 'Default input');
$form->addEmail('formControlSm', '.form-control-sm')
->setHtmlAttribute('class', 'form-control-sm')
->setHtmlAttribute('placeholder', '.form-control-sm');
//sizes select
$form->addSelect('largeSelect', 'Large select', ['Large select'])
->setHtmlAttribute('class', 'form-control-lg');
$form->addSelect('defaultSelect', ' Default select', ['Default select']);
$form->addSelect('smallSelect', 'Small select', ['Small select'])
->setHtmlAttribute('class', 'form-control-sm');
//disables
$form->addText('disabled', 'Disabled:')
->setHtmlAttribute('placeholder', 'Disabled input here…')
->setDisabled(true);
$form->addSubmit('submit', 'Submit')->setHtmlAttribute('class', 'btn btn-primary');
return $form;
$form = new Form;
$form->setRenderer(new VencaX\NetteFormRenderer\BootstrapRendererV4());
$form->addCheckbox('mondayCheckbox', 'Monday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addCheckbox('tuesdayCheckbox', 'Tuesday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addCheckbox('wednesdayCheckbox', 'Wednesday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addCheckbox('thurstdayCheckbox', 'Thurstday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addCheckbox('fridayCheckbox', 'Friday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addCheckbox('saturdayCheckbox', 'Saturday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addCheckbox('sundayCheckbox', 'Sunday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addRadioList('weekRadionline', 'Week radio 2', [
'monday' => 'Monday',
'tuesday' => 'Tuesday',
'wednesday' => 'Wednesday',
'thurstday' => 'Thurstday',
'friday' => 'Friday',
'saturday' => 'Saturday',
'sunday' => 'Sunday',
])->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addSubmit('submit', 'Submit')->setHtmlAttribute('class', 'btn btn-primary');
return $form;
$form = new Form;
$form->setRenderer(new VencaX\NetteFormRenderer\BootstrapRendererV4());
//horizontal form
$renderer = $form->getRenderer();
$renderer->setFormHorizontalOrientation();
//$renderer->setFormControlLabelWidth('col-sm-6');
//$renderer->setFormControlContainerWidth('col-sm-6');
$form->addEmail('exampleInputEmail1', 'Email address:')
->setHtmlAttribute('placeholder', 'Enter email')
->setOption('description', 'We\'ll never share your email with anyone else.');
$form->addPassword('exampleInputPassword1', 'Password')
->setHtmlAttribute('placeholder', 'Password');
$form->addCheckbox('checkbox', 'Check me out');
$form->addCheckbox('checkbox2', 'Check me out2');
$form->addRadioList('country', 'Country', [
'cz' => 'Česká republika',
'sk' => 'Slovensko',
'eu' => 'EU',
]);
$form->addEmail('exampleInputEmail2', 'Email address')
->setHtmlAttribute('placeholder', '[email protected]');
$form->addSelect('exampleSelect', 'Example select', [
'1',
'2',
'3',
'4',
'5', ]);
$form->addMultiSelect('exampleMultipleSelect', 'Example multiple select', [
'1',
'2',
'3',
'4',
'5', ]);
$form->addTextArea('textarea', 'Example textarea');
$form->addUpload('upload', 'Example upload');
$form->addMultiUpload('multiUpload', 'Example multiUpload');
//sizes
$form->addEmail('formControlLg', '.form-control-lg')
->setHtmlAttribute('class', 'form-control-lg')
->setHtmlAttribute('placeholder', '.form-control-lg');
$form->addEmail('formControl', '.form-control')
->setHtmlAttribute('placeholder', 'Default input');
$form->addEmail('formControlSm', '.form-control-sm')
->setHtmlAttribute('class', 'form-control-sm')
->setHtmlAttribute('placeholder', '.form-control-sm');
//sizes select
$form->addSelect('largeSelect', 'Large select', ['Large select'])
->setHtmlAttribute('class', 'form-control-lg');
$form->addSelect('defaultSelect', ' Default select', ['Default select']);
$form->addSelect('smallSelect', 'Small select', ['Small select'])
->setHtmlAttribute('class', 'form-control-sm');
//disables
$form->addText('disabled', 'Disabled:')
->setHtmlAttribute('placeholder', 'Disabled input here…')
->setDisabled(true);
$form->addSubmit('submit', 'Submit')->setHtmlAttribute('class', 'btn btn-primary');
return $form;
It is not possible to place checkboxes on one line, only radios inline.
$form = new Form;
$form->setRenderer(new VencaX\NetteFormRenderer\BootstrapRendererV4());
//horizontal form
$renderer = $form->getRenderer();
$renderer->setFormHorizontalOrientation();
//$renderer->setFormControlLabelWidth('col-sm-6');
//$renderer->setFormControlContainerWidth('col-sm-6');
//!!!!!!!!! this orientation **don't work** !!!!!!!!!!!!!!!!!
$form->addCheckbox('mondayCheckbox', 'Monday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addCheckbox('tuesdayCheckbox', 'Tuesday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addCheckbox('wednesdayCheckbox', 'Wednesday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addCheckbox('thurstdayCheckbox', 'Thurstday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addCheckbox('fridayCheckbox', 'Friday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addCheckbox('saturdayCheckbox', 'Saturday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addCheckbox('sundayCheckbox', 'Sunday')->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addRadioList('weekRadionline', 'Week radio 2', [
'monday' => 'Monday',
'tuesday' => 'Tuesday',
'wednesday' => 'Wednesday',
'thurstday' => 'Thurstday',
'friday' => 'Friday',
'saturday' => 'Saturday',
'sunday' => 'Sunday',
])->setOption('orientation', VencaX\NetteFormRenderer\BootstrapRendererV4::FORM_CHECK_INLINE);
$form->addSubmit('submit', 'Submit')->setHtmlAttribute('class', 'btn btn-primary');
return $form;
$form = new Form;
$form->setRenderer(new VencaX\NetteFormRenderer\BootstrapRendererV4());
//inline form
$renderer = $form->getRenderer();
$renderer->setFormInline();
$form->addEmail('loginemail', 'E-mail address:')
->setHtmlAttribute('placeholder', 'Enter e-mail');
$form->addPassword('password', 'Password')
->setHtmlAttribute('placeholder', 'Password');
$form->addCheckbox('checkbox', 'Check me out');
$form->addSubmit('submit', 'Submit')->setHtmlAttribute('class', 'btn btn-primary');
return $form;