defaultOrder contém uma matriz onde a chave é o nome da coluna e o valor é a SORT_DESC
ou SORT_ASC
é por isso que o código abaixo não funciona.
$dataProvider = new ActiveDataProvider([
'query' => $query,
'sort' => ['defaultOrder'=>'topic_order asc']
]);
Maneira correta
$dataProvider = new ActiveDataProvider([
'query' => $query,
'sort' => [
'defaultOrder' => [
'topic_order' => SORT_ASC,
]
],
]);
Nota: Se uma consulta já especifica a cláusula orderBy, as novas instruções de pedido fornecidas pelos usuários finais (por meio da configuração de classificação) serão anexadas à cláusula orderBy existente. Quaisquer cláusulas de limite e compensação existentes serão substituídas pela solicitação de paginação dos usuários finais (por meio da configuração de paginação).
Você pode aprender detalhadamente com o
Guia de Provedor de Dados Yii2
Classificando passando o objeto Sort na consulta
$sort = new Sort([
'attributes' => [
'age',
'name' => [
'asc' => ['first_name' => SORT_ASC, 'last_name' => SORT_ASC],
'desc' => ['first_name' => SORT_DESC, 'last_name' => SORT_DESC],
'default' => SORT_DESC,
'label' => 'Name',
],
],
]);
$models = Article::find()
->where(['status' => 1])
->orderBy($sort->orders)
->all();