(function (Prism) { var codeLinePattern = /(^(?:[\t ]*(?:\*\s*)*))[^*\s].*$/m; var memberReference = /#\s*\w+(?:\s*\([^()]*\))?/.source; var reference = /(?:\b[a-zA-Z]\w+\s*\.\s*)*\b[A-Z]\w*(?:\s*)?|/.source.replace( //g, function () { return memberReference; } ); Prism.languages.javadoc = Prism.languages.extend('javadoclike', {}); Prism.languages.insertBefore('javadoc', 'keyword', { reference: { pattern: RegExp( /(@(?:exception|link|linkplain|see|throws|value)\s+(?:\*\s*)?)/.source + '(?:' + reference + ')' ), lookbehind: true, inside: { function: { pattern: /(#\s*)\w+(?=\s*\()/, lookbehind: true, }, field: { pattern: /(#\s*)\w+/, lookbehind: true, }, namespace: { pattern: /\b(?:[a-z]\w*\s*\.\s*)+/, inside: { punctuation: /\./, }, }, 'class-name': /\b[A-Z]\w*/, keyword: Prism.languages.java.keyword, punctuation: /[#()[\],.]/, }, }, 'class-name': { // @param the first generic type parameter pattern: /(@param\s+)<[A-Z]\w*>/, lookbehind: true, inside: { punctuation: /[.<>]/, }, }, 'code-section': [ { pattern: /(\{@code\s+(?!\s))(?:[^\s{}]|\s+(?![\s}])|\{(?:[^{}]|\{(?:[^{}]|\{(?:[^{}]|\{[^{}]*\})*\})*\})*\})+(?=\s*\})/, lookbehind: true, inside: { code: { // there can't be any HTML inside of {@code} tags pattern: codeLinePattern, lookbehind: true, inside: Prism.languages.java, alias: 'language-java', }, }, }, { pattern: /(<(code|pre|tt)>(?!)\s*)\S(?:\S|\s+\S)*?(?=\s*<\/\2>)/, lookbehind: true, inside: { line: { pattern: codeLinePattern, lookbehind: true, inside: { // highlight HTML tags and entities tag: Prism.languages.markup.tag, entity: Prism.languages.markup.entity, code: { // everything else is Java code pattern: /.+/, inside: Prism.languages.java, alias: 'language-java', }, }, }, }, }, ], tag: Prism.languages.markup.tag, entity: Prism.languages.markup.entity, }); Prism.languages.javadoclike.addSupport('java', Prism.languages.javadoc); })(Prism); ption>
blob: 062c04ba7bcfc5d468d29bfcd7dbd283ab9b73a4 (plain)
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
import Image, { ImageProps } from 'next/image';
import Link from 'next/link';
import styles from './ResponsiveImage.module.scss';

type ResponsiveImageProps = ImageProps & {
  caption?: string;
  linkTarget?: string;
};

const ResponsiveImage = (props: ResponsiveImageProps) => {
  const { caption, linkTarget, ...attributes } = props;

  return (
    <figure className={styles.wrapper}>
      {linkTarget ? (
        <Link href={linkTarget}>
          <a className={styles.link}>
            <Image alt={attributes.alt} layout="intrinsic" {...attributes} />
            {caption && (
              <figcaption className={styles.caption}>{caption}</figcaption>
            )}
          </a>
        </Link>
      ) : (
        <>
          <Image alt={attributes.alt} layout="intrinsic" {...attributes} />
          {caption && (
            <figcaption className={styles.caption}>{caption}</figcaption>
          )}
        </>
      )}
    </figure>
  );
};

export default ResponsiveImage;