AccountController.php
3.52 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
<?php
    
    namespace frontend\controllers;
    
    use artbox\order\models\Customer;
    use artbox\order\models\Order;
    use artbox\order\models\PasswordForm;
    use yii\web\Controller;
    use yii\web\ForbiddenHttpException;
    use yii\web\NotFoundHttpException;
    
    /**
     * Class AccountController
     *
     * @package frontend\controllers
     */
    class AccountController extends Controller
    {
        public function actionIndex()
        {
            $user = Customer::findOne(\Yii::$app->user->identity->getId());
            
            $orders = $user->getOrders()
                           ->with(
                               [
                                   'label.lang',
                                   'orderProducts',
                               ]
                           )
                           ->orderBy(
                               [
                                   'id' => SORT_DESC,
                               ]
                           )
                           ->all();
            
            return $this->render(
                'index',
                [
                    'orders' => $orders,
                ]
            );
        }
    
        public function actionOrder($id)
        {
            /**
             * @var Order $order
             */
            $order = Order::find()
                          ->with('orderProducts.variant.product.lang')
                          ->where(
                              [
                                  'id' => $id,
                              ]
                          )
                          ->one();
    
            if (empty($order)) {
                throw new NotFoundHttpException(\Yii::t('app', 'Order not found'));
            } elseif ($order->user_id !== \Yii::$app->user->identity->getId()) {
                throw new ForbiddenHttpException();
            }
    
            return $this->render(
                'order',
                [
                    'order' => $order,
                ]
            );
        }
    
        public function actionAccount()
        {
            return $this->render(
                'account',
                [
                    'passwordModel' => new PasswordForm(),
                ]
            );
        }
    
        public function actionChangePassword()
        {
            /**
             * @var Customer $modeluser
             */
            $model = new PasswordForm();
            $modeluser = \Yii::$app->user->identity;
        
            if ($model->load(\Yii::$app->request->post())) {
                if ($model->validate()) {
                    $modeluser->setPassword($model->newpass);
                    if ($modeluser->save()) {
                        return $this->redirect([ 'index' ]);
                    } else {
                        return $this->render(
                            'account',
                            [
                                'passwordModel' => $model,
                            ]
                        );
                    }
                } else {
                    return $this->render(
                        'account',
                        [
                            'passwordModel' => $model,
                        ]
                    );
                }
            } else {
                return $this->render(
                    'account',
                    [
                        'passwordModel' => $model,
                    ]
                );
            }
        }
    } 
