@wertzui/ngx-restworld-client 4.0.0 → 4.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/pipes/safe-url.pipe.mjs +2 -2
- package/esm2020/lib/services/restworld-client.mjs +1 -1
- package/esm2020/lib/views/restworld-edit-form/restworld-edit-form.component.mjs +2 -2
- package/esm2020/lib/views/restworld-edit-view/restworld-edit-view.component.mjs +18 -4
- package/esm2020/lib/views/restworld-image-view/restworld-image-view.component.mjs +3 -3
- package/esm2020/lib/views/restworld-list-view/restworld-list-view.component.mjs +1 -1
- package/fesm2015/wertzui-ngx-restworld-client.mjs +20 -6
- package/fesm2015/wertzui-ngx-restworld-client.mjs.map +1 -1
- package/fesm2020/wertzui-ngx-restworld-client.mjs +20 -6
- package/fesm2020/wertzui-ngx-restworld-client.mjs.map +1 -1
- package/lib/services/restworld-client.d.ts +5 -5
- package/lib/views/restworld-edit-view/restworld-edit-view.component.d.ts +1 -0
- package/lib/views/restworld-list-view/restworld-list-view.component.d.ts +5 -5
- package/package.json +2 -2
|
@@ -7,7 +7,7 @@ export class SafeUrlPipe {
|
|
|
7
7
|
this._domSanitizer = _domSanitizer;
|
|
8
8
|
}
|
|
9
9
|
transform(url) {
|
|
10
|
-
if (_.isString(url))
|
|
10
|
+
if (!_.isString(url))
|
|
11
11
|
throw new Error(`The given url '${url}' is not a string.`);
|
|
12
12
|
return this._domSanitizer.bypassSecurityTrustResourceUrl(url);
|
|
13
13
|
}
|
|
@@ -20,4 +20,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImpor
|
|
|
20
20
|
name: 'safeUrl'
|
|
21
21
|
}]
|
|
22
22
|
}], ctorParameters: function () { return [{ type: i1.DomSanitizer }]; } });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FmZS11cmwucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1yZXN0d29ybGQtY2xpZW50L3NyYy9saWIvcGlwZXMvc2FmZS11cmwucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUVwRCxPQUFPLEtBQUssQ0FBQyxNQUFNLFFBQVEsQ0FBQzs7O0FBSzVCLE1BQU0sT0FBTyxXQUFXO0lBRXRCLFlBQW9CLGFBQTJCO1FBQTNCLGtCQUFhLEdBQWIsYUFBYSxDQUFjO0lBQy9DLENBQUM7SUFFRCxTQUFTLENBQUMsR0FBWTtRQUNwQixJQUFJLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUM7WUFDbEIsTUFBTSxJQUFJLEtBQUssQ0FBQyxrQkFBa0IsR0FBRyxvQkFBb0IsQ0FBQyxDQUFBO1FBRTVELE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyw4QkFBOEIsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNoRSxDQUFDOzt3R0FWVSxXQUFXO3NHQUFYLFdBQVc7MkZBQVgsV0FBVztrQkFIdkIsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsU0FBUztpQkFDaEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IERvbVNhbml0aXplciB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xyXG5pbXBvcnQgKiBhcyBfIGZyb20gJ2xvZGFzaCc7XHJcblxyXG5AUGlwZSh7XHJcbiAgbmFtZTogJ3NhZmVVcmwnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTYWZlVXJsUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9kb21TYW5pdGl6ZXI6IERvbVNhbml0aXplcikge1xyXG4gIH1cclxuXHJcbiAgdHJhbnNmb3JtKHVybDogdW5rbm93bikge1xyXG4gICAgaWYgKCFfLmlzU3RyaW5nKHVybCkpXHJcbiAgICAgIHRocm93IG5ldyBFcnJvcihgVGhlIGdpdmVuIHVybCAnJHt1cmx9JyBpcyBub3QgYSBzdHJpbmcuYClcclxuXHJcbiAgICByZXR1cm4gdGhpcy5fZG9tU2FuaXRpemVyLmJ5cGFzc1NlY3VyaXR5VHJ1c3RSZXNvdXJjZVVybCh1cmwpO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -211,4 +211,4 @@ export class RESTworldClient {
|
|
|
211
211
|
return combinedHeaders;
|
|
212
212
|
}
|
|
213
213
|
}
|
|
214
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-client.js","sourceRoot":"","sources":["../../../../../projects/ngx-restworld-client/src/lib/services/restworld-client.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpHeaders, HttpResponse } from '@angular/common/http';\r\nimport * as _ from \"lodash\";\r\nimport { FormsResource, HalClient, Link, PagedListResource, Resource, Template } from \"@wertzui/ngx-hal-client\";\r\nimport { LinkNames } from \"../constants/link-names\";\r\nimport { ProblemDetails } from \"../models/problem-details\";\r\nimport { RESTworldOptions } from \"../models/restworld-options\";\r\n\r\nexport class RESTworldClient {\r\n\r\n  private _homeResource?: Resource;\r\n  private _defaultCurie?: string;\r\n  public get halClient() {\r\n    return this._halClient;\r\n  }\r\n\r\n  constructor(\r\n    private _halClient: HalClient,\r\n    private _options: RESTworldOptions\r\n  ) { }\r\n\r\n  public async ensureHomeResourceIsSet(): Promise<void> {\r\n    if (!this._homeResource) {\r\n      const response = await this.getHomeForced();\r\n      if (ProblemDetails.isProblemDetails(response.body)) {\r\n        throw new Error(`Cannot get the home resource from ${this._options.BaseUrl} with Version ${this._options.Version}. Response was: ${response}`);\r\n      }\r\n      if (!response.body)\r\n        throw new Error(`Cannot get the home resource from ${this._options.BaseUrl} with Version ${this._options.Version}. Response was empty.`);\r\n      this._homeResource = response.body;\r\n      this.setDefaultCurie();\r\n    }\r\n  }\r\n\r\n  private async getHomeForced(): Promise<HttpResponse<Resource | ProblemDetails>> {\r\n    const header = RESTworldClient.createHeaders('application/hal+json', this._options.Version);\r\n    const response = await this.halClient.get(this._options.BaseUrl, Resource, ProblemDetails, header);\r\n    return response;\r\n  }\r\n\r\n  private setDefaultCurie(): void {\r\n    const curies = this._homeResource?._links?.curies;\r\n    if (!curies || curies.length === 0 || !curies[0])\r\n      this._defaultCurie = undefined;\r\n    else\r\n      this._defaultCurie = curies[0].name;\r\n  }\r\n\r\n  public async getList(rel: string, parameters: {}, headers?: HttpHeaders, curie?: string): Promise<HttpResponse<PagedListResource | ProblemDetails>> {\r\n    const link = this.getLinkFromHome(rel, LinkNames.getList, curie);\r\n    const uri = link.href\r\n\r\n    const response = await this.getListByUri(uri, parameters, headers);\r\n\r\n    return response;\r\n  }\r\n\r\n  public async getListByUri(uri: string, parameters: {}, headers?: HttpHeaders): Promise<HttpResponse<PagedListResource | ProblemDetails>> {\r\n    const link = new Link();\r\n    link.href = uri;\r\n    const filledUri = link.fillTemplate(parameters);\r\n    const defaultHeaders = RESTworldClient.createHeaders('application/hal+json', this._options.Version);\r\n    const combinedHeaders = RESTworldClient.combineHeaders(headers, defaultHeaders, false);\r\n\r\n    const response = await this.halClient.get(filledUri, PagedListResource, ProblemDetails, combinedHeaders);\r\n\r\n    return response;\r\n  }\r\n\r\n  public async getAllPagesFromList(rel: string, parameters: {}, headers?: HttpHeaders, curie?: string): Promise<HttpResponse<PagedListResource | ProblemDetails>> {\r\n    const link = this.getLinkFromHome(rel, LinkNames.getList, curie);\r\n    const uri = link.href;\r\n\r\n    const response = await this.getAllPagesFromListByUri(uri, parameters, headers);\r\n\r\n    return response;\r\n  }\r\n\r\n  public async getAllPagesFromListByUri(uri: string, parameters: {}, headers?: HttpHeaders): Promise<HttpResponse<PagedListResource | ProblemDetails>> {\r\n    const response = await this.getListByUri(uri, parameters, headers);\r\n\r\n    if (!response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body?._embedded?.items)\r\n      return response;\r\n\r\n\r\n    const items = response.body._embedded.items;\r\n    let lastResponse = response;\r\n\r\n    while ((lastResponse?.body?._links?.next?.length ?? 0) > 0) {\r\n      // Get the next response\r\n      const nextLinks = lastResponse.body?._links.next;\r\n      const nextLink = nextLinks ? nextLinks[0]: undefined;\r\n      const nextHref = nextLink?.href;\r\n      if (nextHref) {\r\n        lastResponse = await this.getListByUri(nextHref, parameters, headers);\r\n\r\n        if (!lastResponse.ok || ProblemDetails.isProblemDetails(lastResponse.body) || !lastResponse.body)\r\n          return lastResponse;\r\n\r\n        // Combine the embedded items\r\n        lastResponse.body?._embedded?.items?.forEach(r => items.push(r));\r\n      }\r\n    }\r\n\r\n    // We combined everything, so there is just one big page\r\n    response.body.totalPages = 1;\r\n    response.body._links.next = undefined;\r\n\r\n    return response;\r\n  }\r\n\r\n  public async getSingle(relOrUri: string, id?: number, headers?: HttpHeaders, curie?: string): Promise<HttpResponse<Resource | ProblemDetails>> {\r\n    let uri;\r\n    if (relOrUri.startsWith('http')) {\r\n      if (id !== undefined)\r\n        throw new Error('When supplying a URI, an ID cannot be supplied too.');\r\n      if (curie)\r\n        throw new Error('When supplying a URI, a curie cannot be supplied too.');\r\n\r\n      uri = relOrUri;\r\n    }\r\n    else {\r\n      if (!_.isNumber(id))\r\n        throw new Error('When supplying a rel, an ID must be supplied too.');\r\n\r\n      const link = this.getLinkFromHome(relOrUri, LinkNames.get, curie);\r\n      uri = link.fillTemplate({ id: id.toString() });\r\n    }\r\n\r\n    const defaultHeaders = RESTworldClient.createHeaders('application/hal+json', this._options.Version);\r\n    const combinedHeaders = RESTworldClient.combineHeaders(headers, defaultHeaders, false);\r\n    const response = await this.halClient.get(uri, Resource, ProblemDetails, combinedHeaders);\r\n\r\n    return response;\r\n  }\r\n\r\n  public async save(resource: Resource): Promise<HttpResponse<Resource | ProblemDetails>> {\r\n    const saveLink = resource.findLink('save');\r\n    if (!saveLink)\r\n      throw new Error(`The resource ${resource} does not have a save link.`);\r\n    if (!saveLink.name)\r\n      throw new Error(`The save link ${saveLink} does not have a save name.`);\r\n\r\n    const uri = saveLink.href;\r\n    const method = saveLink.name.toLowerCase();\r\n    const header = RESTworldClient.createHeaders('application/hal+json', this._options.Version);\r\n\r\n    let response;\r\n    switch (method) {\r\n      case 'put':\r\n        response = await this.halClient.put(uri, resource, Resource, ProblemDetails, header);\r\n        break;\r\n      case 'post':\r\n        response = await this.halClient.post(uri, resource, Resource, ProblemDetails, header);\r\n        break;\r\n      default:\r\n        throw new Error(`'${method}' is not allowed as link name for the save link. Only 'POST' and 'PUT' are allowed.`);\r\n    }\r\n\r\n    return response;\r\n  }\r\n\r\n  public async getAllForms(resource: Resource): Promise<HttpResponse<FormsResource | ProblemDetails>[]> {\r\n    const urls = resource.getFormLinkHrefs();\r\n    const header = RESTworldClient.createHeaders('application/prs.hal-forms+json', this._options.Version);\r\n    const formsPromises = urls.map(url => this._halClient.get(url, FormsResource, ProblemDetails, header));\r\n    const formsAndProblems = await Promise.all(formsPromises);\r\n    return formsAndProblems;\r\n  }\r\n\r\n  public async submit(template: Template, formValues: {}): Promise<HttpResponse<FormsResource | ProblemDetails>> {\r\n    const uri = template.target || '';\r\n    const method = template.method?.toLowerCase();\r\n    const header = RESTworldClient.createHeaders('application/prs.hal-forms+json', this._options.Version);\r\n\r\n    let response;\r\n    switch (method) {\r\n      case 'put':\r\n        response = await this.halClient.put(uri, formValues, FormsResource, ProblemDetails, header);\r\n        break;\r\n      case 'post':\r\n        response = await this.halClient.post(uri, formValues, FormsResource, ProblemDetails, header);\r\n        break;\r\n      default:\r\n        response = await this.halClient.get(uri, FormsResource, ProblemDetails, header);\r\n    }\r\n\r\n    return response;\r\n\r\n  }\r\n\r\n  public async delete(resource: Resource): Promise<HttpResponse<void | ProblemDetails>> {\r\n    const deleteLink = resource.findLink('delete');\r\n    if (!deleteLink)\r\n      throw new Error(`The resource ${resource} does not have a delete link.`);\r\n    const uri = deleteLink.href;\r\n    const header = RESTworldClient.createHeaders('application/hal+json', this._options.Version);\r\n\r\n    const response = await this.halClient.delete(uri, ProblemDetails, header);\r\n\r\n    return response;\r\n  }\r\n\r\n  public getAllLinksFromHome(): { [rel: string]: Link[] | undefined; } {\r\n    if (!this._homeResource)\r\n      throw new Error('Home resource is not set. Call ensureHomeResourceIsSet() first.');\r\n\r\n    return this._homeResource._links;\r\n  }\r\n\r\n  public getLinkFromHome(rel: string, name?: string, curie?: string): Link {\r\n    const links = this.getLinksFromHome(rel, curie);\r\n\r\n    const link = name ? links.find(l => l.name === name) : links[0];\r\n\r\n    if (!link)\r\n      throw new Error(`The home resource does not have a link with the rel '${this.getFullRel(rel, curie)}' and the name '${name}'.`);\r\n\r\n    return link;\r\n  }\r\n\r\n  public getLinksFromHome(rel: string, curie?: string): Link[] {\r\n    if (!this._homeResource)\r\n      throw new Error('Home resource is not set. Call ensureHomeResourceIsSet() first.');\r\n\r\n    const fullRel = this.getFullRel(rel, curie);\r\n    const links = this._homeResource._links[fullRel];\r\n    if (!links || links.length === 0)\r\n      throw Error(`The home resource does not have a link with the rel '${fullRel}'.`);\r\n\r\n    return links;\r\n  }\r\n\r\n  private getFullRel(rel: string, curie?: string): string {\r\n    // rel already includes a curie => just return it\r\n    if (rel.includes(':'))\r\n      return rel;\r\n\r\n    // No curie given => use default curie.\r\n    if (!curie)\r\n      curie = this._defaultCurie;\r\n\r\n    // Combine curie and rel\r\n    const fullRel = `${curie}:${rel}`;\r\n\r\n    return fullRel;\r\n  }\r\n\r\n  private static createHeaders(mediaType?: 'application/hal+json' | 'application/prs.hal-forms+json', version?: number): HttpHeaders {\r\n    if (version)\r\n      return new HttpHeaders({\r\n        'Accept': `${mediaType || 'application/hal+json'}; v=${version}`,\r\n        'Content-Type': `${mediaType || 'application/hal+json'}; v=${version}`\r\n      });\r\n    return new HttpHeaders();\r\n  }\r\n\r\n  private static combineHeaders(originalHeaders: HttpHeaders | undefined, headersToAdd: HttpHeaders | undefined, overwriteExisting: boolean) {\r\n    if (!headersToAdd)\r\n      return originalHeaders;\r\n    if (!originalHeaders)\r\n      return headersToAdd;\r\n\r\n    let combinedHeaders = originalHeaders;\r\n\r\n    for (const key in headersToAdd.keys) {\r\n      if (!combinedHeaders.has(key) || overwriteExisting) {\r\n        const headerValuesToAdd = headersToAdd.getAll(key);\r\n        if (headerValuesToAdd)\r\n          combinedHeaders = combinedHeaders.set(key, headerValuesToAdd);\r\n      }\r\n    }\r\n\r\n    return combinedHeaders;\r\n  }\r\n}\r\n"]}
|
|
214
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-client.js","sourceRoot":"","sources":["../../../../../projects/ngx-restworld-client/src/lib/services/restworld-client.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpHeaders, HttpResponse } from '@angular/common/http';\r\nimport * as _ from \"lodash\";\r\nimport { FormsResource, HalClient, Link, PagedListResource, Resource, ResourceDto, Template } from \"@wertzui/ngx-hal-client\";\r\nimport { LinkNames } from \"../constants/link-names\";\r\nimport { ProblemDetails } from \"../models/problem-details\";\r\nimport { RESTworldOptions } from \"../models/restworld-options\";\r\n\r\nexport class RESTworldClient {\r\n\r\n  private _homeResource?: Resource;\r\n  private _defaultCurie?: string;\r\n  public get halClient() {\r\n    return this._halClient;\r\n  }\r\n\r\n  constructor(\r\n    private _halClient: HalClient,\r\n    private _options: RESTworldOptions\r\n  ) { }\r\n\r\n  public async ensureHomeResourceIsSet(): Promise<void> {\r\n    if (!this._homeResource) {\r\n      const response = await this.getHomeForced();\r\n      if (ProblemDetails.isProblemDetails(response.body)) {\r\n        throw new Error(`Cannot get the home resource from ${this._options.BaseUrl} with Version ${this._options.Version}. Response was: ${response}`);\r\n      }\r\n      if (!response.body)\r\n        throw new Error(`Cannot get the home resource from ${this._options.BaseUrl} with Version ${this._options.Version}. Response was empty.`);\r\n      this._homeResource = response.body;\r\n      this.setDefaultCurie();\r\n    }\r\n  }\r\n\r\n  private async getHomeForced(): Promise<HttpResponse<Resource | ProblemDetails>> {\r\n    const header = RESTworldClient.createHeaders('application/hal+json', this._options.Version);\r\n    const response = await this.halClient.get(this._options.BaseUrl, Resource, ProblemDetails, header);\r\n    return response;\r\n  }\r\n\r\n  private setDefaultCurie(): void {\r\n    const curies = this._homeResource?._links?.curies;\r\n    if (!curies || curies.length === 0 || !curies[0])\r\n      this._defaultCurie = undefined;\r\n    else\r\n      this._defaultCurie = curies[0].name;\r\n  }\r\n\r\n  public async getList<TListDto extends ResourceDto>(rel: string, parameters: {}, headers?: HttpHeaders, curie?: string): Promise<HttpResponse<PagedListResource<TListDto> | ProblemDetails>> {\r\n    const link = this.getLinkFromHome(rel, LinkNames.getList, curie);\r\n    const uri = link.href\r\n\r\n    const response = await this.getListByUri<TListDto>(uri, parameters, headers);\r\n\r\n    return response;\r\n  }\r\n\r\n  public async getListByUri<TListDto extends ResourceDto>(uri: string, parameters: {}, headers?: HttpHeaders): Promise<HttpResponse<PagedListResource<TListDto> | ProblemDetails>> {\r\n    const link = new Link();\r\n    link.href = uri;\r\n    const filledUri = link.fillTemplate(parameters);\r\n    const defaultHeaders = RESTworldClient.createHeaders('application/hal+json', this._options.Version);\r\n    const combinedHeaders = RESTworldClient.combineHeaders(headers, defaultHeaders, false);\r\n\r\n    const response = await this.halClient.get<PagedListResource<TListDto>, ProblemDetails>(filledUri, PagedListResource, ProblemDetails, combinedHeaders);\r\n\r\n    return response;\r\n  }\r\n\r\n  public async getAllPagesFromList<TListDto extends ResourceDto>(rel: string, parameters: {}, headers?: HttpHeaders, curie?: string): Promise<HttpResponse<PagedListResource<TListDto> | ProblemDetails>> {\r\n    const link = this.getLinkFromHome(rel, LinkNames.getList, curie);\r\n    const uri = link.href;\r\n\r\n    const response = await this.getAllPagesFromListByUri<TListDto>(uri, parameters, headers);\r\n\r\n    return response;\r\n  }\r\n\r\n  public async getAllPagesFromListByUri<TListDto extends ResourceDto>(uri: string, parameters: {}, headers?: HttpHeaders): Promise<HttpResponse<PagedListResource<TListDto> | ProblemDetails>> {\r\n    const response = await this.getListByUri<TListDto>(uri, parameters, headers);\r\n\r\n    if (!response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body?._embedded?.items)\r\n      return response;\r\n\r\n\r\n    const items = response.body._embedded.items;\r\n    let lastResponse = response;\r\n\r\n    while ((lastResponse?.body?._links?.next?.length ?? 0) > 0) {\r\n      // Get the next response\r\n      const nextLinks = lastResponse.body?._links.next;\r\n      const nextLink = nextLinks ? nextLinks[0]: undefined;\r\n      const nextHref = nextLink?.href;\r\n      if (nextHref) {\r\n        lastResponse = await this.getListByUri<TListDto>(nextHref, parameters, headers);\r\n\r\n        if (!lastResponse.ok || ProblemDetails.isProblemDetails(lastResponse.body) || !lastResponse.body)\r\n          return lastResponse;\r\n\r\n        // Combine the embedded items\r\n        lastResponse.body?._embedded?.items?.forEach(r => items.push(r));\r\n      }\r\n    }\r\n\r\n    // We combined everything, so there is just one big page\r\n    response.body.totalPages = 1;\r\n    response.body._links.next = undefined;\r\n\r\n    return response;\r\n  }\r\n\r\n  public async getSingle(relOrUri: string, id?: number, headers?: HttpHeaders, curie?: string): Promise<HttpResponse<Resource | ProblemDetails>> {\r\n    let uri;\r\n    if (relOrUri.startsWith('http')) {\r\n      if (id !== undefined)\r\n        throw new Error('When supplying a URI, an ID cannot be supplied too.');\r\n      if (curie)\r\n        throw new Error('When supplying a URI, a curie cannot be supplied too.');\r\n\r\n      uri = relOrUri;\r\n    }\r\n    else {\r\n      if (!_.isNumber(id))\r\n        throw new Error('When supplying a rel, an ID must be supplied too.');\r\n\r\n      const link = this.getLinkFromHome(relOrUri, LinkNames.get, curie);\r\n      uri = link.fillTemplate({ id: id.toString() });\r\n    }\r\n\r\n    const defaultHeaders = RESTworldClient.createHeaders('application/hal+json', this._options.Version);\r\n    const combinedHeaders = RESTworldClient.combineHeaders(headers, defaultHeaders, false);\r\n    const response = await this.halClient.get(uri, Resource, ProblemDetails, combinedHeaders);\r\n\r\n    return response;\r\n  }\r\n\r\n  public async save(resource: Resource): Promise<HttpResponse<Resource | ProblemDetails>> {\r\n    const saveLink = resource.findLink('save');\r\n    if (!saveLink)\r\n      throw new Error(`The resource ${resource} does not have a save link.`);\r\n    if (!saveLink.name)\r\n      throw new Error(`The save link ${saveLink} does not have a save name.`);\r\n\r\n    const uri = saveLink.href;\r\n    const method = saveLink.name.toLowerCase();\r\n    const header = RESTworldClient.createHeaders('application/hal+json', this._options.Version);\r\n\r\n    let response;\r\n    switch (method) {\r\n      case 'put':\r\n        response = await this.halClient.put(uri, resource, Resource, ProblemDetails, header);\r\n        break;\r\n      case 'post':\r\n        response = await this.halClient.post(uri, resource, Resource, ProblemDetails, header);\r\n        break;\r\n      default:\r\n        throw new Error(`'${method}' is not allowed as link name for the save link. Only 'POST' and 'PUT' are allowed.`);\r\n    }\r\n\r\n    return response;\r\n  }\r\n\r\n  public async getAllForms(resource: Resource): Promise<HttpResponse<FormsResource | ProblemDetails>[]> {\r\n    const urls = resource.getFormLinkHrefs();\r\n    const header = RESTworldClient.createHeaders('application/prs.hal-forms+json', this._options.Version);\r\n    const formsPromises = urls.map(url => this._halClient.get(url, FormsResource, ProblemDetails, header));\r\n    const formsAndProblems = await Promise.all(formsPromises);\r\n    return formsAndProblems;\r\n  }\r\n\r\n  public async submit(template: Template, formValues: {}): Promise<HttpResponse<FormsResource | ProblemDetails>> {\r\n    const uri = template.target || '';\r\n    const method = template.method?.toLowerCase();\r\n    const header = RESTworldClient.createHeaders('application/prs.hal-forms+json', this._options.Version);\r\n\r\n    let response;\r\n    switch (method) {\r\n      case 'put':\r\n        response = await this.halClient.put(uri, formValues, FormsResource, ProblemDetails, header);\r\n        break;\r\n      case 'post':\r\n        response = await this.halClient.post(uri, formValues, FormsResource, ProblemDetails, header);\r\n        break;\r\n      default:\r\n        response = await this.halClient.get(uri, FormsResource, ProblemDetails, header);\r\n    }\r\n\r\n    return response;\r\n\r\n  }\r\n\r\n  public async delete(resource: Resource): Promise<HttpResponse<void | ProblemDetails>> {\r\n    const deleteLink = resource.findLink('delete');\r\n    if (!deleteLink)\r\n      throw new Error(`The resource ${resource} does not have a delete link.`);\r\n    const uri = deleteLink.href;\r\n    const header = RESTworldClient.createHeaders('application/hal+json', this._options.Version);\r\n\r\n    const response = await this.halClient.delete(uri, ProblemDetails, header);\r\n\r\n    return response;\r\n  }\r\n\r\n  public getAllLinksFromHome(): { [rel: string]: Link[] | undefined; } {\r\n    if (!this._homeResource)\r\n      throw new Error('Home resource is not set. Call ensureHomeResourceIsSet() first.');\r\n\r\n    return this._homeResource._links;\r\n  }\r\n\r\n  public getLinkFromHome(rel: string, name?: string, curie?: string): Link {\r\n    const links = this.getLinksFromHome(rel, curie);\r\n\r\n    const link = name ? links.find(l => l.name === name) : links[0];\r\n\r\n    if (!link)\r\n      throw new Error(`The home resource does not have a link with the rel '${this.getFullRel(rel, curie)}' and the name '${name}'.`);\r\n\r\n    return link;\r\n  }\r\n\r\n  public getLinksFromHome(rel: string, curie?: string): Link[] {\r\n    if (!this._homeResource)\r\n      throw new Error('Home resource is not set. Call ensureHomeResourceIsSet() first.');\r\n\r\n    const fullRel = this.getFullRel(rel, curie);\r\n    const links = this._homeResource._links[fullRel];\r\n    if (!links || links.length === 0)\r\n      throw Error(`The home resource does not have a link with the rel '${fullRel}'.`);\r\n\r\n    return links;\r\n  }\r\n\r\n  private getFullRel(rel: string, curie?: string): string {\r\n    // rel already includes a curie => just return it\r\n    if (rel.includes(':'))\r\n      return rel;\r\n\r\n    // No curie given => use default curie.\r\n    if (!curie)\r\n      curie = this._defaultCurie;\r\n\r\n    // Combine curie and rel\r\n    const fullRel = `${curie}:${rel}`;\r\n\r\n    return fullRel;\r\n  }\r\n\r\n  private static createHeaders(mediaType?: 'application/hal+json' | 'application/prs.hal-forms+json', version?: number): HttpHeaders {\r\n    if (version)\r\n      return new HttpHeaders({\r\n        'Accept': `${mediaType || 'application/hal+json'}; v=${version}`,\r\n        'Content-Type': `${mediaType || 'application/hal+json'}; v=${version}`\r\n      });\r\n    return new HttpHeaders();\r\n  }\r\n\r\n  private static combineHeaders(originalHeaders: HttpHeaders | undefined, headersToAdd: HttpHeaders | undefined, overwriteExisting: boolean) {\r\n    if (!headersToAdd)\r\n      return originalHeaders;\r\n    if (!originalHeaders)\r\n      return headersToAdd;\r\n\r\n    let combinedHeaders = originalHeaders;\r\n\r\n    for (const key in headersToAdd.keys) {\r\n      if (!combinedHeaders.has(key) || overwriteExisting) {\r\n        const headerValuesToAdd = headersToAdd.getAll(key);\r\n        if (headerValuesToAdd)\r\n          combinedHeaders = combinedHeaders.set(key, headerValuesToAdd);\r\n      }\r\n    }\r\n\r\n    return combinedHeaders;\r\n  }\r\n}\r\n"]}
|
|
@@ -79,7 +79,7 @@ export class RestworldEditFormComponent {
|
|
|
79
79
|
const maxIndex = Math.max(...Object.keys(property._templates)
|
|
80
80
|
.map(key => Number.parseInt(key))
|
|
81
81
|
.filter(key => Number.isSafeInteger(key)));
|
|
82
|
-
const nextIndex = maxIndex + 1;
|
|
82
|
+
const nextIndex = maxIndex < 0 ? 0 : maxIndex + 1;
|
|
83
83
|
const defaultTemplate = property._templates['default'];
|
|
84
84
|
const copiedTemplateDto = JSON.parse(JSON.stringify(defaultTemplate));
|
|
85
85
|
const copiedTemplate = new Template(copiedTemplateDto);
|
|
@@ -227,4 +227,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.5", ngImpor
|
|
|
227
227
|
type: ContentChild,
|
|
228
228
|
args: ['inputDefault', { static: false }]
|
|
229
229
|
}] } });
|
|
230
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-edit-form.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-edit-form/restworld-edit-form.component.ts","../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-edit-form/restworld-edit-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop } from '@angular/cdk/drag-drop';\r\nimport { OnInit } from '@angular/core';\r\nimport { ChangeDetectorRef } from '@angular/core';\r\nimport { Component, ContentChild, Input, TemplateRef } from '@angular/core';\nimport { AbstractControl, FormArray, FormGroup } from '@angular/forms';\r\nimport { Property, PropertyType, Resource, Template, TemplateDto } from '@wertzui/ngx-hal-client';\r\nimport { MessageService } from 'primeng/api';\r\nimport { ProblemDetails } from '../../models/problem-details';\r\nimport { FormService } from '../../services/form.service';\r\nimport { RESTworldClient } from '../../services/restworld-client';\r\nimport { RESTworldClientCollection } from '../../services/restworld-client-collection';\r\n\n@Component({\n  selector: 'rw-form',\n  templateUrl: './restworld-edit-form.component.html',\n  styleUrls: ['./restworld-edit-form.component.css']\n})\nexport class RestworldEditFormComponent implements OnInit {\n  @Input()\n  formGroup!: FormGroup;\n\n  @Input()\n  template!: Template;\n\n  @Input()\n  apiName?: string;\n\n  @ContentChild('inputOptionsSingle', { static: false })\n  inputOptionsSingleRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputOptionsMultiple', { static: false })\n  inputOptionsMultipleRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputOptions', { static: false })\n  inputOptionsRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputHidden', { static: false })\n  inputHiddenRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputText', { static: false })\n  inputTextRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputTextarea', { static: false })\n  inputTextareaRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputSearch', { static: false })\n  inputSearchRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputTel', { static: false })\n  inputTelRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputUrl', { static: false })\n  inputUrlRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputEmail', { static: false })\n  inputEmailRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputPassword', { static: false })\n  inputPasswordRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputDate', { static: false })\n  inputDateRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputMonth', { static: false })\n  inputMonthRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputWeek', { static: false })\n  inputWeekRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputTime', { static: false })\n  inputTimeRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputDatetimeLocal', { static: false })\n  inputDatetimeLocalRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputNumber', { static: false })\n  inputNumberRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputRange', { static: false })\n  inputRangeRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputColor', { static: false })\n  inputColorRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputBool', { static: false })\n  inputBoolRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputDatetimeOffset', { static: false })\n  inputDatetimeOffsetRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputDuration', { static: false })\n  inputDurationRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputImage', { static: false })\n  inputImageRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputFile', { static: false })\n  inputFileRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputObject', { static: false })\n  inputObjectRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputCollection', { static: false })\n  inputCollectionRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputDefault', { static: false })\n  inputDefaultRef?: TemplateRef<unknown>;\n\n  public get PropertyType() {\r\n    return PropertyType;\r\n  }\r\n\r\n  public get dateFormat(): string {\r\n    return new Date(3333, 10, 22)\r\n      .toLocaleDateString()\r\n      .replace(\"22\", \"dd\")\r\n      .replace(\"11\", \"mm\")\r\n      .replace(\"3333\", \"yy\")\r\n      .replace(\"33\", \"y\");\r\n  }\n\n  public FormGroup = FormGroup;\n  public FormArray = FormArray;\n  public Number = Number;\n\n  constructor(\n    private _formService: FormService,\n    private _changeDetectorRef: ChangeDetectorRef,\r\n    private _messageService: MessageService,\r\n    private _clients: RESTworldClientCollection\n  ) { }\n\n  ngOnInit(): void {\r\n    if (!this.formGroup)\r\n      throw new Error(\"[formGroup] is required on <rw-form>\");\r\n    if (!this.template)\r\n      throw new Error(\"[template] is required on <rw-form>\");\r\n    if (!this.apiName)\r\n      throw new Error(\"[apiName] is required on <rw-form>\");\r\n  }\r\n\n  public getTooltip(resource: Resource, keysToExclude?: string[]): string {\n    const tooltip = Object.entries(resource)\n      .filter(([key]) => !(key.startsWith('_') || ['createdAt', 'createdBy', 'lastChangedAt', 'lastChangedBy', 'timestamp'].includes(key) || keysToExclude?.includes(key)))\n      .reduce((prev, [key, value], index) => `${prev}${index === 0 ? '' : '\\n'}${key}: ${RestworldEditFormComponent.jsonStringifyWithElipsis(value)}`, '');\n\n    return tooltip;\n  }\n\n  private static jsonStringifyWithElipsis(value: unknown) {\n    const maxLength = 200;\n    const end = 10;\n    const start = maxLength - end - 2;\n    const json = JSON.stringify(value);\n    const shortened = json.length > maxLength ? json.substring(0, start) + '…' + json.substring(json.length - end) : json;\n\n    return shortened;\n  }\n\n  public getCollectionEntryTemplates(property?: Property): Template[] {\n    if (!property)\r\n      return [];\r\n\r\n    return Object.entries(property._templates)\r\n      .filter(([key,]) => Number.isInteger(Number.parseInt(key)))\r\n      .map(([, value]) => value);\r\n  }\n\n  public addNewItemToCollection(property: Property, formArray: FormArray | AbstractControl): void {\n    if (!(formArray instanceof FormArray))\n      throw new Error('formArray is not an instance of FormArray.');\r\n\r\n    const maxIndex = Math.max(...Object.keys(property._templates)\r\n      .map(key => Number.parseInt(key))\r\n      .filter(key => Number.isSafeInteger(key)));\r\n    const nextIndex = maxIndex + 1;\n\n    const defaultTemplate = property._templates['default'];\r\n    const copiedTemplateDto = JSON.parse(JSON.stringify(defaultTemplate)) as TemplateDto;\r\n    const copiedTemplate = new Template(copiedTemplateDto);\r\n    copiedTemplate.title = nextIndex.toString();\r\n\r\n    property._templates[copiedTemplate.title] = copiedTemplate;\r\n    formArray.push(this._formService.createFormGroupFromTemplate(defaultTemplate));\r\n  }\n\n  public deleteItemFromCollection(property: Property, formArray: FormArray | AbstractControl, template: Template): void {\n    if (!template.title)\n      throw new Error(`Cannot delete the item, because the template '${template}' does not have a title.`);\n\n    if (!(formArray instanceof FormArray))\n      throw new Error('formArray is not an instance of FormArray.');\n\n    const templates = property._templates;\r\n    delete templates[template.title];\r\n\r\n    formArray.removeAt(Number.parseInt(template.title));\r\n  }\n\n  public collectionItemDropped($event: CdkDragDrop<{ property: Property; formArray: FormArray }>) {\n    const formArray = $event.container.data.formArray;\r\n    const previousIndex = $event.previousIndex;\r\n    const currentIndex = $event.currentIndex;\r\n    const movementDirection = currentIndex > previousIndex ? 1 : -1;\r\n\r\n    // Move in FormArray\r\n    // We do not need to move the item in the _templates object\r\n    const movedControl = formArray.at(previousIndex);\r\n    for (let i = previousIndex; i * movementDirection < currentIndex * movementDirection; i = i + movementDirection) {\r\n      formArray.setControl(i, formArray.at(i + movementDirection));\r\n    }\r\n    formArray.setControl(currentIndex, movedControl);\r\n\r\n    this._changeDetectorRef.markForCheck();\r\n\r\n    console.log($event);\r\n  }\n\r\n\r\n  public async onOptionsFiltered(property: Property, event: { originalEvent: unknown; filter: string | null }) {\r\n    const options = property?.options;\r\n\r\n    if (!options?.link?.href || !event.filter || event.filter === '')\r\n      return;\r\n\r\n\r\n    const templatedUri = options.link.href;\r\n    let filter = `contains(${options.promptField}, '${event.filter}')`;\r\n    if (options.valueField?.toLowerCase() === 'id' && !Number.isNaN(Number.parseInt(event.filter)))\r\n      filter = `(${options.valueField} eq ${event.filter})  or (${filter})`;\r\n\r\n    const response = await this.getClient().getListByUri(templatedUri, { $filter: filter, $top: 10 });\r\n    if (!response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body) {\r\n      const message = `An error occurred while getting the filtered items.`;\r\n      this._messageService.add({ severity: 'error', summary: 'Error', detail: message, data: response });\r\n      return;\r\n    }\r\n\r\n    const items = response.body._embedded.items;\r\n    options.inline = items;\r\n  }\r\n\r\n  private getClient(): RESTworldClient {\r\n    if (!this.apiName)\r\n      throw new Error('Cannot get a client, because the apiName is not set.');\r\n\r\n    return this._clients.getClient(this.apiName);\r\n  }\n}\n","<div *ngFor=\"let property of template.properties\" class=\"grid field\" [formGroup]=\"formGroup\">\r\n  <label *ngIf=\"property.type !== PropertyType.Hidden\" [attr.for]=\"property.name\" class=\"col-12 mb-2 md:col-2 md:mb-0\" [class.p-disabled]=\"property.readOnly\" [class.hasChildren]=\"property._templates\">{{property.prompt || property.name}}</label>\r\n  <div class=\"col-12 md:col-10\">\r\n\r\n    <ng-template #defaultInputOptions let-property=\"property\" let-template=\"template\">\r\n\r\n      <ng-template #defaultInputOptionsSingle let-property=\"property\" let-template=\"template\">\r\n        <p-dropdown [formControlName]=\"property.name\" [id]=\"property.name\" [options]=\"property.options.inline\" [filterBy]=\"(property.options.promptField || 'prompt') + ',' + (property.options.valueField || 'value')\" [optionValue]=\"property.options.valueField || 'value'\" [readonly]=\"property.readOnly\" [required]=\"property.required || property.options.minItems > 0\" [filter]=\"true\" [autoDisplayFirst]=\"false\" [showClear]=\"!property.required || property.options.minItems <= 0\" (onFilter)=\"onOptionsFiltered(property, $event)\" styleClass=\"w-full\" [filterPlaceholder]=\"property?.options?.link?.href ? 'search for more results' : ''\">\r\n          <ng-template let-item pTemplate=\"selectedItem\">\r\n            <span [pTooltip]=\"getTooltip(item, [property.options.promptField || 'prompt', property.options.valueField || 'value'])\">{{item[property.options.promptField || 'prompt']}} ({{item[property.options.valueField || 'value']}})</span>\r\n          </ng-template>\r\n          <ng-template let-item pTemplate=\"item\">\r\n            <span [pTooltip]=\"getTooltip(item, [property.options.promptField || 'prompt', property.options.valueField || 'value'])\">{{item[property.options.promptField || 'prompt']}} ({{item[property.options.valueField || 'value']}})</span>\r\n          </ng-template>\r\n        </p-dropdown>\r\n      </ng-template>\r\n      <ng-container *ngIf=\"!property.options.maxItems || property.options.maxItems == 1\">\r\n        <ng-container *ngTemplateOutlet=\"inputOptionsSingleRef || defaultInputOptionsSingle; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n      </ng-container>\r\n\r\n      <ng-template #defaultInputOptionsMultiple let-property=\"property\" let-template=\"template\">\r\n        <p-multiSelect [formControlName]=\"property.name\" [id]=\"property.name\" [options]=\"property.options.inline\" [optionLabel]=\"property.options.promptField || 'prompt'\" [optionValue]=\"property.options.valueField || 'value'\" [readonly]=\"property.readOnly\" [selectionLimit]=\"property.options.maxItems\" [required]=\"property.required || property.options.minItems > 0\"></p-multiSelect>\r\n      </ng-template>\r\n      <ng-container *ngIf=\"property.options.maxItems > 1\">\r\n        <ng-container *ngTemplateOutlet=\"inputOptionsMultipleRef || defaultInputOptionsMultiple; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n      </ng-container>\r\n\r\n    </ng-template>\r\n    <ng-container *ngIf=\"property.options\">\r\n      <ng-container *ngTemplateOutlet=\"inputOptionsRef || defaultInputOptions; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n    </ng-container>\r\n\r\n    <div *ngIf=\"!property.options\">\r\n      <div [ngSwitch]=\"property.type\">\r\n\r\n        <ng-template #defaultInputHidden let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"hidden\" [value]=\"property.value\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Hidden\">\r\n          <ng-container *ngTemplateOutlet=\"inputHiddenRef || defaultInputHidden; context:{ property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n        <ng-template #defaultInputText let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"text\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Text\">\r\n          <ng-container *ngTemplateOutlet=\"inputTextRef || defaultInputText; context:{ property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputTextarea let-property=\"property\" let-template=\"template\">\r\n          <textarea [formControlName]=\"property.name\" [id]=\"property.name\" pInputTextarea class=\"w-full p-inputtextarea p-inputtext p-component p-element\" [class.p-disabled]=\"property.readOnly\" [cols]=\"property.cols\" [rows]=\"property.rows\"></textarea>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Textarea\">\r\n          <ng-container *ngTemplateOutlet=\"inputTextareaRef || defaultInputTextarea; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputSearch let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"search\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Search\">\r\n          <ng-container *ngTemplateOutlet=\"inputSearchRef || defaultInputSearch; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputTel let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"tel\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Tel\">\r\n          <ng-container *ngTemplateOutlet=\"inputTelRef || defaultInputTel; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputUrl let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"url\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Url\">\r\n          <ng-container *ngTemplateOutlet=\"inputUrlRef || defaultInputUrl; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputEmail let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"email\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Email\">\r\n          <ng-container *ngTemplateOutlet=\"inputEmailRef || defaultInputEmail; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputPassword let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"password\" pPassword class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Password\">\r\n          <ng-container *ngTemplateOutlet=\"inputPasswordRef || defaultInputPassword; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputDate let-property=\"property\" let-template=\"template\">\r\n          <p-calendar [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showWeek]=\"true\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Date\">\r\n          <ng-container *ngTemplateOutlet=\"inputDateRef || defaultInputDate; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputMonth let-property=\"property\" let-template=\"template\">\r\n          <p-calendar [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showWeek]=\"false\" view=\"month\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Month\">\r\n          <ng-container *ngTemplateOutlet=\"inputMonthRef || defaultInputMonth; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputWeek let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"week\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Week\">\r\n          <ng-container *ngTemplateOutlet=\"inputWeekRef || defaultInputWeek; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputTime let-property=\"property\" let-template=\"template\">\r\n          <p-calendar [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [timeOnly]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Time\">\r\n          <ng-container *ngTemplateOutlet=\"inputTimeRef || defaultInputTime; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputDatetimeLocal let-property=\"property\" let-template=\"template\">\r\n          <p-calendar [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.DatetimeLocal\">\r\n          <ng-container *ngTemplateOutlet=\"inputDatetimeLocalRef || defaultInputDatetimeLocal; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputNumber let-property=\"property\" let-template=\"template\">\r\n          <p-inputNumber [formControlName]=\"property.name\" [id]=\"property.name\" mode=\"decimal\" [showButtons]=\"!property.readOnly\" class=\"w-full\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-inputNumber>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Number\">\r\n          <ng-container *ngTemplateOutlet=\"inputNumberRef || defaultInputNumber; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputRange let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"range\" [min]=\"property.min\" [max]=\"property.max\" [step]=\"property.step\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Range\">\r\n          <ng-container *ngTemplateOutlet=\"inputRangeRef || defaultInputRange; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputColor let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"color\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Color\">\r\n          <ng-container *ngTemplateOutlet=\"inputColorRef || defaultInputColor; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputBool let-property=\"property\" let-template=\"template\" let-formGroup=\"formGroup\">\r\n          <p-checkbox *ngIf=\"property.required\" [binary]=\"true\" [formControl]=\"formGroup.controls[property.name]\" [id]=\"property.name\" [readonly]=\"property.readOnly\"></p-checkbox>\r\n          <p-triStateCheckbox *ngIf=\"!property.required\" [formControl]=\"formGroup.controls[property.name]\" [id]=\"property.name\" [readonly]=\"property.readOnly\"></p-triStateCheckbox>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Bool\">\r\n          <ng-container *ngTemplateOutlet=\"inputBoolRef || defaultInputBool; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputDatetimeOffset let-property=\"property\" let-template=\"template\">\r\n          <p-calendar [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.DatetimeOffset\">\r\n          <ng-container *ngTemplateOutlet=\"inputDatetimeOffsetRef || defaultInputDatetimeOffset; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputDuration let-property=\"property\" let-template=\"template\">\r\n          <p-calendar *ngSwitchCase=\"PropertyType.Duration\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [timeOnly]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Duration\">\r\n          <ng-container *ngTemplateOutlet=\"inputDurationRef || defaultInputDuration; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputImage let-property=\"property\" let-template=\"template\">\r\n          <rw-image [formControlName]=\"property.name\" [accept]=\"property.placeholder\"></rw-image>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Image\">\r\n          <ng-container *ngTemplateOutlet=\"inputImageRef || defaultInputImage; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputFile let-property=\"property\" let-template=\"template\">\r\n          <rw-file [formControlName]=\"property.name\" [fileName]=\"property.name\" [accept]=\"property.placeholder\"></rw-file>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.File\">\r\n          <ng-container *ngTemplateOutlet=\"inputFileRef || defaultInputFile; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputObject let-property=\"property\" let-template=\"template\">\r\n          <div class=\"flex align-items-center\">\r\n            <div class=\"brace\">\r\n            </div>\r\n            <div class=\"w-full\">\r\n              <rw-form [formGroup]=\"(formGroup.controls[property.name] | as : FormGroup)\" [template]=\"property._templates.default\" [apiName]=\"apiName\"></rw-form>\r\n            </div>\r\n          </div>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Object\">\r\n          <ng-container *ngTemplateOutlet=\"inputObjectRef || defaultInputObject; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputCollection let-property=\"property\" let-template=\"template\">\r\n          <div class=\"flex align-items-center\">\r\n            <div class=\"brace\">\r\n            </div>\r\n            <div class=\"w-full\" cdkDropList [cdkDropListData]=\"{ property: property, formArray: (formGroup.controls[property.name] | as : FormArray)}\" (cdkDropListDropped)=\"collectionItemDropped($event)\">\r\n              <div *ngFor=\"let template of getCollectionEntryTemplates(property)\" class=\"flex align-items-center\" cdkDrag>\r\n                <i class=\"fas fa-grip-lines\" cdkDragHandle></i>\r\n                <div class=\"brace\">\r\n                </div>\r\n                <div class=\"w-full flex justify-content-end\">\r\n                  <rw-form [formGroup]=\"((formGroup.controls[property.name] | as : FormArray).controls[Number.parseInt(template.title!)] | as : FormGroup)\" [template]=\"template\" [apiName]=\"apiName\" class=\"w-full\"></rw-form>\r\n                  <button pButton pRipple type=\"button\" icon=\"fas fa-trash\" class=\"p-button-outlined p-button-danger ml-2 mb-3\" (click)=\"deleteItemFromCollection(property, formGroup.controls[property.name], template)\"></button>\r\n                </div>\r\n              </div>\r\n              <div class=\"flex justify-content-end w-full\">\r\n                <button pButton pRipple type=\"button\" icon=\"fas fa-plus\" class=\"p-button-outlined p-button-info\" (click)=\"addNewItemToCollection(property, formGroup.controls[property.name])\"></button>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Collection\">\r\n          <ng-container *ngTemplateOutlet=\"inputCollectionRef || defaultInputCollection; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputDefault let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"text\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchDefault>\r\n          <ng-container *ngTemplateOutlet=\"inputDefaultRef || defaultInputDefault; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n      </div>\r\n    </div>\r\n    <val-errors [controlName]=\"property.name || null\">\r\n      <ng-template valError=\"required\">The field '{{property.prompt || property.name}}' is required.</ng-template>\r\n      <ng-template valError=\"email\">The email must be a valid email address.</ng-template>\r\n      <ng-template valError=\"min\" let-error=\"error\">'{{property.prompt || property.name}}' must be equal or greater than or equal to {{ error.min }}.</ng-template>\r\n      <ng-template valError=\"max\" let-error=\"error\">'{{property.prompt || property.name}}' must be smaller than or equal to {{ error.max }}.</ng-template>\r\n      <ng-template valError=\"minlength\" let-error=\"error\">The length of '{{property.prompt || property.name}}' must be equal or greater than or equal to {{ error.requiredLength }}.</ng-template>\r\n      <ng-template valError=\"maxlength\" let-error=\"error\">The length of '{{property.prompt || property.name}}' must be shorter than or equal to {{ error.requiredLength }}.</ng-template>\r\n      <ng-template valError=\"pattern\" let-error=\"error\">The value for '{{property.prompt || property.name}}' does not match the pattern {{ error }}.</ng-template>\r\n      <ng-template valError=\"remote\" let-error=\"error\">{{ error }}</ng-template>\r\n    </val-errors>\r\n  </div>\r\n</div>\r\n"]}
|
|
230
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restworld-edit-form.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-edit-form/restworld-edit-form.component.ts","../../../../../../projects/ngx-restworld-client/src/lib/views/restworld-edit-form/restworld-edit-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop } from '@angular/cdk/drag-drop';\r\nimport { OnInit } from '@angular/core';\r\nimport { ChangeDetectorRef } from '@angular/core';\r\nimport { Component, ContentChild, Input, TemplateRef } from '@angular/core';\nimport { AbstractControl, FormArray, FormGroup } from '@angular/forms';\r\nimport { Property, PropertyType, Resource, Template, TemplateDto } from '@wertzui/ngx-hal-client';\r\nimport { MessageService } from 'primeng/api';\r\nimport { ProblemDetails } from '../../models/problem-details';\r\nimport { FormService } from '../../services/form.service';\r\nimport { RESTworldClient } from '../../services/restworld-client';\r\nimport { RESTworldClientCollection } from '../../services/restworld-client-collection';\r\n\n@Component({\n  selector: 'rw-form',\n  templateUrl: './restworld-edit-form.component.html',\n  styleUrls: ['./restworld-edit-form.component.css']\n})\nexport class RestworldEditFormComponent implements OnInit {\n  @Input()\n  formGroup!: FormGroup;\n\n  @Input()\n  template!: Template;\n\n  @Input()\n  apiName?: string;\n\n  @ContentChild('inputOptionsSingle', { static: false })\n  inputOptionsSingleRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputOptionsMultiple', { static: false })\n  inputOptionsMultipleRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputOptions', { static: false })\n  inputOptionsRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputHidden', { static: false })\n  inputHiddenRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputText', { static: false })\n  inputTextRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputTextarea', { static: false })\n  inputTextareaRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputSearch', { static: false })\n  inputSearchRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputTel', { static: false })\n  inputTelRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputUrl', { static: false })\n  inputUrlRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputEmail', { static: false })\n  inputEmailRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputPassword', { static: false })\n  inputPasswordRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputDate', { static: false })\n  inputDateRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputMonth', { static: false })\n  inputMonthRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputWeek', { static: false })\n  inputWeekRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputTime', { static: false })\n  inputTimeRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputDatetimeLocal', { static: false })\n  inputDatetimeLocalRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputNumber', { static: false })\n  inputNumberRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputRange', { static: false })\n  inputRangeRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputColor', { static: false })\n  inputColorRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputBool', { static: false })\n  inputBoolRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputDatetimeOffset', { static: false })\n  inputDatetimeOffsetRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputDuration', { static: false })\n  inputDurationRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputImage', { static: false })\n  inputImageRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputFile', { static: false })\n  inputFileRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputObject', { static: false })\n  inputObjectRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputCollection', { static: false })\n  inputCollectionRef?: TemplateRef<unknown>;\n\n  @ContentChild('inputDefault', { static: false })\n  inputDefaultRef?: TemplateRef<unknown>;\n\n  public get PropertyType() {\r\n    return PropertyType;\r\n  }\r\n\r\n  public get dateFormat(): string {\r\n    return new Date(3333, 10, 22)\r\n      .toLocaleDateString()\r\n      .replace(\"22\", \"dd\")\r\n      .replace(\"11\", \"mm\")\r\n      .replace(\"3333\", \"yy\")\r\n      .replace(\"33\", \"y\");\r\n  }\n\n  public FormGroup = FormGroup;\n  public FormArray = FormArray;\n  public Number = Number;\n\n  constructor(\n    private _formService: FormService,\n    private _changeDetectorRef: ChangeDetectorRef,\r\n    private _messageService: MessageService,\r\n    private _clients: RESTworldClientCollection\n  ) { }\n\n  ngOnInit(): void {\r\n    if (!this.formGroup)\r\n      throw new Error(\"[formGroup] is required on <rw-form>\");\r\n    if (!this.template)\r\n      throw new Error(\"[template] is required on <rw-form>\");\r\n    if (!this.apiName)\r\n      throw new Error(\"[apiName] is required on <rw-form>\");\r\n  }\r\n\n  public getTooltip(resource: Resource, keysToExclude?: string[]): string {\n    const tooltip = Object.entries(resource)\n      .filter(([key]) => !(key.startsWith('_') || ['createdAt', 'createdBy', 'lastChangedAt', 'lastChangedBy', 'timestamp'].includes(key) || keysToExclude?.includes(key)))\n      .reduce((prev, [key, value], index) => `${prev}${index === 0 ? '' : '\\n'}${key}: ${RestworldEditFormComponent.jsonStringifyWithElipsis(value)}`, '');\n\n    return tooltip;\n  }\n\n  private static jsonStringifyWithElipsis(value: unknown) {\n    const maxLength = 200;\n    const end = 10;\n    const start = maxLength - end - 2;\n    const json = JSON.stringify(value);\n    const shortened = json.length > maxLength ? json.substring(0, start) + '…' + json.substring(json.length - end) : json;\n\n    return shortened;\n  }\n\n  public getCollectionEntryTemplates(property?: Property): Template[] {\n    if (!property)\r\n      return [];\r\n\r\n    return Object.entries(property._templates)\r\n      .filter(([key,]) => Number.isInteger(Number.parseInt(key)))\r\n      .map(([, value]) => value);\r\n  }\n\n  public addNewItemToCollection(property: Property, formArray: FormArray | AbstractControl): void {\n    if (!(formArray instanceof FormArray))\n      throw new Error('formArray is not an instance of FormArray.');\r\n\r\n    const maxIndex = Math.max(...Object.keys(property._templates)\r\n      .map(key => Number.parseInt(key))\r\n      .filter(key => Number.isSafeInteger(key)));\r\n    const nextIndex = maxIndex < 0 ? 0 : maxIndex + 1;\n\n    const defaultTemplate = property._templates['default'];\r\n    const copiedTemplateDto = JSON.parse(JSON.stringify(defaultTemplate)) as TemplateDto;\r\n    const copiedTemplate = new Template(copiedTemplateDto);\r\n    copiedTemplate.title = nextIndex.toString();\r\n\r\n    property._templates[copiedTemplate.title] = copiedTemplate;\r\n    formArray.push(this._formService.createFormGroupFromTemplate(defaultTemplate));\r\n  }\n\n  public deleteItemFromCollection(property: Property, formArray: FormArray | AbstractControl, template: Template): void {\n    if (!template.title)\n      throw new Error(`Cannot delete the item, because the template '${template}' does not have a title.`);\n\n    if (!(formArray instanceof FormArray))\n      throw new Error('formArray is not an instance of FormArray.');\n\n    const templates = property._templates;\r\n    delete templates[template.title];\r\n\r\n    formArray.removeAt(Number.parseInt(template.title));\r\n  }\n\n  public collectionItemDropped($event: CdkDragDrop<{ property: Property; formArray: FormArray }>) {\n    const formArray = $event.container.data.formArray;\r\n    const previousIndex = $event.previousIndex;\r\n    const currentIndex = $event.currentIndex;\r\n    const movementDirection = currentIndex > previousIndex ? 1 : -1;\r\n\r\n    // Move in FormArray\r\n    // We do not need to move the item in the _templates object\r\n    const movedControl = formArray.at(previousIndex);\r\n    for (let i = previousIndex; i * movementDirection < currentIndex * movementDirection; i = i + movementDirection) {\r\n      formArray.setControl(i, formArray.at(i + movementDirection));\r\n    }\r\n    formArray.setControl(currentIndex, movedControl);\r\n\r\n    this._changeDetectorRef.markForCheck();\r\n\r\n    console.log($event);\r\n  }\n\r\n\r\n  public async onOptionsFiltered(property: Property, event: { originalEvent: unknown; filter: string | null }) {\r\n    const options = property?.options;\r\n\r\n    if (!options?.link?.href || !event.filter || event.filter === '')\r\n      return;\r\n\r\n\r\n    const templatedUri = options.link.href;\r\n    let filter = `contains(${options.promptField}, '${event.filter}')`;\r\n    if (options.valueField?.toLowerCase() === 'id' && !Number.isNaN(Number.parseInt(event.filter)))\r\n      filter = `(${options.valueField} eq ${event.filter})  or (${filter})`;\r\n\r\n    const response = await this.getClient().getListByUri(templatedUri, { $filter: filter, $top: 10 });\r\n    if (!response.ok || ProblemDetails.isProblemDetails(response.body) || !response.body) {\r\n      const message = `An error occurred while getting the filtered items.`;\r\n      this._messageService.add({ severity: 'error', summary: 'Error', detail: message, data: response });\r\n      return;\r\n    }\r\n\r\n    const items = response.body._embedded.items;\r\n    options.inline = items;\r\n  }\r\n\r\n  private getClient(): RESTworldClient {\r\n    if (!this.apiName)\r\n      throw new Error('Cannot get a client, because the apiName is not set.');\r\n\r\n    return this._clients.getClient(this.apiName);\r\n  }\n}\n","<div *ngFor=\"let property of template.properties\" class=\"grid field\" [formGroup]=\"formGroup\">\r\n  <label *ngIf=\"property.type !== PropertyType.Hidden\" [attr.for]=\"property.name\" class=\"col-12 mb-2 md:col-2 md:mb-0\" [class.p-disabled]=\"property.readOnly\" [class.hasChildren]=\"property._templates\">{{property.prompt || property.name}}</label>\r\n  <div class=\"col-12 md:col-10\">\r\n\r\n    <ng-template #defaultInputOptions let-property=\"property\" let-template=\"template\">\r\n\r\n      <ng-template #defaultInputOptionsSingle let-property=\"property\" let-template=\"template\">\r\n        <p-dropdown [formControlName]=\"property.name\" [id]=\"property.name\" [options]=\"property.options.inline\" [filterBy]=\"(property.options.promptField || 'prompt') + ',' + (property.options.valueField || 'value')\" [optionValue]=\"property.options.valueField || 'value'\" [readonly]=\"property.readOnly\" [required]=\"property.required || property.options.minItems > 0\" [filter]=\"true\" [autoDisplayFirst]=\"false\" [showClear]=\"!property.required || property.options.minItems <= 0\" (onFilter)=\"onOptionsFiltered(property, $event)\" styleClass=\"w-full\" [filterPlaceholder]=\"property?.options?.link?.href ? 'search for more results' : ''\">\r\n          <ng-template let-item pTemplate=\"selectedItem\">\r\n            <span [pTooltip]=\"getTooltip(item, [property.options.promptField || 'prompt', property.options.valueField || 'value'])\">{{item[property.options.promptField || 'prompt']}} ({{item[property.options.valueField || 'value']}})</span>\r\n          </ng-template>\r\n          <ng-template let-item pTemplate=\"item\">\r\n            <span [pTooltip]=\"getTooltip(item, [property.options.promptField || 'prompt', property.options.valueField || 'value'])\">{{item[property.options.promptField || 'prompt']}} ({{item[property.options.valueField || 'value']}})</span>\r\n          </ng-template>\r\n        </p-dropdown>\r\n      </ng-template>\r\n      <ng-container *ngIf=\"!property.options.maxItems || property.options.maxItems == 1\">\r\n        <ng-container *ngTemplateOutlet=\"inputOptionsSingleRef || defaultInputOptionsSingle; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n      </ng-container>\r\n\r\n      <ng-template #defaultInputOptionsMultiple let-property=\"property\" let-template=\"template\">\r\n        <p-multiSelect [formControlName]=\"property.name\" [id]=\"property.name\" [options]=\"property.options.inline\" [optionLabel]=\"property.options.promptField || 'prompt'\" [optionValue]=\"property.options.valueField || 'value'\" [readonly]=\"property.readOnly\" [selectionLimit]=\"property.options.maxItems\" [required]=\"property.required || property.options.minItems > 0\"></p-multiSelect>\r\n      </ng-template>\r\n      <ng-container *ngIf=\"property.options.maxItems > 1\">\r\n        <ng-container *ngTemplateOutlet=\"inputOptionsMultipleRef || defaultInputOptionsMultiple; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n      </ng-container>\r\n\r\n    </ng-template>\r\n    <ng-container *ngIf=\"property.options\">\r\n      <ng-container *ngTemplateOutlet=\"inputOptionsRef || defaultInputOptions; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n    </ng-container>\r\n\r\n    <div *ngIf=\"!property.options\">\r\n      <div [ngSwitch]=\"property.type\">\r\n\r\n        <ng-template #defaultInputHidden let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"hidden\" [value]=\"property.value\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Hidden\">\r\n          <ng-container *ngTemplateOutlet=\"inputHiddenRef || defaultInputHidden; context:{ property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n        <ng-template #defaultInputText let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"text\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Text\">\r\n          <ng-container *ngTemplateOutlet=\"inputTextRef || defaultInputText; context:{ property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputTextarea let-property=\"property\" let-template=\"template\">\r\n          <textarea [formControlName]=\"property.name\" [id]=\"property.name\" pInputTextarea class=\"w-full p-inputtextarea p-inputtext p-component p-element\" [class.p-disabled]=\"property.readOnly\" [cols]=\"property.cols\" [rows]=\"property.rows\"></textarea>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Textarea\">\r\n          <ng-container *ngTemplateOutlet=\"inputTextareaRef || defaultInputTextarea; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputSearch let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"search\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Search\">\r\n          <ng-container *ngTemplateOutlet=\"inputSearchRef || defaultInputSearch; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputTel let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"tel\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Tel\">\r\n          <ng-container *ngTemplateOutlet=\"inputTelRef || defaultInputTel; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputUrl let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"url\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Url\">\r\n          <ng-container *ngTemplateOutlet=\"inputUrlRef || defaultInputUrl; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputEmail let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"email\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Email\">\r\n          <ng-container *ngTemplateOutlet=\"inputEmailRef || defaultInputEmail; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputPassword let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"password\" pPassword class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Password\">\r\n          <ng-container *ngTemplateOutlet=\"inputPasswordRef || defaultInputPassword; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputDate let-property=\"property\" let-template=\"template\">\r\n          <p-calendar [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showWeek]=\"true\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Date\">\r\n          <ng-container *ngTemplateOutlet=\"inputDateRef || defaultInputDate; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputMonth let-property=\"property\" let-template=\"template\">\r\n          <p-calendar [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showWeek]=\"false\" view=\"month\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Month\">\r\n          <ng-container *ngTemplateOutlet=\"inputMonthRef || defaultInputMonth; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputWeek let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"week\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Week\">\r\n          <ng-container *ngTemplateOutlet=\"inputWeekRef || defaultInputWeek; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputTime let-property=\"property\" let-template=\"template\">\r\n          <p-calendar [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [timeOnly]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Time\">\r\n          <ng-container *ngTemplateOutlet=\"inputTimeRef || defaultInputTime; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputDatetimeLocal let-property=\"property\" let-template=\"template\">\r\n          <p-calendar [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.DatetimeLocal\">\r\n          <ng-container *ngTemplateOutlet=\"inputDatetimeLocalRef || defaultInputDatetimeLocal; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputNumber let-property=\"property\" let-template=\"template\">\r\n          <p-inputNumber [formControlName]=\"property.name\" [id]=\"property.name\" mode=\"decimal\" [showButtons]=\"!property.readOnly\" class=\"w-full\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-inputNumber>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Number\">\r\n          <ng-container *ngTemplateOutlet=\"inputNumberRef || defaultInputNumber; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputRange let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"range\" [min]=\"property.min\" [max]=\"property.max\" [step]=\"property.step\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Range\">\r\n          <ng-container *ngTemplateOutlet=\"inputRangeRef || defaultInputRange; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputColor let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"color\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Color\">\r\n          <ng-container *ngTemplateOutlet=\"inputColorRef || defaultInputColor; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputBool let-property=\"property\" let-template=\"template\" let-formGroup=\"formGroup\">\r\n          <p-checkbox *ngIf=\"property.required\" [binary]=\"true\" [formControl]=\"formGroup.controls[property.name]\" [id]=\"property.name\" [readonly]=\"property.readOnly\"></p-checkbox>\r\n          <p-triStateCheckbox *ngIf=\"!property.required\" [formControl]=\"formGroup.controls[property.name]\" [id]=\"property.name\" [readonly]=\"property.readOnly\"></p-triStateCheckbox>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Bool\">\r\n          <ng-container *ngTemplateOutlet=\"inputBoolRef || defaultInputBool; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputDatetimeOffset let-property=\"property\" let-template=\"template\">\r\n          <p-calendar [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.DatetimeOffset\">\r\n          <ng-container *ngTemplateOutlet=\"inputDatetimeOffsetRef || defaultInputDatetimeOffset; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputDuration let-property=\"property\" let-template=\"template\">\r\n          <p-calendar *ngSwitchCase=\"PropertyType.Duration\" [formControlName]=\"property.name\" [id]=\"property.name\" [dateFormat]=\"dateFormat\" [showTime]=\"true\" [timeOnly]=\"true\" [showWeek]=\"false\" [showIcon]=\"true\" styleClass=\"w-full\" [class.p-disabled]=\"property.readOnly\"></p-calendar>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Duration\">\r\n          <ng-container *ngTemplateOutlet=\"inputDurationRef || defaultInputDuration; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputImage let-property=\"property\" let-template=\"template\">\r\n          <rw-image [formControlName]=\"property.name\" [accept]=\"property.placeholder\"></rw-image>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Image\">\r\n          <ng-container *ngTemplateOutlet=\"inputImageRef || defaultInputImage; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputFile let-property=\"property\" let-template=\"template\">\r\n          <rw-file [formControlName]=\"property.name\" [fileName]=\"property.name\" [accept]=\"property.placeholder\"></rw-file>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.File\">\r\n          <ng-container *ngTemplateOutlet=\"inputFileRef || defaultInputFile; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputObject let-property=\"property\" let-template=\"template\">\r\n          <div class=\"flex align-items-center\">\r\n            <div class=\"brace\">\r\n            </div>\r\n            <div class=\"w-full\">\r\n              <rw-form [formGroup]=\"(formGroup.controls[property.name] | as : FormGroup)\" [template]=\"property._templates.default\" [apiName]=\"apiName\"></rw-form>\r\n            </div>\r\n          </div>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Object\">\r\n          <ng-container *ngTemplateOutlet=\"inputObjectRef || defaultInputObject; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputCollection let-property=\"property\" let-template=\"template\">\r\n          <div class=\"flex align-items-center\">\r\n            <div class=\"brace\">\r\n            </div>\r\n            <div class=\"w-full\" cdkDropList [cdkDropListData]=\"{ property: property, formArray: (formGroup.controls[property.name] | as : FormArray)}\" (cdkDropListDropped)=\"collectionItemDropped($event)\">\r\n              <div *ngFor=\"let template of getCollectionEntryTemplates(property)\" class=\"flex align-items-center\" cdkDrag>\r\n                <i class=\"fas fa-grip-lines\" cdkDragHandle></i>\r\n                <div class=\"brace\">\r\n                </div>\r\n                <div class=\"w-full flex justify-content-end\">\r\n                  <rw-form [formGroup]=\"((formGroup.controls[property.name] | as : FormArray).controls[Number.parseInt(template.title!)] | as : FormGroup)\" [template]=\"template\" [apiName]=\"apiName\" class=\"w-full\"></rw-form>\r\n                  <button pButton pRipple type=\"button\" icon=\"fas fa-trash\" class=\"p-button-outlined p-button-danger ml-2 mb-3\" (click)=\"deleteItemFromCollection(property, formGroup.controls[property.name], template)\"></button>\r\n                </div>\r\n              </div>\r\n              <div class=\"flex justify-content-end w-full\">\r\n                <button pButton pRipple type=\"button\" icon=\"fas fa-plus\" class=\"p-button-outlined p-button-info\" (click)=\"addNewItemToCollection(property, formGroup.controls[property.name])\"></button>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </ng-template>\r\n        <ng-container *ngSwitchCase=\"PropertyType.Collection\">\r\n          <ng-container *ngTemplateOutlet=\"inputCollectionRef || defaultInputCollection; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <ng-template #defaultInputDefault let-property=\"property\" let-template=\"template\">\r\n          <input [formControlName]=\"property.name\" [id]=\"property.name\" type=\"text\" pInputText class=\"w-full\" [class.p-disabled]=\"property.readOnly\" />\r\n        </ng-template>\r\n        <ng-container *ngSwitchDefault>\r\n          <ng-container *ngTemplateOutlet=\"inputDefaultRef || defaultInputDefault; context: { property: property, template: template, formGroup: formGroup, apiName: apiName }\"></ng-container>\r\n        </ng-container>\r\n\r\n      </div>\r\n    </div>\r\n    <val-errors [controlName]=\"property.name || null\">\r\n      <ng-template valError=\"required\">The field '{{property.prompt || property.name}}' is required.</ng-template>\r\n      <ng-template valError=\"email\">The email must be a valid email address.</ng-template>\r\n      <ng-template valError=\"min\" let-error=\"error\">'{{property.prompt || property.name}}' must be equal or greater than or equal to {{ error.min }}.</ng-template>\r\n      <ng-template valError=\"max\" let-error=\"error\">'{{property.prompt || property.name}}' must be smaller than or equal to {{ error.max }}.</ng-template>\r\n      <ng-template valError=\"minlength\" let-error=\"error\">The length of '{{property.prompt || property.name}}' must be equal or greater than or equal to {{ error.requiredLength }}.</ng-template>\r\n      <ng-template valError=\"maxlength\" let-error=\"error\">The length of '{{property.prompt || property.name}}' must be shorter than or equal to {{ error.requiredLength }}.</ng-template>\r\n      <ng-template valError=\"pattern\" let-error=\"error\">The value for '{{property.prompt || property.name}}' does not match the pattern {{ error }}.</ng-template>\r\n      <ng-template valError=\"remote\" let-error=\"error\">{{ error }}</ng-template>\r\n    </val-errors>\r\n  </div>\r\n</div>\r\n"]}
|