/* * Copyright 2020 Adobe * * 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 React, {MouseEvent} from 'react'; import {AbstractCoreComponent, CoreComponentState} from "../../../AbstractCoreComponent"; import {RoutedCoreComponentModel} from "../../../routing/RoutedCoreComponent"; import {RoutedLink} from "../../../routing/RoutedLink"; export interface ButtonV1Model extends RoutedCoreComponentModel{ text?: string; link?: string; icon?: string; ariaLabel?: string; handleOnClick?(event: MouseEvent): void } export function ButtonV1IsEmptyFn(props:ButtonV1Model): boolean{ return props.text == null || props.text.length === 0; } export class ButtonV1 extends AbstractCoreComponent { public static defaultProps = { isInEditor: false, hidePlaceHolder: false }; constructor(props:Model) { super(props, "cmp-button", "ButtonV1"); this.handleOnClick = this.handleOnClick.bind(this); } handleOnClick(event:MouseEvent){ if(this.props.handleOnClick){ this.props.handleOnClick(event); } } getContent(){ return ( <> { this.props.icon && } {this.props.text} ); } isEmpty(): boolean{ return ButtonV1IsEmptyFn(this.props); } renderComponent(){ const isLink = (!!this.props.link); let props = this.generateAttributes(isLink); if(isLink){ return }else{ return } } generateAttributes(isLink: boolean) { let props: any = { className: this.baseCssCls, onClick: this.handleOnClick }; if (isLink) { props['aria-label'] = this.props.ariaLabel; props['href'] = this.props.link; } return props; } };