Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Ukol 4 - Lubomír Jiřišta #39

Open
wants to merge 4 commits into
base: master
Choose a base branch
from
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -16,3 +16,4 @@
/vendor/
/web/bundles/
composer.lock
composer.phar
10 changes: 10 additions & 0 deletions app/Resources/views/Contact/contact.html.twig
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{% extends "::base.html.twig" %}

{% block body %}
{{ include('::alert.html.twig') }}
<h1>Kontaktujte nás</h1>
{{ form_start(form) }}
{{ form_widget(form) }}
<button class="btn btn-lg btn-primary btn-block" type="submit">Odeslat!</button>
{{ form_end(form) }}
{% endblock %}
26 changes: 26 additions & 0 deletions app/Resources/views/Faq/faqs.html.twig
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
{% extends "::base.html.twig" %}

{% block body %}
<h1>Frequently Asked Questions</h1>
<div class="panel-group" id="accordion" role="tablist" aria-multiselectable="true">
{% for faq in allFaqs %}
<div class="panel panel-default">
<div class="panel-heading" role="tab" id="heading{{ loop.index }}">
<h4 class="panel-title">
<a role="button" data-toggle="collapse" data-parent="#accordion" href="#collapse{{ loop.index }}"
aria-expanded="true" aria-controls="collapse{{ loop.index }}">
{{ faq.question }}
</a>
</h4>
</div>
<div id="collapse{{ loop.index }}" class="panel-collapse collapse {% if loop.first %}in{% endif %}"
role="tabpanel"
aria-labelledby="heading{{ loop.index }}">
<div class="panel-body">
{{ faq.response }}
</div>
</div>
</div>
{% endfor %}
</div>
{% endblock %}
7 changes: 7 additions & 0 deletions app/Resources/views/alert.html.twig
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
{% for type, flashes in app.session.flashbag.all %}
{% for flash in flashes %}
<div class="alert alert-{{ type }} fade in">
{{ flash }}
</div>
{% endfor %}
{% endfor %}
4 changes: 4 additions & 0 deletions app/Resources/views/base.html.twig
Original file line number Diff line number Diff line change
@@ -56,6 +56,10 @@
| <a href="{{ path("user_registration") }}" class="navbar-link">Registrovat</a>
{% endif %}
</p>
<p class="navbar-text navbar-right margin-left">
<a href="{{ path("contact") }}" class="navbar-link">Kontakt</a>
| <a href="{{ path("faqs") }}" class="navbar-link">FAQ</a>
</p>
</div>
<!-- /.navbar-collapse -->
</div>
26 changes: 26 additions & 0 deletions app/config/services.yml
Original file line number Diff line number Diff line change
@@ -20,6 +20,14 @@ services:
class: AppBundle\Controller\UserController
autowire: true

app.controller.faq_controller:
class: AppBundle\Controller\FaqController
autowire: true

app.controller.contact_controller:
class: AppBundle\Controller\ContactController
autowire: true

app.facade.category_facade:
class: AppBundle\Facade\CategoryFacade
autowire: true
@@ -32,6 +40,14 @@ services:
class: AppBundle\Facade\UserFacade
autowire: true

app.facade.faq_facade:
class: AppBundle\Facade\FaqFacade
autowire: true

app.facade.contact_facade:
class: AppBundle\Facade\ContactFacade
autowire: true

app.repository.category_repository:
class: AppBundle\Repository\CategoryRepository
factory: ['@doctrine.orm.default_entity_manager', getRepository]
@@ -42,6 +58,16 @@ services:
factory: ['@doctrine.orm.default_entity_manager', getRepository]
arguments: ['AppBundle\Entity\Product']

app.repository.faq_repository:
class: AppBundle\Repository\FaqRepository
factory: ['@doctrine.orm.default_entity_manager', getRepository]
arguments: ['AppBundle\Entity\Faq']

app.repository.contact_repository:
class: AppBundle\Repository\ContactRepository
factory: ['@doctrine.orm.default_entity_manager', getRepository]
arguments: ['AppBundle\Entity\Contact']

encoder:
class: Symfony\Component\Security\Core\Encoder\BCryptPasswordEncoder
arguments:
74 changes: 74 additions & 0 deletions src/AppBundle/Controller/ContactController.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,74 @@
<?php

