aboutsummaryrefslogtreecommitdiffstats
path: root/src/pages/_app.tsx
blob: 525335f043537890553f552a141182cf19961d0e (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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
import { useRouter } from 'next/router';
import { IntlProvider } from 'react-intl';
import '../styles/globals.scss';
import type { AppPropsWithLayout } from '../types';
import { CONFIG } from '../utils/config';
import { PRISM_THEME_ATTRIBUTE, STORAGE_KEY } from '../utils/constants';
import {
  AckeeProvider,
  MotionProvider,
  PrismThemeProvider,
  ThemeProvider,
} from '../utils/providers';

const App = ({ Component, pageProps }: AppPropsWithLayout) => {
  const { locale, defaultLocale } = useRouter();
  const appLocale: string = locale ?? CONFIG.locales.defaultLocale;
  const getLayout = Component.getLayout ?? ((page) => page);
  const { translation, ...componentProps } = pageProps;

  return (
    <AckeeProvider
      domainId={CONFIG.ackee.siteId}
      server={CONFIG.ackee.url}
      storageKey={STORAGE_KEY.ACKEE}
      tracking="full"
    >
      <MotionProvider
        attribute={STORAGE_KEY.MOTION}
        storageKey={STORAGE_KEY.MOTION}
      >
        <IntlProvider
          locale={appLocale}
          defaultLocale={defaultLocale}
          messages={translation}
        >
          <ThemeProvider
            attribute={STORAGE_KEY.THEME}
            storageKey={STORAGE_KEY.THEME}
          >
            <PrismThemeProvider
              attribute={PRISM_THEME_ATTRIBUTE}
              storageKey={STORAGE_KEY.PRISM}
            >
              {getLayout(<Component {...componentProps} />, {})}
            </PrismThemeProvider>
          </ThemeProvider>
        </IntlProvider>
      </MotionProvider>
    </AckeeProvider>
  );
};

export default App;
be 4 var recursivenessLog2 = 5; for (var i = 0; i < recursivenessLog2; i++) { schemeExpression = schemeExpression.replace(/<expr>/g, function () { return schemeExpression; }); } schemeExpression = schemeExpression.replace(/<expr>/g, /[^\s\S]/.source); var lilypond = (Prism.languages.lilypond = { comment: /%(?:(?!\{).*|\{[\s\S]*?%\})/, 'embedded-scheme': { pattern: RegExp( /(^|[=\s])#(?:"(?:[^"\\]|\\.)*"|[^\s()"]*(?:[^\s()]|<expr>))/.source.replace( /<expr>/g, function () { return schemeExpression; } ), 'm' ), lookbehind: true, greedy: true, inside: { scheme: { pattern: /^(#)[\s\S]+$/, lookbehind: true, alias: 'language-scheme', inside: { 'embedded-lilypond': { pattern: /#\{[\s\S]*?#\}/, greedy: true, inside: { punctuation: /^#\{|#\}$/, lilypond: { pattern: /[\s\S]+/, alias: 'language-lilypond', inside: null, // see below }, }, }, rest: Prism.languages.scheme, }, }, punctuation: /#/, }, }, string: { pattern: /"(?:[^"\\]|\\.)*"/, greedy: true, }, 'class-name': { pattern: /(\\new\s+)[\w-]+/, lookbehind: true, }, keyword: { pattern: /\\[a-z][-\w]*/i, inside: { punctuation: /^\\/, }, }, operator: /[=|]|<<|>>/, punctuation: { pattern: /(^|[a-z\d])(?:'+|,+|[_^]?-[_^]?(?:[-+^!>._]|(?=\d))|[_^]\.?|[.!])|[{}()[\]<>^~]|\\[()[\]<>\\!]|--|__/, lookbehind: true, }, number: /\b\d+(?:\/\d+)?\b/, }); lilypond['embedded-scheme'].inside['scheme'].inside[ 'embedded-lilypond' ].inside['lilypond'].inside = lilypond; Prism.languages.ly = lilypond; })(Prism);