create-nextjs-cms 0.9.6 → 0.9.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (184) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +71 -71
  3. package/dist/helpers/check-directory.d.ts +1 -0
  4. package/dist/helpers/check-directory.d.ts.map +1 -1
  5. package/dist/helpers/check-directory.js +98 -23
  6. package/dist/helpers/utils.js +16 -16
  7. package/dist/index.js +13 -8
  8. package/dist/lib/create-project.js +1 -1
  9. package/dist/lib/section-creators.js +166 -166
  10. package/package.json +1 -1
  11. package/templates/default/.eslintrc.json +5 -5
  12. package/templates/default/.prettierignore +7 -7
  13. package/templates/default/.prettierrc.json +27 -27
  14. package/templates/default/CHANGELOG.md +140 -140
  15. package/templates/default/_gitignore +57 -57
  16. package/templates/default/app/(auth)/auth/login/LoginPage.tsx +192 -192
  17. package/templates/default/app/(auth)/auth/login/page.tsx +11 -11
  18. package/templates/default/app/(auth)/auth-language-provider.tsx +34 -34
  19. package/templates/default/app/(auth)/layout.tsx +81 -81
  20. package/templates/default/app/(rootLayout)/(plugins)/[...slug]/page.tsx +40 -40
  21. package/templates/default/app/(rootLayout)/(plugins)/[...slug]/plugin-server-registry.ts +16 -16
  22. package/templates/default/app/(rootLayout)/admins/page.tsx +10 -10
  23. package/templates/default/app/(rootLayout)/browse/[section]/[page]/page.tsx +22 -22
  24. package/templates/default/app/(rootLayout)/categorized/[section]/page.tsx +15 -15
  25. package/templates/default/app/(rootLayout)/dashboard/page.tsx +63 -63
  26. package/templates/default/app/(rootLayout)/edit/[section]/[itemId]/page.tsx +20 -20
  27. package/templates/default/app/(rootLayout)/layout.tsx +81 -81
  28. package/templates/default/app/(rootLayout)/loading.tsx +10 -10
  29. package/templates/default/app/(rootLayout)/log/page.tsx +7 -7
  30. package/templates/default/app/(rootLayout)/new/[section]/page.tsx +15 -15
  31. package/templates/default/app/(rootLayout)/section/[section]/page.tsx +19 -19
  32. package/templates/default/app/(rootLayout)/settings/page.tsx +13 -13
  33. package/templates/default/app/_trpc/client.ts +3 -3
  34. package/templates/default/app/api/auth/csrf/route.ts +25 -25
  35. package/templates/default/app/api/auth/refresh/route.ts +10 -10
  36. package/templates/default/app/api/auth/route.ts +49 -49
  37. package/templates/default/app/api/auth/session/route.ts +20 -20
  38. package/templates/default/app/api/document/route.ts +165 -165
  39. package/templates/default/app/api/editor/photo/route.ts +49 -49
  40. package/templates/default/app/api/photo/route.ts +27 -27
  41. package/templates/default/app/api/submit/section/item/[slug]/route.ts +95 -95
  42. package/templates/default/app/api/submit/section/item/route.ts +56 -56
  43. package/templates/default/app/api/submit/section/simple/route.ts +86 -86
  44. package/templates/default/app/api/trpc/[trpc]/route.ts +33 -33
  45. package/templates/default/app/api/video/route.ts +174 -174
  46. package/templates/default/app/globals.css +228 -228
  47. package/templates/default/app/providers.tsx +152 -152
  48. package/templates/default/cms.config.ts +57 -58
  49. package/templates/default/components/AdminCard.tsx +166 -166
  50. package/templates/default/components/AdminEditPage.tsx +124 -124
  51. package/templates/default/components/AdminPrivilegeCard.tsx +185 -185
  52. package/templates/default/components/AdminsPage.tsx +43 -43
  53. package/templates/default/components/AnalyticsPage.tsx +144 -144
  54. package/templates/default/components/BarChartBox.tsx +42 -42
  55. package/templates/default/components/BrowsePage.tsx +106 -106
  56. package/templates/default/components/CategorizedSectionPage.tsx +31 -31
  57. package/templates/default/components/CategoryDeleteConfirmPage.tsx +130 -130
  58. package/templates/default/components/CategorySectionSelectInput.tsx +140 -140
  59. package/templates/default/components/ConditionalFields.tsx +49 -49
  60. package/templates/default/components/ContainerBox.tsx +24 -24
  61. package/templates/default/components/DashboardPageAlt.tsx +45 -45
  62. package/templates/default/components/DefaultNavItems.tsx +3 -3
  63. package/templates/default/components/Dropzone.tsx +154 -154
  64. package/templates/default/components/ErrorComponent.tsx +16 -16
  65. package/templates/default/components/GalleryPhoto.tsx +93 -93
  66. package/templates/default/components/InfoCard.tsx +93 -93
  67. package/templates/default/components/ItemEditPage.tsx +294 -294
  68. package/templates/default/components/Layout.tsx +84 -84
  69. package/templates/default/components/LoadingSpinners.tsx +67 -67
  70. package/templates/default/components/LocaleSwitcher.tsx +89 -89
  71. package/templates/default/components/LogPage.tsx +107 -107
  72. package/templates/default/components/Modal.tsx +166 -166
  73. package/templates/default/components/Navbar.tsx +258 -258
  74. package/templates/default/components/NewAdminForm.tsx +173 -173
  75. package/templates/default/components/NewPage.tsx +206 -206
  76. package/templates/default/components/NewVariantComponent.tsx +229 -229
  77. package/templates/default/components/PhotoGallery.tsx +35 -35
  78. package/templates/default/components/PieChartBox.tsx +101 -101
  79. package/templates/default/components/ProgressBar.tsx +48 -48
  80. package/templates/default/components/ProtectedDocument.tsx +44 -44
  81. package/templates/default/components/ProtectedImage.tsx +143 -143
  82. package/templates/default/components/ProtectedVideo.tsx +76 -76
  83. package/templates/default/components/SectionIcon.tsx +8 -8
  84. package/templates/default/components/SectionItemCard.tsx +144 -144
  85. package/templates/default/components/SectionItemStatusBadge.tsx +17 -17
  86. package/templates/default/components/SectionPage.tsx +205 -205
  87. package/templates/default/components/SelectBox.tsx +98 -98
  88. package/templates/default/components/SelectInputButtons.tsx +125 -125
  89. package/templates/default/components/SettingsPage.tsx +232 -232
  90. package/templates/default/components/Sidebar.tsx +204 -204
  91. package/templates/default/components/SidebarDropdownItem.tsx +83 -83
  92. package/templates/default/components/SidebarItem.tsx +24 -24
  93. package/templates/default/components/ThemeProvider.tsx +8 -8
  94. package/templates/default/components/TooltipComponent.tsx +27 -27
  95. package/templates/default/components/VariantCard.tsx +124 -124
  96. package/templates/default/components/VariantEditPage.tsx +230 -230
  97. package/templates/default/components/analytics/BounceRate.tsx +70 -70
  98. package/templates/default/components/analytics/LivePageViews.tsx +55 -55
  99. package/templates/default/components/analytics/LiveUsersCount.tsx +33 -33
  100. package/templates/default/components/analytics/MonthlyPageViews.tsx +42 -42
  101. package/templates/default/components/analytics/TopCountries.tsx +52 -52
  102. package/templates/default/components/analytics/TopDevices.tsx +46 -46
  103. package/templates/default/components/analytics/TopMediums.tsx +58 -58
  104. package/templates/default/components/analytics/TopSources.tsx +45 -45
  105. package/templates/default/components/analytics/TotalPageViews.tsx +41 -41
  106. package/templates/default/components/analytics/TotalSessions.tsx +41 -41
  107. package/templates/default/components/analytics/TotalUniqueUsers.tsx +41 -41
  108. package/templates/default/components/custom/RightHomeRoomVariantCard.tsx +138 -138
  109. package/templates/default/components/dndKit/Draggable.tsx +21 -21
  110. package/templates/default/components/dndKit/Droppable.tsx +20 -20
  111. package/templates/default/components/dndKit/SortableItem.tsx +18 -18
  112. package/templates/default/components/form/Form.tsx +370 -370
  113. package/templates/default/components/form/FormInputElement.tsx +70 -70
  114. package/templates/default/components/form/FormInputs.tsx +136 -136
  115. package/templates/default/components/form/helpers/_section-hot-reload.js +1 -1
  116. package/templates/default/components/form/helpers/util.ts +17 -17
  117. package/templates/default/components/form/inputs/CheckboxFormInput.tsx +46 -46
  118. package/templates/default/components/form/inputs/ColorFormInput.tsx +44 -44
  119. package/templates/default/components/form/inputs/DateFormInput.tsx +167 -110
  120. package/templates/default/components/form/inputs/DateRangeFormInput.tsx +23 -1
  121. package/templates/default/components/form/inputs/DocumentFormInput.tsx +222 -222
  122. package/templates/default/components/form/inputs/MapFormInput.tsx +140 -140
  123. package/templates/default/components/form/inputs/MultipleSelectFormInput.tsx +85 -85
  124. package/templates/default/components/form/inputs/NumberFormInput.tsx +43 -43
  125. package/templates/default/components/form/inputs/PasswordFormInput.tsx +47 -47
  126. package/templates/default/components/form/inputs/PhotoFormInput.tsx +275 -275
  127. package/templates/default/components/form/inputs/RichTextFormInput.tsx +138 -138
  128. package/templates/default/components/form/inputs/SelectFormInput.tsx +175 -175
  129. package/templates/default/components/form/inputs/SlugFormInput.tsx +131 -131
  130. package/templates/default/components/form/inputs/TagsFormInput.tsx +265 -265
  131. package/templates/default/components/form/inputs/TextFormInput.tsx +51 -51
  132. package/templates/default/components/form/inputs/TextareaFormInput.tsx +50 -50
  133. package/templates/default/components/form/inputs/VideoFormInput.tsx +118 -118
  134. package/templates/default/components/multi-select.tsx +1146 -1146
  135. package/templates/default/components/pagination/Pagination.tsx +36 -36
  136. package/templates/default/components/pagination/PaginationButtons.tsx +147 -147
  137. package/templates/default/components/theme-toggle.tsx +39 -39
  138. package/templates/default/components/ui/accordion.tsx +53 -53
  139. package/templates/default/components/ui/alert-dialog.tsx +157 -157
  140. package/templates/default/components/ui/alert.tsx +47 -47
  141. package/templates/default/components/ui/badge.tsx +38 -38
  142. package/templates/default/components/ui/button.tsx +62 -62
  143. package/templates/default/components/ui/calendar.tsx +166 -166
  144. package/templates/default/components/ui/card.tsx +43 -43
  145. package/templates/default/components/ui/checkbox.tsx +29 -29
  146. package/templates/default/components/ui/command.tsx +137 -137
  147. package/templates/default/components/ui/custom-alert-dialog.tsx +113 -113
  148. package/templates/default/components/ui/custom-dialog.tsx +123 -123
  149. package/templates/default/components/ui/dialog.tsx +123 -123
  150. package/templates/default/components/ui/direction.tsx +22 -22
  151. package/templates/default/components/ui/dropdown-menu.tsx +182 -182
  152. package/templates/default/components/ui/input-group.tsx +54 -54
  153. package/templates/default/components/ui/input.tsx +22 -22
  154. package/templates/default/components/ui/label.tsx +19 -19
  155. package/templates/default/components/ui/popover.tsx +42 -42
  156. package/templates/default/components/ui/progress.tsx +31 -31
  157. package/templates/default/components/ui/scroll-area.tsx +42 -42
  158. package/templates/default/components/ui/select.tsx +165 -165
  159. package/templates/default/components/ui/separator.tsx +28 -28
  160. package/templates/default/components/ui/sheet.tsx +103 -103
  161. package/templates/default/components/ui/spinner.tsx +16 -16
  162. package/templates/default/components/ui/switch.tsx +29 -29
  163. package/templates/default/components/ui/table.tsx +83 -83
  164. package/templates/default/components/ui/tabs.tsx +55 -55
  165. package/templates/default/components/ui/toast.tsx +113 -113
  166. package/templates/default/components/ui/toaster.tsx +35 -35
  167. package/templates/default/components/ui/tooltip.tsx +30 -30
  168. package/templates/default/components/ui/use-toast.ts +188 -188
  169. package/templates/default/components.json +21 -21
  170. package/templates/default/context/ModalProvider.tsx +53 -53
  171. package/templates/default/drizzle.config.ts +4 -4
  172. package/templates/default/dynamic-schemas/schema.ts +475 -0
  173. package/templates/default/env/env.js +130 -130
  174. package/templates/default/envConfig.ts +4 -4
  175. package/templates/default/hooks/useModal.ts +8 -8
  176. package/templates/default/lib/apiHelpers.ts +92 -92
  177. package/templates/default/lib/postinstall.js +14 -14
  178. package/templates/default/lib/utils.ts +6 -6
  179. package/templates/default/next-env.d.ts +6 -6
  180. package/templates/default/next.config.ts +23 -23
  181. package/templates/default/package.json +1 -1
  182. package/templates/default/postcss.config.mjs +6 -6
  183. package/templates/default/proxy.ts +32 -32
  184. package/templates/default/tsconfig.json +48 -48
