xref: /aosp_15_r20/external/perfetto/ui/src/widgets/text_paragraph.ts (revision 6dbdd20afdafa5e3ca9b8809fa73465d530080dc)
1*6dbdd20aSAndroid Build Coastguard Worker// Copyright (C) 2023 The Android Open Source Project
2*6dbdd20aSAndroid Build Coastguard Worker//
3*6dbdd20aSAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License");
4*6dbdd20aSAndroid Build Coastguard Worker// you may not use this file except in compliance with the License.
5*6dbdd20aSAndroid Build Coastguard Worker// You may obtain a copy of the License at
6*6dbdd20aSAndroid Build Coastguard Worker//
7*6dbdd20aSAndroid Build Coastguard Worker//      http://www.apache.org/licenses/LICENSE-2.0
8*6dbdd20aSAndroid Build Coastguard Worker//
9*6dbdd20aSAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software
10*6dbdd20aSAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS,
11*6dbdd20aSAndroid Build Coastguard Worker// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*6dbdd20aSAndroid Build Coastguard Worker// See the License for the specific language governing permissions and
13*6dbdd20aSAndroid Build Coastguard Worker// limitations under the License.
14*6dbdd20aSAndroid Build Coastguard Worker
15*6dbdd20aSAndroid Build Coastguard Workerimport m from 'mithril';
16*6dbdd20aSAndroid Build Coastguard Workerimport {classNames} from '../base/classnames';
17*6dbdd20aSAndroid Build Coastguard Worker
18*6dbdd20aSAndroid Build Coastguard Workerexport interface TextParagraphAttrs {
19*6dbdd20aSAndroid Build Coastguard Worker  // Paragraph text.
20*6dbdd20aSAndroid Build Coastguard Worker  text: string;
21*6dbdd20aSAndroid Build Coastguard Worker  // Whether to compress multiple spaces (e.g. the string is multi-line but
22*6dbdd20aSAndroid Build Coastguard Worker  // should render with the default UI wrapping)
23*6dbdd20aSAndroid Build Coastguard Worker  compressSpace?: boolean;
24*6dbdd20aSAndroid Build Coastguard Worker}
25*6dbdd20aSAndroid Build Coastguard Worker
26*6dbdd20aSAndroid Build Coastguard Workerexport class TextParagraph implements m.ClassComponent<TextParagraphAttrs> {
27*6dbdd20aSAndroid Build Coastguard Worker  view({attrs}: m.CVnode<TextParagraphAttrs>) {
28*6dbdd20aSAndroid Build Coastguard Worker    let {text, compressSpace} = attrs;
29*6dbdd20aSAndroid Build Coastguard Worker    if (compressSpace === undefined) {
30*6dbdd20aSAndroid Build Coastguard Worker      compressSpace = true;
31*6dbdd20aSAndroid Build Coastguard Worker    }
32*6dbdd20aSAndroid Build Coastguard Worker    return m(
33*6dbdd20aSAndroid Build Coastguard Worker      `div.pf-text-paragraph`,
34*6dbdd20aSAndroid Build Coastguard Worker      compressSpace ? text.replace(/\s\s+/g, ' ') : text,
35*6dbdd20aSAndroid Build Coastguard Worker    );
36*6dbdd20aSAndroid Build Coastguard Worker  }
37*6dbdd20aSAndroid Build Coastguard Worker}
38*6dbdd20aSAndroid Build Coastguard Worker
39*6dbdd20aSAndroid Build Coastguard Workerinterface MultiParagraphTextAttrs {
40*6dbdd20aSAndroid Build Coastguard Worker  // Space delimited class list applied to element.
41*6dbdd20aSAndroid Build Coastguard Worker  className?: string;
42*6dbdd20aSAndroid Build Coastguard Worker}
43*6dbdd20aSAndroid Build Coastguard Worker
44*6dbdd20aSAndroid Build Coastguard Workerexport class MultiParagraphText
45*6dbdd20aSAndroid Build Coastguard Worker  implements m.ClassComponent<MultiParagraphTextAttrs>
46*6dbdd20aSAndroid Build Coastguard Worker{
47*6dbdd20aSAndroid Build Coastguard Worker  view({attrs, children}: m.Vnode<MultiParagraphTextAttrs>): m.Children {
48*6dbdd20aSAndroid Build Coastguard Worker    const {className = ''} = attrs;
49*6dbdd20aSAndroid Build Coastguard Worker
50*6dbdd20aSAndroid Build Coastguard Worker    const classes = classNames(className);
51*6dbdd20aSAndroid Build Coastguard Worker
52*6dbdd20aSAndroid Build Coastguard Worker    return m('div', {class: classes}, children);
53*6dbdd20aSAndroid Build Coastguard Worker  }
54*6dbdd20aSAndroid Build Coastguard Worker}
55