Commit 62ff66e4c33ca74113533ee6a1b6642ce5921206
1 parent
7882b398
change request to massage
Showing
6 changed files
with
254 additions
and
83 deletions
Show diff stats
src/app/frontend/controllers/EventsController.php
| ... | ... | @@ -76,6 +76,11 @@ class EventsController extends \Phalcon\Mvc\Controller |
| 76 | 76 | } |
| 77 | 77 | } |
| 78 | 78 | |
| 79 | + /** | |
| 80 | + * @param $data | |
| 81 | + * @param $template | |
| 82 | + * @throws \Exception | |
| 83 | + */ | |
| 79 | 84 | private function sendDelivery($data, $template){ |
| 80 | 85 | if($this->post['email']){ |
| 81 | 86 | |
| ... | ... | @@ -94,6 +99,8 @@ class EventsController extends \Phalcon\Mvc\Controller |
| 94 | 99 | |
| 95 | 100 | |
| 96 | 101 | $this->event_info->save(); |
| 102 | + $this->addLetersList($this->post['project_id']); | |
| 103 | + | |
| 97 | 104 | } else { |
| 98 | 105 | |
| 99 | 106 | $this->event_info->event_id = $data->id; |
| ... | ... | @@ -271,12 +278,54 @@ class EventsController extends \Phalcon\Mvc\Controller |
| 271 | 278 | |
| 272 | 279 | } |
| 273 | 280 | |
| 274 | - private function getEventDate($time){ | |
| 275 | - $now = date("Y-m-d H:i:s"); | |
| 276 | - $EmailDate = new \DateTime($now); | |
| 281 | + private function getEventDate($first_delivery,$time){ | |
| 282 | + $now = date("Y-m-d"); | |
| 283 | + $EmailDate = new \DateTime($first_delivery); | |
| 277 | 284 | $EmailDate->modify($time); |
| 278 | - return $EmailDate->format('Y-m-d H:i:s'); | |
| 285 | + return $EmailDate->format('Y-m-d'); | |
| 286 | + } | |
| 287 | + | |
| 288 | + | |
| 289 | + function getNextDate($day) | |
| 290 | + { | |
| 291 | + $ret = false; | |
| 292 | + for ($i=1; $i<=7; $i++) | |
| 293 | + { | |
| 294 | + if (date('w',strtotime('+'.$i.' day'))==$day) | |
| 295 | + { | |
| 296 | + $ret = date('Y-m-d',strtotime('+'.$i.' day')); | |
| 297 | + break; | |
| 298 | + } | |
| 299 | + } | |
| 300 | + return $ret; | |
| 279 | 301 | } |
| 302 | + | |
| 303 | + private function addLetersList($project_id){ | |
| 304 | + $data = \seriesOfLetters::find("project_id ={$project_id} "); | |
| 305 | + | |
| 306 | + foreach($data as $row){ | |
| 307 | + | |
| 308 | + $letters = explode(',',$row->letters); | |
| 309 | + | |
| 310 | + | |
| 311 | + $days = count($letters); | |
| 312 | + for($i=0; $i<$days; $i++){ | |
| 313 | + $now = date('N'); | |
| 314 | + $row->first_delivery = $this->getNextDate($row->first_delivery); | |
| 315 | + $date = $this->getEventDate($row->first_delivery, "+". ($i)*$row->period_val ." days"); | |
| 316 | + $event = new \eventInfo(); | |
| 317 | + $event->customer_id = $this->customers_model->id; | |
| 318 | + $event->event_id = $letters[$i]; | |
| 319 | + $event->next_delivery = $date; | |
| 320 | + $event->project_id = $project_id; | |
| 321 | + $event->event_trigger = 'series_of_letter'; | |
| 322 | + $event->save(); | |
| 323 | + } | |
| 324 | + | |
| 325 | + } | |
| 326 | + } | |
| 327 | + | |
| 328 | + | |
| 280 | 329 | private function subscribeNewCustomer(){ |
| 281 | 330 | $user['email'] = $this->post['email']; |
| 282 | 331 | $user['name'] = isset($this->post['name']) ? $this->post['name']:''; |
| ... | ... | @@ -285,26 +334,9 @@ class EventsController extends \Phalcon\Mvc\Controller |
| 285 | 334 | if($customer instanceof \customersEmailList){ |
| 286 | 335 | |
| 287 | 336 | } else { |
| 288 | - $data = \seriesOfLetters::find("project_id ={$user['project_id']} "); | |
| 289 | 337 | $this->customers_model->save($user); |
| 290 | - foreach($data as $row){ | |
| 338 | + $this->addLetersList($this->post['project_id']); | |
| 291 | 339 | |
| 292 | - $letters = explode(',',$row->letters); | |
| 293 | - | |
| 294 | - | |
| 295 | - $days = count($letters); | |
| 296 | - for($i=0; $i<$days; $i++){ | |
| 297 | - $date = $this->getEventDate("+". ($i+1)*$row->period_val ." days"); | |
| 298 | - $event = new \eventInfo(); | |
| 299 | - $event->customer_id = $this->customers_model->id; | |
| 300 | - $event->event_id = $letters[$i]; | |
| 301 | - $event->next_delivery = $date; | |
| 302 | - $event->project_id = $user['project_id']; | |
| 303 | - $event->event_trigger = 'series_of_letter'; | |
| 304 | - $event->save(); | |
| 305 | - } | |
| 306 | - | |
| 307 | - } | |
| 308 | 340 | |
| 309 | 341 | } |
| 310 | 342 | ... | ... |
src/app/frontend/controllers/SeriesOfLettersController.php
| ... | ... | @@ -20,14 +20,17 @@ class SeriesOfLettersController extends \Phalcon\Mvc\Controller |
| 20 | 20 | ]); |
| 21 | 21 | } |
| 22 | 22 | |
| 23 | + | |
| 23 | 24 | public function addAction(){ |
| 24 | 25 | if( $this->request->isPost() ) |
| 25 | 26 | { |
| 27 | + | |
| 26 | 28 | $data['project_id'] = $this->session->get('project-id'); |
| 27 | 29 | $data['name'] = $this->request->getPost('name', 'string', NULL ); |
| 28 | 30 | $data['status'] = $this->request->getPost('status')?$this->request->getPost('status'):0 ; |
| 29 | 31 | $data['event'] = $this->request->getPost('event' ); |
| 30 | 32 | $data['period_val'] = $this->request->getPost('period_val' ); |
| 33 | + $data['first_delivery'] = $this->request->getPost('first_delivery' ); | |
| 31 | 34 | $data['letters'] = implode(',',$data['event']); |
| 32 | 35 | |
| 33 | 36 | $model = new \seriesOfLetters(); |
| ... | ... | @@ -46,7 +49,8 @@ class SeriesOfLettersController extends \Phalcon\Mvc\Controller |
| 46 | 49 | } |
| 47 | 50 | $this->view->pick( 'series_of_letters/addEdit' ); |
| 48 | 51 | $this->view->setVars([ |
| 49 | - | |
| 52 | + 'page' => new \seriesOfLetters(), | |
| 53 | + 'events' => [] | |
| 50 | 54 | ]); |
| 51 | 55 | } |
| 52 | 56 | |
| ... | ... | @@ -60,12 +64,40 @@ class SeriesOfLettersController extends \Phalcon\Mvc\Controller |
| 60 | 64 | } |
| 61 | 65 | |
| 62 | 66 | public function updateAction($id){ |
| 63 | -// | |
| 64 | -// $data = \seriesOfLetters::findFirst("id=$id AND project_id ={$this->session->get('project-id')} "); | |
| 65 | -// $this->view->pick( 'series_of_letters/addEdit' ); | |
| 66 | -// $this->view->setVars([ | |
| 67 | -// 'page' => $data | |
| 68 | -// ]); | |
| 67 | + $model = \seriesOfLetters::findFirst("id=$id AND project_id ={$this->session->get('project-id')} "); | |
| 68 | + if( $this->request->isPost() ) | |
| 69 | + { | |
| 70 | + | |
| 71 | + | |
| 72 | + $data['project_id'] = $this->session->get('project-id'); | |
| 73 | + $data['name'] = $this->request->getPost('name', 'string', NULL ); | |
| 74 | + $data['status'] = $this->request->getPost('status')?$this->request->getPost('status'):0 ; | |
| 75 | + $data['event'] = $this->request->getPost('event' ); | |
| 76 | + $data['period_val'] = $this->request->getPost('period_val' ); | |
| 77 | + $data['first_delivery'] = $this->request->getPost('first_delivery' ); | |
| 78 | + $data['letters'] = implode(',',$data['event']); | |
| 79 | + | |
| 80 | + if( !empty( $data['name'] )) | |
| 81 | + { | |
| 82 | + if( $model->save( $data ) ) | |
| 83 | + { | |
| 84 | + $this->flash->success( 'Сохранение прошло успешно' ); | |
| 85 | + return $this->response->redirect('series_of_letters/index'); | |
| 86 | + } | |
| 87 | + else | |
| 88 | + { | |
| 89 | + $this->flash->error( 'Произошла ошибка во время добавления.' ); | |
| 90 | + } | |
| 91 | + } | |
| 92 | + } | |
| 93 | + | |
| 94 | + | |
| 95 | + $events = \eventEmail::find("id IN ('".implode("','", explode(',',$model->letters))."') "); | |
| 96 | + $this->view->pick( 'series_of_letters/addEdit' ); | |
| 97 | + $this->view->setVars([ | |
| 98 | + 'page' => $model, | |
| 99 | + 'events' => $events | |
| 100 | + ]); | |
| 69 | 101 | } |
| 70 | 102 | |
| 71 | 103 | public function getTemplateAction() | ... | ... |
src/app/frontend/views/series_of_letters/addEdit.php
| ... | ... | @@ -7,7 +7,7 @@ |
| 7 | 7 | |
| 8 | 8 | |
| 9 | 9 | <div class="input-group"> |
| 10 | - <input type="checkbox" id="status" name="status" class="unique" value="<?= (isset( $page->status ) && !empty( $page->status ) ? $page->status : '') ?>"> | |
| 10 | + <input type="checkbox" id="status" value="1" name="status" <?= ((isset( $page->status ) && !empty( $page->status )) ? 'checked' : '') ?>> | |
| 11 | 11 | <label for="status">Статус рассылки</label> |
| 12 | 12 | </div> |
| 13 | 13 | |
| ... | ... | @@ -16,8 +16,23 @@ |
| 16 | 16 | <div class="input-group"> |
| 17 | 17 | <span class="input-group-addon title-block-sizing">Название рассылки</span> |
| 18 | 18 | <input type="text" name="name" class="form-control" value='<?= (isset( $page->name ) && !empty( $page->name ) ? $page->name : '') ?>'> |
| 19 | + | |
| 19 | 20 | </div> |
| 20 | 21 | |
| 22 | + | |
| 23 | + <div class="input-group"> | |
| 24 | + <span class="input-group-addon title-block-sizing">День первого письма</span> | |
| 25 | + <select class="form-control" name="first_delivery"> | |
| 26 | + | |
| 27 | + <?php foreach($page->getDays() as $day):?> | |
| 28 | + | |
| 29 | + <option <?= !empty( $page->first_delivery )&& $page->isActive($page->first_delivery,$day['val']) ? "selected" :"" ?> value="<?= $day['val'] ?>"><?= $day['name'] ?></option> | |
| 30 | + <?php endforeach?> | |
| 31 | + </select> | |
| 32 | + </div> | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 21 | 36 | <div class="input-group"> |
| 22 | 37 | <span class="input-group-addon title-block-sizing">Период</span> |
| 23 | 38 | <input type="text" name="period_val" class="form-control" value='<?= (isset( $page->period_val ) && !empty( $page->period_val ) ? $page->period_val : '') ?>'> |
| ... | ... | @@ -25,6 +40,10 @@ |
| 25 | 40 | |
| 26 | 41 | |
| 27 | 42 | <table id="templates-list" class="table table-hover"> |
| 43 | + <?php foreach($events as $event):?> | |
| 44 | + <tr><td id='name'><?= $event->name ?></td><td><p class = 'btn btn-primary delete-row'>Убрать из списка</p> | |
| 45 | + <input type='hidden' value='<?= $event->id ?>' name='event[]'></td></tr> | |
| 46 | + <?php endforeach;?> | |
| 28 | 47 | </table> |
| 29 | 48 | <div class="input-group"> |
| 30 | 49 | <span class="input-group-addon title-block-sizing">Введите название письма</span> |
| ... | ... | @@ -92,4 +111,40 @@ |
| 92 | 111 | row.remove(); |
| 93 | 112 | }); |
| 94 | 113 | }); |
| 114 | +</script> | |
| 115 | +<script> | |
| 116 | + $(function() { | |
| 117 | + $.datepicker.regional['ru'] = { | |
| 118 | + closeText: 'Закрыть', | |
| 119 | + prevText: '<Пред', | |
| 120 | + nextText: 'След>', | |
| 121 | + currentText: 'Сегодня', | |
| 122 | + monthNames: ['Январь','Февраль','Март','Апрель','Май','Июнь', | |
| 123 | + 'Июль','Август','Сентябрь','Октябрь','Ноябрь','Декабрь'], | |
| 124 | + monthNamesShort: ['Янв','Фев','Мар','Апр','Май','Июн', | |
| 125 | + 'Июл','Авг','Сен','Окт','Ноя','Дек'], | |
| 126 | + dayNames: ['воскресенье','понедельник','вторник','среда','четверг','пятница','суббота'], | |
| 127 | + dayNamesShort: ['вск','пнд','втр','срд','чтв','птн','сбт'], | |
| 128 | + dayNamesMin: ['Вс','Пн','Вт','Ср','Чт','Пт','Сб'], | |
| 129 | + dateFormat: 'dd.mm.yy', | |
| 130 | + firstDay: 1, | |
| 131 | + isRTL: false | |
| 132 | + }; | |
| 133 | + $.datepicker.setDefaults($.datepicker.regional['ru']); | |
| 134 | + | |
| 135 | + $( "#datepicker" ).datepicker({ | |
| 136 | + dateFormat: "dd-mm-yy" | |
| 137 | + }); | |
| 138 | + | |
| 139 | + | |
| 140 | + $('.active_field_select').each(function(){ | |
| 141 | + if(this.checked){ | |
| 142 | + $(this).parent('li').addClass('active'); | |
| 143 | + }else { | |
| 144 | + $(this).parent('li').addClass('non_active'); | |
| 145 | + } | |
| 146 | + }); | |
| 147 | + | |
| 148 | + }); | |
| 149 | + | |
| 95 | 150 | </script> |
| 96 | 151 | \ No newline at end of file | ... | ... |
src/app/tasks/EventMailTask.php
| ... | ... | @@ -40,27 +40,42 @@ class EventMailTask extends \Phalcon\CLI\Task |
| 40 | 40 | |
| 41 | 41 | foreach($projects as $project){ |
| 42 | 42 | |
| 43 | - $events = $this->eventByTrigger($project,'series_of_letter'); | |
| 43 | + | |
| 44 | + $events = \eventInfo::getEventsByTrigger($this->modelsManager, $project->id, 'series_of_letter'); | |
| 44 | 45 | |
| 45 | 46 | foreach($events as $event){ |
| 47 | + if($event instanceof \eventInfo){ | |
| 46 | 48 | |
| 47 | - if(!$event->isNew() ){ | |
| 48 | - if(!$event->isRecurring()){ | |
| 49 | - continue; | |
| 49 | + $customers = (new customersEmailList())->findFirst("id={$event->customer_id}"); | |
| 50 | + | |
| 51 | + if($customers instanceof customersEmailList){ | |
| 52 | + | |
| 53 | + $eventEmail = ( new \eventEmail())->findFirst("id={$event->event_id}"); | |
| 54 | + if($eventEmail instanceof eventEmail){ | |
| 55 | + $eventEmail = $eventEmail->toArray(); | |
| 56 | + print_r($eventEmail); | |
| 57 | + }else { | |
| 58 | + continue; | |
| 59 | + } | |
| 60 | + $template = \emailTemplates::findFirst("event_id = {$event->event_id} AND project_id = {$project->id}")->toArray(); | |
| 61 | + | |
| 62 | + $this->post['name']=$customers->name; | |
| 63 | + $this->post['email']=$customers->email; | |
| 64 | + $this->post['phone']=$customers->phone; | |
| 65 | + $this->post['address']=$customers->address; | |
| 66 | + | |
| 67 | + $this->sendMailData($template,$customers->toArray(),$eventEmail,$project); | |
| 68 | + | |
| 69 | + $event->last_delivery = date("Y-m-d H:i:s"); | |
| 70 | + $event->delete(); | |
| 50 | 71 | } |
| 51 | - } | |
| 52 | - print_r($event->toArray()); | |
| 53 | 72 | |
| 54 | - $customers = $project->findUsersByBirthday(); | |
| 55 | - foreach($customers as $customer){ | |
| 56 | - $this->post['name']=$customer->name; | |
| 57 | - $this->post['email']=$customer->email; | |
| 58 | - $this->post['phone']=$customer->phone; | |
| 59 | - $this->post['address']=$customer->address; | |
| 60 | - $this->sendMail($customer->toArray(),$project,$event,$event->eventEmail->toArray()); | |
| 61 | - } | |
| 62 | 73 | |
| 74 | + | |
| 75 | + | |
| 76 | + } | |
| 63 | 77 | } |
| 78 | + | |
| 64 | 79 | } |
| 65 | 80 | } |
| 66 | 81 | |
| ... | ... | @@ -116,13 +131,13 @@ class EventMailTask extends \Phalcon\CLI\Task |
| 116 | 131 | } |
| 117 | 132 | } |
| 118 | 133 | |
| 119 | - $users = $model->getSpyUsers($project, $this->modelsManager); | |
| 134 | + $users = $model->getSpyUsers( $this->modelsManager, $project); | |
| 120 | 135 | |
| 121 | 136 | foreach( $users as $user){ |
| 122 | 137 | $event_data = $model->spyTimeAfter($project, $user['id'])->toArray(); |
| 123 | 138 | $customers = $customers_model->findFirst("id={$user['id']}"); |
| 124 | 139 | |
| 125 | - if($customers->checkEventForUser($event->id, $project->id)){ | |
| 140 | + if($customers instanceof customersEmailList && $customers->checkEventForUser($event->id, $project->id)){ | |
| 126 | 141 | $sum = 0; |
| 127 | 142 | foreach($event_data as $item_one){ |
| 128 | 143 | $sum += (integer)$item_one['price']*$item_one['quantity']; |
| ... | ... | @@ -146,7 +161,12 @@ class EventMailTask extends \Phalcon\CLI\Task |
| 146 | 161 | } |
| 147 | 162 | } |
| 148 | 163 | |
| 149 | - | |
| 164 | + /** | |
| 165 | + *TODO: $this->post array with dynamic data for static letters, need to change in some variable | |
| 166 | + * | |
| 167 | + * | |
| 168 | + * | |
| 169 | + **/ | |
| 150 | 170 | private function prepareEventData($item_data, $template){ |
| 151 | 171 | |
| 152 | 172 | if($template['text_type']=='static' ){ |
| ... | ... | @@ -162,8 +182,9 @@ class EventMailTask extends \Phalcon\CLI\Task |
| 162 | 182 | |
| 163 | 183 | } else { |
| 164 | 184 | |
| 165 | - $template['text'] = $this->MyMailer->OfflineEvent->itemDynamicSet( $template, $item_data ); | |
| 166 | - | |
| 185 | + if( $item_data ) { | |
| 186 | + $template['text'] = $this->MyMailer->OfflineEvent->itemDynamicSet($template, $item_data); | |
| 187 | + } | |
| 167 | 188 | $template['text'] = $this->MyMailer->OnlineEvent->dataSet( $template['text'], $this->post ); |
| 168 | 189 | |
| 169 | 190 | } |
| ... | ... | @@ -195,16 +216,6 @@ class EventMailTask extends \Phalcon\CLI\Task |
| 195 | 216 | |
| 196 | 217 | |
| 197 | 218 | |
| 198 | - | |
| 199 | - public function dateEvent(){ | |
| 200 | - $date = date('d.m.y'); | |
| 201 | - } | |
| 202 | - | |
| 203 | - public function fieldEqualEvent(){ | |
| 204 | - | |
| 205 | - } | |
| 206 | - | |
| 207 | - | |
| 208 | 219 | private function getEventInfo($event, $customers,$project){ |
| 209 | 220 | $info = \eventInfo::findFirst("event_id = {$event->id} AND customer_id = {$customers['id']}"); |
| 210 | 221 | |
| ... | ... | @@ -222,6 +233,14 @@ class EventMailTask extends \Phalcon\CLI\Task |
| 222 | 233 | } |
| 223 | 234 | |
| 224 | 235 | |
| 236 | + /** | |
| 237 | + * send Email | |
| 238 | + * @params array $customers | |
| 239 | + * @params object $project | |
| 240 | + * @params object $offline_data_model | |
| 241 | + * @params array $event | |
| 242 | + * @params array $event_data | |
| 243 | + **/ | |
| 225 | 244 | public function sendMail($customers,$project,$offline_data_model, $event, $event_data = [] ){ |
| 226 | 245 | |
| 227 | 246 | if($customers){ |
| ... | ... | @@ -232,33 +251,16 @@ class EventMailTask extends \Phalcon\CLI\Task |
| 232 | 251 | |
| 233 | 252 | |
| 234 | 253 | |
| 235 | - /* if(isset($get['item_data']) && !empty($get['item_data'])){ | |
| 236 | - $item_data = json_decode($get['item_data']); | |
| 237 | - | |
| 238 | - $template->text = $this->UTMParser->itemSet( $template->toArray(), $item_data ); | |
| 239 | - | |
| 240 | - }*/ | |
| 241 | - | |
| 242 | - $template['text'] = $this->prepareEventData($event_data, $template); | |
| 243 | - | |
| 244 | - $template['text'] = $this->UTMParser->parse($event, $template); | |
| 245 | - | |
| 246 | - $this->MyMailer->OfflineEvent->setFromName($project->name); | |
| 247 | - | |
| 248 | - $this->MyMailer->OfflineEvent->SendDelivery(new \delivery(),$template,$event,[$customers]); | |
| 249 | - | |
| 254 | +// if(isset($get['item_data']) && !empty($get['item_data'])){ | |
| 255 | +// $item_data = json_decode($get['item_data']); | |
| 256 | +// | |
| 257 | +// $template->text = $this->UTMParser->itemSet( $template->toArray(), $item_data ); | |
| 258 | +// | |
| 259 | +// } | |
| 250 | 260 | |
| 261 | + $this->sendMailData($template,$customers,$event,$project,$event_data); | |
| 251 | 262 | |
| 252 | 263 | $event_info->last_delivery = date("Y-m-d H:i:s"); |
| 253 | - | |
| 254 | - | |
| 255 | - if($offline_data_model->recurring_val){ | |
| 256 | - | |
| 257 | - $date = new DateTime( date("Y-m-d H:i:s")); | |
| 258 | - $date->modify('+'.$offline_data_model->recurring_val.' '.$offline_data_model->recurring_val_type); | |
| 259 | - $event_info->next_delivery = $date->format("Y-m-d H:i:s"); | |
| 260 | - } | |
| 261 | - | |
| 262 | 264 | $event_info->save(); |
| 263 | 265 | |
| 264 | 266 | // $model = \delivery::find(); |
| ... | ... | @@ -273,9 +275,26 @@ class EventMailTask extends \Phalcon\CLI\Task |
| 273 | 275 | } |
| 274 | 276 | |
| 275 | 277 | |
| 278 | + /** | |
| 279 | + * send Email | |
| 280 | + * @params array $customers | |
| 281 | + * @params object $project | |
| 282 | + * @params array $event | |
| 283 | + * @params array $event_data | |
| 284 | + * @params array $template | |
| 285 | + **/ | |
| 276 | 286 | |
| 287 | + private function sendMailData($template,$customers,$event,$project,$event_data=[]) | |
| 288 | + { | |
| 289 | + $template['text'] = $this->prepareEventData($event_data, $template); | |
| 277 | 290 | |
| 291 | + $template['text'] = $this->UTMParser->parse($event, $template); | |
| 278 | 292 | |
| 293 | + $this->MyMailer->OfflineEvent->setFromName($project->name); | |
| 294 | + | |
| 295 | + $this->MyMailer->OfflineEvent->SendDelivery(new \delivery(),$template,$event,[$customers]); | |
| 296 | + | |
| 297 | + } | |
| 279 | 298 | |
| 280 | 299 | |
| 281 | 300 | ... | ... |
src/lib/models/eventInfo.php
| ... | ... | @@ -14,5 +14,17 @@ class eventInfo extends \Phalcon\Mvc\Model |
| 14 | 14 | return "event_info"; |
| 15 | 15 | } |
| 16 | 16 | |
| 17 | + static public function getEventsByTrigger($modelsManager, $project_id, $trigger){ | |
| 18 | + $now = date("Y-m-d H:i:s"); | |
| 17 | 19 | |
| 20 | + $phql = " | |
| 21 | + SELECT * FROM eventInfo | |
| 22 | + WHERE project_id = $project_id | |
| 23 | + AND event_trigger='{$trigger}' | |
| 24 | + AND next_delivery <= '$now' | |
| 25 | + AND last_delivery IS NULL OR last_delivery = ''"; | |
| 26 | + | |
| 27 | + return $modelsManager->executeQuery($phql); | |
| 28 | + | |
| 29 | + } | |
| 18 | 30 | } |
| 19 | 31 | \ No newline at end of file | ... | ... |
src/lib/models/seriesOfLetters.php
| ... | ... | @@ -14,5 +14,26 @@ class seriesOfLetters extends \Phalcon\Mvc\Model |
| 14 | 14 | return "series_of_letters"; |
| 15 | 15 | } |
| 16 | 16 | |
| 17 | + public function getDays(){ | |
| 18 | + return [ | |
| 19 | + ['val'=>'1','name'=>'понедельник'], | |
| 20 | + ['val'=>'2','name'=>'вторник'], | |
| 21 | + ['val'=>'3','name'=>'среда'], | |
| 22 | + ['val'=>'4','name'=>'четверг'], | |
| 23 | + ['val'=>'5','name'=>'пятница'], | |
| 24 | + ['val'=>'6','name'=>'суббота'], | |
| 25 | + ['val'=>'7','name'=>'воскресенье'], | |
| 26 | + ]; | |
| 27 | + } | |
| 28 | + public function isActive($first_delivery,$day){ | |
| 29 | + if($first_delivery==$day){ | |
| 30 | + return true; | |
| 31 | + }else{ | |
| 32 | + return false; | |
| 33 | + } | |
| 34 | + | |
| 35 | + | |
| 36 | + } | |
| 37 | + | |
| 17 | 38 | |
| 18 | 39 | } |
| 19 | 40 | \ No newline at end of file | ... | ... |