@@ -8,67 +8,67 @@ export async function createBlogSection(targetDir) {
8
8
  const blogSectionPath = path.join(sectionsDir, 'blog.section.ts');
9
9
  // Ensure sections directory exists
10
10
  await fs.ensureDir(sectionsDir);
11
- const blogSectionContent = `import { photoField, richTextField, textField, tagsField } from 'nextjs-cms/core/fields'
12
- import { hasItemsSection } from 'nextjs-cms/core/sections'
13
-
14
- const title = textField({
15
- name: 'title',
16
- label: 'Title',
17
- required: true,
18
- order: 1,
19
- })
20
-
21
- const coverPhotoField = photoField({
22
- name: 'coverphoto',
23
- label: 'Cover Photo',
24
- required: true,
25
- order: 2,
26
- fileType: ['jpg', 'jpeg', 'png', 'webp'],
27
- })
28
-
29
- const content = richTextField({
30
- name: 'content',
31
- label: 'Content',
32
- required: true,
33
- order: 3,
34
- })
35
-
36
- const keywords = tagsField({
37
- name: 'keywords',
38
- label: 'Keywords',
39
- required: false,
40
- order: 4,
41
- })
42
-
43
- export default hasItemsSection({
44
- name: 'blog',
45
- order: 1,
46
- icon: 'icon',
47
- readonly: false,
48
- headingField: title,
49
- title: {
50
- section: 'Blog',
51
- singular: 'Post',
52
- plural: 'Posts',
53
- },
54
- gallery: {
55
- db: {
56
- tableName: 'blog_gallery',
57
- identifierField: 'reference_id',
58
- photoNameField: 'photo',
59
- metaField: 'meta',
60
- },
61
- },
62
- db: {
63
- table: 'blog',
64
- },
65
- search: {
66
- searchFields: [title],
67
- },
68
- coverPhotoField: coverPhotoField,
69
- generateQR: false,
70
- fields: [title, coverPhotoField, content, keywords],
71
- })
11
+ const blogSectionContent = `import { photoField, richTextField, textField, tagsField } from 'nextjs-cms/core/fields'
12
+ import { hasItemsSection } from 'nextjs-cms/core/sections'
13
+
14
+ const title = textField({
15
+ name: 'title',
16
+ label: 'Title',
17
+ required: true,
18
+ order: 1,
19
+ })
20
+
21
+ const coverPhotoField = photoField({
22
+ name: 'coverphoto',
23
+ label: 'Cover Photo',
24
+ required: true,
25
+ order: 2,
26
+ fileType: ['jpg', 'jpeg', 'png', 'webp'],
27
+ })
28
+
29
+ const content = richTextField({
30
+ name: 'content',
31
+ label: 'Content',
32
+ required: true,
33
+ order: 3,
34
+ })
35
+
36
+ const keywords = tagsField({
37
+ name: 'keywords',
38
+ label: 'Keywords',
39
+ required: false,
40
+ order: 4,
41
+ })
42
+
43
+ export default hasItemsSection({
44
+ name: 'blog',
45
+ order: 1,
46
+ icon: 'icon',
47
+ readonly: false,
48
+ headingField: title,
49
+ title: {
50
+ section: 'Blog',
51
+ singular: 'Post',
52
+ plural: 'Posts',
53
+ },
54
+ gallery: {
55
+ db: {
56
+ tableName: 'blog_gallery',
57
+ identifierField: 'reference_id',
58
+ photoNameField: 'photo',
59
+ metaField: 'meta',
60
+ },
61
+ },
62
+ db: {
63
+ table: 'blog',
64
+ },
65
+ search: {
66
+ searchFields: [title],
67
+ },
68
+ coverPhotoField: coverPhotoField,
69
+ generateQR: false,
70
+ fields: [title, coverPhotoField, content, keywords],
71
+ })
72
72
  `;
73
73
  await fs.writeFile(blogSectionPath, blogSectionContent, 'utf-8');
74
74
  }
@@ -80,62 +80,62 @@ export async function createCategorySection(targetDir) {
80
80
  const categorySectionPath = path.join(sectionsDir, 'categories.section.ts');
81
81
  // Ensure sections directory exists
82
82
  await fs.ensureDir(sectionsDir);
83
- const categorySectionContent = `import { numberField, photoField, textField } from 'nextjs-cms/core/fields'
84
- import { categorySection } from 'nextjs-cms/core/sections'
85
-
86
- const orderInput = numberField({
87
- name: 'cat_order',
88
- label: 'Order',
89
- required: true,
90
- order: 0,
91
- })
92
-
93
- const title = textField({
94
- name: 'title',
95
- label: 'Title',
96
- required: true,
97
- order: 1,
98
- })
99
-
100
- const slugInput = textField({
101
- name: 'slug',
102
- label: 'Slug',
103
- required: true,
104
- order: 2,
105
- })
106
-
107
- const image = photoField({
108
- name: 'image',
109
- label: 'Image',
110
- required: false,
111
- order: 3,
112
- fileType: ['png', 'jpg', 'jpeg', 'webp'],
113
- })
114
-
115
- const description = textField({
116
- name: 'description',
117
- label: 'Description',
118
- required: false,
119
- order: 4,
120
- })
121
-
122
- export default categorySection({
123
- title: {
124
- section: 'Categories',
125
- singular: 'Category',
126
- plural: 'Categories',
127
- },
128
- name: 'categories',
129
- icon: 'category',
130
- headingField: title,
131
- order: 2,
132
- db: {
133
- table: 'categories',
134
- unique: [{ columns: [slugInput] }],
135
- },
136
- fields: [orderInput, title, slugInput, image, description],
137
- depth: 3,
138
- })
83
+ const categorySectionContent = `import { numberField, photoField, textField } from 'nextjs-cms/core/fields'
84
+ import { categorySection } from 'nextjs-cms/core/sections'
85
+
86
+ const orderInput = numberField({
87
+ name: 'cat_order',
88
+ label: 'Order',
89
+ required: true,
90
+ order: 0,
91
+ })
92
+
93
+ const title = textField({
94
+ name: 'title',
95
+ label: 'Title',
96
+ required: true,
97
+ order: 1,
98
+ })
99
+
100
+ const slugInput = textField({
101
+ name: 'slug',
102
+ label: 'Slug',
103
+ required: true,
104
+ order: 2,
105
+ })
106
+
107
+ const image = photoField({
108
+ name: 'image',
109
+ label: 'Image',
110
+ required: false,
111
+ order: 3,
112
+ fileType: ['png', 'jpg', 'jpeg', 'webp'],
113
+ })
114
+
115
+ const description = textField({
116
+ name: 'description',
117
+ label: 'Description',
118
+ required: false,
119
+ order: 4,
120
+ })
121
+
122
+ export default categorySection({
123
+ title: {
124
+ section: 'Categories',
125
+ singular: 'Category',
126
+ plural: 'Categories',
127
+ },
128
+ name: 'categories',
129
+ icon: 'category',
130
+ headingField: title,
131
+ order: 2,
132
+ db: {
133
+ table: 'categories',
134
+ unique: [{ columns: [slugInput] }],
135
+ },
136
+ fields: [orderInput, title, slugInput, image, description],
137
+ depth: 3,
138
+ })
139
139
  `;
140
140
  await fs.writeFile(categorySectionPath, categorySectionContent, 'utf-8');
141
141
  }
