copy_link.tsx
TLDR
This file is a TypeScript module that exports a React component called CopyLinkTourStep
. This component renders a step in a tour guide that explains how to copy a link in an onboarding process. It uses the FormattedMessage
component from the react-intl
library for internationalization. It also imports utils from a custom Utils
module and the copyLink
image from the static assets directory.
Methods
This file does not contain any methods.
Classes
This file does not contain any classes.
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import React from 'react'
import {FormattedMessage} from 'react-intl'
import {useMeasurePunchouts} from '../../tutorial_tour_tip/hooks'
import './copy_link.scss'
import {Utils} from '../../../utils'
import copyLink from '../../../../static/copyLink.gif'
import {BoardTourSteps, TOUR_BOARD} from '../index'
import {OnboardingCardClassName} from '../../kanban/kanbanCard'
import TourTipRenderer from '../tourTipRenderer/tourTipRenderer'
const CopyLinkTourStep = (): JSX.Element | null => {
const title = (
<FormattedMessage
id='OnboardingTour.CopyLink.Title'
defaultMessage='Copy link'
/>
)
const screen = (
<FormattedMessage
id='OnboardingTour.CopyLink.Body'
defaultMessage='You can share your cards with teammates by copying the link and pasting it in a channel, direct message, or group message.'
/>
)
const punchout = useMeasurePunchouts([`.${OnboardingCardClassName} .optionsMenu`], [])
return (
<TourTipRenderer
key='CopyLinkTourStep'
requireCard={false}
category={TOUR_BOARD}
step={BoardTourSteps.COPY_LINK}
screen={screen}
title={title}
punchout={punchout}
classname='CopyLinkTourStep'
telemetryTag='tourPoint3b'
placement={'right-start'}
imageURL={Utils.buildURL(copyLink, true)}
hideBackdrop={true}
/>
)
}
export default CopyLinkTourStep