@dargmuesli/nuxt-vio 16.1.0-beta.1 → 17.0.0-beta.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,90 @@
1
+ /* stylelint-disable plugin/no-unsupported-browser-features */
2
+ @layer components {
3
+ .form-input {
4
+ appearance: none;
5
+ background-color: #fff;
6
+ border-color: oklch(55.1% 0.027 264.364deg);
7
+ border-width: 1px;
8
+ border-radius: 0;
9
+ padding: 0.75rem 0.5rem;
10
+ font-size: 1rem;
11
+ line-height: 1.5rem;
12
+
13
+ --tw-shadow: 0 0 #0000;
14
+
15
+ &:focus {
16
+ outline: 2px solid transparent;
17
+ outline-offset: 2px;
18
+
19
+ --tw-ring-inset: var(--tw-empty,/*!*/ /*!*/);
20
+ --tw-ring-offset-width: 0px;
21
+ --tw-ring-offset-color: #fff;
22
+ --tw-ring-color: oklch(54.6% 0.245 262.881deg);
23
+ --tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
24
+ --tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);
25
+
26
+ box-shadow: var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
27
+ border-color: oklch(54.6% 0.245 262.881deg);
28
+ }
29
+
30
+ &::placeholder {
31
+ color: oklch(55.1% 0.027 264.364deg);
32
+ opacity: 1;
33
+ }
34
+
35
+ &::-webkit-datetime-edit-fields-wrapper {
36
+ padding: 0;
37
+ }
38
+
39
+ &::-webkit-date-and-time-value {
40
+ min-height: 1.5em;
41
+ text-align: inherit;
42
+ }
43
+
44
+ &::-webkit-datetime-edit {
45
+ display: inline-flex;
46
+ padding-top: 0;
47
+ padding-bottom: 0;
48
+ }
49
+
50
+ &::-webkit-datetime-edit-year-field {
51
+ padding-top: 0;
52
+ padding-bottom: 0;
53
+ }
54
+
55
+ &::-webkit-datetime-edit-month-field {
56
+ padding-top: 0;
57
+ padding-bottom: 0;
58
+ }
59
+
60
+ &::-webkit-datetime-edit-day-field {
61
+ padding-top: 0;
62
+ padding-bottom: 0;
63
+ }
64
+
65
+ &::-webkit-datetime-edit-hour-field {
66
+ padding-top: 0;
67
+ padding-bottom: 0;
68
+ }
69
+
70
+ &::-webkit-datetime-edit-minute-field {
71
+ padding-top: 0;
72
+ padding-bottom: 0;
73
+ }
74
+
75
+ &::-webkit-datetime-edit-second-field {
76
+ padding-top: 0;
77
+ padding-bottom: 0;
78
+ }
79
+
80
+ &::-webkit-datetime-edit-millisecond-field {
81
+ padding-top: 0;
82
+ padding-bottom: 0;
83
+ }
84
+
85
+ &::-webkit-datetime-edit-meridiem-field {
86
+ padding-top: 0;
87
+ padding-bottom: 0;
88
+ }
89
+ }
90
+ }
@@ -1,25 +1,212 @@
1
+ /* stylelint-disable at-rule-no-deprecated */
1
2
  /* stylelint-disable at-rule-no-unknown */
