com.phloxui
Version:
PhloxUI Ng2+ Framework
150 lines (149 loc) • 18.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Headers, RequestOptions, RequestMethod } from '@angular/http';
import { AbstractServerResource } from '../AbstractServerResource';
var JSONResource = /** @class */ (function (_super) {
tslib_1.__extends(JSONResource, _super);
function JSONResource(connectionMgr) {
var _this = _super.call(this, connectionMgr) || this;
_this.basePath = 'http://' + window.location.hostname + ':8081/hello/json';
_this.schemaCached = {};
_this.defaultHeaders = new Headers(); // default more if exist
return _this;
}
/**
* @param {?} className
* @return {?}
*/
JSONResource.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 {?}
*/
JSONResource.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);
});
};
return JSONResource;
}(AbstractServerResource));
export { JSONResource };
function JSONResource_tsickle_Closure_declarations() {
/** @type {?} */
JSONResource.prototype.schemaCached;
/** @type {?} */
JSONResource.prototype.basePath;
/** @type {?} */
JSONResource.prototype.defaultHeaders;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"JSONResource.js","sourceRoot":"ng://com.phloxui/","sources":["lib/share/resource/JSONResource.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 '../../service/ConnectionManager.service';\nimport { JsonSchema } from '../model/models';\nimport { AbstractServerResource } from '../AbstractServerResource';\nimport { IConnectionManager } from '../IConnectionManager';\n\ndeclare var window: any;\n\nexport class JSONResource extends AbstractServerResource {\n\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: IConnectionManager) {\n    super(connectionMgr);\n\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"]}