1
0
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:
Sebastian Malton 2021-10-19 09:02:59 -04:00 committed by GitHub
parent 6b3725346f
commit e21888c62c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 55 additions and 31 deletions

View File

@ -58,7 +58,7 @@ export class CatalogCategoryRegistry {
iter.reduce( iter.reduce(
this.filters, this.filters,
iter.filter, iter.filter,
this.items, this.items.values(),
) )
); );
} }

View File

@ -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(),
) )
); );
} }

View File

@ -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() {

View File

@ -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}`, "");
}

View File

@ -130,7 +130,7 @@ export class CatalogEntityRegistry {
iter.reduce( iter.reduce(
this.filters, this.filters,
iter.filter, iter.filter,
this.items, this.items.values(),
) )
); );
} }