namespace AppBundle\Controller;

use AppBundle\Entity\Contact;
use AppBundle\Facade\ContactFacade;
use AppBundle\FormType\ContactFormType;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Template;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
use Symfony\Component\Form\FormFactory;
use Symfony\Component\HttpFoundation\RedirectResponse;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Routing\RouterInterface;

/**
* @Route(service="app.controller.contact_controller")
*/
class ContactController extends Controller
{

private $contactFacade;
private $formFactory;
private $router;

public function __construct(
ContactFacade $contactFacade,
FormFactory $formFactory,
RouterInterface $router
) {
$this->contactFacade = $contactFacade;
$this->formFactory = $formFactory;
$this->router = $router;
}

/**
* @Route("/contact", name="contact")
* @Template("contact/contact.html.twig")
*
* @param Request $request
* @return RedirectResponse|array
*/
public function contactAction(Request $request)
{
$contact = new Contact();
$form = $this->formFactory->create(ContactFormType::class, $contact);

$form->handleRequest($request);
if ($form->isSubmitted() && $form->isValid()) {

$contact = $this->contactFacade->setNewContactMessage($contact);
if(null != $contact->getId()) {
$request->getSession()->getFlashBag()->add(
'success',
'Vaše zpráva byla odeslána'
);
} else {
$request->getSession()->getFlashBag()->add(
'error',
'Vaše nebyla odeslána. Zkuste to prosím znovu.'
);
}

return RedirectResponse::create($this->router->generate("contact"));


}

return [
"form" => $form->createView(),
];
}

}
35 changes: 35 additions & 0 deletions src/AppBundle/Controller/FaqController.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
<?php

namespace AppBundle\Controller;

use AppBundle\Facade\FaqFacade;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Template;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;

/**
* @Route(service="app.controller.faq_controller")
*/
class FaqController extends Controller
{
private $faqFacade;

public function __construct(FaqFacade $faqFacade)
{
$this->faqFacade = $faqFacade;
}

/**
* @Route("/faqs", name="faqs")
* @Template("faq/faqs.html.twig")
*/
public function readFaqsAction()
{
$allFaqs = $this->faqFacade->getAllFaqs();

return [
"allFaqs" => $allFaqs
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

jeden tab navíc :)

];
}

}
117 changes: 117 additions & 0 deletions src/AppBundle/Entity/Contact.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,117 @@
<?php

namespace AppBundle\Entity;
use Symfony\Component\Validator\Constraints as Assert;

use Doctrine\ORM\Mapping as ORM;

/**
* Faq
*
* @ORM\Table(name="contact")
* @ORM\Entity(repositoryClass="AppBundle\Repository\ContactRepository")
*/
class Contact
{
/**
* @var int
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;

/**
* @ORM\Column(type="string")
*/
private $name;

/**
* @ORM\Column(type="string", length=255, name="email")
* @Assert\NotBlank()
* @Assert\Email()
*/
private $email;

/**
* @ORM\Column(type="text")
* @Assert\NotBlank()
*/
private $message;

/**
* @return int
*/
public function getId()
{
return $this->id;
}

/**
* @param int $id
* @return Contact
*/
public function setId($id)
{
$this->id = $id;
return $this;
}

/**
* @return mixed
*/
public function getName()
{
return $this->name;
}

/**
* @param mixed $name
* @return Contact
*/
public function setName($name)
{
$this->name = $name;
return $this;
}

/**
* @return mixed
*/
public function getEmail()
{
return $this->email;
}

/**
* @param mixed $email
* @return Contact
*/
public function setEmail($email)
{
$this->email = $email;
return $this;
}

/**
* @return mixed
*/
public function getMessage()
{
return $this->message;
}

/**
* @param mixed $message
* @return Contact
*/
public function setMessage($message)
{
$this->message = $message;
return $this;
}


}

99 changes: 99 additions & 0 deletions src/AppBundle/Entity/Faq.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
<?php

namespace AppBundle\Entity;
use Symfony\Component\Validator\Constraints as Assert;

use Doctrine\ORM\Mapping as ORM;

