com.phloxui
Version:
PhloxUI Ng2+ Framework
165 lines (164 loc) • 18.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Injectable } from '@angular/core';
import { Headers, RequestOptions, RequestMethod } from '@angular/http';
import { ConnectionManager } from './ConnectionManager.service';
var JsonSchemaService = /** @class */ (function () {
function JsonSchemaService(connectionMgr) {
this.basePath = 'http://' + window.location.hostname + ':8081/hello/json';
this.connectionMgr = connectionMgr;
this.schemaCached = {};
this.defaultHeaders = new Headers(); // default more if exist
}
/**
* @param {?} className
* @return {?}
*/
JsonSchemaService.prototype.getSchema = /**
* @param {?} className
* @return {?}
*/
function (className) {
var _this = this;
if (className === null || typeof className !== 'string' || className === '') {
return Promise.resolve(null);
}
if (this.schemaCached[className] !== null && typeof this.schemaCached[className] !== 'undefined') {
return Promise.resolve(this.schemaCached[className]);
}
return new Promise(function (resolve, reject) {
// cache only default load
var /** @type {?} */ path = _this.basePath + "/" + className + "/schema";
var /** @type {?} */ headers = new Headers(_this.defaultHeaders.toJSON());
var /** @type {?} */ requestOptions = new RequestOptions({
method: RequestMethod.Get,
headers: headers
});
var /** @type {?} */ prom = _this.connectionMgr.getWithHttpInfo(path, requestOptions);
prom.then(function (response) {
var /** @type {?} */ jsonSchemaResult = null;
if (response !== null && typeof response !== 'undefined') {
jsonSchemaResult = response.json();
if (jsonSchemaResult !== null && typeof jsonSchemaResult !== 'undefined') {
// cache result
// cache result
_this.schemaCached[className] = jsonSchemaResult;
}
}
resolve(jsonSchemaResult);
}, function (errorResult) {
reject(errorResult);
});
}).catch(function (error) {
return Promise.reject(error);
});
};
/**
* @param {?} className
* @param {?} ignoreNull
* @param {?} ignoreEmpty
* @param {?} ignorePropRegex
* @param {?} includePropsFields
* @return {?}
*/
JsonSchemaService.prototype.getSchemaWithConfigs = /**
* @param {?} className
* @param {?} ignoreNull
* @param {?} ignoreEmpty
* @param {?} ignorePropRegex
* @param {?} includePropsFields
* @return {?}
*/
function (className, ignoreNull, ignoreEmpty, ignorePropRegex, includePropsFields) {
var _this = this;
if (className === null || typeof className !== 'string' || className === '') {
return Promise.resolve(null);
}
return new Promise(function (resolve, reject) {
// cache only default load
var /** @type {?} */ path = _this.basePath + "/" + className + "/schema";
var /** @type {?} */ pathParam = "";
if (ignoreNull !== null && typeof ignoreNull !== 'undefined') {
pathParam += "ignoreNull=" + (ignoreNull ? "true" : "false") + "&";
}
if (ignoreEmpty !== null && typeof ignoreEmpty !== 'undefined') {
pathParam += "ignoreEmpty=" + (ignoreEmpty ? "true" : "false") + "&";
}
if (ignorePropRegex !== null && typeof ignorePropRegex !== 'undefined' && ignorePropRegex !== '') {
pathParam += "ignorePropRegex=" + ignorePropRegex + "&";
}
if (includePropsFields !== null && typeof includePropsFields !== 'undefined') {
var /** @type {?} */ nameAppendStmt = "";
try {
for (var includePropsFields_1 = tslib_1.__values(includePropsFields), includePropsFields_1_1 = includePropsFields_1.next(); !includePropsFields_1_1.done; includePropsFields_1_1 = includePropsFields_1.next()) {
var name_1 = includePropsFields_1_1.value;
nameAppendStmt += name_1 + ",";
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (includePropsFields_1_1 && !includePropsFields_1_1.done && (_a = includePropsFields_1.return)) _a.call(includePropsFields_1);
}
finally { if (e_1) throw e_1.error; }
}
if (nameAppendStmt !== '') {
nameAppendStmt = nameAppendStmt.slice(0, nameAppendStmt.length - 1);
pathParam += "includePropsFields=" + nameAppendStmt + "&";
}
}
if (pathParam !== "") {
pathParam = pathParam.slice(0, pathParam.length - 1);
path += "?" + pathParam;
}
var /** @type {?} */ headers = new Headers(_this.defaultHeaders.toJSON());
var /** @type {?} */ requestOptions = new RequestOptions({
method: RequestMethod.Get,
headers: headers
});
var /** @type {?} */ prom = _this.connectionMgr.getWithHttpInfo(path, requestOptions);
prom.then(function (response) {
var /** @type {?} */ jsonSchemaResult = null;
if (response !== null && typeof response !== 'undefined') {
jsonSchemaResult = response.json();
}
resolve(jsonSchemaResult);
}, function (errorResult) {
reject(errorResult);
});
var e_1, _a;
}).catch(function (error) {
return Promise.reject(error);
});
};
JsonSchemaService.decorators = [
{ type: Injectable },
];
/** @nocollapse */
JsonSchemaService.ctorParameters = function () { return [
{ type: ConnectionManager, },
]; };
return JsonSchemaService;
}());
export { JsonSchemaService };
function JsonSchemaService_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
JsonSchemaService.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
JsonSchemaService.ctorParameters;
/** @type {?} */
JsonSchemaService.prototype.connectionMgr;
/** @type {?} */
JsonSchemaService.prototype.schemaCached;
/** @type {?} */
JsonSchemaService.prototype.basePath;
/** @type {?} */
JsonSchemaService.prototype.defaultHeaders;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"JsonSchemaService.service.js","sourceRoot":"ng://com.phloxui/","sources":["lib/service/JsonSchemaService.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, Optional } from '@angular/core';\nimport { Http, Response, Headers, RequestOptions, RequestOptionsArgs, URLSearchParams, ResponseContentType, RequestMethod } from '@angular/http';\nimport { ConnectionManager } from './ConnectionManager.service';\nimport { JsonSchema } from '../model/models';\n\ndeclare var window: any;\n\n@Injectable()\nexport class JsonSchemaService {\n\n  private connectionMgr: ConnectionManager;\n  private schemaCached: any; // Map<String[className], JsonSchema>\n  protected basePath = 'http://' + window.location.hostname + ':8081/hello/json';\n  public defaultHeaders: Headers;\n\n  constructor(connectionMgr: ConnectionManager) {\n    this.connectionMgr = connectionMgr;\n    this.schemaCached = {};\n    this.defaultHeaders = new Headers(); // default more if exist\n  }\n\n  public getSchema(className: string): Promise<Response> {\n    if (className === null || typeof className !== 'string' || className === '') {\n      return Promise.resolve(null);\n    }\n\n    if (this.schemaCached[className] !== null && typeof this.schemaCached[className] !== 'undefined') {\n      return Promise.resolve(this.schemaCached[className]);\n    }\n\n    return new Promise<Response>((resolve, reject) => {\n      // cache only default load\n      let path = this.basePath + \"/\" + className + \"/schema\";\n\n      let headers = new Headers(this.defaultHeaders.toJSON());\n      let requestOptions: RequestOptionsArgs = new RequestOptions({\n        method: RequestMethod.Get,\n        headers: headers\n      });\n\n      let prom = this.connectionMgr.getWithHttpInfo(path, requestOptions);\n      prom.then((response: any) => {\n        let jsonSchemaResult: any = null;\n        if (response !== null && typeof response !== 'undefined') {\n          jsonSchemaResult = response.json();\n\n          if (jsonSchemaResult !== null && typeof jsonSchemaResult !== 'undefined') {\n            // cache result\n            this.schemaCached[className] = jsonSchemaResult;\n          }\n        }\n\n        resolve(jsonSchemaResult);\n      }, (errorResult) => {\n        reject(errorResult);\n      });\n    }).catch((error) => {\n      return Promise.reject(error);\n    });\n  }\n\n  public getSchemaWithConfigs(className: string, ignoreNull: boolean, ignoreEmpty: boolean, ignorePropRegex: string, includePropsFields: String[]): Promise<Response> {\n    if (className === null || typeof className !== 'string' || className === '') {\n      return Promise.resolve(null);\n    }\n\n    return new Promise<Response>((resolve, reject) => {\n      // cache only default load\n      let path = this.basePath + \"/\" + className + \"/schema\";\n\n      let pathParam = \"\";\n      if (ignoreNull !== null && typeof ignoreNull !== 'undefined') {\n        pathParam += \"ignoreNull=\" + (ignoreNull ? \"true\" : \"false\") + \"&\";\n      }\n      if (ignoreEmpty !== null && typeof ignoreEmpty !== 'undefined') {\n        pathParam += \"ignoreEmpty=\" + (ignoreEmpty ? \"true\" : \"false\") + \"&\";\n      }\n      if (ignorePropRegex !== null && typeof ignorePropRegex !== 'undefined' && ignorePropRegex !== '') {\n        pathParam += \"ignorePropRegex=\" + ignorePropRegex + \"&\";\n      }\n      if (includePropsFields !== null && typeof includePropsFields !== 'undefined') {\n        let nameAppendStmt = \"\";\n        for (let name of includePropsFields) {\n          nameAppendStmt += name + \",\";\n        }\n\n        if (nameAppendStmt !== '') {\n          nameAppendStmt = nameAppendStmt.slice(0, nameAppendStmt.length - 1);\n          pathParam += \"includePropsFields=\" + nameAppendStmt + \"&\";\n        }\n      }\n\n      if (pathParam !== \"\") {\n        pathParam = pathParam.slice(0, pathParam.length - 1);\n        path += \"?\" + pathParam;\n      }\n\n      let headers = new Headers(this.defaultHeaders.toJSON());\n      let requestOptions: RequestOptionsArgs = new RequestOptions({\n        method: RequestMethod.Get,\n        headers: headers\n      });\n\n      let prom = this.connectionMgr.getWithHttpInfo(path, requestOptions);\n      prom.then((response: any) => {\n        let jsonSchemaResult: any = null;\n        if (response !== null && typeof response !== 'undefined') {\n          jsonSchemaResult = response.json();\n        }\n\n        resolve(jsonSchemaResult);\n      }, (errorResult) => {\n        reject(errorResult);\n      });\n    }).catch((error) => {\n      return Promise.reject(error);\n    });\n  }\n}\n"]}