- <?php
-
- namespace frontend\controllers;
-
- use Yii;
- use common\models\Produit;
- use common\models\LoginForm;
- use common\models\Etablissement;
- use frontend\models\PasswordResetRequestForm;
- use frontend\models\ResetPasswordForm;
- use frontend\models\SignupForm;
- use common\models\ContactForm;
- use yii\base\InvalidParamException;
- use yii\web\BadRequestHttpException;
- use yii\web\Controller;
- use yii\filters\VerbFilter;
- use yii\filters\AccessControl;
- use yii\helpers\Html;
- use frontend\controllers\FrontendController;
- use common\models\UserEtablissement;
- use dosamigos\leaflet\types\LatLng;
- use dosamigos\leaflet\layers\Marker;
- use dosamigos\leaflet\layers\TileLayer;
- use dosamigos\leaflet\LeafLet;
- use dosamigos\leaflet\widgets\Map;
-
- /**
- * Site controller
- */
- class SiteController extends FrontendController {
-
- /**
- * @inheritdoc
- */
- public function behaviors() {
- return [
- 'access' => [
- 'class' => AccessControl::className(),
- 'only' => ['logout', 'signup'],
- 'rules' => [
- [
- 'actions' => ['signup'],
- 'allow' => true,
- 'roles' => ['?'],
- ],
- [
- 'actions' => ['logout'],
- 'allow' => true,
- 'roles' => ['@'],
- ],
- ],
- ],
- 'verbs' => [
- 'class' => VerbFilter::className(),
- 'actions' => [
- 'logout' => ['get'],
- ],
- ],
- ];
- }
-
- /**
- * @inheritdoc
- */
- public function actions() {
- return [
- 'error' => [
- 'class' => 'yii\web\ErrorAction',
- ],
- 'captcha' => [
- 'class' => 'yii\captcha\CaptchaAction',
- 'fixedVerifyCode' => YII_ENV_TEST ? 'testme' : null,
- ],
- ];
- }
-
- public function actionIndex() {
-
- return $this->render('index');
- }
-
- public function actionProducers() {
-
- $data_provider_producers = new ActiveDataProvider([
- 'query' => Etablissement::find()
- ->where([
- 'actif' => true,
- ])
- ->orderBy('nom ASC'),
- 'pagination' => [
- 'pageSize' => 100,
- ],
- ]);
-
- return $this->render('producers',[
- 'data_provider_producers' => $data_provider_producers
- ]);
- }
-
- public function actionMentions() {
- return $this->render('mentions');
- }
-
- public function actionLogin() {
- if (!\Yii::$app->user->isGuest) {
- return Yii::$app->getResponse()->redirect(['commande/index']);
- }
-
- $model = new LoginForm();
- if ($model->load(Yii::$app->request->post()) && $model->login()) {
- $return_url = Yii::$app->request->get('return_url');
- if($return_url){
- return $this->redirect($return_url);
- }
- else {
- return $this->goBack();
- }
- } else {
- return $this->render('@frontend/views/site/login', [
- 'model' => $model,
- ]);
- }
- }
-
- public function actionLogout() {
- Yii::$app->user->logout();
- return $this->goHome();
- }
-
- public function actionContact() {
- $model = new ContactForm();
- if ($model->load(Yii::$app->request->post()) && $model->validate()) {
- if ($model->sendEmail(Yii::$app->params['adminEmail'])) {
- Yii::$app->session->setFlash('success', 'Votre message a bien été envoyé. Nous vous répondrons dès que possible.');
- } else {
- Yii::$app->session->setFlash('error', 'Il y a eu une erreur lors de l\'envoi de votre message.');
- }
-
- return $this->refresh();
- } else {
- return $this->render('contact', [
- 'model' => $model,
- ]);
- }
- }
-
- public function actionSignup() {
- $model = new SignupForm();
- if ($model->load(Yii::$app->request->post())) {
- if ($user = $model->signup()) {
- if (Yii::$app->getUser()->login($user)) {
-
- $this->redirect(['commande/index']);
- }
- }
- }
-
- // liste des établissements disponibles
- $etablissements = Etablissement::getEtablissementsPopulateDropdown();
- $data_etablissements_dispos = $etablissements['data'];
- $options_etablissements_dispos = $etablissements['options'];
-
- return $this->render('signup', [
- 'model' => $model,
- 'data_etablissements_dispos' => $data_etablissements_dispos,
- 'options_etablissements_dispos' => $options_etablissements_dispos,
- ]);
- }
-
- public function actionRequestPasswordReset() {
- $model = new PasswordResetRequestForm();
- if ($model->load(Yii::$app->request->post()) && $model->validate()) {
- if ($model->sendEmail()) {
- Yii::$app->getSession()->setFlash('success', 'Un lien vous permettant de réinitialiser votre mot de passe vient d\'être envoyé sur votre boîte mail.');
-
- return $this->goHome();
- } else {
- Yii::$app->getSession()->setFlash('error', 'Sorry, we are unable to reset password for email provided.');
- }
- }
-
- return $this->render('requestPasswordResetToken', [
- 'model' => $model,
- ]);
- }
-
- public function actionResetPassword($token) {
- try {
- $model = new ResetPasswordForm($token);
- } catch (InvalidParamException $e) {
- throw new BadRequestHttpException($e->getMessage());
- }
-
- if ($model->load(Yii::$app->request->post()) && $model->validate() && $model->resetPassword()) {
- Yii::$app->getSession()->setFlash('success', 'Votre nouveau mot de passe vient d\'être sauvegardé.');
-
- return $this->goHome();
- }
-
- return $this->render('resetPassword', [
- 'model' => $model,
- ]);
- }
-
- public function actionCgv() {
- return $this->render('cgv');
- }
-
- public function actionCreditpain() {
- return $this->render('creditpain');
- }
-
- public function actionEtablissement($id_etablissement) {
- $model_login = new LoginForm();
- $model_signup = new SignupForm();
-
- $etablissement = Etablissement::findOne($id_etablissement);
-
- if (Yii::$app->user->isGuest) {
- if ($model_login->load(Yii::$app->request->post()) && $model_login->login()) {
- // ajout de l'établissement en favoris si ce n'est pas encore le cas
- $user_etablissement_exist = UserEtablissement::find()
- ->where([
- 'id_user' => Yii::$app->user->id,
- 'id_etablissement' => $id_etablissement
- ])->one();
-
- if (!$user_etablissement_exist) {
- $etab_user = new UserEtablissement;
- $etab_user->id_etablissement = $id_etablissement;
- $etab_user->id_user = Yii::$app->user->id;
- $etab_user->credit = 0;
- $etab_user->actif = 1;
- $etab_user->save();
- } else {
- if (!$user_etablissement_exist->actif) {
- $user_etablissement_exist->actif = 1;
- $user_etablissement_exist->save();
- }
- }
-
- $this->redirect(['commande/index']);
- }
-
- if ($model_signup->load(Yii::$app->request->post())) {
-
- $model_signup->id_etablissement = $id_etablissement;
- $model_signup->option_client_boulanger = 'client';
-
- if ($user = $model_signup->signup()) {
- if (Yii::$app->getUser()->login($user)) {
- $this->redirect(['commande/index']);
- }
- }
- }
- } else {
- $this->redirect(['commande/create', 'id_etablissement' => $id_etablissement]);
- }
-
- return $this->render('etablissement', [
- 'model_login' => $model_login,
- 'model_signup' => $model_signup,
- 'etablissement' => $etablissement,
- ]);
- }
-
- }
|