Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
yii2
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
PSDI Army
yii2
Commits
49652481
Commit
49652481
authored
Jul 19, 2013
by
Qiang Xue
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Refactored Sort.
parent
058c1f1b
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
25 additions
and
21 deletions
+25
-21
Sort.php
framework/yii/data/Sort.php
+25
-21
No files found.
framework/yii/data/Sort.php
View file @
49652481
...
@@ -8,8 +8,10 @@
...
@@ -8,8 +8,10 @@
namespace
yii\data
;
namespace
yii\data
;
use
Yii
;
use
Yii
;
use
yii\base\InvalidConfigException
;
use
yii\base\Object
;
use
yii\base\Object
;
use
yii\helpers\Html
;
use
yii\helpers\Html
;
use
yii\helpers\Inflector
;
/**
/**
* Sort represents information relevant to sorting.
* Sort represents information relevant to sorting.
...
@@ -97,7 +99,8 @@ class Sort extends Object
...
@@ -97,7 +99,8 @@ class Sort extends Object
* 'user' => array(
* 'user' => array(
* 'asc' => array('first_name' => Sort::ASC, 'last_name' => Sort::ASC),
* 'asc' => array('first_name' => Sort::ASC, 'last_name' => Sort::ASC),
* 'desc' => array('first_name' => Sort::DESC, 'last_name' => Sort::DESC),
* 'desc' => array('first_name' => Sort::DESC, 'last_name' => Sort::DESC),
* 'default' => 'desc',
* 'default' => Sort::DESC,
* 'label' => 'Name',
* ),
* ),
* )
* )
* ~~~
* ~~~
...
@@ -109,6 +112,8 @@ class Sort extends Object
...
@@ -109,6 +112,8 @@ class Sort extends Object
* 'age' => array(
* 'age' => array(
* 'asc' => array('age' => Sort::ASC),
* 'asc' => array('age' => Sort::ASC),
* 'desc' => array('age' => Sort::DESC),
* 'desc' => array('age' => Sort::DESC),
* 'default' => Sort::ASC,
* 'label' => Inflector::camel2words('age'),
* )
* )
* ~~~
* ~~~
*
*
...
@@ -119,8 +124,10 @@ class Sort extends Object
...
@@ -119,8 +124,10 @@ class Sort extends Object
* - The "asc" and "desc" elements specify how to sort by the attribute in ascending
* - The "asc" and "desc" elements specify how to sort by the attribute in ascending
* and descending orders, respectively. Their values represent the actual columns and
* and descending orders, respectively. Their values represent the actual columns and
* the directions by which the data should be sorted by.
* the directions by which the data should be sorted by.
* - And the "default" element specifies if the attribute is not sorted currently,
* - The "default" element specifies by which direction the attribute should be sorted
* in which direction it should be sorted (the default value is ascending order).
* if it is not currently sorted (the default value is ascending order).
* - The "label" element specifies what label should be used when calling [[link()]] to create
* a sort link. If not set, [[Inflector::camel2words()]] will be called to get a label.
*/
*/
public
$attributes
=
array
();
public
$attributes
=
array
();
/**
/**
...
@@ -196,28 +203,25 @@ class Sort extends Object
...
@@ -196,28 +203,25 @@ class Sort extends Object
* Based on the sort direction, the CSS class of the generated hyperlink will be appended
* Based on the sort direction, the CSS class of the generated hyperlink will be appended
* with "asc" or "desc".
* with "asc" or "desc".
* @param string $attribute the attribute name by which the data should be sorted by.
* @param string $attribute the attribute name by which the data should be sorted by.
* @param string $label the link label. Note that the label will not be HTML-encoded.
* @param array $options additional HTML attributes for the hyperlink tag
* @param array $htmlOptions additional HTML attributes for the hyperlink tag
* @return string the generated hyperlink
* @return string the generated hyperlink
* @throws InvalidConfigException if the attribute is unknown
*/
*/
public
function
link
(
$attribute
,
$
label
,
$htmlO
ptions
=
array
())
public
function
link
(
$attribute
,
$
o
ptions
=
array
())
{
{
if
((
$definition
=
$this
->
getAttribute
(
$attribute
))
===
false
)
{
return
$label
;
}
if
((
$direction
=
$this
->
getAttributeOrder
(
$attribute
))
!==
null
)
{
if
((
$direction
=
$this
->
getAttributeOrder
(
$attribute
))
!==
null
)
{
$class
=
$direction
?
'desc'
:
'asc'
;
$class
=
$direction
?
'desc'
:
'asc'
;
if
(
isset
(
$
htmlO
ptions
[
'class'
]))
{
if
(
isset
(
$
o
ptions
[
'class'
]))
{
$
htmlO
ptions
[
'class'
]
.=
' '
.
$class
;
$
o
ptions
[
'class'
]
.=
' '
.
$class
;
}
else
{
}
else
{
$
htmlO
ptions
[
'class'
]
=
$class
;
$
o
ptions
[
'class'
]
=
$class
;
}
}
}
}
$url
=
$this
->
createUrl
(
$attribute
);
$url
=
$this
->
createUrl
(
$attribute
);
$definition
=
$this
->
getAttribute
(
$attribute
);
return
Html
::
a
(
$label
,
$url
,
$htmlOptions
);
$label
=
isset
(
$definition
[
'label'
])
?
$definition
[
'label'
]
:
Html
::
encode
(
Inflector
::
camel2words
(
$attribute
));
return
Html
::
a
(
$label
,
$url
,
$options
);
}
}
private
$_attributeOrders
;
private
$_attributeOrders
;
...
@@ -278,23 +282,22 @@ class Sort extends Object
...
@@ -278,23 +282,22 @@ class Sort extends Object
* For example, if the current page already sorts the data by the specified attribute in ascending order,
* For example, if the current page already sorts the data by the specified attribute in ascending order,
* then the URL created will lead to a page that sorts the data by the specified attribute in descending order.
* then the URL created will lead to a page that sorts the data by the specified attribute in descending order.
* @param string $attribute the attribute name
* @param string $attribute the attribute name
* @return string|boolean the URL for sorting. False if the attribute is invalid.
* @return string the URL for sorting. False if the attribute is invalid.
* @throws InvalidConfigException if the attribute is unknown
* @see attributeOrders
* @see attributeOrders
* @see params
* @see params
*/
*/
public
function
createUrl
(
$attribute
)
public
function
createUrl
(
$attribute
)
{
{
if
((
$definition
=
$this
->
getAttribute
(
$attribute
))
===
false
)
{
if
((
$definition
=
$this
->
getAttribute
(
$attribute
))
===
false
)
{
return
false
;
throw
new
InvalidConfigException
(
"Unknown attribute:
$attribute
"
)
;
}
}
$directions
=
$this
->
getAttributeOrders
();
$directions
=
$this
->
getAttributeOrders
();
if
(
isset
(
$directions
[
$attribute
]))
{
if
(
isset
(
$directions
[
$attribute
]))
{
$descending
=
!
$directions
[
$attribute
];
$descending
=
!
$directions
[
$attribute
];
unset
(
$directions
[
$attribute
]);
unset
(
$directions
[
$attribute
]);
}
elseif
(
isset
(
$definition
[
'default'
]))
{
$descending
=
$definition
[
'default'
]
===
'desc'
;
}
else
{
}
else
{
$descending
=
false
;
$descending
=
!
empty
(
$definition
[
'default'
])
;
}
}
if
(
$this
->
enableMultiSort
)
{
if
(
$this
->
enableMultiSort
)
{
...
@@ -309,7 +312,7 @@ class Sort extends Object
...
@@ -309,7 +312,7 @@ class Sort extends Object
}
}
$params
=
$this
->
params
===
null
?
$_GET
:
$this
->
params
;
$params
=
$this
->
params
===
null
?
$_GET
:
$this
->
params
;
$params
[
$this
->
sortVar
]
=
implode
(
$this
->
separators
[
0
],
$sorts
);
$params
[
$this
->
sortVar
]
=
implode
(
$this
->
separators
[
0
],
$sorts
);
$route
=
$this
->
route
===
null
?
Yii
::
$app
->
controller
->
route
:
$this
->
route
;
$route
=
$this
->
route
===
null
?
Yii
::
$app
->
controller
->
getRoute
()
:
$this
->
route
;
return
Yii
::
$app
->
getUrlManager
()
->
createUrl
(
$route
,
$params
);
return
Yii
::
$app
->
getUrlManager
()
->
createUrl
(
$route
,
$params
);
}
}
...
@@ -329,6 +332,7 @@ class Sort extends Object
...
@@ -329,6 +332,7 @@ class Sort extends Object
return
array
(
return
array
(
'asc'
=>
array
(
$name
=>
self
::
ASC
),
'asc'
=>
array
(
$name
=>
self
::
ASC
),
'desc'
=>
array
(
$name
=>
self
::
DESC
),
'desc'
=>
array
(
$name
=>
self
::
DESC
),
'label'
=>
Inflector
::
camel2words
(
$name
),
);
);
}
else
{
}
else
{
return
false
;
return
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