Skip to content

Latest commit

 

History

History
665 lines (498 loc) · 16.4 KB

README.md

File metadata and controls

665 lines (498 loc) · 16.4 KB

Common UI components using FORGE UI

This is a quick reference and showcase of standard UI components using the Forge UI. For complete info, see Forge UI components developer documentation.

WHY?

  • It's common to think your Forge apps UI in terms of standard UI components(example: Carousel, Pagination, ...), but FORGE UI has very few components. It's an attempt to build standard UI components using FORGE UI
  • DON'T REINVENT THE WHEEL, use already existing standard UI pattern in your app.
  • LESS IS MORE, to show Forge UI components are sufficient to create most of the standard UI components.

Forge UI Design Principles

  1. Ease and speed over flexibility. Minimise options to stay lighting fast.
  2. Provide direction. Components are moleculer and composed and avoid minutiae

Table of Contents

Heading

It's tempting to think about heading with HTML header tags (h1 to h6). But, we need to understand Forge apps are embedded in the Atlassian products (JIRA, Confluence page ..,). Consider using strong text or emphasis text for important or header content.

Strong text

strong text demo

  <Text> **It's a strong text**</Text>
  <Text> __It's a strong text__</Text>

Forge UI components used

  1. Strong text with star and underscore

Emphasis text

emphasis text demo

  <Text> *It's a emphasis text*</Text>
  <Text> _It's a emphasis text_</Text>

Forge UI components used

  1. Emphasis text with star and underscore

Link

Link demo

