blob: f0c4adc13085da9b8d14d9db9e3f4c3d4b8bf269 [file] [log] [blame] [edit]
// Copyright (C) 2023 The Android Open Source Project
//
// 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 m from 'mithril';
import {classForIntent, HTMLAttrs, Intent} from './common';
import {Icon} from './icon';
import {classNames} from '../base/classnames';
interface CalloutAttrs extends HTMLAttrs {
// An icon to show to the left of the callout content.
readonly icon?: string;
// Color the callout by specifying an intent.
readonly intent?: Intent;
}
export class Callout implements m.ClassComponent<CalloutAttrs> {
view({attrs, children}: m.CVnode<CalloutAttrs>) {
const {icon, intent = Intent.None, className, ...htmlAttrs} = attrs;
return m(
'.pf-callout',
{
className: classNames(classForIntent(intent), className),
...htmlAttrs,
},
icon && m(Icon, {className: 'pf-left-icon', icon}),
m('span', children),
);
}
}