mirror of
				https://github.com/Theodor-Springmann-Stiftung/musenalm.git
				synced 2025-10-29 09:15:33 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			41 lines
		
	
	
		
			803 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			803 B
		
	
	
	
		
			Go
		
	
	
	
	
	
| package dbmodels
 | |
| 
 | |
| import (
 | |
| 	"slices"
 | |
| 
 | |
| 	"github.com/pocketbase/dbx"
 | |
| 	"github.com/pocketbase/pocketbase/core"
 | |
| 	"golang.org/x/text/collate"
 | |
| 	"golang.org/x/text/language"
 | |
| )
 | |
| 
 | |
| func AllPlaces(app core.App) ([]*Place, error) {
 | |
| 	places := []*Place{}
 | |
| 	err := app.RecordQuery(PLACES_TABLE).
 | |
| 		OrderBy(PLACES_NAME_FIELD).
 | |
| 		All(&places)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	return places, nil
 | |
| }
 | |
| 
 | |
| func SortPlacesByName(places []*Place) {
 | |
| 	collator := collate.New(language.German)
 | |
| 	slices.SortFunc(places, func(i, j *Place) int {
 | |
| 		return collator.CompareString(i.Name(), j.Name())
 | |
| 	})
 | |
| }
 | |
| 
 | |
| func PlaceForId(app core.App, id string) (*Place, error) {
 | |
| 	place := &Place{}
 | |
| 	err := app.RecordQuery(PLACES_TABLE).
 | |
| 		Where(dbx.HashExp{ID_FIELD: id}).
 | |
| 		One(place)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	return place, nil
 | |
| }
 | 
