mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Fix iter function return values (#3958)
This commit is contained in:
parent
6b3725346f
commit
e21888c62c
@ -58,7 +58,7 @@ export class CatalogCategoryRegistry {
|
|||||||
iter.reduce(
|
iter.reduce(
|
||||||
this.filters,
|
this.filters,
|
||||||
iter.filter,
|
iter.filter,
|
||||||
this.items,
|
this.items.values(),
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@ -105,7 +105,7 @@ export abstract class CatalogCategory extends (EventEmitter as new () => TypedEm
|
|||||||
iter.reduce(
|
iter.reduce(
|
||||||
this.filters,
|
this.filters,
|
||||||
iter.filter,
|
iter.filter,
|
||||||
menuItems,
|
menuItems.values(),
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@ -20,7 +20,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
import { KubeObject } from "../kube-object";
|
import { KubeObject } from "../kube-object";
|
||||||
import { autoBind, cpuUnitsToNumber, unitsToBytes } from "../../../renderer/utils";
|
import { autoBind, cpuUnitsToNumber, iter, unitsToBytes } from "../../../renderer/utils";
|
||||||
import { IMetrics, metricsApi } from "./metrics.api";
|
import { IMetrics, metricsApi } from "./metrics.api";
|
||||||
import { KubeApi } from "../kube-api";
|
import { KubeApi } from "../kube-api";
|
||||||
import type { KubeJsonApiData } from "../kube-json-api";
|
import type { KubeJsonApiData } from "../kube-json-api";
|
||||||
@ -71,6 +71,15 @@ export function formatNodeTaint(taint: NodeTaint): string {
|
|||||||
return `${taint.key}:${taint.effect}`;
|
return `${taint.key}:${taint.effect}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export interface NodeCondition {
|
||||||
|
type: string;
|
||||||
|
status: string;
|
||||||
|
lastHeartbeatTime?: string;
|
||||||
|
lastTransitionTime?: string;
|
||||||
|
reason?: string;
|
||||||
|
message?: string;
|
||||||
|
}
|
||||||
|
|
||||||
export interface Node {
|
export interface Node {
|
||||||
spec: {
|
spec: {
|
||||||
podCIDR?: string;
|
podCIDR?: string;
|
||||||
@ -100,14 +109,7 @@ export interface Node {
|
|||||||
memory: string;
|
memory: string;
|
||||||
pods: string;
|
pods: string;
|
||||||
};
|
};
|
||||||
conditions?: {
|
conditions?: NodeCondition[];
|
||||||
type: string;
|
|
||||||
status: string;
|
|
||||||
lastHeartbeatTime?: string;
|
|
||||||
lastTransitionTime?: string;
|
|
||||||
reason?: string;
|
|
||||||
message?: string;
|
|
||||||
}[];
|
|
||||||
addresses?: {
|
addresses?: {
|
||||||
type: string;
|
type: string;
|
||||||
address: string;
|
address: string;
|
||||||
@ -141,6 +143,19 @@ export interface Node {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Iterate over `conditions` yielding the `type` field if the `status` field is
|
||||||
|
* the string `"True"`
|
||||||
|
* @param conditions An iterator of some conditions
|
||||||
|
*/
|
||||||
|
function* getTrueConditionTypes(conditions: IterableIterator<NodeCondition> | Iterable<NodeCondition>): IterableIterator<string> {
|
||||||
|
for (const { status, type } of conditions) {
|
||||||
|
if (status === "True") {
|
||||||
|
yield type;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
export class Node extends KubeObject {
|
export class Node extends KubeObject {
|
||||||
static kind = "Node";
|
static kind = "Node";
|
||||||
static namespaced = false;
|
static namespaced = false;
|
||||||
@ -151,16 +166,15 @@ export class Node extends KubeObject {
|
|||||||
autoBind(this);
|
autoBind(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
getNodeConditionText() {
|
/**
|
||||||
const { conditions } = this.status;
|
* Returns the concatination of all current condition types which have a status
|
||||||
|
* of `"True"`
|
||||||
if (!conditions) return "";
|
*/
|
||||||
|
getNodeConditionText(): string {
|
||||||
return conditions.reduce((types, current) => {
|
return iter.join(
|
||||||
if (current.status !== "True") return "";
|
getTrueConditionTypes(this.status?.conditions ?? []),
|
||||||
|
" ",
|
||||||
return types += ` ${current.type}`;
|
);
|
||||||
}, "");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
getTaints() {
|
getTaints() {
|
||||||
|
|||||||
@ -25,7 +25,7 @@ export type Falsey = false | 0 | "" | null | undefined;
|
|||||||
* Create a new type safe empty Iterable
|
* Create a new type safe empty Iterable
|
||||||
* @returns An `Iterable` that yields 0 items
|
* @returns An `Iterable` that yields 0 items
|
||||||
*/
|
*/
|
||||||
export function* newEmpty<T>(): Iterable<T> {
|
export function* newEmpty<T>(): IterableIterator<T> {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -35,7 +35,7 @@ export function* newEmpty<T>(): Iterable<T> {
|
|||||||
* @param src An initial iterator
|
* @param src An initial iterator
|
||||||
* @param n The maximum number of elements to take from src. Yields up to the floor of `n` and 0 items if n < 0
|
* @param n The maximum number of elements to take from src. Yields up to the floor of `n` and 0 items if n < 0
|
||||||
*/
|
*/
|
||||||
export function* take<T>(src: Iterable<T>, n: number): Iterable<T> {
|
export function* take<T>(src: Iterable<T>, n: number): IterableIterator<T> {
|
||||||
outer: for (let i = 0; i < n; i += 1) {
|
outer: for (let i = 0; i < n; i += 1) {
|
||||||
for (const item of src) {
|
for (const item of src) {
|
||||||
yield item;
|
yield item;
|
||||||
@ -53,7 +53,7 @@ export function* take<T>(src: Iterable<T>, n: number): Iterable<T> {
|
|||||||
* @param src A type that can be iterated over
|
* @param src A type that can be iterated over
|
||||||
* @param fn The function that is called for each value
|
* @param fn The function that is called for each value
|
||||||
*/
|
*/
|
||||||
export function* map<T, U>(src: Iterable<T>, fn: (from: T) => U): Iterable<U> {
|
export function* map<T, U>(src: Iterable<T>, fn: (from: T) => U): IterableIterator<U> {
|
||||||
for (const from of src) {
|
for (const from of src) {
|
||||||
yield fn(from);
|
yield fn(from);
|
||||||
}
|
}
|
||||||
@ -64,7 +64,7 @@ export function* map<T, U>(src: Iterable<T>, fn: (from: T) => U): Iterable<U> {
|
|||||||
* @param src A type that can be iterated over
|
* @param src A type that can be iterated over
|
||||||
* @param fn The function that returns either an iterable over items that should be filtered out or a `Falsey` value indicating that it should be ignored
|
* @param fn The function that returns either an iterable over items that should be filtered out or a `Falsey` value indicating that it should be ignored
|
||||||
*/
|
*/
|
||||||
export function* filterFlatMap<T, U>(src: Iterable<T>, fn: (from: T) => Iterable<U | Falsey> | Falsey): Iterable<U> {
|
export function* filterFlatMap<T, U>(src: Iterable<T>, fn: (from: T) => Iterable<U | Falsey> | Falsey): IterableIterator<U> {
|
||||||
for (const from of src) {
|
for (const from of src) {
|
||||||
if (!from) {
|
if (!from) {
|
||||||
continue;
|
continue;
|
||||||
@ -89,7 +89,7 @@ export function* filterFlatMap<T, U>(src: Iterable<T>, fn: (from: T) => Iterable
|
|||||||
* @param src A type that can be iterated over
|
* @param src A type that can be iterated over
|
||||||
* @param fn A function that returns an iterator
|
* @param fn A function that returns an iterator
|
||||||
*/
|
*/
|
||||||
export function* flatMap<T, U>(src: Iterable<T>, fn: (from: T) => Iterable<U>): Iterable<U> {
|
export function* flatMap<T, U>(src: Iterable<T>, fn: (from: T) => Iterable<U>): IterableIterator<U> {
|
||||||
for (const from of src) {
|
for (const from of src) {
|
||||||
yield* fn(from);
|
yield* fn(from);
|
||||||
}
|
}
|
||||||
@ -101,7 +101,7 @@ export function* flatMap<T, U>(src: Iterable<T>, fn: (from: T) => Iterable<U>):
|
|||||||
* @param src A type that can be iterated over
|
* @param src A type that can be iterated over
|
||||||
* @param fn The function that is called for each value
|
* @param fn The function that is called for each value
|
||||||
*/
|
*/
|
||||||
export function* filter<T>(src: Iterable<T>, fn: (from: T) => any): Iterable<T> {
|
export function* filter<T>(src: Iterable<T>, fn: (from: T) => any): IterableIterator<T> {
|
||||||
for (const from of src) {
|
for (const from of src) {
|
||||||
if (fn(from)) {
|
if (fn(from)) {
|
||||||
yield from;
|
yield from;
|
||||||
@ -115,7 +115,7 @@ export function* filter<T>(src: Iterable<T>, fn: (from: T) => any): Iterable<T>
|
|||||||
* @param src A type that can be iterated over
|
* @param src A type that can be iterated over
|
||||||
* @param fn The function that is called for each value
|
* @param fn The function that is called for each value
|
||||||
*/
|
*/
|
||||||
export function* filterMap<T, U>(src: Iterable<T>, fn: (from: T) => U | Falsey): Iterable<U> {
|
export function* filterMap<T, U>(src: Iterable<T>, fn: (from: T) => U | Falsey): IterableIterator<U> {
|
||||||
for (const from of src) {
|
for (const from of src) {
|
||||||
const res = fn(from);
|
const res = fn(from);
|
||||||
|
|
||||||
@ -131,7 +131,7 @@ export function* filterMap<T, U>(src: Iterable<T>, fn: (from: T) => U | Falsey):
|
|||||||
* @param src A type that can be iterated over
|
* @param src A type that can be iterated over
|
||||||
* @param fn The function that is called for each value
|
* @param fn The function that is called for each value
|
||||||
*/
|
*/
|
||||||
export function* filterMapStrict<T, U>(src: Iterable<T>, fn: (from: T) => U | null | undefined): Iterable<U> {
|
export function* filterMapStrict<T, U>(src: Iterable<T>, fn: (from: T) => U | null | undefined): IterableIterator<U> {
|
||||||
for (const from of src) {
|
for (const from of src) {
|
||||||
const res = fn(from);
|
const res = fn(from);
|
||||||
|
|
||||||
@ -164,7 +164,7 @@ export function find<T>(src: Iterable<T>, match: (i: T) => any): T | undefined {
|
|||||||
* @param reducer A function for producing the next item from an accumilation and the current item
|
* @param reducer A function for producing the next item from an accumilation and the current item
|
||||||
* @param initial The initial value for the iteration
|
* @param initial The initial value for the iteration
|
||||||
*/
|
*/
|
||||||
export function reduce<T, R>(src: Iterable<T>, reducer: (acc: Iterable<R>, cur: T) => Iterable<R>, initial: Iterable<R>): Iterable<R>;
|
export function reduce<T, R extends Iterable<any>>(src: Iterable<T>, reducer: (acc: R, cur: T) => R, initial: R): R;
|
||||||
|
|
||||||
export function reduce<T, R = T>(src: Iterable<T>, reducer: (acc: R, cur: T) => R, initial: R): R {
|
export function reduce<T, R = T>(src: Iterable<T>, reducer: (acc: R, cur: T) => R, initial: R): R {
|
||||||
let acc = initial;
|
let acc = initial;
|
||||||
@ -175,3 +175,13 @@ export function reduce<T, R = T>(src: Iterable<T>, reducer: (acc: R, cur: T) =>
|
|||||||
|
|
||||||
return acc;
|
return acc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A convenience function for reducing over an iterator of strings and concatenating them together
|
||||||
|
* @param src The value to iterate over
|
||||||
|
* @param connector The string value to intersperse between the yielded values
|
||||||
|
* @returns The concatenated entries of `src` interspersed with copies of `connector`
|
||||||
|
*/
|
||||||
|
export function join(src: Iterable<string>, connector = ","): string {
|
||||||
|
return reduce(src, (acc, cur) => `${acc}${connector}${cur}`, "");
|
||||||
|
}
|
||||||
|
|||||||
@ -130,7 +130,7 @@ export class CatalogEntityRegistry {
|
|||||||
iter.reduce(
|
iter.reduce(
|
||||||
this.filters,
|
this.filters,
|
||||||
iter.filter,
|
iter.filter,
|
||||||
this.items,
|
this.items.values(),
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user