import React from "react"; import styled from "styled-components"; import { ComponentProps } from "components/designSystems/appsmith/BaseComponent"; import { Checkbox, Classes } from "@blueprintjs/core"; import { BlueprintControlTransform } from "constants/DefaultTheme"; const CheckboxContainer = styled.div<{ isValid: boolean }>` && { width: 100%; height: 100%; display: flex; justify-content: flex-start; align-items: center; .bp3-control-indicator { border: ${(props) => !props.isValid ? `1px solid ${props.theme.colors.error} !important` : `1px solid transparent`}; } label { margin: 0; color: ${(props) => !props.isValid ? `${props.theme.colors.error}` : `inherit`}; } } ${BlueprintControlTransform} `; class CheckboxComponent extends React.Component { render() { return ( ); } onCheckChange = () => { this.props.onCheckChange(!this.props.isChecked); }; } export interface CheckboxComponentProps extends ComponentProps { label: string; isChecked: boolean; onCheckChange: (isChecked: boolean) => void; isLoading: boolean; isRequired?: boolean; } export default CheckboxComponent;