/**
* Faq
*
* @ORM\Table(name="faq")
* @ORM\Entity(repositoryClass="AppBundle\Repository\FaqRepository")
*/
class Faq
{
/**
* @var int
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
private $id;

/**
* @var string
*
* @ORM\Column(name="question", type="text")
* @Assert\NotBlank()
*/
private $question;

/**
* @var string
* @Assert\NotBlank()
* @ORM\Column(name="response", type="text")
*/
private $response;


/**
* Get id
*
* @return int
*/
public function getId()
{
return $this->id;
}

/**
* Set question
*
* @param string $question
*
* @return Faq
*/
public function setQuestion($question)
{
$this->question = $question;

return $this;
}

/**
* Get question
*
* @return string
*/
public function getQuestion()
{
return $this->question;
}

/**
* Set response
*
* @param string $response
*
* @return Faq
*/
public function setResponse($response)
{
$this->response = $response;

return $this;
}

/**
* Get response
*
* @return string
*/
public function getResponse()
{
return $this->response;
}
}

6 changes: 3 additions & 3 deletions src/AppBundle/Entity/User.php
Original file line number Diff line number Diff line change
@@ -44,19 +44,19 @@ class User implements UserInterface

/**
* @var string
* @ORM\Column(type="string")
* @ORM\Column(type="string", nullable=true)
*/
private $firstName;

/**
* @var string
* @ORM\Column(type="string")
* @ORM\Column(type="string", nullable=true)
*/
private $lastName;

/**
* @var string
* @ORM\Column(type="string")
* @ORM\Column(type="string", nullable=true)
*/
private $phone;

28 changes: 28 additions & 0 deletions src/AppBundle/Facade/ContactFacade.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
<?php

namespace AppBundle\Facade;

use AppBundle\Repository\ContactRepository;
use Doctrine\ORM\EntityManager;

class ContactFacade {

private $contactRepository;
private $entityManager;

public function __construct(
ContactRepository $contactRepository,
EntityManager $entityManager
) {
$this->contactRepository = $contactRepository;
$this->entityManager = $entityManager;
}

public function setNewContactMessage($contact) {
$this->entityManager->persist($contact);
$this->entityManager->flush([$contact]);
return $contact;
}


}
22 changes: 22 additions & 0 deletions src/AppBundle/Facade/FaqFacade.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
<?php

namespace AppBundle\Facade;

use AppBundle\Entity\Faq;
use AppBundle\Repository\FaqRepository;

class FaqFacade {

private $faqRepository;

public function __construct(FaqRepository $faqRepository) {
$this->faqRepository = $faqRepository;
}

/** @return Faq[] */
public function getAllFaqs() {
return $this->faqRepository->findAll();
}


}
65 changes: 65 additions & 0 deletions src/AppBundle/FormType/ContactFormType.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
<?php

namespace AppBundle\FormType;

use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\Extension\Core\Type\TextareaType;
use Symfony\Component\Form\Extension\Core\Type\TextType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;
use Symfony\Component\Validator\Constraints\NotBlank;

class ContactFormType extends AbstractType
{
/**
* {@inheritdoc}
*/
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder->add("name", TextType::class, [
"label" => "Jméno",
"attr" => [
"class" => "form-control",
],
"constraints" => [
new NotBlank(["message" => "Prosím vyplňte Vaše jméno"]),
],
])->add("email", TextType::class, [
"label" => "Email",
"attr" => [
"class" => "form-control",
],
"constraints" => [
new NotBlank(["message" => "Prosím vyplňte Váš email"]),
],
])->add("message", TextareaType::class, [
"label" => "Zpráva",
"attr" => [
"class" => "form-control",
],
"constraints" => [
new NotBlank(["message" => "Prosím vyplňte Vaši zprávu"]),
],
]);
}

/**
* {@inheritdoc}
*/
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults(array(
'data_class' => 'AppBundle\Entity\Contact'
));
}

/**
* {@inheritdoc}
*/
public function getBlockPrefix()
{
return 'appbundle_contact';
}


}
15 changes: 15 additions & 0 deletions src/AppBundle/Repository/ContactRepository.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
<?php

namespace AppBundle\Repository;

use Doctrine\ORM\EntityRepository;

