CustomersController.php
8.83 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
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
<?php
namespace controllers;
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
class CustomersController extends \Phalcon\Mvc\Controller
{
    function indexAction()
    {
        if( !$this->session->get('isAdminAuth') )
        {
            return $this->response->redirect([ 'for' => 'admin_login' ]);
        }
        $params     = $this->dispatcher->getParams();
        $page       = !empty( $params['page']  ) ? $params['page'] : 1;
        $search_name = $this->request->getPost('search_name', 'string', NULL);
        $search_phone = $this->request->getPost('search_phone', 'string', NULL);
        $this->session->set('search_name', $search_name);
        $this->session->set('search_phone', $search_phone);
        if (!empty($search_name) && isset($search_phone)) {
            $data       = $this->models->getCustomers()->getDataByNameAndPhone($search_name, $search_phone);
            $total = 1;
        }
        elseif (!empty($search_name)) {
            $data       = $this->models->getCustomers()->getDataByName($search_name);
            $total = 1;
        }
        elseif(isset($search_phone)) {
            $data       = $this->models->getCustomers()->getDataByPhone($search_phone);
            $total = 1;
        }
        else {
            $this->flash->notice("Параметры поиска не указаны");
            $data       = $this->models->getCustomers()->getAllData($page);
            $total      = $this->models->getCustomers()->countData();
        }
        if( $total['0']['total'] > \config::get( 'limits/items') )
        {
            $paginate = $this->common->paginate(
                [
                    'page'              => $page,
                    'items_per_page'    => \config::get( 'limits/admin_orders', 5),
                    'total_items'       => $total[0]['total'],
                    'url_for'           => [ 'for' => 'customers_index_paged', 'page' => $page ],
                    'index_page'       => 'customers_index'
                ], true
            );
        }
        $this->view->setVars([
            'info' => $data,
            'paginate' => !empty($paginate['output']) ? $paginate['output'] : '' ,
        ]);
    }
    function deleteAction($id)
    {
        if( !$this->session->get('isAdminAuth') )
        {
            return $this->response->redirect([ 'for' => 'admin_login' ]);
        }
        $this->models->getCustomers()->deleteData($id);
        return $this->response->redirect([ 'for' => 'customers_index' ]);
    }
    function updateAction($id)
    {
        if( !$this->session->get('isAdminAuth') )
        {
            return $this->response->redirect([ 'for' => 'admin_login' ]);
        }
        if( $this->request->isPost() )
        {
            $data['name'] = $this->request->getPost('name', 'string', NULL );
            $data['email'] = $this->request->getPost('email', 'string', NULL );
            $data['password'] = $this->request->getPost('password', 'string', NULL );
            $data['birth_date'] = $this->request->getPost('birth_date', 'string', NULL );
            $data['phone'] = $this->request->getPost('phone', 'string', NULL );
            $data['city'] = $this->request->getPost('city', 'string', NULL );
            $data['address'] = $this->request->getPost('address', 'string', NULL );
            $data['delivery'] = $this->request->getPost('delivery', 'int', NULL );
            $data['pay'] = $this->request->getPost('pay', 'int', NULL );
            $data['subscribed'] = $this->request->getPost('subscribed', 'int', NULL );
            $data['comments'] = $this->request->getPost('comments', 'string', NULL );
            $data['status'] = $this->request->getPost('status', 'int', NULL );
            $data['users_group_id'] = $this->request->getPost('users_group', 'string', NULL );
            $data['special_users_id'] = $this->request->getPost('special_users', 'string', NULL );
            $data['pay']        = empty( $data['pay'] ) ? 0 : 1;
            $data['subscribed'] = empty( $data['subscribed'] ) ? 0 : 1;
            $data['status']     = empty( $data['status'] ) ? 0 : 1;
            if( !empty( $data['password'] ) )
            {
                $data['password'] = $this->common->hashPasswd($data['password']);
            }
            $current_customer = $this->models->getCustomers()->getCustomerByEmail($data['email']);
            if( !empty( $data ) && isset($current_customer[0]))
            {
                if( $this->models->getCustomers()->UpdateData( $data, $id ) )
                {
                    $this->flash->success( 'Сохранение прошло успешно' );
                    return $this->response->redirect([ 'for' => 'customers_index' ]);
                }
                else
                {
                    $this->flash->error( 'Произошла ошибка во время обновления. Повторите попытку позже' );
                }
            }
            else
            {
                $this->flash->error('Пользователь с таким эмейлом не найден');
            }
        }
        $users_group = $this->models->getUsersGroup()->getAllData(1);
        $special_users = $this->models->getSpecialUsers()->getAllData(1, 0);
        $data = $this->models->getCustomers()->getOneData($id);
        $this->view->pick( 'customers/addEdit' );
        $this->view->setVars([
            'users_group'=> !empty($users_group) ? $users_group : array(),
            'special_users' => !empty($special_users) ? $special_users : array(),
            'page' => $data
        ]);
    }
    function addAction()
    {
        if( !$this->session->get('isAdminAuth') )
        {
            return $this->response->redirect([ 'for' => 'admin_login' ]);
        }
        if( $this->request->isPost() )
        {
            $data['name']       = $this->request->getPost('name', 'string', NULL );
            $data['email']      = $this->request->getPost('email', 'string', NULL );
            $data['password']   = $this->request->getPost('password', 'string', NULL );
            $data['birth_date'] = $this->request->getPost('birth_date', 'string', NULL );
            $data['phone']      = $this->request->getPost('phone', 'string', NULL );
            $data['city']       = $this->request->getPost('city', 'string', NULL );
            $data['address']    = $this->request->getPost('address', 'string', NULL );
            $data['delivery']   = $this->request->getPost('delivery', 'int', NULL );
            $data['pay']        = $this->request->getPost('pay', 'int', NULL );
            $data['subscribed'] = $this->request->getPost('subscribed', 'int', NULL );
            $data['comments']   = $this->request->getPost('comments', 'string', NULL );
            $data['status']     = $this->request->getPost('status', 'int', NULL );
            $data['users_group_id'] = $this->request->getPost('users_group', 'string', NULL );
            $data['special_users_id'] = $this->request->getPost('special_users', 'string', NULL );
            $data['pay']        = empty( $data['pay'] ) ? 0 : 1;
            $data['subscribed'] = empty( $data['subscribed'] ) ? 0 : 1;
            $data['status']     = empty( $data['status'] ) ? 0 : 1;
            if( !empty( $data['password'] ) )
            {
                $data['password'] = $this->common->hashPasswd($data['password']);
            }
            if( !empty( $data ) && !isset($this->models->getCustomers()->getCustomerByEmail($data['email'])['0']) )
            {
                if( $this->models->getCustomers()->addData( $data ) )
                {
                    $this->flash->success( 'Сохранение прошло успешно' );
                    return $this->response->redirect([ 'for' => 'customers_index' ]);
                }
                else
                {
                    $this->flash->error( 'Произошла ошибка во время добавления. Повторите попытку позже' );
                }
            }
            else
            {
                $this->flash->error('Пользователь с таким эмейлом уже существует');
            }
        }
        $users_group = $this->models->getUsersGroup()->getAllData(1);
        $special_users = $this->models->getSpecialUsers()->getAllData(1);
        $this->view->pick( 'customers/addEdit' );
        $this->view->setVars([
            'users_group'=> !empty($users_group) ? $users_group : array(),
            'special_users' => !empty($special_users) ? $special_users : array()
        ]);
    }
}