<Text>
  [It's a link to my
  project](https://github.com/anilkk/ui-component-with-forge-ui)
</Text>

Forge UI components used

  1. Text with link markdown

List

Unordered list

Unordered list

<Text> - Item 1 </Text>
<Text> - Item 2 </Text>
<Text> - Item 3 </Text>
<Text> - Item 4 </Text>

Forge UI components used

  1. Text

Ordered list

Ordered list

<Text> 1. Item 1 </Text>
<Text> 2. Item 2 </Text>
<Text> 3. Item 3 </Text>
<Text> 4. Item 4 </Text>

Forge UI components used

  1. Text

Code

Code demo

<Text>{`<Text>sample text</Text>`}</Text>

Forge UI components used

  1. Text with markdown for code

Button

Button demo

<Button text="demo button" onClick={() => console.log('perform action')} />

Forge UI components used

  1. Button

ButtonSet

Link demo

<ButtonSet>
  <Button text="demo button 1" onClick={() => console.log('perform action')} />
  <Button text="demo button 2" onClick={() => console.log('perform action')} />
</ButtonSet>

Forge UI components used

  1. ButtonSet
  2. Button

Layout

Two columns

Two columns

<Table>
  <Row>
    <Cell>
      <Text>Column 1</Text>
    </Cell>
    <Cell>
      <Text>Column 2</Text>
    </Cell>
  </Row>
</Table>

Three columns

Three columns

<Table>
  <Row>
    <Cell>
      <Text>Column 1</Text>
    </Cell>
    <Cell>
      <Text>Column 2</Text>
    </Cell>
    <Cell>
      <Text>Column 3</Text>
    </Cell>
  </Row>
</Table>

Columns with spacing

columns with spacing demo

<Table>
  <Row>
    <Cell>
      <Text>Column 1</Text>
    </Cell>
    <Cell>
      <Text>Column 2</Text>
    </Cell>
    {/* Empty cells for spacing */}
    <Cell></Cell>
    <Cell></Cell>
    <Cell></Cell>
    <Cell></Cell>
    <Cell>
      <Text>Column 3</Text>
    </Cell>
  </Row>
</Table>

Forge UI components used

  1. Table

Note

  1. ⚠️ Be careful while using Table cells as a column, same UI is also rendred on the mobile apps.

Image

You don't have the option to style image(example: width and height). It's good practice to pass formatted images with right dimention and style.

Image demo

<Image
  src="https://images.unsplash.com/photo-1560969184-10fe8719e047?auto=format&fit=crop&w=1200&q=50"
  alt="Berlin"
/>

Thumbnail image

Thumbnail

<Image
  src="https://res.cloudinary.com/anilkumark/image/upload/c_thumb,w_200,g_face/v1589315094/projects/forge/ui-components/photo-1560969184-10fe8719e047_hfksqn.jpg"
  alt="Berlin"
/>

Round image

Thumbnail

<Image
  src="https://res.cloudinary.com/anilkumark/image/upload/w_1000,c_fill,ar_1:1,g_auto,r_max,bo_5px_solid_red,b_rgb:262c35/v1589315094/projects/forge/ui-components/photo-1560969184-10fe8719e047_hfksqn.jpg"
  alt="Berlin"
/>

Forge UI components used

  1. Image

Note

  1. You can't style using CSS and so use 3rd party services like cloudinary to customize your image if possible.

Icons

You can use a small Image component, or you can also use emoji as an icon with text.

Button text with icon emoji

<Button text="✅ button with emoji icon" />

Forge UI components used

  1. Image

Note

  1. You can find a collection of emojis on getemoji and emojipedia.

Carousel

Carousel demo

const [images] = useState(() => {
  // You can make API call here
  return imageUrls;
});
const [currentIndex, setCurrentIndex] = useState(0);
return (
  <Fragment>
    <Text>**Carousel demo**</Text>
    <Table>
      <Row>
        <Cell>
          <Button
            text="<"
            onClick={() => {
              setCurrentIndex(
                currentIndex === 0 ? images.length - 1 : currentIndex - 1
              );
            }}
          />
        </Cell>
        <Cell>
          <Image src={images[currentIndex]} />
        </Cell>
        <Cell>
          <Button
            text=">"
            onClick={() => {
              setCurrentIndex(
                currentIndex === images.length - 1 ? 0 : currentIndex + 1
              );
            }}
          />
        </Cell>
      </Row>
    </Table>
  </Fragment>
);

Forge UI components used

  1. Image
  2. Button
  3. Table

Forge UI hooks used

  1. useState

Note

  1. You may expect delay, and you don't have a smooth transition effect.

Video

It's not a video component; it's just a fallback with image and link.

forge tunnel debug

  <Image
    src="https://res.cloudinary.com/anilkumark/image/upload/v1589197328/projects/forge/ui-components/Group_4_3_w6zihu.png"
    alt="forge tunnel debug"
  />
  <Text>
    [**Play Demo of Forge tunnel debug ▶️**](https://youtu.be/1AlzjCsczV4)
  </Text>

Forge UI components used

  1. Image
  2. Text with link markdown

Note

  1. Yes, it's not a video component, it's just a fallback with image and link.

Collapse

collapse

const [isOpen, setIsOpen] = useState(false);
<Button
  text="Toggle text view"
  onClick={() => {
    setIsOpen(!isOpen);
  }}
/>;
{
  isOpen && <Text>It's a collapsable text content</Text>;
}

Forge UI components used

  1. Button
  2. Text

Chart

Using 3rd party service quickchart.

Chart

<Image
  src="https://quickchart.io/chart?bkg=white&c={type:%27bar%27,data:{labels:[2012,2013,2014,2015,2016],datasets:[{label:%27Users%27,data:[120,60,50,180,120]}]}}"
  alt="progress"
/>

Forge UI components used

  1. Image

Note

  1. For more details refer to the documentation quickchart.

Forge UI components used

  1. Image

Progress

Using 3rd party service quickchart.

<Image
  src="https://quickchart.io/chart?c={type:'radialGauge',data:{datasets:[{data:[70],backgroundColor:'blue'}]}}"
  alt="progress"
/>

progress

Forge UI components used

  1. Image

Note

  1. For more details refer to the documentation quickchart.

Pagination

pagination demo

const handleClick = (buttonPressed) => {
  console.log('buttonPressed ---->', buttonPressed);
};

<ButtonSet>
  <Button
    text="Previous"
    onClick={(event) => {
      console.log('EVENT ---->', event);
      handleClick('Previous');
    }}
  />
  <Button
    text="2"
    onClick={() => {
      handleClick(2);
    }}
  />
  <Button
    text="3"
    onClick={() => {
      handleClick(3);
    }}
  />
  <Button
    text="4"
    onClick={() => {
      handleClick(4);
    }}
  />
  <Button
    text="Next"
    onClick={() => {
      handleClick('Next');
    }}
  />
</ButtonSet>;

Forge UI components used

  1. Button
  2. ButtonSet

Alert

Using StatusLozenge

Alerts are available for any length of text. For proper styling, use one of the six appearance value (e.g., .inprogress).

forge tunnel debug

      <Text>
        <StatusLozenge text="A simple default alert" appearance="default" />
      </Text>
      <Text>
        <StatusLozenge text="A simple primary alert" appearance="inprogress" />
      </Text>
      <Text>
        <StatusLozenge text="A simple info alert" appearance="new" />
      </Text>
      <Text>
        <StatusLozenge text="A simple warning alert ⚠️" appearance="moved" />
      </Text>
      <Text>
        <StatusLozenge text="A simple danger alert ⛔" appearance="removed" />
      </Text>
      <Text>
        <StatusLozenge text="A simple success alert ✅" appearance="success" />
      </Text>

Using ModalDialog

Danger ModelDialog

danger ModalDialog

const [isOpen, setIsOpen] = useState(false);

<Button text="Show modal" onClick={() => setIsOpen(true)} />;
{
  isOpen && (
    <ModalDialog
      header="My modal dialog"
      onClose={() => setIsOpen(false)}
      appearance="danger"
    >
      <Text>It's a ModalDialog danger on the header</Text>
    </ModalDialog>
  );
}

Warning ModelDialog

warning ModalDialog

const [isOpen, setIsOpen] = useState(false);

<Button text="Show modal" onClick={() => setIsOpen(true)} />;
{
  isOpen && (
    <ModalDialog
      header="My modal dialog"
      onClose={() => setIsOpen(false)}
      appearance="warning"
    >
      <Text>It's a ModalDialog warning on the header</Text>
    </ModalDialog>
  );
}

Forge UI components used

  1. Text
  2. StatusLozenge
  3. ModalDialog

Modal

ModalDialog

const [isOpen, setOpen] = useState(false);
<Button text="Show modal" onClick={() => setOpen(true)} />;
{
  isOpen && (
    <ModalDialog header="My modal dialog" onClose={() => setOpen(false)}>
      <Text>It's a ModalDialog</Text>
    </ModalDialog>
  );
}

Forge UI components used

  1. ModalDialog

Forge UI hooks used

  1. useState

Navbar

Navbar with buttons

Navbar using Forge UI

<Table>
  <Row>
    <Cell>
      <Image
        src="https://res.cloudinary.com/anilkumark/image/upload/c_thumb,w_200,g_face/v1589212010/projects/forge/ui-components/anil-logo_yq4vyu.png"
        alt="demo logo"
      />
    </Cell>
    {/* Create many empty Cell for spacing */}
    <Cell></Cell>
    <Cell></Cell>
    <Cell></Cell>
    <Cell>
      <ButtonSet>
        <Button text="Home" />
        <Button text="About" />
        <Button text="Contact" />
      </ButtonSet>
    </Cell>
  </Row>
</Table>

Forge UI components used

  1. Image
  2. Button
  3. ButtonSet
  4. Table

Navbar with text lnks

Navbar using Forge UI

<Table>
  <Row>
    <Cell>
      <Image
        src="https://res.cloudinary.com/anilkumark/image/upload/c_thumb,w_200,g_face/v1589212010/projects/forge/ui-components/anil-logo_yq4vyu.png"
        alt="demo logo"
      />
    </Cell>
    {/* Create many empty Cell for spacing */}
    <Cell></Cell>
    <Cell></Cell>
    <Cell></Cell>
    <Cell>
      <Text>
        [Home](https://developer.atlassian.com/platform/forge)
        {'  '} {/* For extra spacing */}
        [Reference](https://developer.atlassian.com/platform/forge/manifest-reference/)
        {'  '} {/* For extra spacing */}
        [Help](https://developer.atlassian.com/platform/forge/get-help/)
      </Text>
    </Cell>
  </Row>
</Table>

Forge UI components used

  1. Image
  2. Text with link markdown
  3. Table