UNPKG

@solid-nestjs/rest-api

Version:

solid-nestjs Rest-API utilities

116 lines 5.99 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; Object.defineProperty(exports, "__esModule", { value: true }); exports.ORDER_BY_CLASS_KEY = exports.WHERE_CLASS_KEY = void 0; exports.FindArgsFrom = FindArgsFrom; exports.getWhereClass = getWhereClass; exports.getOrderByClass = getOrderByClass; const class_validator_1 = require("class-validator"); const class_transformer_1 = require("class-transformer"); const common_1 = require("@nestjs/common"); const swagger_1 = require("@nestjs/swagger"); const inputs_1 = require("../classes/inputs"); exports.WHERE_CLASS_KEY = 'WhereClass'; exports.ORDER_BY_CLASS_KEY = 'OrderByClass'; /** * Generates a dynamic argument class for querying entities with optional pagination, filtering (where), and sorting (order by) capabilities. * * This mixin function creates a class based on the provided structure, supporting: * - Pagination via a `pagination` property. * - Filtering via a `where` property, supporting logical `_and` and `_or` operators. * - Sorting via an `orderBy` property. * * The generated class is decorated for use with NestJS, class-validator, and Swagger/OpenAPI. * * @typeParam EntityType - The entity type being queried. * @typeParam WhereType - The type used for filtering (where clause). Defaults to `Where<EntityType>`. * @typeParam OrderByType - The type used for sorting (order by clause). Defaults to `OrderBy<EntityType>`. * @param findArgsStructure - Optional structure specifying the types for where and orderBy clauses. * @returns A dynamically generated class implementing `FindArgs<EntityType>`, decorated for validation and API documentation. */ function FindArgsFrom(findArgsStructure) { const { whereType, orderByType } = findArgsStructure ?? {}; class ArgsClass { } __decorate([ (0, swagger_1.ApiProperty)({ type: () => inputs_1.PaginationRequest, required: false }), (0, class_transformer_1.Type)(() => inputs_1.PaginationRequest), (0, class_validator_1.IsOptional)(), (0, class_validator_1.ValidateNested)(), __metadata("design:type", inputs_1.PaginationRequest) ], ArgsClass.prototype, "pagination", void 0); let returnedClass = ArgsClass; if (whereType) { let WhereClass = class WhereClass extends (0, swagger_1.PartialType)(whereType) { }; __decorate([ (0, swagger_1.ApiProperty)({ type: () => [whereType], required: false, example: [] }), (0, class_validator_1.IsArray)(), (0, class_transformer_1.Type)(() => WhereClass), (0, class_validator_1.IsOptional)(), (0, class_validator_1.ValidateNested)(), __metadata("design:type", Array) ], WhereClass.prototype, "_and", void 0); __decorate([ (0, swagger_1.ApiProperty)({ type: () => [whereType], required: false, example: [] }), (0, class_validator_1.IsArray)(), (0, class_transformer_1.Type)(() => WhereClass), (0, class_validator_1.IsOptional)(), (0, class_validator_1.ValidateNested)(), __metadata("design:type", Array) ], WhereClass.prototype, "_or", void 0); WhereClass = __decorate([ (0, swagger_1.ApiSchema)({ name: whereType.name }) ], WhereClass); let ArgsClassWithWhere = class ArgsClassWithWhere extends returnedClass { }; __decorate([ (0, swagger_1.ApiProperty)({ type: () => WhereClass, required: false }), (0, class_transformer_1.Type)(() => WhereClass), (0, class_validator_1.IsOptional)(), (0, class_validator_1.ValidateNested)(), __metadata("design:type", WhereClass) ], ArgsClassWithWhere.prototype, "where", void 0); ArgsClassWithWhere = __decorate([ (0, common_1.SetMetadata)(exports.WHERE_CLASS_KEY, WhereClass) ], ArgsClassWithWhere); returnedClass = ArgsClassWithWhere; } if (orderByType) { let OrderByClass = class OrderByClass extends (0, swagger_1.PartialType)(orderByType) { }; OrderByClass = __decorate([ (0, swagger_1.ApiSchema)({ name: orderByType.name }) ], OrderByClass); let ArgsClassWithOrderBy = class ArgsClassWithOrderBy extends returnedClass { }; __decorate([ (0, swagger_1.ApiProperty)({ type: () => [OrderByClass], required: false }), (0, class_validator_1.IsArray)(), (0, class_transformer_1.Type)(() => OrderByClass), (0, class_validator_1.IsOptional)(), (0, class_validator_1.ValidateNested)(), __metadata("design:type", Array) ], ArgsClassWithOrderBy.prototype, "orderBy", void 0); ArgsClassWithOrderBy = __decorate([ (0, common_1.SetMetadata)(exports.ORDER_BY_CLASS_KEY, OrderByClass) ], ArgsClassWithOrderBy); returnedClass = ArgsClassWithOrderBy; } return (0, common_1.mixin)(returnedClass); } function getWhereClass(findArgsType) { return Reflect.getMetadata(exports.WHERE_CLASS_KEY, findArgsType); } function getOrderByClass(findArgsType) { return Reflect.getMetadata(exports.ORDER_BY_CLASS_KEY, findArgsType); } //# sourceMappingURL=find-args.mixin.js.map