Commit 3d16390953c8e28082cf03cb00366b0310a2d807
Merge remote-tracking branch 'origin/master'
# Conflicts: # frontend/controllers/AccountsController.php
Showing
11 changed files
with
271 additions
and
158 deletions
Show diff stats
1 | +$('body').on('click', '.delete-field-item', function(){ | ||
2 | + | ||
3 | + $(this).parent('.form-group').remove(); | ||
4 | + | ||
5 | +}); | ||
6 | + | ||
7 | + | ||
8 | +$('.add_field').click(function(){ | ||
9 | + var block = $('.fields_video_result'); | ||
10 | + var sub_block = '<div class="form-group">'+ | ||
11 | + '<input type="text" class="form-control" value="" name="Fields[video]['+ start_i++ +'][value]">'+ | ||
12 | + '<span data-id="none" title="удалить" class="glyphicon glyphicon-trash delete-field-item"></span>'+ | ||
13 | + '<div>'; | ||
14 | + block.append(sub_block); | ||
15 | + | ||
16 | +}); | ||
0 | \ No newline at end of file | 17 | \ No newline at end of file |
backend/web/js/option.js
@@ -58,55 +58,55 @@ $(function() { | @@ -58,55 +58,55 @@ $(function() { | ||
58 | } | 58 | } |
59 | return false; | 59 | return false; |
60 | }); | 60 | }); |
61 | - //$.each($('.nav-tabs.f32'), function(key, value) { | ||
62 | - // if($(value).find('li').length > 1) { | ||
63 | - // $(value).find('li').append('<span class="glyphicon glyphicon-remove-circle remove-lang"></span>'); | ||
64 | - // } | ||
65 | - //}); | ||
66 | - //$(document).on('click', '.dropdown-menu.f32:not(.old) li a[data-lang]', function() { | ||
67 | - // var lang = $(this).data('lang'); | ||
68 | - // var flag = $(this).find('span').first().clone(); | ||
69 | - // var el = $(this); | ||
70 | - // var id = $(this).attr('href').substr(1); | ||
71 | - // var path = form[id].handler; | ||
72 | - // var view = form[id].view; | ||
73 | - // var model = form[id].model; | ||
74 | - // $.get(path, { language_id: lang, widget_id: id, ajaxView: view, model: model }, function(data) { | ||
75 | - // $('#'+id+'-tabs li').removeClass('active'); | ||
76 | - // $('#'+id+'-tabs').append('<li role="lang_inputs" class="active" data-lang="'+lang+'"><a href="#'+id+'-'+lang+'" aria-controls="'+id+'-'+lang+'" role="tab" data-toggle="tab">'+$('<p>').append($(flag)).html()+'</a></li>'); | ||
77 | - // $('#tab-content-'+id+' .tab-pane.active').removeClass('active'); | ||
78 | - // $('#tab-content-'+id).append($(data).find('.ajax-loaded').first()); | ||
79 | - // $('body').append($(data).filter('script')); | ||
80 | - // $(el).parent().remove(); | ||
81 | - // if(!$('#lang-'+id+' li').length) { | ||
82 | - // $('#'+id+'Lang').addClass('disabled'); | ||
83 | - // } | ||
84 | - // if($('#'+id+'-tabs li').length > 1) { | ||
85 | - // $('#'+id+'-tabs li').append('<span class="glyphicon glyphicon-remove-circle remove-lang"></span>') | ||
86 | - // } | ||
87 | - // }); | ||
88 | - //}); | ||
89 | - //$(document).on('click', '.dropdown-menu.f32.old li a[data-lang]', function(e) { | ||
90 | - // e.preventDefault(); | ||
91 | - // var lang = $(this).data('lang'); | ||
92 | - // var flag = $(this).find('span').first().clone(); | ||
93 | - // var el = $(this); | ||
94 | - // var id = $(this).attr('href').substr(1); | ||
95 | - // $.get(form[id], { language_id: lang, widget_id: id }, function(data) { | ||
96 | - // $('#'+id+'-tabs li').removeClass('active'); | ||
97 | - // $('#'+id+'-tabs').append('<li role="lang_inputs" class="active" data-lang="'+lang+'"><a href="#'+id+'-'+lang+'" aria-controls="'+id+'-'+lang+'" role="tab" data-toggle="tab">'+$('<p>').append($(flag)).html()+'</a></li>'); | ||
98 | - // $('#tab-content-'+id+' .tab-pane.active').removeClass('active'); | ||
99 | - // $('#tab-content-'+id).append($(data).find('.ajax-loaded').first()); | ||
100 | - // $('body').append($(data).filter('script')); | ||
101 | - // $(el).parent().remove(); | ||
102 | - // if(!$('#lang-'+id+' li').length) { | ||
103 | - // $('#'+id+'Lang').addClass('disabled'); | ||
104 | - // } | ||
105 | - // if($('#'+id+'-tabs li').length > 1) { | ||
106 | - // $('#'+id+'-tabs li').append('<span class="glyphicon glyphicon-remove-circle remove-lang"></span>') | ||
107 | - // } | ||
108 | - // }); | ||
109 | - //}); | 61 | + $.each($('.nav-tabs.f32'), function(key, value) { |
62 | + if($(value).find('li').length > 1) { | ||
63 | + $(value).find('li').append('<span class="glyphicon glyphicon-remove-circle remove-lang"></span>'); | ||
64 | + } | ||
65 | + }); | ||
66 | + $(document).on('click', '.dropdown-menu.f32:not(.old) li a[data-lang]', function() { | ||
67 | + var lang = $(this).data('lang'); | ||
68 | + var flag = $(this).find('span').first().clone(); | ||
69 | + var el = $(this); | ||
70 | + var id = $(this).attr('href').substr(1); | ||
71 | + var path = form[id].handler; | ||
72 | + var view = form[id].view; | ||
73 | + var model = form[id].model; | ||
74 | + $.get(path, { language_id: lang, widget_id: id, ajaxView: view, model: model }, function(data) { | ||
75 | + $('#'+id+'-tabs li').removeClass('active'); | ||
76 | + $('#'+id+'-tabs').append('<li role="lang_inputs" class="active" data-lang="'+lang+'"><a href="#'+id+'-'+lang+'" aria-controls="'+id+'-'+lang+'" role="tab" data-toggle="tab">'+$('<p>').append($(flag)).html()+'</a></li>'); | ||
77 | + $('#tab-content-'+id+' .tab-pane.active').removeClass('active'); | ||
78 | + $('#tab-content-'+id).append($(data).find('.ajax-loaded').first()); | ||
79 | + $('body').append($(data).filter('script')); | ||
80 | + $(el).parent().remove(); | ||
81 | + if(!$('#lang-'+id+' li').length) { | ||
82 | + $('#'+id+'Lang').addClass('disabled'); | ||
83 | + } | ||
84 | + if($('#'+id+'-tabs li').length > 1) { | ||
85 | + $('#'+id+'-tabs li').append('<span class="glyphicon glyphicon-remove-circle remove-lang"></span>') | ||
86 | + } | ||
87 | + }); | ||
88 | + }); | ||
89 | + $(document).on('click', '.dropdown-menu.f32.old li a[data-lang]', function(e) { | ||
90 | + e.preventDefault(); | ||
91 | + var lang = $(this).data('lang'); | ||
92 | + var flag = $(this).find('span').first().clone(); | ||
93 | + var el = $(this); | ||
94 | + var id = $(this).attr('href').substr(1); | ||
95 | + $.get(form[id], { language_id: lang, widget_id: id }, function(data) { | ||
96 | + $('#'+id+'-tabs li').removeClass('active'); | ||
97 | + $('#'+id+'-tabs').append('<li role="lang_inputs" class="active" data-lang="'+lang+'"><a href="#'+id+'-'+lang+'" aria-controls="'+id+'-'+lang+'" role="tab" data-toggle="tab">'+$('<p>').append($(flag)).html()+'</a></li>'); | ||
98 | + $('#tab-content-'+id+' .tab-pane.active').removeClass('active'); | ||
99 | + $('#tab-content-'+id).append($(data).find('.ajax-loaded').first()); | ||
100 | + $('body').append($(data).filter('script')); | ||
101 | + $(el).parent().remove(); | ||
102 | + if(!$('#lang-'+id+' li').length) { | ||
103 | + $('#'+id+'Lang').addClass('disabled'); | ||
104 | + } | ||
105 | + if($('#'+id+'-tabs li').length > 1) { | ||
106 | + $('#'+id+'-tabs li').append('<span class="glyphicon glyphicon-remove-circle remove-lang"></span>') | ||
107 | + } | ||
108 | + }); | ||
109 | + }); | ||
110 | $(document).on('click', '.remove-lang', function() { | 110 | $(document).on('click', '.remove-lang', function() { |
111 | var lang = $(this).parent().data('lang'); | 111 | var lang = $(this).parent().data('lang'); |
112 | var flag = $(this).parent().find('span.flag').first().clone(); | 112 | var flag = $(this).parent().find('span.flag').first().clone(); |
common/models/Fields.php
@@ -13,6 +13,9 @@ use Yii; | @@ -13,6 +13,9 @@ use Yii; | ||
13 | * @property string $value | 13 | * @property string $value |
14 | * @property string $field_name | 14 | * @property string $field_name |
15 | * @property string $field_type | 15 | * @property string $field_type |
16 | + * @property string $language | ||
17 | + * @property string $parent_key | ||
18 | + * @property string $key | ||
16 | */ | 19 | */ |
17 | class Fields extends \yii\db\ActiveRecord | 20 | class Fields extends \yii\db\ActiveRecord |
18 | { | 21 | { |
@@ -31,8 +34,8 @@ class Fields extends \yii\db\ActiveRecord | @@ -31,8 +34,8 @@ class Fields extends \yii\db\ActiveRecord | ||
31 | { | 34 | { |
32 | return [ | 35 | return [ |
33 | [['table_name', 'table_id',], 'required'], | 36 | [['table_name', 'table_id',], 'required'], |
34 | - [['table_id','language'], 'integer'], | ||
35 | - [['table_name', 'value', 'field_name','field_type'], 'string', 'max' => 255] | 37 | + [['table_id','parent_key','key'], 'integer'], |
38 | + [['table_name', 'value', 'field_name','field_type','language'], 'string', 'max' => 255] | ||
36 | ]; | 39 | ]; |
37 | } | 40 | } |
38 | 41 | ||
@@ -54,4 +57,44 @@ class Fields extends \yii\db\ActiveRecord | @@ -54,4 +57,44 @@ class Fields extends \yii\db\ActiveRecord | ||
54 | public static function getData($id, $model, $type){ | 57 | public static function getData($id, $model, $type){ |
55 | return self::find()->where(['table_id'=>$id, 'table_name'=>$model, 'field_type'=>$type])->all(); | 58 | return self::find()->where(['table_id'=>$id, 'table_name'=>$model, 'field_type'=>$type])->all(); |
56 | } | 59 | } |
60 | + | ||
61 | + | ||
62 | + /** | ||
63 | + * @param $post - array with field data | ||
64 | + * @param $table_id - row id in model table | ||
65 | + * @param $table_name - madel table name | ||
66 | + * @param $language - language id | ||
67 | + */ | ||
68 | + | ||
69 | + public static function saveFieldData($post,$table_id,$table_name, $language){ | ||
70 | + | ||
71 | + self::deleteAll(['table_id'=>$table_id, 'table_name'=>$table_name, 'language' => $language]); | ||
72 | + | ||
73 | + if($post){ | ||
74 | + | ||
75 | + | ||
76 | + foreach($post as $k => $field){ | ||
77 | + | ||
78 | + | ||
79 | + | ||
80 | + foreach($field as $parent_key => $row){ | ||
81 | + | ||
82 | + foreach($row as $key => $value){ | ||
83 | + | ||
84 | + $field_model = new Fields(); | ||
85 | + $field_model->field_name = array_keys($value)[0]; | ||
86 | + $field_model->value = $value[array_keys($value)[0]]; | ||
87 | + $field_model->table_name = $table_name; | ||
88 | + $field_model->table_id = $table_id; | ||
89 | + $field_model->field_type = $k; | ||
90 | + $field_model->language = 'ru'; | ||
91 | + $field_model->parent_key = $parent_key; | ||
92 | + $field_model->key = $key; | ||
93 | + $field_model->save(); | ||
94 | + } | ||
95 | + | ||
96 | + } | ||
97 | + } | ||
98 | + } | ||
99 | + } | ||
57 | } | 100 | } |
common/models/User.php
@@ -254,9 +254,13 @@ class User extends ActiveRecord implements IdentityInterface, UserRbacInterface | @@ -254,9 +254,13 @@ class User extends ActiveRecord implements IdentityInterface, UserRbacInterface | ||
254 | } | 254 | } |
255 | } | 255 | } |
256 | 256 | ||
257 | - public function afterSave ($insert, $changedAttributes) | ||
258 | - { | ||
259 | - parent::afterSave ($insert, $changedAttributes); | ||
260 | - \Yii::$app->options->createOptions($this->id); | 257 | +// public function afterSave ($insert, $changedAttributes) |
258 | +// { | ||
259 | +// parent::afterSave ($insert, $changedAttributes); | ||
260 | +// \Yii::$app->options->createOptions($this->id); | ||
261 | +// } | ||
262 | + | ||
263 | + public function getUserInfo(){ | ||
264 | + return $this->hasOne(UserInfo::className(), ['user_id' => 'id']); | ||
261 | } | 265 | } |
262 | } | 266 | } |
common/widgets/FieldEditor.php
1 | <?php | 1 | <?php |
2 | namespace common\widgets; | 2 | namespace common\widgets; |
3 | use common\models\Fields; | 3 | use common\models\Fields; |
4 | +use common\models\Language; | ||
4 | use yii\base\Widget; | 5 | use yii\base\Widget; |
5 | - | 6 | +use yii\helpers\ArrayHelper; |
6 | 7 | ||
7 | class FieldEditor extends Widget | 8 | class FieldEditor extends Widget |
8 | { | 9 | { |
9 | public $item_id; | 10 | public $item_id; |
10 | public $model; | 11 | public $model; |
11 | public $template; | 12 | public $template; |
13 | + public $language; | ||
12 | 14 | ||
13 | public function init(){ | 15 | public function init(){ |
14 | 16 | ||
@@ -25,14 +27,18 @@ class FieldEditor extends Widget | @@ -25,14 +27,18 @@ class FieldEditor extends Widget | ||
25 | $widgetData= [new Fields()]; | 27 | $widgetData= [new Fields()]; |
26 | } | 28 | } |
27 | 29 | ||
28 | - | ||
29 | - return $this->render($this->template.'_field',['model'=>$widgetData]); | 30 | + return $this->render($this->template.'_field',['model'=>ArrayHelper::toArray($widgetData)]); |
30 | } | 31 | } |
31 | 32 | ||
32 | protected function findModel() | 33 | protected function findModel() |
33 | { | 34 | { |
34 | - if (($model = Fields::find()->where(['table_id'=>$this->item_id, 'table_name'=>$this->model, 'field_type'=>$this->template])->all()) !== null) { | ||
35 | 35 | ||
36 | + if (($model = Fields::find()->where([ | ||
37 | + 'table_id'=>$this->item_id, | ||
38 | + 'table_name'=>$this->model, | ||
39 | + 'field_type'=>$this->template, | ||
40 | + 'language'=>$this->language, | ||
41 | + ])->all())) { | ||
36 | return $model; | 42 | return $model; |
37 | 43 | ||
38 | } else { | 44 | } else { |
1 | +<?php | ||
2 | +use yii\helpers\Html; | ||
3 | +?> | ||
4 | +<fieldset> | ||
5 | + | ||
6 | + <legend>Образование</legend> | ||
7 | + | ||
8 | + <p class="btn btn-success add_field">Добавить поле</p> | ||
9 | + | ||
10 | + | ||
11 | + <?php for($i=1; $i <= count($model); $i++): | ||
12 | + $row = $i; | ||
13 | + ?> | ||
14 | + | ||
15 | + <?= Html::beginTag('div',['class'=>'form-group','id'=>isset($model[$i]['parent_key']) ? $model[$i]['parent_key'] : 0 ])?> | ||
16 | + <input type="text" placeholder="С" class="form-control" value="<?= isset($model[$i]['value']) ? $model[$i]['value'] : '' ?>" name="Fields[education][<?=$row?>][0][year_from]" /> | ||
17 | + <input type="text" placeholder="По" class="form-control" value="<?= isset($model[++$i]['value']) ? $model[$i]['value'] : '' ?>" name="Fields[education][<?=$row?>][1][year_to]" /> | ||
18 | + <textarea placeholder="Место" name="Fields[education][<?=$row?>][2][place]" /><?= isset($model[++$i]['value']) ? $model[$i]['value'] : '' ?></textarea> | ||
19 | + <span data-id="<?= isset($model[$i]['parent_key']) ? $model[$i]['parent_key'] : 0 ?>" title="удалить" class="glyphicon glyphicon-trash delete-field-item"></span> | ||
20 | + <?= Html::endTag('div')?> | ||
21 | + <?php endfor; ?> | ||
22 | + | ||
23 | + | ||
24 | + | ||
25 | +</fieldset> | ||
26 | +<script> | ||
27 | + $( document ).ready(function(){ | ||
28 | + var start_i = <?=$i?>; | ||
29 | + $('.add_field').click(function(){ | ||
30 | + var block = $(this).parent('fieldset'); | ||
31 | + var block_id = $(this).parent('fieldset'); | ||
32 | + var sub_block = '<div class="form-group" >'+ | ||
33 | + '<input type="text" placeholder="С" class="form-control" value="" name="Fields[education]['+ start_i++ +'][0][year_from]" />'+ | ||
34 | + '<input type="text" placeholder="По" class="form-control" value="" name="Fields[education]['+ start_i +'][1][year_to]" />'+ | ||
35 | + '<textarea placeholder="Место" name="Fields[education]['+ start_i +'][2][place]" /></textarea>'+ | ||
36 | + '<span title="удалить" class="glyphicon glyphicon-trash delete-field-item"></span>'+ | ||
37 | + '<div>'; | ||
38 | + block.append(sub_block); | ||
39 | + | ||
40 | + }); | ||
41 | + }); | ||
42 | +</script> | ||
43 | + | ||
44 | + |
console/migrations/m160128_101543_fields.php
@@ -15,7 +15,9 @@ class m160128_101543_fields extends Migration | @@ -15,7 +15,9 @@ class m160128_101543_fields extends Migration | ||
15 | 'value' => $this->string(255), | 15 | 'value' => $this->string(255), |
16 | 'field_name' => $this->string(), | 16 | 'field_name' => $this->string(), |
17 | 'field_type' => $this->string(32)->notNull(), | 17 | 'field_type' => $this->string(32)->notNull(), |
18 | - 'language' => $this->integer() | 18 | + 'language' => $this->string(3), |
19 | + 'key' => $this->integer(), | ||
20 | + 'parent_key' => $this->integer() | ||
19 | ], $tableOptions); | 21 | ], $tableOptions); |
20 | 22 | ||
21 | } | 23 | } |
frontend/assets/AdminAsset.php
@@ -30,7 +30,7 @@ class AdminAsset extends AssetBundle | @@ -30,7 +30,7 @@ class AdminAsset extends AssetBundle | ||
30 | 'js/jquery.scrollbox.min.js', | 30 | 'js/jquery.scrollbox.min.js', |
31 | 'js/slider.js', | 31 | 'js/slider.js', |
32 | 'js/jquery.rating.js', | 32 | 'js/jquery.rating.js', |
33 | - '/admin/js/option.js' | 33 | + '/admin/js/fieldWidget.js' |
34 | ]; | 34 | ]; |
35 | public $depends = [ | 35 | public $depends = [ |
36 | 'yii\web\YiiAsset', | 36 | 'yii\web\YiiAsset', |
frontend/controllers/AccountsController.php
1 | <?php | 1 | <?php |
2 | namespace frontend\controllers; | 2 | namespace frontend\controllers; |
3 | 3 | ||
4 | +use common\models\Fields; | ||
4 | use common\models\Language; | 5 | use common\models\Language; |
5 | use Yii; | 6 | use Yii; |
6 | use common\models\User; | 7 | use common\models\User; |
@@ -27,7 +28,7 @@ class AccountsController extends Controller | @@ -27,7 +28,7 @@ class AccountsController extends Controller | ||
27 | 'class' => AccessControl::className(), | 28 | 'class' => AccessControl::className(), |
28 | 'rules' => [ | 29 | 'rules' => [ |
29 | [ | 30 | [ |
30 | - 'actions' => ['cabinet','change-password', 'bookmarks', 'projects'], | 31 | + 'actions' => ['cabinet','change-password', 'bookmarks'], |
31 | 'allow' => true, | 32 | 'allow' => true, |
32 | 'roles' => ['@'], | 33 | 'roles' => ['@'], |
33 | ], | 34 | ], |
@@ -43,18 +44,28 @@ class AccountsController extends Controller | @@ -43,18 +44,28 @@ class AccountsController extends Controller | ||
43 | 44 | ||
44 | $user = $this->findUser(Yii::$app->user->identity->id); | 45 | $user = $this->findUser(Yii::$app->user->identity->id); |
45 | 46 | ||
46 | - $user_info = $this->findUserInfo(Yii::$app->user->identity->id); | ||
47 | - | ||
48 | $langs = Language::getActiveLanguages(); | 47 | $langs = Language::getActiveLanguages(); |
49 | 48 | ||
50 | 49 | ||
50 | + if ($user->load(Yii::$app->request->post()) && $user->save()) { | ||
51 | + $user->userInfo->load(Yii::$app->request->post()); | ||
52 | + $user->userInfo->save(); | ||
53 | + Fields::saveFieldData( Yii::$app->request->post('Fields'), $user->id, $user::className()); | ||
54 | + return $this->render('cabinet', [ | ||
55 | + 'user' => $user, | ||
56 | + 'user_info' => $user->userInfo, | ||
57 | + 'langs' => $langs, | ||
58 | + ]); | ||
51 | 59 | ||
52 | - return $this->render('cabinet', [ | ||
53 | - 'user' => $user, | ||
54 | - 'user_info' => $user_info, | ||
55 | - 'langs' => $langs, | ||
56 | - ]); | 60 | + } else { |
57 | 61 | ||
62 | + return $this->render('cabinet', [ | ||
63 | + 'user' => $user, | ||
64 | + 'user_info' => $user->userInfo, | ||
65 | + 'langs' => $langs, | ||
66 | + ]); | ||
67 | + | ||
68 | + } | ||
58 | 69 | ||
59 | 70 | ||
60 | } | 71 | } |
@@ -65,12 +76,15 @@ class AccountsController extends Controller | @@ -65,12 +76,15 @@ class AccountsController extends Controller | ||
65 | } | 76 | } |
66 | 77 | ||
67 | 78 | ||
68 | - | ||
69 | - | 79 | + /** |
80 | + * @param $id | ||
81 | + * @return User | ||
82 | + * @throws NotFoundHttpException | ||
83 | + */ | ||
70 | protected function findUser($id) | 84 | protected function findUser($id) |
71 | { | 85 | { |
72 | 86 | ||
73 | - if (($model = User::findOne(["id"=>$id])) !== null) { | 87 | + if ($model = User::findOne(["id"=>$id])) { |
74 | return $model; | 88 | return $model; |
75 | } else { | 89 | } else { |
76 | throw new NotFoundHttpException('The requested page does not exist.'); | 90 | throw new NotFoundHttpException('The requested page does not exist.'); |
@@ -79,19 +93,4 @@ class AccountsController extends Controller | @@ -79,19 +93,4 @@ class AccountsController extends Controller | ||
79 | 93 | ||
80 | 94 | ||
81 | 95 | ||
82 | - protected function findUserInfo($id) | ||
83 | - { | ||
84 | - | ||
85 | - if (($model = UserInfo::findOne(["user_id"=>$id])) !== null) { | ||
86 | - return $model; | ||
87 | - } else { | ||
88 | - throw new NotFoundHttpException('The requested page does not exist.'); | ||
89 | - } | ||
90 | - } | ||
91 | - | ||
92 | - public function actionProjects() | ||
93 | - { | ||
94 | - return $this->render('projects'); | ||
95 | - } | ||
96 | - | ||
97 | } | 96 | } |
frontend/controllers/SiteController.php
@@ -94,70 +94,70 @@ class SiteController extends Controller | @@ -94,70 +94,70 @@ class SiteController extends Controller | ||
94 | } | 94 | } |
95 | 95 | ||
96 | // creat new model table Social and new model User | 96 | // creat new model table Social and new model User |
97 | - $social = new Social(); | ||
98 | - $user = new User(); | ||
99 | - | ||
100 | - $serviceName = Yii::$app->getRequest()->getQueryParam('service'); | ||
101 | - | ||
102 | - if (isset($serviceName)) { | ||
103 | - /** @var $eauth \nodge\eauth\ServiceBase */ | ||
104 | - $eauth = Yii::$app->get('eauth')->getIdentity($serviceName); | ||
105 | - $eauth->setRedirectUrl(Yii::$app->getUser()->getReturnUrl()); | ||
106 | - $eauth->setCancelUrl(Yii::$app->getUrlManager()->createAbsoluteUrl('site/login')); | ||
107 | - | ||
108 | - try { | ||
109 | - if ($eauth->authenticate()) { | ||
110 | - $identity = User::findByEAuth($eauth); | ||
111 | - Yii::$app->getUser()->login($identity); | ||
112 | - | ||
113 | - //Save date get social network in database | ||
114 | - if (! $social::find()->where(['social_user_id' => $identity[profile][id], 'social_name' => $identity[profile][service]])->exists()) { | ||
115 | - $name = explode(' ',$identity[profile][name]); | ||
116 | - $user->firstname = $name[0]; | ||
117 | - $user->lastname = $name[1]; | ||
118 | - $user->id_system_date = date("d.m.y.H:i:s"); | ||
119 | - $user->save(); | ||
120 | - $social->social_name = $identity[profile][service]; | ||
121 | - $social->social_user_id = $identity[profile][id]; | ||
122 | - $social->user_id = $user->id; | ||
123 | - $social->validate(); | ||
124 | - $social->errors; | ||
125 | - $social->save(); | ||
126 | - } | ||
127 | - | ||
128 | - // special redirect with closing popup window | ||
129 | - $eauth->redirect(); | ||
130 | - } | ||
131 | - else { | ||
132 | - // close popup window and redirect to cancelUrl | ||
133 | - $eauth->cancel(); | ||
134 | - } | ||
135 | - } | ||
136 | - catch (\nodge\eauth\ErrorException $e) { | ||
137 | - // save error to show it later | ||
138 | - Yii::$app->getSession()->setFlash('error', 'EAuthException: '.$e->getMessage()); | ||
139 | - | ||
140 | - // close popup window and redirect to cancelUrl | ||
141 | - // $eauth->cancel(); | ||
142 | - $eauth->redirect($eauth->getCancelUrl()); | ||
143 | - } | ||
144 | - } | ||
145 | - | ||
146 | - | ||
147 | - | ||
148 | - | ||
149 | - if (!\Yii::$app->user->isGuest) { | ||
150 | - return $this->goHome(); | ||
151 | - } | ||
152 | - | ||
153 | - $model = new LoginForm(); | ||
154 | - if ($model->load(Yii::$app->request->post()) && $model->login()) { | ||
155 | - return $this->goBack(); | ||
156 | - } else { | ||
157 | - return $this->render('login', [ | ||
158 | - 'model' => $model, | ||
159 | - ]); | ||
160 | - } | 97 | +// $social = new Social(); |
98 | +// $user = new User(); | ||
99 | +// | ||
100 | +// $serviceName = Yii::$app->getRequest()->getQueryParam('service'); | ||
101 | +// | ||
102 | +// if (isset($serviceName)) { | ||
103 | +// /** @var $eauth \nodge\eauth\ServiceBase */ | ||
104 | +// $eauth = Yii::$app->get('eauth')->getIdentity($serviceName); | ||
105 | +// $eauth->setRedirectUrl(Yii::$app->getUser()->getReturnUrl()); | ||
106 | +// $eauth->setCancelUrl(Yii::$app->getUrlManager()->createAbsoluteUrl('site/login')); | ||
107 | +// | ||
108 | +// try { | ||
109 | +// if ($eauth->authenticate()) { | ||
110 | +// $identity = User::findByEAuth($eauth); | ||
111 | +// Yii::$app->getUser()->login($identity); | ||
112 | +// | ||
113 | +// //Save date get social network in database | ||
114 | +// if (! $social::find()->where(['social_user_id' => $identity[profile][id], 'social_name' => $identity[profile][service]])->exists()) { | ||
115 | +// $name = explode(' ',$identity[profile][name]); | ||
116 | +// $user->firstname = $name[0]; | ||
117 | +// $user->lastname = $name[1]; | ||
118 | +// $user->id_system_date = date("d.m.y.H:i:s"); | ||
119 | +// $user->save(); | ||
120 | +// $social->social_name = $identity[profile][service]; | ||
121 | +// $social->social_user_id = $identity[profile][id]; | ||
122 | +// $social->user_id = $user->id; | ||
123 | +// $social->validate(); | ||
124 | +// $social->errors; | ||
125 | +// $social->save(); | ||
126 | +// } | ||
127 | +// | ||
128 | +// // special redirect with closing popup window | ||
129 | +// $eauth->redirect(); | ||
130 | +// } | ||
131 | +// else { | ||
132 | +// // close popup window and redirect to cancelUrl | ||
133 | +// $eauth->cancel(); | ||
134 | +// } | ||
135 | +// } | ||
136 | +// catch (\nodge\eauth\ErrorException $e) { | ||
137 | +// // save error to show it later | ||
138 | +// Yii::$app->getSession()->setFlash('error', 'EAuthException: '.$e->getMessage()); | ||
139 | +// | ||
140 | +// // close popup window and redirect to cancelUrl | ||
141 | +// // $eauth->cancel(); | ||
142 | +// $eauth->redirect($eauth->getCancelUrl()); | ||
143 | +// } | ||
144 | +// } | ||
145 | +// | ||
146 | +// | ||
147 | +// | ||
148 | +// | ||
149 | +// if (!\Yii::$app->user->isGuest) { | ||
150 | +// return $this->goHome(); | ||
151 | +// } | ||
152 | +// | ||
153 | +// $model = new LoginForm(); | ||
154 | +// if ($model->load(Yii::$app->request->post()) && $model->login()) { | ||
155 | +// return $this->goBack(); | ||
156 | +// } else { | ||
157 | +// return $this->render('login', [ | ||
158 | +// 'model' => $model, | ||
159 | +// ]); | ||
160 | +// } | ||
161 | } | 161 | } |
162 | 162 | ||
163 | /** | 163 | /** |
frontend/views/accounts/_form.php
@@ -17,16 +17,10 @@ use yii\widgets\ActiveForm; | @@ -17,16 +17,10 @@ use yii\widgets\ActiveForm; | ||
17 | 17 | ||
18 | <?= $form->field($user_info, 'user_id')->textInput() ?> | 18 | <?= $form->field($user_info, 'user_id')->textInput() ?> |
19 | 19 | ||
20 | -<?= $form->field($user_info, 'view_count')->textInput() ?> | ||
21 | - | ||
22 | <?= $form->field($user_info, 'busy')->textInput(['maxlength' => true]) ?> | 20 | <?= $form->field($user_info, 'busy')->textInput(['maxlength' => true]) ?> |
23 | 21 | ||
24 | -<?= $form->field($user_info, 'date_visit')->textInput() ?> | ||
25 | - | ||
26 | <?= $form->field($user_info, 'experience')->textInput() ?> | 22 | <?= $form->field($user_info, 'experience')->textInput() ?> |
27 | 23 | ||
28 | -<?= $form->field($user_info, 'rank')->textInput(['maxlength' => true]) ?> | ||
29 | - | ||
30 | <?= $form->field($user_info, 'salary')->textInput(['maxlength' => true]) ?> | 24 | <?= $form->field($user_info, 'salary')->textInput(['maxlength' => true]) ?> |
31 | 25 | ||
32 | <?= $form->field($user_info, 'job')->textInput(['maxlength' => true]) ?> | 26 | <?= $form->field($user_info, 'job')->textInput(['maxlength' => true]) ?> |
@@ -49,7 +43,12 @@ use yii\widgets\ActiveForm; | @@ -49,7 +43,12 @@ use yii\widgets\ActiveForm; | ||
49 | 43 | ||
50 | <?= $form->field($user_info, 'about')->textarea(['rows' => 6]) ?> | 44 | <?= $form->field($user_info, 'about')->textarea(['rows' => 6]) ?> |
51 | 45 | ||
52 | -<?= \common\widgets\FieldEditor::widget(['template'=>'', 'item_id'=> $user->id, 'model'=>'User']); ?> | 46 | +<?= \common\widgets\FieldEditor::widget([ |
47 | + 'template'=>'education', | ||
48 | + 'item_id'=> $user->id, | ||
49 | + 'model'=>'common\models\User', | ||
50 | + 'language'=>'0' | ||
51 | +]); ?> | ||
53 | 52 | ||
54 | 53 | ||
55 | <div class="form-group"> | 54 | <div class="form-group"> |