UNPKG

@lxlib/theme

Version:

This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 9.1.1.

360 lines 27.3 kB
/** * @fileoverview added by tsickle * Generated from: src/services/http/http.decorator.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Inject, Injector } from '@angular/core'; import { ACLService } from '@lxlib/acl'; import { throwError } from 'rxjs'; import { _HttpClient } from './http.client'; /** * @abstract */ export class BaseApi { /** * @param {?} injector */ constructor(injector) { this.injector = injector; } } /** @nocollapse */ BaseApi.ctorParameters = () => [ { type: Injector, decorators: [{ type: Inject, args: [Injector,] }] } ]; if (false) { /** * @type {?} * @protected */ BaseApi.prototype.injector; } /** * @record */ export function HttpOptions() { } if (false) { /** * ACL配置,若导入 `\@lxlib/acl` 时自动有效,等同于 `ACLService.can(roleOrAbility: ACLCanType)` 参数值 * @type {?|undefined} */ HttpOptions.prototype.acl; /** @type {?|undefined} */ HttpOptions.prototype.observe; /** @type {?|undefined} */ HttpOptions.prototype.responseType; /** @type {?|undefined} */ HttpOptions.prototype.reportProgress; /** @type {?|undefined} */ HttpOptions.prototype.withCredentials; } /** * @record */ function ParamType() { } if (false) { /** @type {?} */ ParamType.prototype.key; /** @type {?} */ ParamType.prototype.index; /* Skipping unhandled member: [key: string]: any;*/ /* Skipping unhandled member: [key: number]: any;*/ } /** @type {?} */ const paramKey = `__api_params`; /** * @param {?} target * @param {?=} key * @return {?} */ function setParam(target, key = paramKey) { /** @type {?} */ let params = target[key]; if (typeof params === 'undefined') { params = target[key] = {}; } return params; } /** * 默认基准URL * - 有效范围:类 * @param {?} url * @return {?} */ export function BaseUrl(url) { return (/** * @template TClass * @param {?} target * @return {?} */ function (target) { /** @type {?} */ const params = setParam(target.prototype); params.baseUrl = url; return target; }); } /** * 默认 `headers` * - 有效范围:类 * @param {?} headers * @return {?} */ export function BaseHeaders(headers) { return (/** * @template TClass * @param {?} target * @return {?} */ function (target) { /** @type {?} */ const params = setParam(target.prototype); params.baseHeaders = headers; return target; }); } /** * @param {?} paramName * @return {?} */ function makeParam(paramName) { return (/** * @param {?=} key * @return {?} */ function (key) { return (/** * @param {?} target * @param {?} propertyKey * @param {?} index * @return {?} */ function (target, propertyKey, index) { /** @type {?} */ const params = setParam(setParam(target), propertyKey); /** @type {?} */ let tParams = params[paramName]; if (typeof tParams === 'undefined') { tParams = params[paramName] = []; } tParams.push({ key, index, }); }); }); } /** * URL路由参数 * - 有效范围:方法参数 * @type {?} */ export const Path = makeParam('path'); /** * URL 参数 `QueryString` * - 有效范围:方法参数 * @type {?} */ export const Query = makeParam('query'); /** * 参数 `Body` * - 有效范围:方法参数 * @type {?} */ export const Body = makeParam('body')(); /** * 参数 `headers` * - 有效范围:方法参数 * - 合并 `BaseHeaders` * @type {?} */ export const Headers = makeParam('headers'); /** * Request Payload * - Supported body (like`POST`, `PUT`) as a body data, equivalent to `\@Body` * - Not supported body (like `GET`, `DELETE` etc) as a `QueryString` * @type {?} */ export const Payload = makeParam('payload')(); /** * @param {?} data * @param {?} key * @param {?} args * @return {?} */ function getValidArgs(data, key, args) { if (!data[key] || !Array.isArray(data[key]) || data[key].length <= 0) { return undefined; } return args[data[key][0].index]; } /** * @param {?=} data * @param {?=} payload * @return {?} */ function genBody(data, payload) { if (Array.isArray(data) || Array.isArray(payload)) { // tslint:disable-next-line:prefer-object-spread return Object.assign([], data, payload); } // tslint:disable-next-line:prefer-object-spread return Object.assign({}, data, payload); } /** * @param {?} method * @return {?} */ function makeMethod(method) { return (/** * @param {?=} url * @param {?=} options * @return {?} */ function (url = '', options) { return (/** * @param {?} _target * @param {?=} targetKey * @param {?=} descriptor * @return {?} */ (_target, targetKey, descriptor) => { (/** @type {?} */ (descriptor)).value = (/** * @param {...?} args * @return {?} */ function (...args) { options = options || {}; /** @type {?} */ const injector = (/** @type {?} */ (((/** @type {?} */ (this))).injector)); /** @type {?} */ const http = (/** @type {?} */ (injector.get(_HttpClient, null))); if (http == null) { throw new TypeError(`Not found '_HttpClient', You can import 'LxlibThemeModule' && 'HttpClientModule' in your root module.`); } /** @type {?} */ const baseData = setParam(this); /** @type {?} */ const data = setParam(baseData, targetKey); /** @type {?} */ let requestUrl = url || ''; requestUrl = [baseData.baseUrl || '', requestUrl.startsWith('/') ? requestUrl.substr(1) : requestUrl].join('/'); // fix last split if (requestUrl.length > 1 && requestUrl.endsWith('/')) { requestUrl = requestUrl.substr(0, requestUrl.length - 1); } if (options.acl) { /** @type {?} */ const aclSrv = injector.get(ACLService, null); if (aclSrv && !aclSrv.can(options.acl)) { return throwError({ url: requestUrl, status: 401, statusText: `From Http Decorator`, }); } delete options.acl; } requestUrl = requestUrl.replace(/::/g, '^^'); (((/** @type {?} */ (data.path))) || []) .filter((/** * @param {?} w * @return {?} */ w => typeof args[w.index] !== 'undefined')) .forEach((/** * @param {?} i * @return {?} */ (i) => { requestUrl = requestUrl.replace(new RegExp(`:${i.key}`, 'g'), encodeURIComponent(args[i.index])); })); requestUrl = requestUrl.replace(/\^\^/g, `:`); /** @type {?} */ const params = (data.query || []).reduce((/** * @param {?} p * @param {?} i * @return {?} */ (p, i) => { p[i.key] = args[i.index]; return p; }), {}); /** @type {?} */ const headers = (data.headers || []).reduce((/** * @param {?} p * @param {?} i * @return {?} */ (p, i) => { p[i.key] = args[i.index]; return p; }), {}); if (method === 'FORM') { headers['content-type'] = 'application/x-www-form-urlencoded'; } /** @type {?} */ const payload = getValidArgs(data, 'payload', args); /** @type {?} */ const supportedBody = method === 'POST' || method === 'PUT'; return http.request(method, requestUrl, Object.assign({ body: supportedBody ? genBody(getValidArgs(data, 'body', args), payload) : null, params: !supportedBody ? Object.assign(Object.assign({}, params), payload) : params, headers: Object.assign(Object.assign({}, baseData.baseHeaders), headers) }, options)); }); return descriptor; }); }); } /** * `OPTIONS` 请求 * - 有效范围:方法 * @type {?} */ export const OPTIONS = makeMethod('OPTIONS'); /** * `GET` 请求 * - 有效范围:方法 * @type {?} */ export const GET = makeMethod('GET'); /** * `POST` 请求 * - 有效范围:方法 * @type {?} */ export const POST = makeMethod('POST'); /** * `DELETE` 请求 * - 有效范围:方法 * @type {?} */ export const DELETE = makeMethod('DELETE'); /** * `PUT` 请求 * - 有效范围:方法 * @type {?} */ export const PUT = makeMethod('PUT'); /** * `HEAD` 请求 * - 有效范围:方法 * @type {?} */ export const HEAD = makeMethod('HEAD'); /** * `PATCH` 请求 * - 有效范围:方法 * @type {?} */ export const PATCH = makeMethod('PATCH'); /** * `JSONP` 请求 * - 有效范围:方法 * @type {?} */ export const JSONP = makeMethod('JSONP'); /** * `FORM` 请求 * - 有效范围:方法 * @type {?} */ export const FORM = makeMethod('FORM'); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http.decorator.js","sourceRoot":"ng://@lxlib/theme/","sources":["src/services/http/http.decorator.ts"],"names":[],"mappings":"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","sourcesContent":["// tslint:disable: only-arrow-functions\nimport { HttpHeaders } from '@angular/common/http';\nimport { Inject, Injector } from '@angular/core';\nimport { ACLService } from '@lxlib/acl';\nimport { NzSafeAny } from 'ng-zorro-antd/core/types';\nimport { Observable, throwError } from 'rxjs';\nimport { _HttpClient } from './http.client';\n\nexport abstract class BaseApi {\n  constructor(@Inject(Injector) protected injector: Injector) {}\n}\n\nexport interface HttpOptions {\n  /** ACL配置，若导入 `@lxlib/acl` 时自动有效，等同于 `ACLService.can(roleOrAbility: ACLCanType)` 参数值 */\n  acl?: any;\n  observe?: 'body' | 'events' | 'response';\n  responseType?: 'arraybuffer' | 'blob' | 'json' | 'text';\n  reportProgress?: boolean;\n  withCredentials?: boolean;\n}\n\ninterface ParamType {\n  key: string;\n  index: number;\n  [key: string]: any;\n  [key: number]: any;\n}\n\nconst paramKey = `__api_params`;\n\nfunction setParam(target: any, key = paramKey) {\n  let params = target[key];\n  if (typeof params === 'undefined') {\n    params = target[key] = {};\n  }\n  return params;\n}\n\n/**\n * 默认基准URL\n * - 有效范围：类\n */\nexport function BaseUrl(url: string) {\n  return function <TClass extends new (...args: any[]) => BaseApi>(target: TClass): TClass {\n    const params = setParam(target.prototype);\n    params.baseUrl = url;\n    return target;\n  };\n}\n\n/**\n * 默认 `headers`\n * - 有效范围：类\n */\nexport function BaseHeaders(\n  headers:\n    | HttpHeaders\n    | {\n        [header: string]: string | string[];\n      },\n) {\n  return function <TClass extends new (...args: any[]) => BaseApi>(target: TClass): TClass {\n    const params = setParam(target.prototype);\n    params.baseHeaders = headers;\n    return target;\n  };\n}\n\nfunction makeParam(paramName: string) {\n  return function (key?: string) {\n    return function (target: BaseApi, propertyKey: string, index: number) {\n      const params = setParam(setParam(target), propertyKey);\n      let tParams = params[paramName];\n      if (typeof tParams === 'undefined') {\n        tParams = params[paramName] = [];\n      }\n      tParams.push({\n        key,\n        index,\n      });\n    };\n  };\n}\n\n/**\n * URL路由参数\n * - 有效范围：方法参数\n */\nexport const Path = makeParam('path');\n\n/**\n * URL 参数 `QueryString`\n * - 有效范围：方法参数\n */\nexport const Query = makeParam('query');\n\n/**\n * 参数 `Body`\n * - 有效范围：方法参数\n */\nexport const Body = makeParam('body')();\n\n/**\n * 参数 `headers`\n * - 有效范围：方法参数\n * - 合并 `BaseHeaders`\n */\nexport const Headers = makeParam('headers');\n\n/**\n * Request Payload\n * - Supported body (like`POST`, `PUT`) as a body data, equivalent to `@Body`\n * - Not supported body (like `GET`, `DELETE` etc) as a `QueryString`\n */\nexport const Payload = makeParam('payload')();\n\nfunction getValidArgs(data: any, key: string, args: any[]): {} | undefined {\n  if (!data[key] || !Array.isArray(data[key]) || data[key].length <= 0) {\n    return undefined;\n  }\n  return args[data[key][0].index];\n}\n\nfunction genBody(data?: any, payload?: any): any {\n  if (Array.isArray(data) || Array.isArray(payload)) {\n    // tslint:disable-next-line:prefer-object-spread\n    return Object.assign([], data, payload);\n  }\n  // tslint:disable-next-line:prefer-object-spread\n  return Object.assign({}, data, payload);\n}\n\nexport type METHOD_TYPE = 'OPTIONS' | 'GET' | 'POST' | 'DELETE' | 'PUT' | 'HEAD' | 'PATCH' | 'JSONP' | 'FORM';\n\nfunction makeMethod(method: METHOD_TYPE) {\n  return function (url: string = '', options?: HttpOptions) {\n    return (_target: BaseApi, targetKey?: string, descriptor?: PropertyDescriptor) => {\n      descriptor!.value = function (...args: any[]): Observable<any> {\n        options = options || {};\n\n        const injector = (this as NzSafeAny).injector as Injector;\n        const http = injector.get(_HttpClient, null) as _HttpClient;\n        if (http == null) {\n          throw new TypeError(`Not found '_HttpClient', You can import 'LxlibThemeModule' && 'HttpClientModule' in your root module.`);\n        }\n\n        const baseData = setParam(this);\n        const data = setParam(baseData, targetKey);\n\n        let requestUrl = url || '';\n        requestUrl = [baseData.baseUrl || '', requestUrl.startsWith('/') ? requestUrl.substr(1) : requestUrl].join('/');\n        // fix last split\n        if (requestUrl.length > 1 && requestUrl.endsWith('/')) {\n          requestUrl = requestUrl.substr(0, requestUrl.length - 1);\n        }\n\n        if (options.acl) {\n          const aclSrv = injector.get(ACLService, null);\n          if (aclSrv && !aclSrv.can(options.acl)) {\n            return throwError({\n              url: requestUrl,\n              status: 401,\n              statusText: `From Http Decorator`,\n            });\n          }\n          delete options.acl;\n        }\n\n        requestUrl = requestUrl.replace(/::/g, '^^');\n        ((data.path as ParamType[]) || [])\n          .filter(w => typeof args[w.index] !== 'undefined')\n          .forEach((i: ParamType) => {\n            requestUrl = requestUrl.replace(new RegExp(`:${i.key}`, 'g'), encodeURIComponent(args[i.index]));\n          });\n        requestUrl = requestUrl.replace(/\\^\\^/g, `:`);\n\n        const params = (data.query || []).reduce((p: NzSafeAny, i: ParamType) => {\n          p[i.key] = args[i.index];\n          return p;\n        }, {});\n\n        const headers = (data.headers || []).reduce((p: NzSafeAny, i: ParamType) => {\n          p[i.key] = args[i.index];\n          return p;\n        }, {});\n\n        if (method === 'FORM') {\n          headers['content-type'] = 'application/x-www-form-urlencoded';\n        }\n\n        const payload = getValidArgs(data, 'payload', args);\n        const supportedBody = method === 'POST' || method === 'PUT';\n\n        return http.request(method, requestUrl, {\n          body: supportedBody ? genBody(getValidArgs(data, 'body', args), payload) : null,\n          params: !supportedBody ? { ...params, ...payload } : params,\n          headers: { ...baseData.baseHeaders, ...headers },\n          ...options,\n        });\n      };\n\n      return descriptor;\n    };\n  };\n}\n\n/**\n * `OPTIONS` 请求\n * - 有效范围：方法\n */\nexport const OPTIONS = makeMethod('OPTIONS');\n\n/**\n * `GET` 请求\n * - 有效范围：方法\n */\nexport const GET = makeMethod('GET');\n\n/**\n * `POST` 请求\n * - 有效范围：方法\n */\nexport const POST = makeMethod('POST');\n\n/**\n * `DELETE` 请求\n * - 有效范围：方法\n */\nexport const DELETE = makeMethod('DELETE');\n\n/**\n * `PUT` 请求\n * - 有效范围：方法\n */\nexport const PUT = makeMethod('PUT');\n\n/**\n * `HEAD` 请求\n * - 有效范围：方法\n */\nexport const HEAD = makeMethod('HEAD');\n\n/**\n * `PATCH` 请求\n * - 有效范围：方法\n */\nexport const PATCH = makeMethod('PATCH');\n\n/**\n * `JSONP` 请求\n * - 有效范围：方法\n */\nexport const JSONP = makeMethod('JSONP');\n\n/**\n * `FORM` 请求\n * - 有效范围：方法\n */\nexport const FORM = makeMethod('FORM');\n"]}