/**
* ContactRepository
*
* This class was generated by the Doctrine ORM. Add your own custom
* repository methods below.
*/
class ContactRepository extends EntityRepository
{
}
15 changes: 15 additions & 0 deletions src/AppBundle/Repository/FaqRepository.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
<?php

namespace AppBundle\Repository;

use Doctrine\ORM\EntityRepository;

/**
* FaqRepository
*
* This class was generated by the Doctrine ORM. Add your own custom
* repository methods below.
*/
class FaqRepository extends EntityRepository
{
}
16 changes: 16 additions & 0 deletions src/AppBundle/Tests/Controller/ContactControllerTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
<?php

namespace AppBundle\Tests\Controller;

use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;

class ContactControllerTest extends WebTestCase
{
public function testContact()
{
$client = static::createClient();

$crawler = $client->request('GET', '/contact');
}

}
16 changes: 16 additions & 0 deletions src/AppBundle/Tests/Controller/FaqControllerTest.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
<?php

namespace AppBundle\Tests\Controller;

use Symfony\Bundle\FrameworkBundle\Test\WebTestCase;

class FaqControllerTest extends WebTestCase
{
public function testReadfaqs()
{
$client = static::createClient();

$crawler = $client->request('GET', '/faqs');
}

}
217 changes: 212 additions & 5 deletions web/config.php
Original file line number Diff line number Diff line change
@@ -38,9 +38,216 @@
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
<meta name="robots" content="noindex,nofollow" />
<title>Symfony Configuration Checker</title>
<link rel="stylesheet" href="bundles/framework/css/structure.css" media="all" />
<link rel="stylesheet" href="bundles/framework/css/body.css" media="all" />
<style type="text/css">
<style>
/* styles copied from symfony framework bundle */
html {
background: #eee;
}
body {
font: 11px Verdana, Arial, sans-serif;
color: #333;
}
.sf-reset, .sf-reset .block, .sf-reset #message {
margin: auto;
}
img {
border: 0;
}
.clear {
clear: both;
height: 0;
font-size: 0;
line-height: 0;
}
.clear-fix:after {
content: "\0020";
display: block;
height: 0;
clear: both;
visibility: hidden;
}
.clear-fix {
display: inline-block;
}
* html .clear-fix {
height: 1%;
}
.clear-fix {
display: block;
}
.header {
padding: 30px 30px 20px 30px;
}
.header-logo {
float: left;
}
.search {
float: right;
padding-top: 20px;
}
.search label {
line-height: 28px;
vertical-align: middle;
}
.search input {
width: 195px;
font-size: 12px;
border: 1px solid #dadada;
background: #fff url() repeat-x left top;
padding: 5px 6px;
color: #565656;
}
.search input[type="search"] {
-webkit-appearance: textfield;
}
#content {
width: 970px;
margin: 0 auto;
}
#content pre {
white-space: normal;
font-family: Arial, Helvetica, sans-serif;
}

