mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-12 17:04:57 +00:00
98 lines
3.5 KiB
TypeScript
98 lines
3.5 KiB
TypeScript
/*!
|
|
* @license
|
|
* Copyright 2019 Alfresco Software, Ltd.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
import { Type } from '@angular/core';
|
|
import { getType } from './get-type';
|
|
|
|
export interface DynamicComponentModel { type: string }
|
|
export type DynamicComponentResolveFunction = (model: DynamicComponentModel) => Type<any>;
|
|
export class DynamicComponentResolver {
|
|
static fromType(type: Type<any>): DynamicComponentResolveFunction {
|
|
return getType(type);
|
|
}
|
|
}
|
|
|
|
export abstract class DynamicComponentMapper {
|
|
|
|
protected defaultValue: Type<any> = undefined;
|
|
protected types: { [key: string]: DynamicComponentResolveFunction } = {};
|
|
|
|
/**
|
|
* Gets the currently active DynamicComponentResolveFunction for a field type.
|
|
*
|
|
* @param type The type whose resolver you want
|
|
* @param defaultValue Default type returned for types that are not yet mapped
|
|
* @returns Resolver function
|
|
*/
|
|
getComponentTypeResolver(type: string, defaultValue: Type<any> = this.defaultValue): DynamicComponentResolveFunction {
|
|
if (type) {
|
|
return this.types[type] || DynamicComponentResolver.fromType(defaultValue);
|
|
}
|
|
return DynamicComponentResolver.fromType(defaultValue);
|
|
}
|
|
|
|
/**
|
|
* Sets or optionally replaces a DynamicComponentResolveFunction for a field type.
|
|
*
|
|
* @param type The type whose resolver you want to set
|
|
* @param resolver The new resolver function
|
|
* @param override The new resolver will only replace an existing one if this parameter is true
|
|
*/
|
|
setComponentTypeResolver(type: string, resolver: DynamicComponentResolveFunction, override: boolean = true) {
|
|
if (!type) {
|
|
throw new Error(`type is null or not defined`);
|
|
}
|
|
|
|
if (!resolver) {
|
|
throw new Error(`resolver is null or not defined`);
|
|
}
|
|
|
|
const existing = this.types[type];
|
|
if (existing && !override) {
|
|
throw new Error(`already mapped, use override option if you intend replacing existing mapping.`);
|
|
}
|
|
|
|
this.types[type] = resolver;
|
|
}
|
|
|
|
/**
|
|
* Register multiple components
|
|
*/
|
|
register(components: { [key: string]: DynamicComponentResolveFunction }, override: boolean = false) {
|
|
if (components) {
|
|
for (const type of Object.keys(components)) {
|
|
this.setComponentTypeResolver(type, components[type], override);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Finds the component type that is needed to render a form field.
|
|
*
|
|
* @param model Form field model for the field to render
|
|
* @param defaultValue Default type returned for field types that are not yet mapped.
|
|
* @returns Component type
|
|
*/
|
|
resolveComponentType(model: DynamicComponentModel, defaultValue: Type<any> = this.defaultValue): Type<any> {
|
|
if (model) {
|
|
const resolver = this.getComponentTypeResolver(model.type, defaultValue);
|
|
return resolver(model);
|
|
}
|
|
return defaultValue;
|
|
}
|
|
}
|