@@ -147,55 +147,55 @@ export async function createSimpleSection(targetDir) {
147
147
  const simpleSectionPath = path.join(sectionsDir, 'settings.section.ts');
148
148
  // Ensure sections directory exists
149
149
  await fs.ensureDir(sectionsDir);
150
- const simpleSectionContent = `import { richTextField, textField } from 'nextjs-cms/core/fields'
151
- import { simpleSection } from 'nextjs-cms/core/sections'
152
-
153
- const facebook = textField({
154
- name: 'facebook',
155
- label: 'Facebook',
156
- required: false,
157
- order: 1,
158
- })
159
-
160
- const instagram = textField({
161
- name: 'instagram',
162
- label: 'Instagram',
163
- required: false,
164
- order: 2,
165
- })
166
-
167
- const twitter = textField({
168
- name: 'twitter',
169
- label: 'Twitter',
170
- required: false,
171
- order: 3,
172
- })
173
-
174
- const about = richTextField({
175
- name: 'about',
176
- label: 'About',
177
- required: false,
178
- order: 4,
179
- })
180
-
181
- const contact = richTextField({
182
- name: 'contact',
183
- label: 'Contact',
184
- required: false,
185
- order: 5,
186
- })
187
-
188
- export default simpleSection({
189
- name: 'settings',
190
- order: 3,
191
- icon: 'settings',
192
- readonly: false,
193
- title: 'Site Settings',
194
- db: {
195
- table: 'settings',
196
- },
197
- fields: [facebook, instagram, twitter, about, contact],
198
- })
150
+ const simpleSectionContent = `import { richTextField, textField } from 'nextjs-cms/core/fields'
151
+ import { simpleSection } from 'nextjs-cms/core/sections'
152
+
153
+ const facebook = textField({
154
+ name: 'facebook',
155
+ label: 'Facebook',
156
+ required: false,
157
+ order: 1,
158
+ })
159
+
160
+ const instagram = textField({
161
+ name: 'instagram',
162
+ label: 'Instagram',
163
+ required: false,
164
+ order: 2,
165
+ })
166
+
167
+ const twitter = textField({
168
+ name: 'twitter',
169
+ label: 'Twitter',
170
+ required: false,
171
+ order: 3,
172
+ })
173
+
174
+ const about = richTextField({
175
+ name: 'about',
176
+ label: 'About',
177
+ required: false,
178
+ order: 4,
179
+ })
180
+
181
+ const contact = richTextField({
182
+ name: 'contact',
183
+ label: 'Contact',
184
+ required: false,
185
+ order: 5,
186
+ })
187
+
188
+ export default simpleSection({
189
+ name: 'settings',
190
+ order: 3,
191
+ icon: 'settings',
192
+ readonly: false,
193
+ title: 'Site Settings',
194
+ db: {
195
+ table: 'settings',
196
+ },
197
+ fields: [facebook, instagram, twitter, about, contact],
198
+ })
199
199
  `;
200
200
  await fs.writeFile(simpleSectionPath, simpleSectionContent, 'utf-8');
201
201
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "create-nextjs-cms",
3
- "version": "0.9.6",
3
+ "version": "0.9.7",
4
4
  "private": false,
5
5
  "type": "module",
6
6
  "bin": {
@@ -1,5 +1,5 @@
1
- {
2
- "extends": ["next/core-web-vitals", "prettier", "next", "plugin:drizzle/recommended"],
3
- "parser": "@typescript-eslint/parser",
4
- "plugins": ["@typescript-eslint", "prettier", "drizzle"]
5
- }
1
+ {
2
+ "extends": ["next/core-web-vitals", "prettier", "next", "plugin:drizzle/recommended"],
3
+ "parser": "@typescript-eslint/parser",
4
+ "plugins": ["@typescript-eslint", "prettier", "drizzle"]
5
+ }
@@ -1,7 +1,7 @@
1
- build/*
2
- dist/*
3
- public/*
4
- .next/*
5
- node_modules/*
6
- package.json
7
- *.log
1
+ build/*
2
+ dist/*
3
+ public/*
4
+ .next/*
5
+ node_modules/*
6
+ package.json
7
+ *.log
@@ -1,27 +1,27 @@
1
- {
2
- "arrowParens": "always",
3
- "bracketSpacing": true,
4
- "embeddedLanguageFormatting": "auto",
5
- "htmlWhitespaceSensitivity": "css",
6
- "insertPragma": false,
7
- "jsxSingleQuote": true,
8
- "printWidth": 120,
9
- "proseWrap": "preserve",
10
- "quoteProps": "as-needed",
11
- "requirePragma": false,
12
- "semi": false,
13
- "singleQuote": true,
14
- "tabWidth": 4,
15
- "trailingComma": "all",
16
- "useTabs": false,
17
- "vueIndentScriptAndStyle": false,
18
- "overrides": [
19
- {
20
- "files": "*.json",
21
- "options": {
22
- "tabWidth": 4
23
- }
24
- }
25
- ],
26
- "plugins": ["prettier-plugin-tailwindcss"]
27
- }
1
+ {
2
+ "arrowParens": "always",
3
+ "bracketSpacing": true,
4
+ "embeddedLanguageFormatting": "auto",
5
+ "htmlWhitespaceSensitivity": "css",
6
+ "insertPragma": false,
7
+ "jsxSingleQuote": true,
8
+ "printWidth": 120,
9
+ "proseWrap": "preserve",
10
+ "quoteProps": "as-needed",
11
+ "requirePragma": false,
12
+ "semi": false,
13
+ "singleQuote": true,
14
+ "tabWidth": 4,
15
+ "trailingComma": "all",
16
+ "useTabs": false,
17
+ "vueIndentScriptAndStyle": false,
18
+ "overrides": [
19
+ {
20
+ "files": "*.json",
21
+ "options": {
22
+ "tabWidth": 4
23
+ }
24
+ }
25
+ ],
26
+ "plugins": ["prettier-plugin-tailwindcss"]
27
+ }