mirror of
https://github.com/mantinedev/next-app-template.git
synced 2025-11-13 00:02:32 +10:00
Compare commits
125 Commits
sass
...
801324e17e
| Author | SHA1 | Date | |
|---|---|---|---|
| 801324e17e | |||
| dba951aee5 | |||
| ec459e32a1 | |||
| e41a6d974b | |||
| 7a9918204c | |||
| c6079c7741 | |||
| 596bfa3093 | |||
| 8926c997b9 | |||
| f3ab9bddb7 | |||
| 929c09edd7 | |||
| f5d9bc78ac | |||
| 0c327e8247 | |||
| 18effba097 | |||
| 316114717a | |||
| 835f4a9561 | |||
| fac653befc | |||
| 4298ec1a11 | |||
| 62f53ffef9 | |||
| 00b9d6b643 | |||
| 9738dd865c | |||
| 40f6fc48b9 | |||
| 0240e79c88 | |||
| 3c786b5a33 | |||
| a1af77b733 | |||
| e4d565fca8 | |||
| d8fddcc1d7 | |||
| 7ac48ade90 | |||
| 6e789e167a | |||
| 25c19542ab | |||
| 07643beb99 | |||
| e6e18446cb | |||
| 6c223a0d10 | |||
| 299c4e6215 | |||
| 2c6d23846e | |||
| 6b07d1e156 | |||
| d425e334e9 | |||
| 8ace050a57 | |||
| 30ca5b66a2 | |||
| f97a7f308c | |||
| a01844c8c7 | |||
| 0b3fc460e0 | |||
| 8d2a692c36 | |||
| 48952147df | |||
| 33de4133b7 | |||
| 476585ba0b | |||
| 756bfd1099 | |||
| 3c52527454 | |||
| 2bf3d76329 | |||
| 2d0e9095e9 | |||
| 9008798728 | |||
| d0d24039ae | |||
| da65f3102c | |||
| 9dc776f1b2 | |||
| 31af2255dd | |||
| 59f438dcf7 | |||
| 1daa7ca3a6 | |||
| 7d6ca574f8 | |||
| fe27d99406 | |||
| a8187cb00e | |||
| 0cd7976efd | |||
| b6feb6730e | |||
| 5948b21a22 | |||
| 2dabfc6ca4 | |||
| 763f36480d | |||
| 80772b4044 | |||
| 8f50381361 | |||
| 6f71ff274f | |||
| bf2c8f2863 | |||
| ba896e0c50 | |||
| aa2c27d9b9 | |||
| 406145dd0d | |||
| c89286ee36 | |||
| 33f5de903b | |||
| b5c4c6d84c | |||
| fc2837d53d | |||
| 758f433e62 | |||
| da7b03909f | |||
| 5da3f96e19 | |||
| 06654aa2fb | |||
| 060cc561d9 | |||
| 8cdd3e0c40 | |||
| 3aabc6598c | |||
| 81693bdf35 | |||
| ed4fb3a500 | |||
| 210b9e3655 | |||
| be152406ef | |||
| 2def41a2e3 | |||
| 92580fae10 | |||
| 8e9aa5918d | |||
| 512f7fe8b7 | |||
| d80c8050b8 | |||
| d99e6247c4 | |||
| b94938783b | |||
| ca230d642e | |||
| 75d75126d4 | |||
| df6fcffe80 | |||
| 52b02c8e4b | |||
| e9fcda02af | |||
| d0721178db | |||
| 9547d74226 | |||
| 1b329ae7ce | |||
| 959af2e32b | |||
| 55c4883729 | |||
| 77b979b2e1 | |||
| 414e3c4b5c | |||
| e1d572f6db | |||
| a280211ac8 | |||
| e912744391 | |||
| bcc07a7c59 | |||
| 05411fa287 | |||
| 893ad91d71 | |||
| 8fd71b288c | |||
| 8ee9720044 | |||
| bd385eae7f | |||
| 7f88fcd322 | |||
| 8cc5221a83 | |||
| 84451ce1f3 | |||
| 2e0c3f3ba7 | |||
| 08d0fd548b | |||
| 1e771619d7 | |||
| ad03e8a795 | |||
| ea200db349 | |||
| 70294c4892 | |||
| 4e66fce93f | |||
| 3396f1acf5 |
@ -1 +0,0 @@
|
|||||||
*.js
|
|
||||||
17
.eslintrc.js
17
.eslintrc.js
@ -1,17 +0,0 @@
|
|||||||
module.exports = {
|
|
||||||
extends: ['mantine', 'plugin:@next/next/recommended', 'plugin:jest/recommended'],
|
|
||||||
plugins: ['testing-library', 'jest'],
|
|
||||||
overrides: [
|
|
||||||
{
|
|
||||||
files: ['**/?(*.)+(spec|test).[jt]s?(x)'],
|
|
||||||
extends: ['plugin:testing-library/react'],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
parserOptions: {
|
|
||||||
project: './tsconfig.json',
|
|
||||||
},
|
|
||||||
rules: {
|
|
||||||
'react/react-in-jsx-scope': 'off',
|
|
||||||
'import/extensions': 'off',
|
|
||||||
},
|
|
||||||
};
|
|
||||||
27
.github/workflows/npm_test.yml
vendored
Normal file
27
.github/workflows/npm_test.yml
vendored
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
name: npm test
|
||||||
|
|
||||||
|
on:
|
||||||
|
pull_request:
|
||||||
|
branches:
|
||||||
|
- '**'
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
group: ${{ github.workflow }}-${{ github.event.number || github.sha }}
|
||||||
|
cancel-in-progress: true
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
test_pull_request:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
- uses: actions/setup-node@v3
|
||||||
|
with:
|
||||||
|
node-version-file: '.nvmrc'
|
||||||
|
cache: 'yarn'
|
||||||
|
cache-dependency-path: '**/yarn.lock'
|
||||||
|
- name: Install dependencies
|
||||||
|
run: yarn
|
||||||
|
- name: Run build
|
||||||
|
run: npm run build
|
||||||
|
- name: Run tests
|
||||||
|
run: npm test
|
||||||
152
.gitignore
vendored
152
.gitignore
vendored
@ -1,38 +1,132 @@
|
|||||||
# See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
|
# Logs
|
||||||
|
logs
|
||||||
# dependencies
|
*.log
|
||||||
/node_modules
|
|
||||||
/.pnp
|
|
||||||
.pnp.js
|
|
||||||
|
|
||||||
# testing
|
|
||||||
/coverage
|
|
||||||
|
|
||||||
# next.js
|
|
||||||
/.next/
|
|
||||||
/out/
|
|
||||||
|
|
||||||
# production
|
|
||||||
/build
|
|
||||||
|
|
||||||
# misc
|
|
||||||
.DS_Store
|
|
||||||
*.pem
|
|
||||||
|
|
||||||
# debug
|
|
||||||
npm-debug.log*
|
npm-debug.log*
|
||||||
yarn-debug.log*
|
yarn-debug.log*
|
||||||
yarn-error.log*
|
yarn-error.log*
|
||||||
|
lerna-debug.log*
|
||||||
|
.pnpm-debug.log*
|
||||||
|
|
||||||
# local env files
|
# Diagnostic reports (https://nodejs.org/api/report.html)
|
||||||
.env.local
|
report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json
|
||||||
|
|
||||||
|
# Runtime data
|
||||||
|
pids
|
||||||
|
*.pid
|
||||||
|
*.seed
|
||||||
|
*.pid.lock
|
||||||
|
|
||||||
|
# Directory for instrumented libs generated by jscoverage/JSCover
|
||||||
|
lib-cov
|
||||||
|
|
||||||
|
# Coverage directory used by tools like istanbul
|
||||||
|
coverage
|
||||||
|
*.lcov
|
||||||
|
|
||||||
|
# nyc test coverage
|
||||||
|
.nyc_output
|
||||||
|
|
||||||
|
# Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files)
|
||||||
|
.grunt
|
||||||
|
|
||||||
|
# Bower dependency directory (https://bower.io/)
|
||||||
|
bower_components
|
||||||
|
|
||||||
|
# node-waf configuration
|
||||||
|
.lock-wscript
|
||||||
|
|
||||||
|
# Compiled binary addons (https://nodejs.org/api/addons.html)
|
||||||
|
build/Release
|
||||||
|
|
||||||
|
# Dependency directories
|
||||||
|
node_modules/
|
||||||
|
jspm_packages/
|
||||||
|
|
||||||
|
# Snowpack dependency directory (https://snowpack.dev/)
|
||||||
|
web_modules/
|
||||||
|
|
||||||
|
# TypeScript cache
|
||||||
|
*.tsbuildinfo
|
||||||
|
|
||||||
|
# Optional npm cache directory
|
||||||
|
.npm
|
||||||
|
|
||||||
|
# Optional eslint cache
|
||||||
|
.eslintcache
|
||||||
|
|
||||||
|
# Optional stylelint cache
|
||||||
|
.stylelintcache
|
||||||
|
|
||||||
|
# Microbundle cache
|
||||||
|
.rpt2_cache/
|
||||||
|
.rts2_cache_cjs/
|
||||||
|
.rts2_cache_es/
|
||||||
|
.rts2_cache_umd/
|
||||||
|
|
||||||
|
# Optional REPL history
|
||||||
|
.node_repl_history
|
||||||
|
|
||||||
|
# Output of 'npm pack'
|
||||||
|
*.tgz
|
||||||
|
|
||||||
|
# Yarn Integrity file
|
||||||
|
.yarn-integrity
|
||||||
|
|
||||||
|
# dotenv environment variable files
|
||||||
|
.env
|
||||||
.env.development.local
|
.env.development.local
|
||||||
.env.test.local
|
.env.test.local
|
||||||
.env.production.local
|
.env.production.local
|
||||||
|
.env.local
|
||||||
|
|
||||||
# vercel
|
# parcel-bundler cache (https://parceljs.org/)
|
||||||
.vercel
|
.cache
|
||||||
*.tsbuildinfo
|
.parcel-cache
|
||||||
|
|
||||||
# storybook
|
# Next.js build output
|
||||||
storybook-static
|
.next
|
||||||
|
out
|
||||||
|
|
||||||
|
# Nuxt.js build / generate output
|
||||||
|
.nuxt
|
||||||
|
dist
|
||||||
|
|
||||||
|
# Gatsby files
|
||||||
|
.cache/
|
||||||
|
# Comment in the public line in if your project uses Gatsby and not Next.js
|
||||||
|
# https://nextjs.org/blog/next-9-1#public-directory-support
|
||||||
|
# public
|
||||||
|
|
||||||
|
# vuepress build output
|
||||||
|
.vuepress/dist
|
||||||
|
|
||||||
|
# vuepress v2.x temp and cache directory
|
||||||
|
.temp
|
||||||
|
.cache
|
||||||
|
|
||||||
|
# Docusaurus cache and generated files
|
||||||
|
.docusaurus
|
||||||
|
|
||||||
|
# Serverless directories
|
||||||
|
.serverless/
|
||||||
|
|
||||||
|
# FuseBox cache
|
||||||
|
.fusebox/
|
||||||
|
|
||||||
|
# DynamoDB Local files
|
||||||
|
.dynamodb/
|
||||||
|
|
||||||
|
# TernJS port file
|
||||||
|
.tern-port
|
||||||
|
|
||||||
|
# Stores VSCode versions used for testing VSCode extensions
|
||||||
|
.vscode-test
|
||||||
|
|
||||||
|
# yarn v2
|
||||||
|
.yarn/cache
|
||||||
|
.yarn/unplugged
|
||||||
|
.yarn/build-state.yml
|
||||||
|
.yarn/install-state.gz
|
||||||
|
.pnp.*
|
||||||
|
|
||||||
|
.DS_Store
|
||||||
@ -1 +0,0 @@
|
|||||||
module.exports = require('eslint-config-mantine/.prettierrc.js');
|
|
||||||
35
.prettierrc.mjs
Normal file
35
.prettierrc.mjs
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
/** @type {import("@ianvs/prettier-plugin-sort-imports").PrettierConfig} */
|
||||||
|
const config = {
|
||||||
|
printWidth: 100,
|
||||||
|
singleQuote: true,
|
||||||
|
trailingComma: 'es5',
|
||||||
|
plugins: ['@ianvs/prettier-plugin-sort-imports'],
|
||||||
|
importOrder: [
|
||||||
|
'.*styles.css$',
|
||||||
|
'',
|
||||||
|
'dayjs',
|
||||||
|
'^react$',
|
||||||
|
'^next$',
|
||||||
|
'^next/.*$',
|
||||||
|
'<BUILTIN_MODULES>',
|
||||||
|
'<THIRD_PARTY_MODULES>',
|
||||||
|
'^@mantine/(.*)$',
|
||||||
|
'^@mantinex/(.*)$',
|
||||||
|
'^@mantine-tests/(.*)$',
|
||||||
|
'^@docs/(.*)$',
|
||||||
|
'^@/.*$',
|
||||||
|
'^../(?!.*.css$).*$',
|
||||||
|
'^./(?!.*.css$).*$',
|
||||||
|
'\\.css$',
|
||||||
|
],
|
||||||
|
overrides: [
|
||||||
|
{
|
||||||
|
files: '*.mdx',
|
||||||
|
options: {
|
||||||
|
printWidth: 70,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
};
|
||||||
|
|
||||||
|
export default config;
|
||||||
@ -1,7 +1,13 @@
|
|||||||
import type { StorybookConfig } from '@storybook/nextjs';
|
import type { StorybookConfig } from '@storybook/nextjs';
|
||||||
|
|
||||||
const config: StorybookConfig = {
|
const config: StorybookConfig = {
|
||||||
|
core: {
|
||||||
|
disableWhatsNewNotifications: true,
|
||||||
|
disableTelemetry: true,
|
||||||
|
enableCrashReports: false,
|
||||||
|
},
|
||||||
stories: ['../components/**/*.(stories|story).@(js|jsx|ts|tsx)'],
|
stories: ['../components/**/*.(stories|story).@(js|jsx|ts|tsx)'],
|
||||||
addons: ['@storybook/addon-essentials', 'storybook-dark-mode', '@storybook/addon-styling'],
|
addons: ['@storybook/addon-themes'],
|
||||||
framework: {
|
framework: {
|
||||||
name: '@storybook/nextjs',
|
name: '@storybook/nextjs',
|
||||||
options: {},
|
options: {},
|
||||||
|
|||||||
@ -1,25 +1,41 @@
|
|||||||
import '@mantine/core/styles.css';
|
import '@mantine/core/styles.css';
|
||||||
import React, { useEffect } from 'react';
|
|
||||||
import { addons } from '@storybook/preview-api';
|
import { ColorSchemeScript, MantineProvider } from '@mantine/core';
|
||||||
import { DARK_MODE_EVENT_NAME } from 'storybook-dark-mode';
|
|
||||||
import { MantineProvider, useMantineColorScheme } from '@mantine/core';
|
|
||||||
import { theme } from '../theme';
|
import { theme } from '../theme';
|
||||||
|
|
||||||
const channel = addons.getChannel();
|
export const parameters = {
|
||||||
|
layout: 'fullscreen',
|
||||||
|
options: {
|
||||||
|
showPanel: false,
|
||||||
|
// @ts-expect-error – storybook throws build error for (a: any, b: any)
|
||||||
|
storySort: (a, b) => a.title.localeCompare(b.title, undefined, { numeric: true }),
|
||||||
|
},
|
||||||
|
backgrounds: { disable: true },
|
||||||
|
};
|
||||||
|
|
||||||
function ColorSchemeWrapper({ children }: { children: React.ReactNode }) {
|
export const globalTypes = {
|
||||||
const { setColorScheme } = useMantineColorScheme();
|
theme: {
|
||||||
const handleColorScheme = (value: boolean) => setColorScheme(value ? 'dark' : 'light');
|
name: 'Theme',
|
||||||
|
description: 'Mantine color scheme',
|
||||||
useEffect(() => {
|
defaultValue: 'light',
|
||||||
channel.on(DARK_MODE_EVENT_NAME, handleColorScheme);
|
toolbar: {
|
||||||
return () => channel.off(DARK_MODE_EVENT_NAME, handleColorScheme);
|
icon: 'mirror',
|
||||||
}, [channel]);
|
items: [
|
||||||
|
{ value: 'light', title: 'Light' },
|
||||||
return <>{children}</>;
|
{ value: 'dark', title: 'Dark' },
|
||||||
}
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
export const decorators = [
|
export const decorators = [
|
||||||
(renderStory: any) => <ColorSchemeWrapper>{renderStory()}</ColorSchemeWrapper>,
|
(renderStory: any, context: any) => {
|
||||||
(renderStory: any) => <MantineProvider theme={theme}>{renderStory()}</MantineProvider>,
|
const scheme = (context.globals.theme || 'light') as 'light' | 'dark';
|
||||||
|
return (
|
||||||
|
<MantineProvider theme={theme} forceColorScheme={scheme}>
|
||||||
|
<ColorSchemeScript />
|
||||||
|
{renderStory()}
|
||||||
|
</MantineProvider>
|
||||||
|
);
|
||||||
|
},
|
||||||
];
|
];
|
||||||
|
|||||||
2
.stylelintignore
Normal file
2
.stylelintignore
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
.next
|
||||||
|
out
|
||||||
28
.stylelintrc.json
Normal file
28
.stylelintrc.json
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
{
|
||||||
|
"extends": ["stylelint-config-standard-scss"],
|
||||||
|
"rules": {
|
||||||
|
"custom-property-pattern": null,
|
||||||
|
"selector-class-pattern": null,
|
||||||
|
"scss/no-duplicate-mixins": null,
|
||||||
|
"declaration-empty-line-before": null,
|
||||||
|
"declaration-block-no-redundant-longhand-properties": null,
|
||||||
|
"alpha-value-notation": null,
|
||||||
|
"custom-property-empty-line-before": null,
|
||||||
|
"property-no-vendor-prefix": null,
|
||||||
|
"color-function-notation": null,
|
||||||
|
"length-zero-no-unit": null,
|
||||||
|
"selector-not-notation": null,
|
||||||
|
"no-descending-specificity": null,
|
||||||
|
"comment-empty-line-before": null,
|
||||||
|
"scss/at-mixin-pattern": null,
|
||||||
|
"scss/at-rule-no-unknown": null,
|
||||||
|
"value-keyword-case": null,
|
||||||
|
"media-feature-range-notation": null,
|
||||||
|
"selector-pseudo-class-no-unknown": [
|
||||||
|
true,
|
||||||
|
{
|
||||||
|
"ignorePseudoClasses": ["global"]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
942
.yarn/releases/yarn-4.10.3.cjs
vendored
Executable file
942
.yarn/releases/yarn-4.10.3.cjs
vendored
Executable file
File diff suppressed because one or more lines are too long
3
.yarnrc.yml
Normal file
3
.yarnrc.yml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
nodeLinker: node-modules
|
||||||
|
|
||||||
|
yarnPath: .yarn/releases/yarn-4.10.3.cjs
|
||||||
@ -1,52 +0,0 @@
|
|||||||
@use 'sass:math';
|
|
||||||
|
|
||||||
// Define variables for your breakpoints,
|
|
||||||
// values must be the same as in your theme
|
|
||||||
$mantine-breakpoint-xs: '36em';
|
|
||||||
$mantine-breakpoint-sm: '48em';
|
|
||||||
$mantine-breakpoint-md: '62em';
|
|
||||||
$mantine-breakpoint-lg: '75em';
|
|
||||||
$mantine-breakpoint-xl: '88em';
|
|
||||||
|
|
||||||
@function rem($value) {
|
|
||||||
@return #{math.div(math.div($value, $value * 0 + 1), 16)}rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
@mixin light {
|
|
||||||
[data-mantine-color-scheme='light'] & {
|
|
||||||
@content;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@mixin dark {
|
|
||||||
[data-mantine-color-scheme='dark'] & {
|
|
||||||
@content;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@mixin hover {
|
|
||||||
@media (hover: hover) {
|
|
||||||
&:hover {
|
|
||||||
@content;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (hover: none) {
|
|
||||||
&:active {
|
|
||||||
@content;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add direction mixins if you need rtl support
|
|
||||||
@mixin rtl {
|
|
||||||
[dir='rtl'] & {
|
|
||||||
@content;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@mixin ltr {
|
|
||||||
[dir='ltr'] & {
|
|
||||||
@content;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,6 +1,7 @@
|
|||||||
import '@mantine/core/styles.css';
|
import '@mantine/core/styles.css';
|
||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { MantineProvider, ColorSchemeScript } from '@mantine/core';
|
import { ColorSchemeScript, mantineHtmlProps, MantineProvider } from '@mantine/core';
|
||||||
import { theme } from '../theme';
|
import { theme } from '../theme';
|
||||||
|
|
||||||
export const metadata = {
|
export const metadata = {
|
||||||
@ -10,7 +11,7 @@ export const metadata = {
|
|||||||
|
|
||||||
export default function RootLayout({ children }: { children: any }) {
|
export default function RootLayout({ children }: { children: any }) {
|
||||||
return (
|
return (
|
||||||
<html lang="en">
|
<html lang="en" {...mantineHtmlProps}>
|
||||||
<head>
|
<head>
|
||||||
<ColorSchemeScript />
|
<ColorSchemeScript />
|
||||||
<link rel="shortcut icon" href="/favicon.svg" />
|
<link rel="shortcut icon" href="/favicon.svg" />
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
import { Welcome } from '../components/Welcome/Welcome';
|
|
||||||
import { ColorSchemeToggle } from '../components/ColorSchemeToggle/ColorSchemeToggle';
|
import { ColorSchemeToggle } from '../components/ColorSchemeToggle/ColorSchemeToggle';
|
||||||
|
import { Welcome } from '../components/Welcome/Welcome';
|
||||||
|
|
||||||
export default function HomePage() {
|
export default function HomePage() {
|
||||||
return (
|
return (
|
||||||
|
|||||||
10
components/Welcome/Welcome.module.css
Normal file
10
components/Welcome/Welcome.module.css
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
.title {
|
||||||
|
color: light-dark(var(--mantine-color-black), var(--mantine-color-white));
|
||||||
|
font-size: rem(100px);
|
||||||
|
font-weight: 900;
|
||||||
|
letter-spacing: rem(-2px);
|
||||||
|
|
||||||
|
@media (max-width: $mantine-breakpoint-md) {
|
||||||
|
font-size: rem(50px);
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -1,18 +0,0 @@
|
|||||||
.title {
|
|
||||||
color: light-dark(var(--mantine-color-black), var(--mantine-color-white));
|
|
||||||
font-size: 100px;
|
|
||||||
font-weight: 900;
|
|
||||||
letter-spacing: -2px;
|
|
||||||
|
|
||||||
@include dark {
|
|
||||||
background-color: red;
|
|
||||||
}
|
|
||||||
|
|
||||||
@include light {
|
|
||||||
background-color: blue;
|
|
||||||
}
|
|
||||||
|
|
||||||
@media (max-width: $mantine-breakpoint-md) {
|
|
||||||
font-size: 50px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@ -1,5 +1,5 @@
|
|||||||
import { Title, Text, Anchor } from '@mantine/core';
|
import { Anchor, Text, Title } from '@mantine/core';
|
||||||
import classes from './Welcome.module.scss';
|
import classes from './Welcome.module.css';
|
||||||
|
|
||||||
export function Welcome() {
|
export function Welcome() {
|
||||||
return (
|
return (
|
||||||
|
|||||||
22
eslint.config.mjs
Normal file
22
eslint.config.mjs
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
import mantine from 'eslint-config-mantine';
|
||||||
|
import { defineConfig } from 'eslint/config';
|
||||||
|
import tseslint from 'typescript-eslint';
|
||||||
|
|
||||||
|
// @ts-check
|
||||||
|
export default defineConfig(
|
||||||
|
tseslint.configs.recommended,
|
||||||
|
...mantine,
|
||||||
|
{ ignores: ['**/*.{mjs,cjs,js,d.ts,d.mts}', '.next'] },
|
||||||
|
{
|
||||||
|
files: ['**/*.story.tsx'],
|
||||||
|
rules: { 'no-console': 'off' },
|
||||||
|
},
|
||||||
|
{
|
||||||
|
languageOptions: {
|
||||||
|
parserOptions: {
|
||||||
|
tsconfigRootDir: process.cwd(),
|
||||||
|
project: ['./tsconfig.json'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
);
|
||||||
@ -5,7 +5,7 @@ const createJestConfig = nextJest({
|
|||||||
});
|
});
|
||||||
|
|
||||||
const customJestConfig = {
|
const customJestConfig = {
|
||||||
setupFilesAfterEnv: ['<rootDir>/jest.setup.js'],
|
setupFilesAfterEnv: ['<rootDir>/jest.setup.cjs'],
|
||||||
moduleNameMapper: {
|
moduleNameMapper: {
|
||||||
'^@/components/(.*)$': '<rootDir>/components/$1',
|
'^@/components/(.*)$': '<rootDir>/components/$1',
|
||||||
'^@/pages/(.*)$': '<rootDir>/pages/$1',
|
'^@/pages/(.*)$': '<rootDir>/pages/$1',
|
||||||
@ -1,7 +1,8 @@
|
|||||||
import '@testing-library/jest-dom/extend-expect';
|
require('@testing-library/jest-dom');
|
||||||
|
|
||||||
const { getComputedStyle } = window;
|
const { getComputedStyle } = window;
|
||||||
window.getComputedStyle = (elt) => getComputedStyle(elt);
|
window.getComputedStyle = (elt) => getComputedStyle(elt);
|
||||||
|
window.HTMLElement.prototype.scrollIntoView = () => {};
|
||||||
|
|
||||||
Object.defineProperty(window, 'matchMedia', {
|
Object.defineProperty(window, 'matchMedia', {
|
||||||
writable: true,
|
writable: true,
|
||||||
3
next-env.d.ts
vendored
3
next-env.d.ts
vendored
@ -1,5 +1,6 @@
|
|||||||
/// <reference types="next" />
|
/// <reference types="next" />
|
||||||
/// <reference types="next/image-types/global" />
|
/// <reference types="next/image-types/global" />
|
||||||
|
/// <reference path="./.next/types/routes.d.ts" />
|
||||||
|
|
||||||
// NOTE: This file should not be edited
|
// NOTE: This file should not be edited
|
||||||
// see https://nextjs.org/docs/basic-features/typescript for more information.
|
// see https://nextjs.org/docs/app/api-reference/config/typescript for more information.
|
||||||
|
|||||||
@ -1,8 +1,10 @@
|
|||||||
const withBundleAnalyzer = require('@next/bundle-analyzer')({
|
import bundleAnalyzer from '@next/bundle-analyzer';
|
||||||
|
|
||||||
|
const withBundleAnalyzer = bundleAnalyzer({
|
||||||
enabled: process.env.ANALYZE === 'true',
|
enabled: process.env.ANALYZE === 'true',
|
||||||
});
|
});
|
||||||
|
|
||||||
module.exports = withBundleAnalyzer({
|
export default withBundleAnalyzer({
|
||||||
reactStrictMode: false,
|
reactStrictMode: false,
|
||||||
eslint: {
|
eslint: {
|
||||||
ignoreDuringBuilds: true,
|
ignoreDuringBuilds: true,
|
||||||
@ -10,8 +12,4 @@ module.exports = withBundleAnalyzer({
|
|||||||
experimental: {
|
experimental: {
|
||||||
optimizePackageImports: ['@mantine/core', '@mantine/hooks'],
|
optimizePackageImports: ['@mantine/core', '@mantine/hooks'],
|
||||||
},
|
},
|
||||||
|
|
||||||
sassOptions: {
|
|
||||||
prependData: `@import "./_mantine.scss";`,
|
|
||||||
},
|
|
||||||
});
|
});
|
||||||
90
package.json
90
package.json
@ -8,7 +8,9 @@
|
|||||||
"analyze": "ANALYZE=true next build",
|
"analyze": "ANALYZE=true next build",
|
||||||
"start": "next start",
|
"start": "next start",
|
||||||
"typecheck": "tsc --noEmit",
|
"typecheck": "tsc --noEmit",
|
||||||
"lint": "next lint",
|
"lint": "npm run eslint && npm run stylelint",
|
||||||
|
"eslint": "eslint .",
|
||||||
|
"stylelint": "stylelint '**/*.css' --cache",
|
||||||
"jest": "jest",
|
"jest": "jest",
|
||||||
"jest:watch": "jest --watch",
|
"jest:watch": "jest --watch",
|
||||||
"prettier:check": "prettier --check \"**/*.{ts,tsx}\"",
|
"prettier:check": "prettier --check \"**/*.{ts,tsx}\"",
|
||||||
@ -18,52 +20,48 @@
|
|||||||
"storybook:build": "storybook build"
|
"storybook:build": "storybook build"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@mantine/core": "7.1.3",
|
"@mantine/core": "8.3.4",
|
||||||
"@mantine/hooks": "7.1.3",
|
"@mantine/hooks": "8.3.4",
|
||||||
"@next/bundle-analyzer": "^13.5.3",
|
"@next/bundle-analyzer": "^15.5.4",
|
||||||
"@tabler/icons-react": "^2.20.0",
|
"@tabler/icons-react": "^3.35.0",
|
||||||
"next": "13.5.3",
|
"next": "15.5.4",
|
||||||
"react": "18.2.0",
|
"react": "19.2.0",
|
||||||
"react-dom": "18.2.0"
|
"react-dom": "19.2.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@babel/core": "^7.22.1",
|
"@babel/core": "^7.28.4",
|
||||||
"@next/eslint-plugin-next": "^13.5.3",
|
"@eslint/eslintrc": "^3",
|
||||||
"@storybook/addon-essentials": "^7.4.3",
|
"@eslint/js": "^9.37.0",
|
||||||
"@storybook/addon-styling": "^1.0.8",
|
"@ianvs/prettier-plugin-sort-imports": "^4.7.0",
|
||||||
"@storybook/blocks": "^7.4.3",
|
"@storybook/addon-themes": "^9.1.10",
|
||||||
"@storybook/nextjs": "^7.4.3",
|
"@storybook/nextjs": "^9.1.10",
|
||||||
"@storybook/react": "^7.4.3",
|
"@storybook/react": "^9.1.10",
|
||||||
"@testing-library/dom": "^9.3.0",
|
"@testing-library/dom": "^10.4.1",
|
||||||
"@testing-library/jest-dom": "^5.16.5",
|
"@testing-library/jest-dom": "^6.9.1",
|
||||||
"@testing-library/react": "^14.0.0",
|
"@testing-library/react": "^16.3.0",
|
||||||
"@testing-library/user-event": "^14.4.3",
|
"@testing-library/user-event": "^14.6.1",
|
||||||
"@types/jest": "^29.5.1",
|
"@types/eslint-plugin-jsx-a11y": "^6",
|
||||||
"@types/node": "^20.2.5",
|
"@types/jest": "^30.0.0",
|
||||||
"@types/react": "18.2.7",
|
"@types/node": "^24.7.1",
|
||||||
"@typescript-eslint/eslint-plugin": "^5.59.7",
|
"@types/react": "19.2.2",
|
||||||
"@typescript-eslint/parser": "^5.59.7",
|
"babel-loader": "^10.0.0",
|
||||||
"babel-loader": "^9.1.2",
|
"eslint": "^9.37.0",
|
||||||
"eslint": "^8.41.0",
|
"eslint-config-mantine": "^4.0.3",
|
||||||
"eslint-config-airbnb": "19.0.4",
|
"eslint-config-next": "15.5.4",
|
||||||
"eslint-config-airbnb-typescript": "^17.0.0",
|
"eslint-plugin-jsx-a11y": "^6.10.2",
|
||||||
"eslint-config-mantine": "2.0.0",
|
"eslint-plugin-react": "^7.37.5",
|
||||||
"eslint-plugin-import": "^2.27.5",
|
"jest": "^30.2.0",
|
||||||
"eslint-plugin-jest": "^27.2.1",
|
"jest-environment-jsdom": "^30.2.0",
|
||||||
"eslint-plugin-jsx-a11y": "^6.7.1",
|
"postcss": "^8.5.6",
|
||||||
"eslint-plugin-react": "^7.32.2",
|
"postcss-preset-mantine": "1.18.0",
|
||||||
"eslint-plugin-react-hooks": "^4.6.0",
|
|
||||||
"eslint-plugin-testing-library": "^5.11.0",
|
|
||||||
"jest": "^29.5.0",
|
|
||||||
"jest-environment-jsdom": "^29.5.0",
|
|
||||||
"postcss": "^8.4.23",
|
|
||||||
"postcss-preset-mantine": "1.8.0",
|
|
||||||
"postcss-simple-vars": "^7.0.1",
|
"postcss-simple-vars": "^7.0.1",
|
||||||
"prettier": "^2.8.8",
|
"prettier": "^3.6.2",
|
||||||
"sass": "^1.69.3",
|
"storybook": "^9.1.10",
|
||||||
"storybook": "^7.4.3",
|
"stylelint": "^16.25.0",
|
||||||
"storybook-dark-mode": "^3.0.0",
|
"stylelint-config-standard-scss": "^16.0.0",
|
||||||
"ts-jest": "^29.1.0",
|
"ts-jest": "^29.4.4",
|
||||||
"typescript": "5.2.2"
|
"typescript": "5.9.3",
|
||||||
}
|
"typescript-eslint": "^8.46.0"
|
||||||
|
},
|
||||||
|
"packageManager": "yarn@4.10.3"
|
||||||
}
|
}
|
||||||
|
|||||||
13
renovate.json
Normal file
13
renovate.json
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
{
|
||||||
|
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
|
||||||
|
"schedule": ["before 5am on sunday"],
|
||||||
|
"groupName": "all dependencies",
|
||||||
|
"packageRules": [
|
||||||
|
{
|
||||||
|
"matchPackagePatterns": ["*"],
|
||||||
|
"groupName": "all dependencies"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"prHourlyLimit": 0,
|
||||||
|
"prConcurrentLimit": 0
|
||||||
|
}
|
||||||
@ -5,7 +5,9 @@ import { theme } from '../theme';
|
|||||||
export function render(ui: React.ReactNode) {
|
export function render(ui: React.ReactNode) {
|
||||||
return testingLibraryRender(<>{ui}</>, {
|
return testingLibraryRender(<>{ui}</>, {
|
||||||
wrapper: ({ children }: { children: React.ReactNode }) => (
|
wrapper: ({ children }: { children: React.ReactNode }) => (
|
||||||
<MantineProvider theme={theme}>{children}</MantineProvider>
|
<MantineProvider theme={theme} env="test">
|
||||||
|
{children}
|
||||||
|
</MantineProvider>
|
||||||
),
|
),
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,5 +1,10 @@
|
|||||||
{
|
{
|
||||||
"compilerOptions": {
|
"compilerOptions": {
|
||||||
|
"types": [
|
||||||
|
"node",
|
||||||
|
"jest",
|
||||||
|
"@testing-library/jest-dom"
|
||||||
|
],
|
||||||
"target": "es5",
|
"target": "es5",
|
||||||
"lib": [
|
"lib": [
|
||||||
"dom",
|
"dom",
|
||||||
@ -30,9 +35,11 @@
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
"include": [
|
"include": [
|
||||||
"next-env.d.ts",
|
|
||||||
"**/*.ts",
|
"**/*.ts",
|
||||||
"**/*.tsx",
|
"**/*.tsx",
|
||||||
|
".storybook/main.ts",
|
||||||
|
".storybook/preview.tsx",
|
||||||
|
"next-env.d.ts",
|
||||||
".next/types/**/*.ts"
|
".next/types/**/*.ts"
|
||||||
],
|
],
|
||||||
"exclude": [
|
"exclude": [
|
||||||
|
|||||||
Reference in New Issue
Block a user