2
- @tailwind base;
3
- @tailwind components;
4
- @tailwind utilities;
5
- /* stylelint-enable at-rule-no-unknown */
3
+ /* stylelint-disable custom-property-pattern */
4
+ /* stylelint-disable import-notation */
5
+ /* stylelint-disable plugin/no-unsupported-browser-features */
6
+
7
+ @import 'tailwindcss';
8
+ @import './forms.css';
9
+
10
+ @plugin "@tailwindcss/forms" {
11
+ strategy: 'base';
12
+ }
13
+
14
+ @plugin "@tailwindcss/typography";
15
+
16
+ @theme {
17
+ --animate-shake: shake 0.6s ease-in-out 0s 1 normal forwards running;
18
+
19
+ @keyframes shake {
20
+ 0%,
21
+ 100% {
22
+ transform: translateX(0);
23
+ }
24
+
25
+ 15% {
26
+ transform: translateX(0.375rem);
27
+ }
28
+
29
+ 30% {
30
+ transform: translateX(-0.375rem);
31
+ }
32
+
33
+ 45% {
34
+ transform: translateX(0.375rem);
35
+ }
36
+
37
+ 60% {
38
+ transform: translateX(-0.375rem);
39
+ }
40
+
41
+ 75% {
42
+ transform: translateX(0.375rem);
43
+ }
44
+
45
+ 90% {
46
+ transform: translateX(-0.375rem);
47
+ }
48
+ }
49
+
50
+ --color-background-bright: rgb(255 255 255);
51
+ --color-background-brighten: rgb(229 231 235);
52
+ --color-background-dark: rgb(31 41 55);
53
+ --color-background-darken: rgb(55 65 81);
54
+ --color-link-bright: rgb(96 165 250);
55
+ --color-link-dark: rgb(37 99 235);
56
+ --color-text-bright: rgb(249 250 251);
57
+ --color-text-dark: rgb(17 24 39);
58
+ --color-vio-primary-bg: rgb(243 244 246);
59
+ --color-vio-primary-text: rgb(17 24 39);
60
+
61
+ /* --text-3xl--line-height: calc(2.5 / 1.875);
62
+ --text-4xl--line-height: calc(3 / 2.25);
63
+ --text-5xl--line-height: calc(4 / 3);
64
+ --text-6xl--line-height: calc(4.75 / 3.75);
65
+ --text-7xl--line-height: calc(4.75 / 4);
66
+ --text-8xl--line-height: calc(7.5 / 6);
67
+ --text-9xl--line-height: calc(10 / 8); */
68
+ }
6
69
 