/*
Copyright (c) 2010, Yahoo! Inc. All rights reserved.
Code licensed under the BSD License:
http://developer.yahoo.com/yui/license.html
version: 3.1.2
build: 56
*/
.sf-reset div,.sf-reset dl,.sf-reset dt,.sf-reset dd,.sf-reset ul,.sf-reset ol,.sf-reset li,.sf-reset h1,.sf-reset h2,.sf-reset h3,.sf-reset h4,.sf-reset h5,.sf-reset h6,.sf-reset pre,.sf-reset code,.sf-reset form,.sf-reset fieldset,.sf-reset legend,.sf-reset input,.sf-reset textarea,.sf-reset p,.sf-reset blockquote,.sf-reset th,.sf-reset td{margin:0;padding:0;}.sf-reset table{border-collapse:collapse;border-spacing:0;}.sf-reset fieldset,.sf-reset img{border:0;}.sf-reset address,.sf-reset caption,.sf-reset cite,.sf-reset code,.sf-reset dfn,.sf-reset em,.sf-reset strong,.sf-reset th,.sf-reset var{font-style:normal;font-weight:normal;}.sf-reset li{list-style:none;}.sf-reset caption,.sf-reset th{text-align:left;}.sf-reset h1,.sf-reset h2,.sf-reset h3,.sf-reset h4,.sf-reset h5,.sf-reset h6{font-size:100%;font-weight:normal;}.sf-reset q:before,.sf-reset q:after{content:'';}.sf-reset abbr,.sf-reset acronym{border:0;font-variant:normal;}.sf-reset sup{vertical-align:text-top;}.sf-reset sub{vertical-align:text-bottom;}.sf-reset input,.sf-reset textarea,.sf-reset select{font-family:inherit;font-size:inherit;font-weight:inherit;}.sf-reset input,.sf-reset textarea,.sf-reset select{font-size:100%;}.sf-reset legend{color:#000;}
.sf-reset abbr {
border-bottom: 1px dotted #000;
cursor: help;
}
.sf-reset p {
font-size: 14px;
line-height: 20px;
padding-bottom: 20px;
}
.sf-reset strong {
color: #313131;
font-weight: bold;
}
.sf-reset a {
color: #6c6159;
}
.sf-reset a img {
border: none;
}
.sf-reset a:hover {
text-decoration: underline;
}
.sf-reset em {
font-style: italic;
}
.sf-reset h2,
.sf-reset h3 {
font-weight: bold;
}
.sf-reset h1 {
font-family: Georgia, "Times New Roman", Times, serif;
font-size: 20px;
color: #313131;
word-wrap: break-word;
}
.sf-reset li {
padding-bottom: 10px;
}
.sf-reset .block {
-moz-border-radius: 16px;
-webkit-border-radius: 16px;
border-radius: 16px;
margin-bottom: 20px;
background-color: #FFFFFF;
border: 1px solid #dfdfdf;
padding: 40px 50px;
word-break: break-all;
}
.sf-reset h2 {
font-size: 16px;
font-family: Arial, Helvetica, sans-serif;
}
.sf-reset li a {
background: none;
color: #868686;
text-decoration: none;
}
.sf-reset li a:hover {
background: none;
color: #313131;
text-decoration: underline;
}
.sf-reset ol {
padding: 10px 0;
}
.sf-reset ol li {
list-style: decimal;
margin-left: 20px;
padding: 2px;
padding-bottom: 20px;
}
.sf-reset ol ol li {
list-style-position: inside;
margin-left: 0;
white-space: nowrap;
font-size: 12px;
padding-bottom: 0;
}
.sf-reset li .selected {
background-color: #ffd;
}
.sf-button {
display: -moz-inline-box;
display: inline-block;
text-align: center;
vertical-align: middle;
border: 0;
background: transparent none;
text-transform: uppercase;
cursor: pointer;
font: bold 11px Arial, Helvetica, sans-serif;
}
.sf-button span {
text-decoration: none;
display: block;
height: 28px;
float: left;
}
.sf-button .border-l {
text-decoration: none;
display: block;
height: 28px;
float: left;
padding: 0 0 0 7px;
background: transparent url() no-repeat top left;
}
.sf-button .border-r {
padding: 0 7px 0 0;
background: transparent url() right top no-repeat;
}
.sf-button .btn-bg {
padding: 0 14px;
color: #636363;
line-height: 28px;
background: transparent url() repeat-x top left;
}
.sf-button:hover .border-l,
.sf-button-selected .border-l {
background: transparent url() no-repeat top left;
}
.sf-button:hover .border-r,
.sf-button-selected .border-r {
background: transparent url() right top no-repeat;
}
.sf-button:hover .btn-bg,
.sf-button-selected .btn-bg {
color: #FFFFFF;
text-shadow:0 1px 1px #6b9311;
background: transparent url() repeat-x top left;
}

/* styles copied from bundles/sensiodistribution/webconfigurator/css/install.css */
body {
font-size: 14px;
@@ -126,15 +333,15 @@
<div id="content">
<div class="header clear-fix">
<div class="header-logo">
<img src="bundles/framework/images/logo_symfony.png" alt="Symfony" />
<img src="" alt="Symfony" />
</div>

<div class="search">
<form method="get" action="http://symfony.com/search">
<div class="form-row">

<label for="search-id">
<img src="bundles/framework/images/grey_magnifier.png" alt="Search on Symfony website" />
<img src="" alt="Search on Symfony website" />
</label>

<input name="q" id="search-id" type="search" placeholder="Search on Symfony website" />