EntityViewerInterstitialInstructions.tsx 3.35 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
/**
 * See the NOTICE file distributed with this work for additional information
 * regarding copyright ownership.
 *
 * 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 React from 'react';
import { useDispatch } from 'react-redux';
import { push } from 'connected-react-router';

import * as urlFor from 'src/shared/helpers/urlHelper';

import { Step } from 'src/shared/components/step/Step';
import { ImageButton } from 'src/shared/components/image-button/ImageButton';
import { PrimaryButton } from 'src/shared/components/button/Button';
import { Status } from 'src/shared/types/status';

import { ReactComponent as SpeciesSelectorIcon } from 'static/img/launchbar/species-selector.svg';
import { ReactComponent as EntityViewerIcon } from 'static/img/launchbar/entity-viewer.svg';
import { ReactComponent as SearchIcon } from 'static/img/sidebar/search.svg';

import styles from './EntityViewerInterstitialInstructions.scss';

const EntityViewerInterstitialInstructions = () => {
  const dispatch = useDispatch();

  const goToSpeciesSelector = () => {
    const url = urlFor.speciesSelector();
    dispatch(push(url));
  };

  return (
    <section className={styles.instructionsPanel}>
      <div className={styles.instructionsWrapper}>
        <div className={styles.stepWrapper}>
46 47 48 49 50 51 52 53 54 55
          <Step count={1} label="Find and add a species">
            <div className={styles.description}>
              <ImageButton
                className={styles.imageButtonIcon}
                status={Status.DISABLED}
                image={SpeciesSelectorIcon}
              />
              <div className={styles.iconLabel}>Species Selector</div>
            </div>
          </Step>
56 57 58
        </div>

        <div className={styles.stepWrapper}>
59 60 61 62 63 64 65 66 67 68
          <Step count={2} label="Return to this app">
            <div className={styles.description}>
              <ImageButton
                className={styles.imageButtonIcon}
                status={Status.DISABLED}
                image={EntityViewerIcon}
              />
              <div className={styles.iconLabel}>Entity Viewer</div>
            </div>
          </Step>
69 70 71 72 73
        </div>

        <div className={styles.stepWrapper}>
          <Step
            count={3}
74 75 76 77 78 79 80 81 82 83 84
            label="Use Search or the example links to view a gene"
          >
            <div className={styles.searchDescription}>
              <ImageButton
                className={styles.searchButtonIcon}
                status={Status.DISABLED}
                image={SearchIcon}
              />
              <div className={styles.exampleText}>Example gene</div>
            </div>
          </Step>
85 86 87 88 89 90 91 92 93 94 95 96 97 98
        </div>

        <PrimaryButton
          className={styles.speciesSelectorButton}
          onClick={goToSpeciesSelector}
        >
          Go to Species Selector
        </PrimaryButton>
      </div>
    </section>
  );
};

export default EntityViewerInterstitialInstructions;