UNPKG

gen-jhipster

Version:

VHipster - Spring Boot + Angular/React/Vue in one handy generator

68 lines (67 loc) 3.02 kB
/** * Copyright 2013-2026 the original author or authors from the JHipster project. * * This file is part of the JHipster project, see https://www.jhipster.tech/ * for more information. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * https://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import type { OmitIndexSignature, ReadonlyKeysOf, RequiredKeysOf, SetRequired, Simplify } from 'type-fest'; /** * Copy and remove null and undefined values * @param object * @returns */ export declare function removeFieldsWithNullishValues<const T extends Record<string, any>>(object: T): T; /** * Picks every field from source. * A field with undefined value is returned for missing fields. */ export declare const pickFields: (source: Record<string | number, any>, fields: (string | number)[]) => { [k: string]: any; }; export type MutateDataParam<T extends object> = Simplify<OmitIndexSignature<{ [Key in keyof (T & { __override__?: boolean; })]?: Key extends '__override__' ? boolean : Key extends ReadonlyKeysOf<T> ? never : Key extends keyof T ? T[Key] extends Function ? (ctx: T) => T[Key] : T[Key] | ((ctx: T) => T[Key]) : never; }>>; /** * Utility to ensure required mutation properties are set. */ export type MutateDataPropertiesWithRequiredProperties<D extends Record<string, any>, N extends Record<string, any>> = SetRequired<D, RequiredKeysOf<N>>; declare const OverrideMutation: unique symbol; type MutateDataFunction = ((ctx: any) => any) & { [OverrideMutation]?: boolean; }; export declare const overrideMutateDataProperty: <const T extends MutateDataFunction>(fn: T) => T; /** * Mutation properties accepts: * - functions: receives the data and the return value is set at the data property. * - non functions: data property will receive the property in case current value is undefined. * - __override__ property: if set to false, functions will not override existing values. * * Applies each mutation object in order. * * Note: if data property is expected to be a function, mutation should be a function that returns the desired function. * * @example * // data = { prop: 'foo-bar', prop2: 'foo2', fn: () => 'fn' } * mutateData( * data, * { prop: 'foo', prop2: ({ prop }) => prop + 2, fn: () => () => 'fn' }, * { prop: ({ prop }) => prop + '-bar', prop2: 'won\'t override' }, * { __override__: false, prop: () => 'won\'t override' }, * ); */ export declare const mutateData: <const T extends Record<string | number, any>>(context: T, ...mutations: MutateDataParam<T>[]) => void; export {};