Commit 735ae87f87a77d9b260b341a61d6cd51674166ad
1 parent
19235aca
sending email
Showing
9 changed files
with
314 additions
and
62 deletions
Show diff stats
1 | +<?php | ||
2 | + use frontend\models\Feedback; | ||
3 | + use yii\web\View; | ||
4 | + | ||
5 | + /** | ||
6 | + * @var View $this | ||
7 | + * @var Feedback $model | ||
8 | + */ | ||
9 | + | ||
10 | +?> | ||
11 | + | ||
12 | +<table> | ||
13 | + <tbody> | ||
14 | + <tr> | ||
15 | + <td><b><?= \Yii::t('app', 'Name: ') ?></b></td> | ||
16 | + <td><?= $model->name ?></td> | ||
17 | + </tr> | ||
18 | + <tr> | ||
19 | + <td><b><?= \Yii::t('app', 'Phone: ') ?></b></td> | ||
20 | + <td><?= $model->phone ?></td> | ||
21 | + </tr> | ||
22 | + <tr> | ||
23 | + <td><b><?= \Yii::t('app', 'Date: ') ?></b></td> | ||
24 | + <td><?= $model->date ?></td> | ||
25 | + </tr> | ||
26 | + <tr> | ||
27 | + <td><b><?= \Yii::t('app', 'Time: ') ?></b></td> | ||
28 | + <td><?= $model->time ?></td> | ||
29 | + </tr> | ||
30 | + <tr> | ||
31 | + <td><b><?= \Yii::t('app', 'Service: ') ?></b></td> | ||
32 | + <td><?= $model->service ?></td> | ||
33 | + </tr> | ||
34 | + <tr> | ||
35 | + <td><b><?= \Yii::t('app', 'Url: ') ?></b></td> | ||
36 | + <td><?= $model->url ?></td> | ||
37 | + </tr> | ||
38 | + </tbody> | ||
39 | +</table> |
common/mail/feedback.php
@@ -27,5 +27,9 @@ | @@ -27,5 +27,9 @@ | ||
27 | <td><b><?= \Yii::t('app', 'Message: ') ?></b></td> | 27 | <td><b><?= \Yii::t('app', 'Message: ') ?></b></td> |
28 | <td><?= $model->message ?></td> | 28 | <td><?= $model->message ?></td> |
29 | </tr> | 29 | </tr> |
30 | + <tr> | ||
31 | + <td><b><?= \Yii::t('app', 'Url: ') ?></b></td> | ||
32 | + <td><?= $model->url ?></td> | ||
33 | + </tr> | ||
30 | </tbody> | 34 | </tbody> |
31 | </table> | 35 | </table> |
composer.json
@@ -34,8 +34,7 @@ | @@ -34,8 +34,7 @@ | ||
34 | "artweb/artbox-core": "@dev", | 34 | "artweb/artbox-core": "@dev", |
35 | "artweb/artbox-weblog": "@dev", | 35 | "artweb/artbox-weblog": "@dev", |
36 | "artweb/artbox-webcomment": "@dev", | 36 | "artweb/artbox-webcomment": "@dev", |
37 | - "modernkernel/yii2-photoswipe": "*", | ||
38 | - "udokmeci/yii2-phone-validator" : "dev-master" | 37 | + "modernkernel/yii2-photoswipe": "*" |
39 | }, | 38 | }, |
40 | "require-dev": { | 39 | "require-dev": { |
41 | "yiisoft/yii2-debug": "~2.0.0", | 40 | "yiisoft/yii2-debug": "~2.0.0", |
console/migrations/m171109_141930_add_date_service_column_to_feedback_table.php
0 → 100644
1 | +<?php | ||
2 | + | ||
3 | +use yii\db\Migration; | ||
4 | + | ||
5 | +/** | ||
6 | + * Handles adding date_service to table `feedback`. | ||
7 | + */ | ||
8 | +class m171109_141930_add_date_service_column_to_feedback_table extends Migration | ||
9 | +{ | ||
10 | + /** | ||
11 | + * @inheritdoc | ||
12 | + */ | ||
13 | + public function up() | ||
14 | + { | ||
15 | + $this->addColumn('feedback', 'date', $this->string()); | ||
16 | + $this->addColumn('feedback', 'service', $this->string()); | ||
17 | + } | ||
18 | + | ||
19 | + /** | ||
20 | + * @inheritdoc | ||
21 | + */ | ||
22 | + public function down() | ||
23 | + { | ||
24 | + $this->dropColumn('feedback', 'date'); | ||
25 | + $this->dropColumn('feedback', 'service'); | ||
26 | + } | ||
27 | +} |
console/migrations/m171109_143936_add_time_column_to_feedback_table.php
0 → 100644
1 | +<?php | ||
2 | + | ||
3 | +use yii\db\Migration; | ||
4 | + | ||
5 | +/** | ||
6 | + * Handles adding time to table `feedback`. | ||
7 | + */ | ||
8 | +class m171109_143936_add_time_column_to_feedback_table extends Migration | ||
9 | +{ | ||
10 | + /** | ||
11 | + * @inheritdoc | ||
12 | + */ | ||
13 | + public function up() | ||
14 | + { | ||
15 | + $this->addColumn('feedback', 'time', $this->string()); | ||
16 | + } | ||
17 | + | ||
18 | + /** | ||
19 | + * @inheritdoc | ||
20 | + */ | ||
21 | + public function down() | ||
22 | + { | ||
23 | + $this->dropColumn('feedback', 'time'); | ||
24 | + } | ||
25 | +} |
frontend/controllers/SiteController.php
1 | <?php | 1 | <?php |
2 | namespace frontend\controllers; | 2 | namespace frontend\controllers; |
3 | 3 | ||
4 | - use artbox\core\models\Feedback; | 4 | + use frontend\models\Feedback; |
5 | use artbox\core\models\Page; | 5 | use artbox\core\models\Page; |
6 | use common\models\Gallery; | 6 | use common\models\Gallery; |
7 | use common\models\Settings; | 7 | use common\models\Settings; |
@@ -126,7 +126,21 @@ | @@ -126,7 +126,21 @@ | ||
126 | if (empty(Yii::$app->request->post())) { | 126 | if (empty(Yii::$app->request->post())) { |
127 | throw new BadRequestHttpException(); | 127 | throw new BadRequestHttpException(); |
128 | } else { | 128 | } else { |
129 | - $model = new Feedback(); | 129 | + $type = Yii::$app->request->post("type"); |
130 | + | ||
131 | + $viewFileName = "feedback"; | ||
132 | + $model = new Feedback(['scenario' => Feedback::SCENARIO_WRITE_US]); | ||
133 | + | ||
134 | + if ( $type === "write_us" ){ | ||
135 | + $viewFileName = "feedback"; | ||
136 | + $model = new Feedback(['scenario' => Feedback::SCENARIO_WRITE_US]); | ||
137 | + } | ||
138 | + elseif ( $type === "appointment" ){ | ||
139 | + $viewFileName = "appointment"; | ||
140 | + $model = new Feedback(['scenario' => Feedback::SCENARIO_APPOINTMENT]); | ||
141 | + } | ||
142 | + | ||
143 | + | ||
130 | if ($model->load(Yii::$app->request->post()) && $model->save()) { | 144 | if ($model->load(Yii::$app->request->post()) && $model->save()) { |
131 | 145 | ||
132 | $pattern = '/([a-zA-Z0-9\._-]*@[a-zA-Z0-9\._-]*)([;\s,:]*)/'; | 146 | $pattern = '/([a-zA-Z0-9\._-]*@[a-zA-Z0-9\._-]*)([;\s,:]*)/'; |
@@ -136,8 +150,9 @@ | @@ -136,8 +150,9 @@ | ||
136 | 150 | ||
137 | $emails = explode("; ", $emailStr); | 151 | $emails = explode("; ", $emailStr); |
138 | 152 | ||
153 | + | ||
139 | $mailer->compose( | 154 | $mailer->compose( |
140 | - 'feedback', | 155 | + $viewFileName, |
141 | [ | 156 | [ |
142 | 'model' => $model, | 157 | 'model' => $model, |
143 | ] | 158 | ] |
@@ -160,6 +175,8 @@ | @@ -160,6 +175,8 @@ | ||
160 | 'alert' => $alert, | 175 | 'alert' => $alert, |
161 | ]; | 176 | ]; |
162 | } else { | 177 | } else { |
178 | + Yii::$app->response->setStatusCode(500); | ||
179 | + | ||
163 | return [ | 180 | return [ |
164 | 'success' => false, | 181 | 'success' => false, |
165 | 'error' => $model->errors, | 182 | 'error' => $model->errors, |
frontend/models/Feedback.php
1 | <?php | 1 | <?php |
2 | + | ||
2 | namespace frontend\models; | 3 | namespace frontend\models; |
3 | 4 | ||
5 | + use Yii; | ||
4 | /** | 6 | /** |
5 | * Created by PhpStorm. | 7 | * Created by PhpStorm. |
6 | * User: timur | 8 | * User: timur |
7 | * Date: 09.11.17 | 9 | * Date: 09.11.17 |
8 | * Time: 14:50 | 10 | * Time: 14:50 |
11 | + * | ||
12 | + * @property string $date | ||
13 | + * @property string $service | ||
14 | + * @property string $time | ||
15 | + * | ||
9 | */ | 16 | */ |
10 | - | ||
11 | class Feedback extends \artbox\core\models\Feedback | 17 | class Feedback extends \artbox\core\models\Feedback |
12 | { | 18 | { |
13 | const SCENARIO_WRITE_US = "write_us"; | 19 | const SCENARIO_WRITE_US = "write_us"; |
@@ -18,13 +24,12 @@ | @@ -18,13 +24,12 @@ | ||
18 | $scenarios = array_merge( | 24 | $scenarios = array_merge( |
19 | parent::scenarios(), | 25 | parent::scenarios(), |
20 | [ | 26 | [ |
21 | - self::SCENARIO_APPOINTMENT=>[ | 27 | + self::SCENARIO_APPOINTMENT => [ |
22 | 'name', | 28 | 'name', |
23 | 'phone', | 29 | 'phone', |
24 | 'date', | 30 | 'date', |
25 | 'time', | 31 | 'time', |
26 | 'service', | 32 | 'service', |
27 | - 'url' | ||
28 | ], | 33 | ], |
29 | 34 | ||
30 | self::SCENARIO_WRITE_US => [ | 35 | self::SCENARIO_WRITE_US => [ |
@@ -32,8 +37,7 @@ | @@ -32,8 +37,7 @@ | ||
32 | 'email', | 37 | 'email', |
33 | 'phone', | 38 | 'phone', |
34 | 'message', | 39 | 'message', |
35 | - 'url' | ||
36 | - ] | 40 | + ], |
37 | ] | 41 | ] |
38 | ); | 42 | ); |
39 | 43 | ||
@@ -48,7 +52,6 @@ | @@ -48,7 +52,6 @@ | ||
48 | 'name', | 52 | 'name', |
49 | 'phone', | 53 | 'phone', |
50 | 'date', | 54 | 'date', |
51 | - 'url' | ||
52 | ], | 55 | ], |
53 | 'required', | 56 | 'required', |
54 | 'on' => self::SCENARIO_APPOINTMENT, | 57 | 'on' => self::SCENARIO_APPOINTMENT, |
@@ -58,7 +61,6 @@ | @@ -58,7 +61,6 @@ | ||
58 | 'name', | 61 | 'name', |
59 | 'email', | 62 | 'email', |
60 | 'phone', | 63 | 'phone', |
61 | - 'url', | ||
62 | ], | 64 | ], |
63 | 'required', | 65 | 'required', |
64 | 'on' => self::SCENARIO_WRITE_US, | 66 | 'on' => self::SCENARIO_WRITE_US, |
@@ -71,14 +73,16 @@ | @@ -71,14 +73,16 @@ | ||
71 | [ | 73 | [ |
72 | 'name', | 74 | 'name', |
73 | 'date', | 75 | 'date', |
74 | - 'phone', | 76 | + 'service', |
77 | + 'time', | ||
75 | ], | 78 | ], |
76 | 'string', | 79 | 'string', |
77 | - 'max' => 255, | 80 | + 'max' => 55, |
78 | ], | 81 | ], |
79 | [ | 82 | [ |
80 | - [ 'url' ], | ||
81 | - 'url' | 83 | + [ 'phone' ], |
84 | + 'match', | ||
85 | + 'pattern' => '/^\+38\(\d{3}\)\d{3}-\d{2}-\d{2}$/', | ||
82 | ], | 86 | ], |
83 | [ | 87 | [ |
84 | [ 'message' ], | 88 | [ 'message' ], |
@@ -91,4 +95,24 @@ | @@ -91,4 +95,24 @@ | ||
91 | ]; | 95 | ]; |
92 | } | 96 | } |
93 | 97 | ||
98 | + /** | ||
99 | + * @inheritdoc | ||
100 | + */ | ||
101 | + public function attributeLabels() | ||
102 | + { | ||
103 | + return [ | ||
104 | + 'id' => Yii::t('core', 'id'), | ||
105 | + 'name' => Yii::t('core', 'name'), | ||
106 | + 'phone' => Yii::t('core', 'phone'), | ||
107 | + 'created_at' => Yii::t('core', 'created_at'), | ||
108 | + 'ip' => Yii::t('core', 'ip'), | ||
109 | + 'url' => Yii::t('core', 'url'), | ||
110 | + 'status' => Yii::t('core', 'status'), | ||
111 | + 'message' => Yii::t('core', 'message'), | ||
112 | + 'email' => Yii::t('core', 'email'), | ||
113 | + 'service' => Yii::t('core', 'service'), | ||
114 | + 'date' => Yii::t('core', 'date'), | ||
115 | + ]; | ||
116 | + } | ||
117 | + | ||
94 | } | 118 | } |
95 | \ No newline at end of file | 119 | \ No newline at end of file |
frontend/views/layouts/main.php
@@ -10,7 +10,7 @@ | @@ -10,7 +10,7 @@ | ||
10 | 10 | ||
11 | use artbox\core\components\SeoComponent; | 11 | use artbox\core\components\SeoComponent; |
12 | use artbox\core\helpers\ImageHelper; | 12 | use artbox\core\helpers\ImageHelper; |
13 | - use artbox\core\models\Feedback; | 13 | + use frontend\models\Feedback; |
14 | use artbox\core\models\PageCategory; | 14 | use artbox\core\models\PageCategory; |
15 | use artbox\core\models\User; | 15 | use artbox\core\models\User; |
16 | use common\models\Settings; | 16 | use common\models\Settings; |
@@ -27,7 +27,8 @@ | @@ -27,7 +27,8 @@ | ||
27 | AppAsset::register($this); | 27 | AppAsset::register($this); |
28 | $user = \Yii::$app->user->identity; | 28 | $user = \Yii::$app->user->identity; |
29 | $seo = Yii::$app->get('seo'); | 29 | $seo = Yii::$app->get('seo'); |
30 | - $feedback = new Feedback(); | 30 | + $feedback = new Feedback(['scenario' => Feedback::SCENARIO_WRITE_US]); |
31 | + $appointment = new Feedback(['scenario' => Feedback::SCENARIO_APPOINTMENT]); | ||
31 | $settings = Settings::getInstance(); | 32 | $settings = Settings::getInstance(); |
32 | $controller = Yii::$app->controller; | 33 | $controller = Yii::$app->controller; |
33 | $default_controller = Yii::$app->defaultRoute; | 34 | $default_controller = Yii::$app->defaultRoute; |
@@ -66,7 +67,19 @@ | @@ -66,7 +67,19 @@ | ||
66 | 'name' => 'robots', | 67 | 'name' => 'robots', |
67 | 'content' => $seo->robots, | 68 | 'content' => $seo->robots, |
68 | ] | 69 | ] |
69 | - ) | 70 | + ); |
71 | + | ||
72 | + $this->registerJsFile( | ||
73 | + '/js/jquery.maskedinput.js', | ||
74 | + [ | ||
75 | + 'depends' => 'yii\web\JqueryAsset' | ||
76 | + ] | ||
77 | + ); | ||
78 | + | ||
79 | + $js = <<<JS | ||
80 | + $("#feedback-phone, #appointment-phone").mask("+38(999)999-99-99"); | ||
81 | +JS; | ||
82 | + $this->registerJs($js, View::POS_READY); | ||
70 | ?> | 83 | ?> |
71 | 84 | ||
72 | <?php $this->beginPage() ?> | 85 | <?php $this->beginPage() ?> |
@@ -374,49 +387,144 @@ _________________________________________________________ --> | @@ -374,49 +387,144 @@ _________________________________________________________ --> | ||
374 | </div> | 387 | </div> |
375 | <div class="modal-body"> | 388 | <div class="modal-body"> |
376 | 389 | ||
377 | - <form id="appointment-form" action="/site/appointment" method="POST" role="form"> | ||
378 | - <div class="form-group field-appointment-name"> | ||
379 | - <div class="on_input_"></div> | ||
380 | - <label class="control-label" for="appointment-name">Имя</label> | ||
381 | - <input type="text" id="appointment-name" class="form-control" name="Appointment[name]" aria-invalid="false"> | ||
382 | - | ||
383 | - <p class="help-block help-block-error"></p> | ||
384 | - </div> | ||
385 | - <div class="form-group field-appointment-name required"> | ||
386 | - <div class="on_input_"></div> | ||
387 | - <label class="control-label" for="appointment-name">Номер телефона</label> | ||
388 | - <input type="text" id="appointment-phone" class="form-control" name="Appointment[phone]"> | ||
389 | - | ||
390 | - <p class="help-block help-block-error"></p> | ||
391 | - </div> | ||
392 | - <div class="form-group field-appointment-date required has-datepicker"> | ||
393 | - <div class="on_input_"></div> | ||
394 | - <label class="control-label" for="appointment-date">Дата</label> | ||
395 | - <input type="text" id="appointment-date" class="form-control" name="Appointment[date]"> | ||
396 | - | ||
397 | - <p class="help-block help-block-error"></p> | ||
398 | - </div> | ||
399 | - <div class="datepicker-wr"> | ||
400 | - <div id="datepicker"></div> | ||
401 | - </div> | ||
402 | - <div class="form-group field-appointment-time"> | ||
403 | - <div class="on_input_"></div> | ||
404 | - <label class="control-label" for="appointment-service">Время</label> | ||
405 | - <input type="text" id="appointment-time" class="form-control" name="Appointment[time]"> | ||
406 | - | ||
407 | - <p class="help-block help-block-error"></p> | ||
408 | - </div> | ||
409 | - <div class="form-group field-appointment-service"> | ||
410 | - <div class="on_input_"></div> | ||
411 | - <label class="control-label" for="appointment-service">Услуга</label> | ||
412 | - <input type="text" id="appointment-service" class="form-control" name="Appointment[service]"> | ||
413 | - | ||
414 | - <p class="help-block help-block-error"></p> | ||
415 | - </div> | ||
416 | - <p class="text-center"> | ||
417 | - <button type="submit" class="send-form btn btn-lg btn-template-primary">Отправить</button> | ||
418 | - </p> | ||
419 | - </form> | 390 | + |
391 | + <?php | ||
392 | + | ||
393 | + | ||
394 | + $formAppointment = ActiveForm::begin( | ||
395 | + [ | ||
396 | + 'id' => 'appointment-form', | ||
397 | + 'method' => 'POST', | ||
398 | + 'action' => '/site/feedback', | ||
399 | + ] | ||
400 | + ); | ||
401 | + | ||
402 | + echo Html::hiddenInput('type', 'appointment'); | ||
403 | + echo $formAppointment->field( | ||
404 | + $appointment, | ||
405 | + "name", | ||
406 | + [ | ||
407 | + 'options' => [ | ||
408 | + 'class' => 'form-group field-appointment-name', | ||
409 | + ], | ||
410 | + 'template' => "<div class=\"on_input_\"></div>{label}\n{input}\n", | ||
411 | + 'inputOptions' => [ | ||
412 | + 'id' => 'appointment-name' | ||
413 | + ], | ||
414 | + 'labelOptions' => [ | ||
415 | + 'for' => 'appointment-name', | ||
416 | + 'class' => 'control-label' | ||
417 | + ], | ||
418 | + ] | ||
419 | + ) | ||
420 | + ->label( | ||
421 | + "Имя" | ||
422 | + ); | ||
423 | + | ||
424 | + echo $formAppointment->field( | ||
425 | + $appointment, | ||
426 | + "phone", | ||
427 | + [ | ||
428 | + 'options' => [ | ||
429 | + 'class' => 'form-group field-appointment-phone', | ||
430 | + ], | ||
431 | + 'template' => "<div class=\"on_input_\"></div>{label}\n{input}\n", | ||
432 | + 'inputOptions' => [ | ||
433 | + 'id' => 'appointment-phone' | ||
434 | + ], | ||
435 | + 'labelOptions' => [ | ||
436 | + 'for' => 'appointment-phone', | ||
437 | + 'class' => 'control-label' | ||
438 | + ], | ||
439 | + ] | ||
440 | + ) | ||
441 | + ->label( | ||
442 | + "Номер телефона" | ||
443 | + ); | ||
444 | + | ||
445 | + echo $formAppointment->field( | ||
446 | + $appointment, | ||
447 | + "date", | ||
448 | + [ | ||
449 | + 'options' => [ | ||
450 | + 'class' => 'form-group field-appointment-date has-datepicker', | ||
451 | + ], | ||
452 | + 'template' => "<div class=\"on_input_\"></div>{label}\n{input}\n", | ||
453 | + 'inputOptions' => [ | ||
454 | + 'id' => 'appointment-date' | ||
455 | + ], | ||
456 | + 'labelOptions' => [ | ||
457 | + 'for' => 'appointment-date', | ||
458 | + 'class' => 'control-label' | ||
459 | + ], | ||
460 | + ] | ||
461 | + ) | ||
462 | + ->label( | ||
463 | + "Дата" | ||
464 | + ); | ||
465 | + echo "<div class=\"datepicker-wr\"> | ||
466 | + <div id=\"datepicker\"></div> | ||
467 | + </div>"; | ||
468 | + | ||
469 | + echo $formAppointment->field( | ||
470 | + $appointment, | ||
471 | + "time", | ||
472 | + [ | ||
473 | + 'options' => [ | ||
474 | + 'class' => 'form-group field-appointment-time', | ||
475 | + ], | ||
476 | + 'template' => "<div class=\"on_input_\"></div>{label}\n{input}\n", | ||
477 | + 'inputOptions' => [ | ||
478 | + 'id' => 'appointment-time' | ||
479 | + ], | ||
480 | + 'labelOptions' => [ | ||
481 | + 'for' => 'appointment-time', | ||
482 | + 'class' => 'control-label' | ||
483 | + ], | ||
484 | + ] | ||
485 | + ) | ||
486 | + ->label( | ||
487 | + "Время" | ||
488 | + ); | ||
489 | + | ||
490 | + echo $formAppointment->field( | ||
491 | + $appointment, | ||
492 | + "service", | ||
493 | + [ | ||
494 | + 'options' => [ | ||
495 | + 'class' => 'form-group field-appointment-service', | ||
496 | + ], | ||
497 | + 'template' => "<div class=\"on_input_\"></div>{label}\n{input}\n", | ||
498 | + 'inputOptions' => [ | ||
499 | + 'id' => 'appointment-service' | ||
500 | + ], | ||
501 | + 'labelOptions' => [ | ||
502 | + 'for' => 'appointment-service', | ||
503 | + 'class' => 'control-label' | ||
504 | + ], | ||
505 | + ] | ||
506 | + ) | ||
507 | + ->label( | ||
508 | + "Услуга" | ||
509 | + ); | ||
510 | + | ||
511 | + echo Html::tag( | ||
512 | + "p", | ||
513 | + Html::button( | ||
514 | + "Отправить", | ||
515 | + [ | ||
516 | + 'type' => "submit", | ||
517 | + 'class' => "send-form btn btn-lg btn-template-primary" | ||
518 | + ] | ||
519 | + ), | ||
520 | + [ | ||
521 | + 'class' => "text-center" | ||
522 | + ] | ||
523 | + ); | ||
524 | + | ||
525 | + $formAppointment::end(); | ||
526 | + ?> | ||
527 | + | ||
420 | 528 | ||
421 | </div> | 529 | </div> |
422 | </div> | 530 | </div> |
@@ -444,6 +552,8 @@ _________________________________________________________ --> | @@ -444,6 +552,8 @@ _________________________________________________________ --> | ||
444 | ] | 552 | ] |
445 | ); ?> | 553 | ); ?> |
446 | 554 | ||
555 | + <?= Html::hiddenInput('type', 'write_us');?> | ||
556 | + | ||
447 | <?= $form->field($feedback, 'name') | 557 | <?= $form->field($feedback, 'name') |
448 | ->textInput() | 558 | ->textInput() |
449 | ->Label('Имя'); ?> | 559 | ->Label('Имя'); ?> |
1 | +/* | ||
2 | + jQuery Masked Input Plugin | ||
3 | + Copyright (c) 2007 - 2015 Josh Bush (digitalbush.com) | ||
4 | + Licensed under the MIT license (http://digitalbush.com/projects/masked-input-plugin/#license) | ||
5 | + Version: 1.4.1 | ||
6 | +*/ | ||
7 | +!function(a){"function"==typeof define&&define.amd?define(["jquery"],a):a("object"==typeof exports?require("jquery"):jQuery)}(function(a){var b,c=navigator.userAgent,d=/iphone/i.test(c),e=/chrome/i.test(c),f=/android/i.test(c);a.mask={definitions:{9:"[0-9]",a:"[A-Za-z]","*":"[A-Za-z0-9]"},autoclear:!0,dataName:"rawMaskFn",placeholder:"_"},a.fn.extend({caret:function(a,b){var c;if(0!==this.length&&!this.is(":hidden"))return"number"==typeof a?(b="number"==typeof b?b:a,this.each(function(){this.setSelectionRange?this.setSelectionRange(a,b):this.createTextRange&&(c=this.createTextRange(),c.collapse(!0),c.moveEnd("character",b),c.moveStart("character",a),c.select())})):(this[0].setSelectionRange?(a=this[0].selectionStart,b=this[0].selectionEnd):document.selection&&document.selection.createRange&&(c=document.selection.createRange(),a=0-c.duplicate().moveStart("character",-1e5),b=a+c.text.length),{begin:a,end:b})},unmask:function(){return this.trigger("unmask")},mask:function(c,g){var h,i,j,k,l,m,n,o;if(!c&&this.length>0){h=a(this[0]);var p=h.data(a.mask.dataName);return p?p():void 0}return g=a.extend({autoclear:a.mask.autoclear,placeholder:a.mask.placeholder,completed:null},g),i=a.mask.definitions,j=[],k=n=c.length,l=null,a.each(c.split(""),function(a,b){"?"==b?(n--,k=a):i[b]?(j.push(new RegExp(i[b])),null===l&&(l=j.length-1),k>a&&(m=j.length-1)):j.push(null)}),this.trigger("unmask").each(function(){function h(){if(g.completed){for(var a=l;m>=a;a++)if(j[a]&&C[a]===p(a))return;g.completed.call(B)}}function p(a){return g.placeholder.charAt(a<g.placeholder.length?a:0)}function q(a){for(;++a<n&&!j[a];);return a}function r(a){for(;--a>=0&&!j[a];);return a}function s(a,b){var c,d;if(!(0>a)){for(c=a,d=q(b);n>c;c++)if(j[c]){if(!(n>d&&j[c].test(C[d])))break;C[c]=C[d],C[d]=p(d),d=q(d)}z(),B.caret(Math.max(l,a))}}function t(a){var b,c,d,e;for(b=a,c=p(a);n>b;b++)if(j[b]){if(d=q(b),e=C[b],C[b]=c,!(n>d&&j[d].test(e)))break;c=e}}function u(){var a=B.val(),b=B.caret();if(o&&o.length&&o.length>a.length){for(A(!0);b.begin>0&&!j[b.begin-1];)b.begin--;if(0===b.begin)for(;b.begin<l&&!j[b.begin];)b.begin++;B.caret(b.begin,b.begin)}else{for(A(!0);b.begin<n&&!j[b.begin];)b.begin++;B.caret(b.begin,b.begin)}h()}function v(){A(),B.val()!=E&&B.change()}function w(a){if(!B.prop("readonly")){var b,c,e,f=a.which||a.keyCode;o=B.val(),8===f||46===f||d&&127===f?(b=B.caret(),c=b.begin,e=b.end,e-c===0&&(c=46!==f?r(c):e=q(c-1),e=46===f?q(e):e),y(c,e),s(c,e-1),a.preventDefault()):13===f?v.call(this,a):27===f&&(B.val(E),B.caret(0,A()),a.preventDefault())}}function x(b){if(!B.prop("readonly")){var c,d,e,g=b.which||b.keyCode,i=B.caret();if(!(b.ctrlKey||b.altKey||b.metaKey||32>g)&&g&&13!==g){if(i.end-i.begin!==0&&(y(i.begin,i.end),s(i.begin,i.end-1)),c=q(i.begin-1),n>c&&(d=String.fromCharCode(g),j[c].test(d))){if(t(c),C[c]=d,z(),e=q(c),f){var k=function(){a.proxy(a.fn.caret,B,e)()};setTimeout(k,0)}else B.caret(e);i.begin<=m&&h()}b.preventDefault()}}}function y(a,b){var c;for(c=a;b>c&&n>c;c++)j[c]&&(C[c]=p(c))}function z(){B.val(C.join(""))}function A(a){var b,c,d,e=B.val(),f=-1;for(b=0,d=0;n>b;b++)if(j[b]){for(C[b]=p(b);d++<e.length;)if(c=e.charAt(d-1),j[b].test(c)){C[b]=c,f=b;break}if(d>e.length){y(b+1,n);break}}else C[b]===e.charAt(d)&&d++,k>b&&(f=b);return a?z():k>f+1?g.autoclear||C.join("")===D?(B.val()&&B.val(""),y(0,n)):z():(z(),B.val(B.val().substring(0,f+1))),k?b:l}var B=a(this),C=a.map(c.split(""),function(a,b){return"?"!=a?i[a]?p(b):a:void 0}),D=C.join(""),E=B.val();B.data(a.mask.dataName,function(){return a.map(C,function(a,b){return j[b]&&a!=p(b)?a:null}).join("")}),B.one("unmask",function(){B.off(".mask").removeData(a.mask.dataName)}).on("focus.mask",function(){if(!B.prop("readonly")){clearTimeout(b);var a;E=B.val(),a=A(),b=setTimeout(function(){B.get(0)===document.activeElement&&(z(),a==c.replace("?","").length?B.caret(0,a):B.caret(a))},10)}}).on("blur.mask",v).on("keydown.mask",w).on("keypress.mask",x).on("input.mask paste.mask",function(){B.prop("readonly")||setTimeout(function(){var a=A(!0);B.caret(a),h()},0)}),e&&f&&B.off("input.mask").on("input.mask",u),A()})}})}); | ||
0 | \ No newline at end of file | 8 | \ No newline at end of file |