2018-12-02 01:49:30 +01:00
/ *
* Copyright ( c ) 2018 the Vikunja Authors . All rights reserved .
* Use of this source code is governed by a LPGLv3 - style
* license that can be found in the LICENSE file .
* /
package models
2018-12-22 19:06:14 +01:00
import (
"code.vikunja.io/web"
2019-05-25 09:33:57 +02:00
"sort"
2018-12-22 19:06:14 +01:00
"time"
)
2018-12-02 01:49:30 +01:00
// SortBy declares constants to sort
type SortBy int
// These are possible sort options
const (
SortTasksByUnsorted SortBy = - 1
SortTasksByDueDateAsc = iota
SortTasksByDueDateDesc
SortTasksByPriorityAsc
SortTasksByPriorityDesc
)
// ReadAll gets all tasks for a user
// @Summary Get tasks
// @Description Returns all tasks on any list the user has access to.
// @tags task
// @Accept json
// @Produce json
// @Param p query int false "The page number. Used for pagination. If not provided, the first page of results is returned."
// @Param s query string false "Search tasks by task text."
2019-05-31 10:10:56 +02:00
// @Param sort query string false "The sorting parameter. Possible values to sort by are priority, prioritydesc, priorityasc, duedate, duedatedesc, duedateasc."
2019-04-21 20:18:17 +02:00
// @Param startdate query int false "The start date parameter to filter by. Expects a unix timestamp. If no end date, but a start date is specified, the end date is set to the current time."
// @Param enddate query int false "The end date parameter to filter by. Expects a unix timestamp. If no start date, but an end date is specified, the start date is set to the current time."
2019-01-03 23:22:06 +01:00
// @Security JWTKeyAuth
2019-04-23 21:53:37 +02:00
// @Success 200 {array} models.ListTask "The tasks"
2018-12-02 01:49:30 +01:00
// @Failure 500 {object} models.Message "Internal error"
2018-12-25 21:45:26 +01:00
// @Router /tasks/all [get]
2019-01-14 22:49:50 +01:00
func ( t * ListTask ) ReadAll ( search string , a web . Auth , page int ) ( interface { } , error ) {
2018-12-02 01:49:30 +01:00
var sortby SortBy
2019-01-14 22:49:50 +01:00
switch t . Sorting {
2018-12-02 01:49:30 +01:00
case "priority" :
sortby = SortTasksByPriorityDesc
case "prioritydesc" :
sortby = SortTasksByPriorityDesc
case "priorityasc" :
sortby = SortTasksByPriorityAsc
2019-05-31 10:10:56 +02:00
case "duedate" :
2018-12-02 01:49:30 +01:00
sortby = SortTasksByDueDateDesc
2019-05-31 10:10:56 +02:00
case "duedatedesc" :
2018-12-02 01:49:30 +01:00
sortby = SortTasksByDueDateDesc
case "duedateasc" :
sortby = SortTasksByDueDateAsc
default :
sortby = SortTasksByUnsorted
}
2019-06-28 10:21:48 +02:00
return GetTasksByUser ( search , & User { ID : a . GetID ( ) } , page , sortby , time . Unix ( t . StartDateSortUnix , 0 ) , time . Unix ( t . EndDateSortUnix , 0 ) )
2018-12-02 01:49:30 +01:00
}
//GetTasksByUser returns all tasks for a user
2019-05-25 09:33:57 +02:00
func GetTasksByUser ( search string , u * User , page int , sortby SortBy , startDate time . Time , endDate time . Time ) ( [ ] * ListTask , error ) {
2018-12-02 01:49:30 +01:00
// Get all lists
lists , err := getRawListsForUser ( "" , u , page )
if err != nil {
return nil , err
}
// Get all list IDs and get the tasks
var listIDs [ ] int64
for _ , l := range lists {
listIDs = append ( listIDs , l . ID )
}
var orderby string
switch sortby {
case SortTasksByPriorityDesc :
orderby = "priority desc"
case SortTasksByPriorityAsc :
orderby = "priority asc"
case SortTasksByDueDateDesc :
orderby = "due_date_unix desc"
case SortTasksByDueDateAsc :
orderby = "due_date_unix asc"
}
2019-05-25 09:33:57 +02:00
taskMap := make ( map [ int64 ] * ListTask )
2018-12-02 01:49:30 +01:00
// Then return all tasks for that lists
2018-12-22 19:06:14 +01:00
if startDate . Unix ( ) != 0 || endDate . Unix ( ) != 0 {
startDateUnix := time . Now ( ) . Unix ( )
if startDate . Unix ( ) != 0 {
startDateUnix = startDate . Unix ( )
}
endDateUnix := time . Now ( ) . Unix ( )
if endDate . Unix ( ) != 0 {
endDateUnix = endDate . Unix ( )
}
if err := x . In ( "list_id" , listIDs ) .
Where ( "text LIKE ?" , "%" + search + "%" ) .
And ( "((due_date_unix BETWEEN ? AND ?) OR " +
"(start_date_unix BETWEEN ? and ?) OR " +
"(end_date_unix BETWEEN ? and ?))" , startDateUnix , endDateUnix , startDateUnix , endDateUnix , startDateUnix , endDateUnix ) .
And ( "(parent_task_id = 0 OR parent_task_id IS NULL)" ) .
OrderBy ( orderby ) .
2019-05-25 09:33:57 +02:00
Find ( & taskMap ) ; err != nil {
2018-12-22 19:06:14 +01:00
return nil , err
}
} else {
if err := x . In ( "list_id" , listIDs ) .
Where ( "text LIKE ?" , "%" + search + "%" ) .
And ( "(parent_task_id = 0 OR parent_task_id IS NULL)" ) .
OrderBy ( orderby ) .
2019-05-25 09:33:57 +02:00
Find ( & taskMap ) ; err != nil {
2018-12-22 19:06:14 +01:00
return nil , err
}
2018-12-02 01:49:30 +01:00
}
2019-05-25 09:33:57 +02:00
tasks , err := addMoreInfoToTasks ( taskMap )
if err != nil {
return nil , err
}
// Because the list is sorted by id which we don't want (since we're dealing with maps)
// we have to manually sort the tasks again here.
sortTasks ( tasks , sortby )
2018-12-02 01:49:30 +01:00
return tasks , err
}
2019-05-25 09:33:57 +02:00
func sortTasks ( tasks [ ] * ListTask , by SortBy ) {
switch by {
case SortTasksByPriorityDesc :
sort . Slice ( tasks , func ( i , j int ) bool {
return tasks [ i ] . Priority > tasks [ j ] . Priority
} )
case SortTasksByPriorityAsc :
sort . Slice ( tasks , func ( i , j int ) bool {
return tasks [ i ] . Priority < tasks [ j ] . Priority
} )
case SortTasksByDueDateDesc :
sort . Slice ( tasks , func ( i , j int ) bool {
return tasks [ i ] . DueDateUnix > tasks [ j ] . DueDateUnix
} )
case SortTasksByDueDateAsc :
sort . Slice ( tasks , func ( i , j int ) bool {
return tasks [ i ] . DueDateUnix < tasks [ j ] . DueDateUnix
} )
}
}