Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
T
taskonsite-архив-перенесен
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Packages
Packages
Container Registry
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Dmitry Korolev
taskonsite-архив-перенесен
Commits
e0ca19ee
Commit
e0ca19ee
authored
Jun 28, 2016
by
Александр Кузнецов
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'blog-hashtag-filtr' into 'master'
#1255 п1 See merge request !55
parents
1ed7b60f
2d22dbcb
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
27 additions
and
4 deletions
+27
-4
common/modules/blog/controllers/PostController.php
common/modules/blog/controllers/PostController.php
+27
-4
No files found.
common/modules/blog/controllers/PostController.php
View file @
e0ca19ee
...
@@ -118,6 +118,9 @@ class PostController extends BaseController
...
@@ -118,6 +118,9 @@ class PostController extends BaseController
*/
*/
public
function
actionTag
(
$tag
)
public
function
actionTag
(
$tag
)
{
{
$tagId
=
$this
->
getTagIdByName
(
$tag
);
$this
->
actionSetCookie
(
$tagId
,
true
);
$model
=
PostTag
::
find
()
->
where
([
'name'
=>
$tag
])
->
one
();
$model
=
PostTag
::
find
()
->
where
([
'name'
=>
$tag
])
->
one
();
if
(
!
$model
||
!
$model
->
posts
)
if
(
!
$model
||
!
$model
->
posts
)
...
@@ -258,18 +261,25 @@ class PostController extends BaseController
...
@@ -258,18 +261,25 @@ class PostController extends BaseController
* Запишет или удалит хэштэг в куки
* Запишет или удалит хэштэг в куки
* используется на странице блога в списке категорий, для отбора статей по хэштегам
* используется на странице блога в списке категорий, для отбора статей по хэштегам
*/
*/
public
function
actionSetCookie
(
$hashtag
)
public
function
actionSetCookie
(
$hashtag
,
$clean
=
false
)
{
{
$session
=
Yii
::
$app
->
session
;
$session
=
Yii
::
$app
->
session
;
if
(
$session
->
isActive
)
{
if
(
$session
->
isActive
)
{
if
(
$clean
)
{
$session
->
set
(
'blog_hashtag'
,
null
);
}
$cookie
=
$session
->
get
(
'blog_hashtag'
);
$cookie
=
$session
->
get
(
'blog_hashtag'
);
$cookie
=
$cookie
?
$cookie
:
[];
$cookie
=
$cookie
?
$cookie
:
[];
$session
->
set
(
'blog_hashtag_lifetime'
,
time
()
+
3600
*
24
);
$session
->
set
(
'blog_hashtag_lifetime'
,
time
()
+
3600
*
24
);
$key
=
array_search
(
$hashtag
,
$cookie
);
$key
=
array_search
(
$hashtag
,
$cookie
);
if
(
$key
!==
false
)
{
if
(
$key
!==
false
)
{
unset
(
$cookie
[
$key
]);
unset
(
$cookie
[
$key
]);
$cookie_
=
[];
$cookie_
=
[];
foreach
(
$cookie
as
$c
)
foreach
(
$cookie
as
$c
)
...
@@ -279,7 +289,8 @@ class PostController extends BaseController
...
@@ -279,7 +289,8 @@ class PostController extends BaseController
$session
->
set
(
'blog_hashtag'
,
$cookie_
);
$session
->
set
(
'blog_hashtag'
,
$cookie_
);
return
false
;
return
false
;
}
}
else
{
else
{
$cookie
[]
=
$hashtag
;
$cookie
[]
=
$hashtag
;
$session
->
set
(
'blog_hashtag'
,
$cookie
);
$session
->
set
(
'blog_hashtag'
,
$cookie
);
return
true
;
return
true
;
...
@@ -335,4 +346,16 @@ class PostController extends BaseController
...
@@ -335,4 +346,16 @@ class PostController extends BaseController
'count'
=>
(
int
)
$count
,
'count'
=>
(
int
)
$count
,
];
];
}
}
public
function
getTagIdByName
(
$tagname
)
{
$tag
=
PostTag
::
find
()
->
select
(
'id'
)
->
where
([
'name'
=>
$tagname
])
->
one
();
if
(
!
$tag
)
{
$tag
=
PostTag
::
find
()
->
select
(
'id'
)
->
where
([
'translit'
=>
$tagname
])
->
one
();
}
return
isset
(
$tag
->
id
)
?
$tag
->
id
:
false
;
}
}
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment