|
|
@ -410,11 +410,11 @@ func ExceptWhile(data any, fn Predicate) any {
|
|
|
|
// Map a list to new list
|
|
|
|
// Map a list to new list
|
|
|
|
//
|
|
|
|
//
|
|
|
|
// eg: mapping [object0{},object1{},...] to flatten list [object0.someKey, object1.someKey, ...]
|
|
|
|
// eg: mapping [object0{},object1{},...] to flatten list [object0.someKey, object1.someKey, ...]
|
|
|
|
func Map[T any, V any](list []T, mapFn func(obj T) (val V, find bool)) []V {
|
|
|
|
func Map[T any, V any](list []T, mapFn func(idx int, obj T) (val V, find bool)) []V {
|
|
|
|
flatArr := make([]V, 0, len(list))
|
|
|
|
flatArr := make([]V, 0, len(list))
|
|
|
|
|
|
|
|
|
|
|
|
for _, obj := range list {
|
|
|
|
for i, obj := range list {
|
|
|
|
if target, ok := mapFn(obj); ok {
|
|
|
|
if target, ok := mapFn(i, obj); ok {
|
|
|
|
flatArr = append(flatArr, target)
|
|
|
|
flatArr = append(flatArr, target)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -422,17 +422,17 @@ func Map[T any, V any](list []T, mapFn func(obj T) (val V, find bool)) []V {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Column alias of Map func
|
|
|
|
// Column alias of Map func
|
|
|
|
func Column[T any, V any](list []T, mapFn func(obj T) (val V, find bool)) []V {
|
|
|
|
func Column[T any, V any](list []T, mapFn func(idx int, obj T) (val V, find bool)) []V {
|
|
|
|
return Map(list, mapFn)
|
|
|
|
return Map(list, mapFn)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Every check all true in given slice
|
|
|
|
// Every check all true in given slice
|
|
|
|
func Every[T any](list []T, fn func(T) bool) bool {
|
|
|
|
func Every[T any](list []T, fn func(idx int, v T) bool) bool {
|
|
|
|
if len(list) == 0 {
|
|
|
|
if len(list) == 0 {
|
|
|
|
return false
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for _, t := range list {
|
|
|
|
for i, t := range list {
|
|
|
|
if !fn(t) {
|
|
|
|
if !fn(i, t) {
|
|
|
|
return false
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -440,12 +440,12 @@ func Every[T any](list []T, fn func(T) bool) bool {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Some check some true in given slice
|
|
|
|
// Some check some true in given slice
|
|
|
|
func Some[T any](list []T, fn func(T) bool) bool {
|
|
|
|
func Some[T any](list []T, fn func(idx int, v T) bool) bool {
|
|
|
|
if len(list) == 0 {
|
|
|
|
if len(list) == 0 {
|
|
|
|
return false
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for _, t := range list {
|
|
|
|
for i, t := range list {
|
|
|
|
if fn(t) {
|
|
|
|
if fn(i, t) {
|
|
|
|
return true
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -453,7 +453,7 @@ func Some[T any](list []T, fn func(T) bool) bool {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Filter returns a new slice by given filter func
|
|
|
|
// Filter returns a new slice by given filter func
|
|
|
|
func Filter[T any](list []T, filterFn func(i int, currentValue T) bool) []T {
|
|
|
|
func Filter[T any](list []T, filterFn func(idx int, v T) bool) []T {
|
|
|
|
ret := make([]T, 0)
|
|
|
|
ret := make([]T, 0)
|
|
|
|
if list == nil {
|
|
|
|
if list == nil {
|
|
|
|
return ret
|
|
|
|
return ret
|
|
|
@ -469,7 +469,7 @@ func Filter[T any](list []T, filterFn func(i int, currentValue T) bool) []T {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Reduce all list item by given func
|
|
|
|
// Reduce all list item by given func
|
|
|
|
func Reduce[T any, M any](list []T, reduceFn func(total M, currentVal T, idx int) M, initialValue M) M {
|
|
|
|
func Reduce[T any, M any](list []T, reduceFn func(sum M, v T, idx int) M, initialValue M) M {
|
|
|
|
ret := initialValue
|
|
|
|
ret := initialValue
|
|
|
|
for i, item := range list {
|
|
|
|
for i, item := range list {
|
|
|
|
ret = reduceFn(ret, item, i)
|
|
|
|
ret = reduceFn(ret, item, i)
|
|
|
|