7
- /* doiuse-disable css-cascade-layers */
8
70
  @layer base {
9
- /* doiuse-enable css-cascade-layers */
10
-
11
- :root {
12
- /* stylelint-disable plugin/no-unsupported-browser-features */
13
- --color-background-bright: 255 255 255;
14
- --color-background-brighten: 229 231 235;
15
- --color-background-dark: 31 41 55;
16
- --color-background-darken: 55 65 81;
17
- --color-link-bright: 96 165 250;
18
- --color-link-dark: 37 99 235;
19
- --color-text-bright: 249 250 251;
20
- --color-text-dark: 17 24 39;
21
- --color-vio-primary-bg: 243 244 246;
22
- --color-vio-primary-text: 17 24 39;
23
- /* stylelint-enable plugin/no-unsupported-browser-features */
71
+ ::placeholder {
72
+ @apply italic;
73
+ }
74
+
75
+ :disabled {
76
+ /* pointer-events-none */
77
+ @apply cursor-not-allowed opacity-50;
78
+ }
79
+
80
+ a,
81
+ button {
82
+ @apply focus:ring-3 focus:ring-blue-500/50 focus:outline-none;
83
+ }
84
+
85
+ a[target='_blank']:not([is-external-icon-disabled])::after {
86
+ /* inline-table centers the element vertically in the tiptap text area, instead of inline-block */
87
+ @apply ml-[5px] inline-table h-3 w-3 bg-current;
88
+
89
+ content: '';
90
+ mask: url('')
91
+ no-repeat 50% 50%;
92
+ mask-size: cover;
93
+ }
94
+
95
+ address {
96
+ @apply m-4;
97
+ }
98
+
99
+ button:not(:disabled),
100
+ [role='button']:not(:disabled) {
101
+ cursor: pointer;
102
+ }
103
+
104
+ h1 {
105
+ /* mb-4 */
106
+ @apply heading text-center text-4xl;
107
+ }
108
+
109
+ h2 {
110
+ @apply heading text-3xl;
111
+ }
112
+
113
+ h3 {
114
+ @apply heading text-2xl;
115
+ }
116
+
117
+ h4 {
118
+ @apply heading text-xl;
119
+ }
120
+
121
+ h5 {
122
+ @apply heading text-lg;
123
+ }
124
+
125
+ h6 {
126
+ @apply heading;
127
+ }
128
+
129
+ img::before {
130
+ @apply flex h-full items-center justify-center;
131
+ }
132
+
133
+ table {
134
+ @apply w-full;
135
+ }
136
+
137
+ td {
138
+ @apply px-4 py-6 whitespace-nowrap;
139
+ }
140
+
141
+ th {
142
+ @apply px-3 py-6 text-left text-xs font-medium tracking-wider uppercase;
143
+ }
144
+ }
145
+
146
+ @layer components {
147
+ .form-input {
148
+ appearance: none;
149
+ background-color: rgb(249 250 251 / var(--tw-bg-opacity, 1));
150
+ border-color: rgb(209 213 219 / var(--tw-border-opacity, 1));
151
+ border-radius: 0.25rem;
152
+ border-width: 1px;
153
+ box-shadow: 0 1px 2px 0 rgb(0 0 0 / 5%);
154
+ color: rgb(24 24 27 / var(--tw-text-opacity, 1));
155
+ line-height: 1.25;
156
+ padding: 0.5rem 1rem;
157
+ width: 100%;
158
+ }
159
+
160
+ .form-input:focus {
161
+ background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
162
+ }
163
+
164
+ .form-input::placeholder {
165
+ opacity: 0.5;
166
+ }
167
+
168
+ .form-input-error .form-input {
169
+ border-color: rgb(239 68 68 / var(--tw-border-opacity, 1));
170
+ }
171
+
172
+ .form-input-success .form-input {
173
+ border-color: rgb(22 163 74 / var(--tw-border-opacity, 1));
174
+ }
175
+
176
+ .form-input-warning .form-input {
177
+ border-color: rgb(202 138 4 / var(--tw-border-opacity, 1));
178
+ }
179
+
180
+ .form-textarea::placeholder {
181
+ opacity: 0.5;
182
+ }
183
+ }
184
+
185
+ @utility disabled {
186
+ /* pointer-events-none */
187
+ @apply cursor-not-allowed opacity-50;
188
+ }
189
+
190
+ @utility heading {
191
+ @apply font-bold;
192
+ } /* set overflow truncate/ellipsis in the surrounding container, or larger fonts will be cut off due to their line-heights */
193
+
194
+ .dark {
195
+ @apply scheme-dark;
196
+ }
197
+
198
+ .prose {
199
+ a {
200
+ /* color-link */
201
+ @apply no-underline;
202
+ }
203
+
204
+ h1,
205
+ h2,
206
+ h3,
207
+ h4,
208
+ h5,
209
+ h6 {
210
+ @apply leading-snug;
24
211
  }
25
212
  }
@@ -56,7 +56,7 @@ const route = useRoute()
56
56
  // computations
57
57
  const classes = computed(() => {
58
58
  return [
59
- 'rounded',
59
+ 'rounded-sm',
60
60
  ...(props.isColored ? ['text-link-dark dark:text-link-bright'] : []),
61
61
  ...(props.isUnderlined ? ['underline'] : []),
62
62
  ].join(' ')
@@ -7,10 +7,10 @@
7
7
  [
8
8
  ...(isPrimary
9
9
  ? [
10
- 'border-transparent bg-gray-800 text-text-bright hover:brightness-90 dark:bg-vio-primary-bg dark:text-vio-primary-text',
10
+ 'text-text-bright dark:bg-vio-primary-bg dark:text-vio-primary-text border-transparent bg-gray-800 hover:brightness-90',
11
11
  ]
12
12
  : [
13
- 'border-gray-300 text-text-dark hover:bg-black/5 dark:border-gray-600 dark:text-text-bright dark:hover:bg-black/30',
13
+ 'text-text-dark dark:text-text-bright border-gray-300 hover:bg-black/5 dark:border-gray-600 dark:hover:bg-black/30',
14
14
  ]),
15
15
  ].join(' ')
16
16
  "
@@ -2,7 +2,7 @@
2
2
  <div>
3
3
  <input
4
4
  :id="`input-${formKey}`"
5
- class="rounded"
5
+ class="rounded-sm"
6
6
  type="checkbox"
7
7
  :checked="value"
8
8
  @change="emit('change', ($event.target as HTMLInputElement).checked)"
@@ -20,7 +20,7 @@
20
20
  >
21
21
  <span>{{ title }}</span>
22
22
  <span
23
- class="text-xs font-medium text-gray-500 dark:text-gray-400 md:text-right"
23
+ class="text-xs font-medium text-gray-500 md:text-right dark:text-gray-400"
24
24
  >
25
25
  <span v-if="isRequired">
26
26
  {{ t('required') }}
@@ -1,5 +1,5 @@
1
1
  <template>
2
- <span class="absolute right-0 top-1/2 -translate-y-1/2 px-3">
2
+ <span class="absolute top-1/2 right-0 -translate-y-1/2 px-3">
3
3
  <div class="rounded-full bg-gray-50">
4
4
  <slot />
5
5
  </div>
@@ -16,7 +16,7 @@
16
16
  >
17
17
  <span>{{ t('separator') }}</span>
18
18
  <VioLink
19
- class="whitespace-nowrap text-2xl"
19
+ class="text-2xl whitespace-nowrap"
20
20
  :data-testid="`breadcrumb-prefix-${prefix.to}`"
21
21
  :is-colored="false"
22
22
  :to="prefix.to"
@@ -28,7 +28,7 @@
28
28
  <span>{{ t('separator') }}</span>
29
29
  <VioLink :is-colored="false" :to="route.path">
30
30
  <span
31
- class="whitespace-nowrap text-2xl font-bold"
31
+ class="text-2xl font-bold whitespace-nowrap"
32
32
  data-testid="breadcrumb"
33
33
  >
34
34
  <slot />
@@ -42,7 +42,7 @@
42
42
  >
43
43
  <span>{{ t('separator') }}</span>
44
44
  <VioLink
45
- class="whitespace-nowrap text-2xl"
45
+ class="text-2xl whitespace-nowrap"
46
46
  :data-testid="`breadcrumb-suffix-${suffix.to}`"
47
47
  :is-colored="false"
48
48
  :to="suffix.to"
@@ -2,7 +2,7 @@
2
2
  <div
3
3
  class="flex flex-1 basis-1/2 flex-col items-start gap-2 p-4 md:flex-none md:basis-auto"
4
4
  >
5
- <span class="whitespace-nowrap text-lg font-medium leading-7">
5
+ <span class="text-lg leading-7 font-medium whitespace-nowrap">
6
6
  {{ heading }}
7
7
  </span>
8
8
  <slot />
@@ -1,6 +1,6 @@
1
1
  <template>
2
2
  <tbody
3
- class="divide-y divide-background-brighten dark:divide-background-darken"
3
+ class="divide-background-brighten dark:divide-background-darken divide-y"
4
4
  >
5
5
  <slot />
6
6
  </tbody>
@@ -1,6 +1,6 @@
1
1
  <template>
2
2
  <thead
3
- class="sticky top-0 z-10 bg-background-brighten dark:bg-background-darken"
3
+ class="bg-background-brighten dark:bg-background-darken sticky top-0 z-10"
4
4
  >
5
5
  <slot />
6
6
  </thead>
package/nuxt.config.ts CHANGED
@@ -1,6 +1,4 @@
1
- import { dirname, join } from 'node:path'
2
- import { fileURLToPath } from 'node:url'
3
-
1
+ import tailwindcss from '@tailwindcss/vite'
4
2
  import { defu } from 'defu'
5
3
 
6
4
  import {
@@ -12,9 +10,6 @@ import {
12
10
  } from './utils/constants'
13
11
  import { VIO_NUXT_BASE_CONFIG } from './utils/nuxt'
14
12
 
15
- const currentDir = dirname(fileURLToPath(import.meta.url))
16
-
17
- // https://v3.nuxtjs.org/api/configuration/nuxt.config
18
13
  export default defineNuxtConfig(
19
14
  defu(
20
15
  {
@@ -30,6 +25,7 @@ export default defineNuxtConfig(
30
25
  },
31
26
  },
32
27
  compatibilityDate: '2024-04-03',
28
+ css: ['./assets/css/tailwind.css'],
33
29
  ...(process.env.NUXT_PUBLIC_SITE_URL
34
30
  ? {}
35
31
  : {
@@ -54,7 +50,6 @@ export default defineNuxtConfig(
54
50
  '@nuxtjs/html-validator',
55
51
  '@nuxtjs/i18n',
56
52
  '@nuxtjs/seo',
57
- '@nuxtjs/tailwindcss',
58
53
  '@pinia/nuxt',
59
54
  'nuxt-gtag',
60
55
  (_options, nuxt) => {
@@ -125,6 +120,9 @@ export default defineNuxtConfig(
125
120
  // },
126
121
  },
127
122
  },
123
+ vite: {
124
+ plugins: [tailwindcss()],
125
+ },
128
126
 
129
127
  // modules
130
128
  colorMode: {
@@ -256,9 +254,6 @@ export default defineNuxtConfig(
256
254
  sitemap: {
257
255
  credits: false,
258
256
  },
259
- tailwindcss: {
260
- cssPath: join(currentDir, './assets/css/tailwind.css'),
261
- },
262
257
 
263
258
  // environments
264
259
  $development: {
package/package.json CHANGED
@@ -1,19 +1,18 @@
1
1
  {
2
2
  "dependencies": {
3
- "@dargmuesli/nuxt-cookie-control": "8.4.20",
4
- "@eslint/compat": "1.2.5",
3
+ "@dargmuesli/nuxt-cookie-control": "8.5.2",
4
+ "@eslint/compat": "1.2.6",
5
5
  "@heroicons/vue": "2.2.0",
6
6
  "@http-util/status-i18n": "0.8.1",
7
7
  "@intlify/eslint-plugin-vue-i18n": "4.0.0-next.1",
8
- "@nuxt/devtools": "1.7.0",
9
- "@nuxt/eslint": "0.7.5",
8
+ "@nuxt/devtools": "2.1.0",
9
+ "@nuxt/eslint": "1.0.1",
10
10
  "@nuxt/image": "1.9.0",
11
11
  "@nuxtjs/color-mode": "3.5.2",
12
12
  "@nuxtjs/html-validator": "1.8.2",
13
13
  "@nuxtjs/i18n": "9.1.1",
14
- "@nuxtjs/seo": "2.0.2",
15
- "@nuxtjs/tailwindcss": "6.12.2",
16
- "@pinia/nuxt": "0.9.0",
14
+ "@nuxtjs/seo": "2.1.1",
15
+ "@pinia/nuxt": "0.10.1",
17
16
  "@tailwindcss/forms": "0.5.10",
18
17
  "@tailwindcss/typography": "0.5.16",
19
18
  "@types/lodash-es": "4.17.12",
@@ -23,40 +22,41 @@
23
22
  "@vuelidate/validators": "2.0.4",
24
23
  "clipboardy": "4.0.0",
25
24
  "dayjs": "2.0.0-alpha.4",
26
- "eslint": "9.18.0",
25
+ "eslint": "9.20.1",
27
26
  "eslint-config-prettier": "10.0.1",
28
27
  "eslint-plugin-compat": "6.0.2",
29
- "eslint-plugin-prettier": "5.2.1",
28
+ "eslint-plugin-prettier": "5.2.3",
30
29
  "eslint-plugin-yml": "1.16.0",
31
- "globals": "15.14.0",
30
+ "globals": "15.15.0",
32
31
  "jiti": "2.4.2",
33
- "jose": "5.9.6",
32
+ "jose": "5.10.0",
34
33
  "nuxt-gtag": "3.0.2",
35
34
  "nuxt-security": "2.1.5",
36
- "sweetalert2": "11.15.10",
35
+ "sweetalert2": "11.17.2",
37
36
  "vue-tsc": "2.2.0"
38
37
  },
39
38
  "devDependencies": {
40
- "@unhead/vue": "1.11.16",
39
+ "@tailwindcss/vite": "4.0.6",
40
+ "@unhead/vue": "1.11.19",
41
41
  "@urql/devtools": "2.0.3",
42
- "@urql/exchange-graphcache": "7.2.1",
42
+ "@urql/exchange-graphcache": "7.2.2",
43
43
  "consola": "3.4.0",
44
44
  "cookie-es": "1.2.2",
45
45
  "defu": "6.1.4",
46
- "h3": "1.13.1",
46
+ "h3": "1.15.0",
47
47
  "lodash-es": "4.17.21",
48
- "nuxt": "3.15.1",
49
- "pinia": "2.3.0",
50
- "prettier": "3.4.2",
51
- "prettier-plugin-tailwindcss": "0.6.9",
48
+ "nuxt": "3.15.4",
49
+ "pinia": "3.0.1",
50
+ "prettier": "3.5.1",
51
+ "prettier-plugin-tailwindcss": "0.6.11",
52
52
  "serve": "14.2.4",
53
53
  "sharp": "0.33.5",
54
- "stylelint": "16.13.1",
55
- "stylelint-config-recommended-vue": "1.5.0",
54
+ "stylelint": "16.14.1",
55
+ "stylelint-config-recommended-vue": "1.6.0",
56
56
  "stylelint-config-standard": "37.0.0",
57
- "stylelint-no-unsupported-browser-features": "8.0.2",
58
- "tailwindcss": "3.4.17",
59
- "unhead": "1.11.16",
57
+ "stylelint-no-unsupported-browser-features": "8.0.4",
58
+ "tailwindcss": "4.0.6",
59
+ "unhead": "1.11.19",
60
60
  "vue": "3.5.13",
61
61
  "vue-router": "4.5.0"
62
62
  },
@@ -80,13 +80,12 @@
80
80
  "error.vue",
81
81
  "i18n.config.ts",
82
82
  "nuxt.config.ts",
83
- "package.json",
84
- "tailwind.config.ts"
83
+ "package.json"
85
84
  ],
86
85
  "main": "nuxt.config.ts",
87
86
  "name": "@dargmuesli/nuxt-vio",
88
87
  "peerDependencies": {
89
- "nuxt": "3.15.1",
88
+ "nuxt": "3.15.4",
90
89
  "vue": "3.5.13",
91
90
  "vue-router": "4.5.0"
92
91
  },
@@ -101,8 +100,7 @@
101
100
  "build": "pnpm run build:node",
102
101
  "build:node": "nuxt build .playground",
103
102
  "build:static": "nuxt generate .playground",
104
- "build:static:test": "cross-env NUXT_PUBLIC_VIO_IS_TESTING=true SITE_URL=https://localhost:3002 pnpm run build:static",
105
- "build:test": "pnpm run build:static:test",
103
+ "build:static:test": "SITE_URL=https://localhost:3002 pnpm run build:static",
106
104
  "dev": "pnpm run start:dev",
107
105
  "generate": "pnpm run build:static",
108
106
  "lint:fix": "pnpm run lint:js --fix && pnpm run lint:ts --fix && pnpm run lint:style --fix",
@@ -113,13 +111,11 @@
113
111
  "lint": "pnpm run lint:js && pnpm run lint:ts && pnpm run lint:style",
114
112
  "prepare": "nuxt prepare && nuxt prepare .playground && ./.config/certificates/mkcert.sh",
115
113
  "preview": "nuxt preview .playground",
114
+ "start": "pnpm run start:node",
116
115
  "start:dev": "nuxt dev .playground",
117
116
  "start:node": "node .playground/.output/server/index.mjs",
118
- "start:node:test": "PORT=3001 pnpm run start:node",
119
- "start:static": "serve .playground/.output/public --ssl-cert ./.config/certificates/ssl.crt --ssl-key ./.config/certificates/ssl.key",
120
- "start:static:test": "PORT=3002 pnpm run start:static",
121
- "start:test": "pnpm run start:static:test"
117
+ "start:static": "serve .playground/.output/public --ssl-cert ./.config/certificates/ssl.crt --ssl-key ./.config/certificates/ssl.key"
122
118
  },
123
119
  "type": "module",
124
- "version": "16.1.0-beta.1"
120
+ "version": "17.0.0-beta.1"
125
121
  }
@@ -1,253 +0,0 @@
1
- import type { ModuleOptions } from '@nuxtjs/tailwindcss'
2
- import formsPlugin from '@tailwindcss/forms'
3
- import typographyPlugin from '@tailwindcss/typography'
4
- import type { PluginAPI } from 'tailwindcss/types/config'
5
-
6
- const heading = (theme: PluginAPI['theme']): Record<string, string> => ({
7
- fontWeight: theme('fontWeight.bold'),
8
- // marginBottom: theme('margin.1'),
9
- // marginTop: theme('margin.4'),
10
- // set overflow truncate/ellipsis in the surrounding container, or larger fonts will be cut off due to their line-heights
11
- })
12
-
13
- const prose = (theme: PluginAPI['theme']) => ({
14
- css: {
15
- a: {
16
- color: theme('colors.link'),
17
- textDecoration: 'none',
18
- },
19
- h1: {
20
- lineHeight: theme('lineHeight.snug'),
21
- },
22
- h2: {
23
- lineHeight: theme('lineHeight.snug'),
24
- },
25
- h3: {
26
- lineHeight: theme('lineHeight.snug'),
27
- },
28
- h4: {
29
- lineHeight: theme('lineHeight.snug'),
30
- },
31
- h5: {
32
- lineHeight: theme('lineHeight.snug'),
33
- },
34
- h6: {
35
- lineHeight: theme('lineHeight.snug'),
36
- },
37
- },
38
- })
39
-
40
- export default {
41
- darkMode: 'class',
42
- plugins: [
43
- formsPlugin,
44
- typographyPlugin,
45
- ({ addBase, addComponents, addUtilities, theme }: PluginAPI) => {
46
- addBase({
47
- ':disabled': {
48
- cursor: theme('cursor.not-allowed'),
49
- opacity: theme('opacity.50'),
50
- },
51
- 'a[target="_blank"]:not([is-external-icon-disabled]):after': {
52
- backgroundColor: 'currentColor',
53
- content: '""',
54
- display: 'inline-table', // inline-table centers the element vertically in the tiptap text area, instead of inline-block
55
- mask: 'url() no-repeat 50% 50%',
56
- maskSize: 'cover',
57
- height: theme('fontSize.xs'),
58
- marginLeft: '5px',
59
- width: theme('fontSize.xs'),
60
- },
61
- 'a:focus': {
62
- // @apply outline-none ring
63
- outline: '2px solid transparent',
64
- outlineOffset: '2px',
65
- boxShadow:
66
- 'var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color)',
67
- },
68
- address: {
69
- margin: theme('margin.4'),
70
- },
71
- 'button:focus': {
72
- // @apply outline-none ring
73
- outline: '2px solid transparent',
74
- outlineOffset: '2px',
75
- boxShadow:
76
- 'var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color)',
77
- },
78
- h1: {
79
- ...heading(theme),
80
- fontSize: theme('fontSize.4xl'),
81
- // marginBottom: theme('margin.4'),
82
- textAlign: 'center',
83
- },
84
- h2: {
85
- ...heading(theme),
86
- fontSize: theme('fontSize.3xl'),
87
- },
88
- h3: {
89
- ...heading(theme),
90
- fontSize: theme('fontSize.2xl'),
91
- },
92
- h4: {
93
- ...heading(theme),
94
- fontSize: theme('fontSize.xl'),
95
- },
96
- h5: {
97
- ...heading(theme),
98
- fontSize: theme('fontSize.lg'),
99
- },
100
- h6: {
101
- ...heading(theme),
102
- },
103
- img: {
104
- '&::before': {
105
- alignItems: 'center',
106
- display: 'flex',
107
- height: '100%',
108
- justifyContent: 'center',
109
- },
110
- },
111
- table: {
112
- width: '100%',
113
- },
114
- td: {
115
- padding: theme('padding.4') + ' ' + theme('padding.6'),
116
- whiteSpace: 'nowrap',
117
- },
118
- th: {
119
- padding: theme('padding.3') + ' ' + theme('padding.6'),
120
- textAlign: 'left',
121
- fontSize: theme('fontSize.xs'),
122
- fontWeight: theme('fontWeight.medium'),
123
- textTransform: 'uppercase',
124
- letterSpacing: theme('letterSpacing.wider'),
125
- },
126
- })
127
- addComponents({
128
- '::placeholder': {
129
- fontStyle: 'italic',
130
- '.form-input&,.form-textarea&': {
131
- opacity: '0.5',
132
- },
133
- },
134
- '.form-input': {
135
- appearance: 'none',
136
- backgroundColor: theme('colors.gray.50'),
137
- borderColor: theme('colors.gray.300'),
138
- borderRadius: theme('borderRadius.DEFAULT'),
139
- borderWidth: theme('borderWidth.DEFAULT'),
140
- boxShadow: theme('boxShadow.sm'),
141
- color: theme('colors.text.dark'),
142
- lineHeight: theme('lineHeight.tight'),
143
- padding: theme('padding.2') + ' ' + theme('padding.4'),
144
- width: theme('width.full'),
145
- '&:focus': {
146
- backgroundColor: theme('colors.white'),
147
- },
148
- },
149
- '.form-input-error': {
150
- '.form-input': {
151
- borderColor: theme('colors.red.500'),
152
- },
153
- },
154
- '.form-input-success': {
155
- '.form-input': {
156
- borderColor: theme('colors.green.600'),
157
- },
158
- },
159
- '.form-input-warning': {
160
- '.form-input': {
161
- borderColor: theme('colors.yellow.600'),
162
- },
163
- },
164
- '.fullscreen': {
165
- bottom: '0',
166
- height: theme('height.full'),
167
- left: '0',
168
- position: 'absolute',
169
- right: '0',
170
- top: '0',
171
- width: theme('width.full'),
172
- },
173
- '.object-position-custom': {
174
- objectPosition: '50% 30%',
175
- },
176
- })
177
- addUtilities({
178
- '.disabled': {
179
- cursor: theme('cursor.not-allowed'),
180
- opacity: theme('opacity.50'),
181
- },
182
- })
183
- },
184
- ],
185
- theme: {
186
- extend: {
187
- animation: {
188
- shake: 'shake 0.6s ease-in-out 0s 1 normal forwards running',
189
- },
190
- colors: {
191
- background: {
192
- bright: 'rgb(var(--color-background-bright))',
193
- brighten: 'rgb(var(--color-background-brighten))',
194
- dark: 'rgb(var(--color-background-dark))',
195
- darken: 'rgb(var(--color-background-darken))',
196
- },
197
- link: {
198
- bright: 'rgb(var(--color-link-bright))',
199
- dark: 'rgb(var(--color-link-dark))',
200
- },
201
- text: {
202
- bright: 'rgb(var(--color-text-bright))',
203
- dark: 'rgb(var(--color-text-dark))',
204
- },
205
- vio: {
206
- primary: {
207
- bg: 'rgb(var(--color-vio-primary-bg))',
208
- text: 'rgb(var(--color-vio-primary-text))',
209
- },
210
- },
211
- },
212
- keyframes: {
213
- shake: {
214
- '0%': {
215
- transform: 'translateX(0)',
216
- },
217
- '15%': {
218
- transform: 'translateX(0.375rem)',
219
- },
220
- '30%': {
221
- transform: 'translateX(-0.375rem)',
222
- },
223
- '45%': {
224
- transform: 'translateX(0.375rem)',
225
- },
226
- '60%': {
227
- transform: 'translateX(-0.375rem)',
228
- },
229
- '75%': {
230
- transform: 'translateX(0.375rem)',
231
- },
232
- '90%': {
233
- transform: 'translateX(-0.375rem)',
234
- },
235
- '100%': {
236
- transform: 'translateX(0)',
237
- },
238
- },
239
- },
240
- screens: {
241
- 12: { raw: '(min-aspect-ratio: 2/1)' },
242
- },
243
- typography: (theme: PluginAPI['theme']) => ({
244
- DEFAULT: prose(theme),
245
- sm: prose(theme),
246
- base: prose(theme),
247
- lg: prose(theme),
248
- xl: prose(theme),
249
- '2xl': prose(theme),
250
- }),
251
- },
252
- },
253
- } as ModuleOptions['config']