@actuate-media/cms-admin 0.9.0 → 0.11.0

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 (294) hide show
  1. package/dist/AdminRoot.d.ts.map +1 -1
  2. package/dist/AdminRoot.js +8 -5
  3. package/dist/AdminRoot.js.map +1 -1
  4. package/dist/__tests__/layout/primitives.test.d.ts +2 -0
  5. package/dist/__tests__/layout/primitives.test.d.ts.map +1 -0
  6. package/dist/__tests__/layout/primitives.test.js +34 -0
  7. package/dist/__tests__/layout/primitives.test.js.map +1 -0
  8. package/dist/__tests__/lib/cv.test.d.ts +2 -0
  9. package/dist/__tests__/lib/cv.test.d.ts.map +1 -0
  10. package/dist/__tests__/lib/cv.test.js +66 -0
  11. package/dist/__tests__/lib/cv.test.js.map +1 -0
  12. package/dist/actuate-admin.css +1 -1
  13. package/dist/assets/actuate-logo.d.ts +36 -0
  14. package/dist/assets/actuate-logo.d.ts.map +1 -0
  15. package/dist/assets/actuate-logo.js +15 -0
  16. package/dist/assets/actuate-logo.js.map +1 -0
  17. package/dist/components/Breadcrumbs.js +2 -2
  18. package/dist/components/CommandPalette.js +10 -10
  19. package/dist/components/ContentOverviewChart.js +3 -3
  20. package/dist/components/ErrorBoundary.js +1 -1
  21. package/dist/components/FocalPointPicker.js +2 -2
  22. package/dist/components/FolderTree.js +20 -20
  23. package/dist/components/LivePreview.js +3 -3
  24. package/dist/components/LocaleSwitcher.js +1 -1
  25. package/dist/components/MediaPickerModal.js +4 -4
  26. package/dist/components/PresenceIndicator.js +1 -1
  27. package/dist/components/SEOConfigPanel.d.ts +2 -0
  28. package/dist/components/SEOConfigPanel.d.ts.map +1 -0
  29. package/dist/components/SEOConfigPanel.js +174 -0
  30. package/dist/components/SEOConfigPanel.js.map +1 -0
  31. package/dist/components/SEOPanel.js +9 -9
  32. package/dist/components/SEOPerformance.js +2 -2
  33. package/dist/components/SchedulePublishDialog.d.ts +18 -0
  34. package/dist/components/SchedulePublishDialog.d.ts.map +1 -0
  35. package/dist/components/SchedulePublishDialog.js +106 -0
  36. package/dist/components/SchedulePublishDialog.js.map +1 -0
  37. package/dist/components/SharePreviewLinkDialog.d.ts +17 -0
  38. package/dist/components/SharePreviewLinkDialog.d.ts.map +1 -0
  39. package/dist/components/SharePreviewLinkDialog.js +83 -0
  40. package/dist/components/SharePreviewLinkDialog.js.map +1 -0
  41. package/dist/components/TipTapEditor.js +5 -5
  42. package/dist/components/VersionHistory.js +2 -2
  43. package/dist/components/ui/Badge.d.ts +33 -3
  44. package/dist/components/ui/Badge.d.ts.map +1 -1
  45. package/dist/components/ui/Badge.js +42 -8
  46. package/dist/components/ui/Badge.js.map +1 -1
  47. package/dist/components/ui/Button.d.ts +19 -8
  48. package/dist/components/ui/Button.d.ts.map +1 -1
  49. package/dist/components/ui/Button.js +35 -14
  50. package/dist/components/ui/Button.js.map +1 -1
  51. package/dist/components/ui/Card.d.ts +26 -0
  52. package/dist/components/ui/Card.d.ts.map +1 -0
  53. package/dist/components/ui/Card.js +45 -0
  54. package/dist/components/ui/Card.js.map +1 -0
  55. package/dist/components/ui/DataTable.js +1 -1
  56. package/dist/components/ui/Input.d.ts +15 -0
  57. package/dist/components/ui/Input.d.ts.map +1 -0
  58. package/dist/components/ui/Input.js +23 -0
  59. package/dist/components/ui/Input.js.map +1 -0
  60. package/dist/components/ui/SearchInput.js +1 -1
  61. package/dist/components/ui/Select.d.ts +16 -0
  62. package/dist/components/ui/Select.d.ts.map +1 -0
  63. package/dist/components/ui/Select.js +25 -0
  64. package/dist/components/ui/Select.js.map +1 -0
  65. package/dist/components/ui/Toast.js +1 -1
  66. package/dist/components/ui/index.d.ts +10 -4
  67. package/dist/components/ui/index.d.ts.map +1 -1
  68. package/dist/components/ui/index.js +5 -2
  69. package/dist/components/ui/index.js.map +1 -1
  70. package/dist/fields/BlockBuilderField.js +3 -3
  71. package/dist/fields/DateField.js +1 -1
  72. package/dist/fields/RelationshipField.js +3 -3
  73. package/dist/fields/TextField.js +1 -1
  74. package/dist/index.d.ts +6 -0
  75. package/dist/index.d.ts.map +1 -1
  76. package/dist/index.js +5 -0
  77. package/dist/index.js.map +1 -1
  78. package/dist/layout/Header.js +1 -1
  79. package/dist/layout/Layout.d.ts +14 -0
  80. package/dist/layout/Layout.d.ts.map +1 -1
  81. package/dist/layout/Layout.js +17 -11
  82. package/dist/layout/Layout.js.map +1 -1
  83. package/dist/layout/Sidebar.d.ts.map +1 -1
  84. package/dist/layout/Sidebar.js +21 -11
  85. package/dist/layout/Sidebar.js.map +1 -1
  86. package/dist/layout/primitives/AdminShell.d.ts +43 -0
  87. package/dist/layout/primitives/AdminShell.d.ts.map +1 -0
  88. package/dist/layout/primitives/AdminShell.js +51 -0
  89. package/dist/layout/primitives/AdminShell.js.map +1 -0
  90. package/dist/layout/primitives/Box.d.ts +19 -0
  91. package/dist/layout/primitives/Box.d.ts.map +1 -0
  92. package/dist/layout/primitives/Box.js +12 -0
  93. package/dist/layout/primitives/Box.js.map +1 -0
  94. package/dist/layout/primitives/Cluster.d.ts +27 -0
  95. package/dist/layout/primitives/Cluster.d.ts.map +1 -0
  96. package/dist/layout/primitives/Cluster.js +37 -0
  97. package/dist/layout/primitives/Cluster.js.map +1 -0
  98. package/dist/layout/primitives/Grid.d.ts +45 -0
  99. package/dist/layout/primitives/Grid.d.ts.map +1 -0
  100. package/dist/layout/primitives/Grid.js +59 -0
  101. package/dist/layout/primitives/Grid.js.map +1 -0
  102. package/dist/layout/primitives/PageContainer.d.ts +36 -0
  103. package/dist/layout/primitives/PageContainer.d.ts.map +1 -0
  104. package/dist/layout/primitives/PageContainer.js +41 -0
  105. package/dist/layout/primitives/PageContainer.js.map +1 -0
  106. package/dist/layout/primitives/Split.d.ts +34 -0
  107. package/dist/layout/primitives/Split.d.ts.map +1 -0
  108. package/dist/layout/primitives/Split.js +27 -0
  109. package/dist/layout/primitives/Split.js.map +1 -0
  110. package/dist/layout/primitives/Stack.d.ts +23 -0
  111. package/dist/layout/primitives/Stack.d.ts.map +1 -0
  112. package/dist/layout/primitives/Stack.js +34 -0
  113. package/dist/layout/primitives/Stack.js.map +1 -0
  114. package/dist/layout/primitives/index.d.ts +30 -0
  115. package/dist/layout/primitives/index.d.ts.map +1 -0
  116. package/dist/layout/primitives/index.js +22 -0
  117. package/dist/layout/primitives/index.js.map +1 -0
  118. package/dist/layout/primitives/tokens.d.ts +48 -0
  119. package/dist/layout/primitives/tokens.d.ts.map +1 -0
  120. package/dist/layout/primitives/tokens.js +54 -0
  121. package/dist/layout/primitives/tokens.js.map +1 -0
  122. package/dist/lib/cv.d.ts +53 -0
  123. package/dist/lib/cv.d.ts.map +1 -0
  124. package/dist/lib/cv.js +39 -0
  125. package/dist/lib/cv.js.map +1 -0
  126. package/dist/views/ApiKeys.d.ts.map +1 -1
  127. package/dist/views/ApiKeys.js +13 -11
  128. package/dist/views/ApiKeys.js.map +1 -1
  129. package/dist/views/CollectionList.js +8 -8
  130. package/dist/views/Dashboard.d.ts.map +1 -1
  131. package/dist/views/Dashboard.js +333 -78
  132. package/dist/views/Dashboard.js.map +1 -1
  133. package/dist/views/DocumentEdit.d.ts.map +1 -1
  134. package/dist/views/DocumentEdit.js +17 -5
  135. package/dist/views/DocumentEdit.js.map +1 -1
  136. package/dist/views/ForgotPassword.js +2 -2
  137. package/dist/views/FormEditor.js +5 -5
  138. package/dist/views/FormSubmissions.js +6 -6
  139. package/dist/views/Forms.js +2 -2
  140. package/dist/views/Login.d.ts +16 -1
  141. package/dist/views/Login.d.ts.map +1 -1
  142. package/dist/views/Login.js +17 -7
  143. package/dist/views/Login.js.map +1 -1
  144. package/dist/views/MediaBrowser.js +16 -16
  145. package/dist/views/PageEditor.js +2 -2
  146. package/dist/views/Pages.js +10 -10
  147. package/dist/views/PostEditor.js +2 -2
  148. package/dist/views/Posts.js +4 -4
  149. package/dist/views/Redirects.js +4 -4
  150. package/dist/views/ResetPassword.js +2 -2
  151. package/dist/views/SEO.js +6 -6
  152. package/dist/views/ScriptTagEditor.js +4 -4
  153. package/dist/views/ScriptTags.js +2 -2
  154. package/dist/views/Settings.d.ts.map +1 -1
  155. package/dist/views/Settings.js +9 -8
  156. package/dist/views/Settings.js.map +1 -1
  157. package/dist/views/SetupWizard.js +2 -2
  158. package/dist/views/Users.js +4 -4
  159. package/dist/views/page-builder/AIBlockAssist.js +1 -1
  160. package/dist/views/page-builder/AIGenerateDialog.js +10 -10
  161. package/dist/views/page-builder/BlockEditor.js +10 -10
  162. package/dist/views/page-builder/BlockPicker.js +4 -4
  163. package/dist/views/page-builder/BottomBar.js +1 -1
  164. package/dist/views/page-builder/BuilderToolbar.js +2 -2
  165. package/dist/views/page-builder/ContextPanel.js +2 -2
  166. package/dist/views/page-builder/DesignScore.js +9 -9
  167. package/dist/views/page-builder/NodeSettings.js +8 -8
  168. package/dist/views/page-builder/PageBuilder.js +3 -3
  169. package/dist/views/page-builder/PageSettings.js +1 -1
  170. package/dist/views/page-builder/PageTemplates.js +2 -2
  171. package/dist/views/page-builder/SEOPanel.js +13 -13
  172. package/dist/views/page-builder/SavedSections.js +5 -5
  173. package/dist/views/page-builder/TemplatePicker.js +2 -2
  174. package/dist/views/page-builder/block-renderers/CTAPreview.js +5 -5
  175. package/dist/views/page-builder/block-renderers/CardsPreview.js +1 -1
  176. package/dist/views/page-builder/block-renderers/CodePreview.js +1 -1
  177. package/dist/views/page-builder/block-renderers/FAQPreview.js +3 -3
  178. package/dist/views/page-builder/block-renderers/FallbackPreview.js +1 -1
  179. package/dist/views/page-builder/block-renderers/FormPreview.js +3 -3
  180. package/dist/views/page-builder/block-renderers/GalleryPreview.js +5 -5
  181. package/dist/views/page-builder/block-renderers/HeroPreview.js +3 -3
  182. package/dist/views/page-builder/block-renderers/ImagePreview.js +3 -3
  183. package/dist/views/page-builder/block-renderers/TextPreview.js +3 -3
  184. package/dist/views/page-builder/block-renderers/VideoPreview.js +4 -4
  185. package/dist/views/page-builder/canvas/BlockRenderer.js +1 -1
  186. package/dist/views/page-builder/canvas/BuilderCanvas.js +3 -3
  187. package/dist/views/page-builder/canvas/ColumnRenderer.js +2 -2
  188. package/dist/views/page-builder/canvas/ContainerRenderer.js +2 -2
  189. package/dist/views/page-builder/canvas/RowRenderer.js +2 -2
  190. package/dist/views/page-builder/canvas/SectionRenderer.js +2 -2
  191. package/package.json +6 -2
  192. package/src/AdminRoot.tsx +21 -11
  193. package/src/__tests__/layout/primitives.test.ts +37 -0
  194. package/src/__tests__/lib/cv.test.ts +74 -0
  195. package/src/assets/actuate-logo.tsx +72 -0
  196. package/src/components/Breadcrumbs.tsx +6 -6
  197. package/src/components/CommandPalette.tsx +34 -34
  198. package/src/components/ContentOverviewChart.tsx +3 -3
  199. package/src/components/ErrorBoundary.tsx +3 -3
  200. package/src/components/FocalPointPicker.tsx +4 -4
  201. package/src/components/FolderTree.tsx +38 -38
  202. package/src/components/LivePreview.tsx +16 -16
  203. package/src/components/LocaleSwitcher.tsx +7 -7
  204. package/src/components/MediaPickerModal.tsx +21 -21
  205. package/src/components/PresenceIndicator.tsx +2 -2
  206. package/src/components/SEOConfigPanel.tsx +582 -0
  207. package/src/components/SEOPanel.tsx +46 -46
  208. package/src/components/SEOPerformance.tsx +21 -21
  209. package/src/components/SchedulePublishDialog.tsx +241 -0
  210. package/src/components/SharePreviewLinkDialog.tsx +227 -0
  211. package/src/components/TipTapEditor.tsx +33 -33
  212. package/src/components/VersionHistory.tsx +16 -16
  213. package/src/components/ui/Badge.tsx +66 -14
  214. package/src/components/ui/Button.tsx +70 -33
  215. package/src/components/ui/Card.tsx +101 -0
  216. package/src/components/ui/DataTable.tsx +1 -1
  217. package/src/components/ui/Input.tsx +35 -0
  218. package/src/components/ui/SearchInput.tsx +4 -4
  219. package/src/components/ui/Select.tsx +56 -0
  220. package/src/components/ui/Toast.tsx +1 -1
  221. package/src/components/ui/index.ts +18 -4
  222. package/src/fields/BlockBuilderField.tsx +3 -3
  223. package/src/fields/DateField.tsx +1 -1
  224. package/src/fields/RelationshipField.tsx +10 -10
  225. package/src/fields/TextField.tsx +1 -1
  226. package/src/index.ts +32 -0
  227. package/src/layout/Header.tsx +28 -28
  228. package/src/layout/Layout.tsx +39 -46
  229. package/src/layout/Sidebar.tsx +37 -64
  230. package/src/layout/primitives/AdminShell.tsx +118 -0
  231. package/src/layout/primitives/Box.tsx +30 -0
  232. package/src/layout/primitives/Cluster.tsx +74 -0
  233. package/src/layout/primitives/Grid.tsx +120 -0
  234. package/src/layout/primitives/PageContainer.tsx +96 -0
  235. package/src/layout/primitives/Split.tsx +73 -0
  236. package/src/layout/primitives/Stack.tsx +67 -0
  237. package/src/layout/primitives/index.ts +36 -0
  238. package/src/layout/primitives/tokens.ts +76 -0
  239. package/src/lib/cv.ts +96 -0
  240. package/src/styles/build-input.css +1 -1
  241. package/src/views/ApiKeys.tsx +57 -57
  242. package/src/views/CollectionList.tsx +30 -30
  243. package/src/views/Dashboard.tsx +737 -186
  244. package/src/views/DocumentEdit.tsx +90 -10
  245. package/src/views/ForgotPassword.tsx +18 -18
  246. package/src/views/FormEditor.tsx +75 -75
  247. package/src/views/FormSubmissions.tsx +76 -76
  248. package/src/views/Forms.tsx +27 -27
  249. package/src/views/Login.tsx +65 -25
  250. package/src/views/MediaBrowser.tsx +127 -127
  251. package/src/views/PageEditor.tsx +25 -25
  252. package/src/views/Pages.tsx +59 -59
  253. package/src/views/PostEditor.tsx +37 -37
  254. package/src/views/Posts.tsx +48 -48
  255. package/src/views/Redirects.tsx +21 -21
  256. package/src/views/ResetPassword.tsx +28 -28
  257. package/src/views/SEO.tsx +144 -144
  258. package/src/views/ScriptTagEditor.tsx +24 -24
  259. package/src/views/ScriptTags.tsx +10 -10
  260. package/src/views/Settings.tsx +88 -80
  261. package/src/views/SetupWizard.tsx +28 -28
  262. package/src/views/Users.tsx +20 -20
  263. package/src/views/page-builder/AIBlockAssist.tsx +1 -1
  264. package/src/views/page-builder/AIGenerateDialog.tsx +63 -63
  265. package/src/views/page-builder/BlockEditor.tsx +26 -26
  266. package/src/views/page-builder/BlockPicker.tsx +22 -22
  267. package/src/views/page-builder/BottomBar.tsx +8 -8
  268. package/src/views/page-builder/BuilderToolbar.tsx +17 -17
  269. package/src/views/page-builder/ContextPanel.tsx +3 -3
  270. package/src/views/page-builder/DesignScore.tsx +21 -21
  271. package/src/views/page-builder/NodeSettings.tsx +27 -27
  272. package/src/views/page-builder/PageBuilder.tsx +11 -11
  273. package/src/views/page-builder/PageSettings.tsx +4 -4
  274. package/src/views/page-builder/PageTemplates.tsx +18 -18
  275. package/src/views/page-builder/SEOPanel.tsx +53 -53
  276. package/src/views/page-builder/SavedSections.tsx +37 -37
  277. package/src/views/page-builder/TemplatePicker.tsx +17 -17
  278. package/src/views/page-builder/block-renderers/CTAPreview.tsx +13 -13
  279. package/src/views/page-builder/block-renderers/CardsPreview.tsx +5 -5
  280. package/src/views/page-builder/block-renderers/CodePreview.tsx +6 -6
  281. package/src/views/page-builder/block-renderers/FAQPreview.tsx +13 -13
  282. package/src/views/page-builder/block-renderers/FallbackPreview.tsx +3 -3
  283. package/src/views/page-builder/block-renderers/FormPreview.tsx +20 -20
  284. package/src/views/page-builder/block-renderers/GalleryPreview.tsx +8 -8
  285. package/src/views/page-builder/block-renderers/HeroPreview.tsx +16 -16
  286. package/src/views/page-builder/block-renderers/ImagePreview.tsx +4 -4
  287. package/src/views/page-builder/block-renderers/TextPreview.tsx +14 -14
  288. package/src/views/page-builder/block-renderers/VideoPreview.tsx +12 -12
  289. package/src/views/page-builder/canvas/BlockRenderer.tsx +4 -4
  290. package/src/views/page-builder/canvas/BuilderCanvas.tsx +6 -6
  291. package/src/views/page-builder/canvas/ColumnRenderer.tsx +3 -3
  292. package/src/views/page-builder/canvas/ContainerRenderer.tsx +2 -2
  293. package/src/views/page-builder/canvas/RowRenderer.tsx +2 -2
  294. package/src/views/page-builder/canvas/SectionRenderer.tsx +2 -2
@@ -110,18 +110,18 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
110
110
 
111
111
  if (loading && !isNew) {
112
112
  return (
113
- <div className="p-3 pr-6 sm:p-4 sm:pr-8 flex items-center justify-center h-64">
114
- <Loader2 className="w-6 h-6 animate-spin text-blue-600" />
113
+ <div className="flex h-64 items-center justify-center p-3 pr-6 sm:p-4 sm:pr-8">
114
+ <Loader2 className="h-6 w-6 animate-spin text-blue-600" />
115
115
  </div>
116
116
  )
117
117
  }
118
118
 
119
119
  return (
120
- <div className="p-3 pr-6 sm:p-4 sm:pr-8 max-w-3xl">
120
+ <div className="max-w-3xl p-3 pr-6 sm:p-4 sm:pr-8">
121
121
  {error && (
122
122
  <div className="mb-4 flex items-center gap-3 rounded-lg border border-red-200 bg-red-50 p-3">
123
- <AlertTriangle className="w-5 h-5 text-red-600 shrink-0" />
124
- <span className="text-sm text-red-800 flex-1">{error}</span>
123
+ <AlertTriangle className="h-5 w-5 shrink-0 text-red-600" />
124
+ <span className="flex-1 text-sm text-red-800">{error}</span>
125
125
  </div>
126
126
  )}
127
127
 
@@ -129,9 +129,9 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
129
129
  <button
130
130
  type="button"
131
131
  onClick={() => onNavigate?.('/script-tags')}
132
- className="flex items-center gap-1.5 text-sm text-gray-500 hover:text-gray-700 transition-colors mb-3"
132
+ className="mb-3 flex items-center gap-1.5 text-sm text-gray-500 transition-colors hover:text-gray-700"
133
133
  >
134
- <ArrowLeft className="w-4 h-4" />
134
+ <ArrowLeft className="h-4 w-4" />
135
135
  Back to Script Tags
136
136
  </button>
137
137
  <h1 className="text-2xl font-semibold text-gray-900">
@@ -139,9 +139,9 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
139
139
  </h1>
140
140
  </div>
141
141
 
142
- <div className="rounded-lg border border-amber-200 bg-amber-50 p-3 mb-6">
142
+ <div className="mb-6 rounded-lg border border-amber-200 bg-amber-50 p-3">
143
143
  <div className="flex items-start gap-2">
144
- <AlertTriangle className="w-4 h-4 text-amber-600 mt-0.5 shrink-0" />
144
+ <AlertTriangle className="mt-0.5 h-4 w-4 shrink-0 text-amber-600" />
145
145
  <p className="text-sm text-amber-800">
146
146
  This code will run on public pages matching the scope below. Only add trusted code from
147
147
  verified sources (e.g. Google Analytics, Meta Pixel).
@@ -150,7 +150,7 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
150
150
  </div>
151
151
 
152
152
  <div className="space-y-6">
153
- <div className="rounded-lg border border-gray-200 bg-white p-4 space-y-4">
153
+ <div className="space-y-4 rounded-lg border border-gray-200 bg-white p-4">
154
154
  <div>
155
155
  <label className="mb-1 block text-sm font-medium text-gray-700">Name</label>
156
156
  <input
@@ -158,7 +158,7 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
158
158
  value={name}
159
159
  onChange={(e) => setName(e.target.value)}
160
160
  placeholder="e.g. Google Tag Manager, Facebook Pixel"
161
- className="w-full rounded-lg border border-gray-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-blue-500"
161
+ className="w-full rounded-lg border border-gray-300 px-3 py-2 text-sm focus:ring-2 focus:ring-blue-500 focus:outline-none"
162
162
  />
163
163
  </div>
164
164
 
@@ -169,7 +169,7 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
169
169
  onChange={(e) => setCode(e.target.value)}
170
170
  placeholder="Paste your HTML/JavaScript snippet here..."
171
171
  rows={10}
172
- className="w-full rounded-lg border border-gray-300 px-3 py-2 text-sm font-mono focus:outline-none focus:ring-2 focus:ring-blue-500"
172
+ className="w-full rounded-lg border border-gray-300 px-3 py-2 font-mono text-sm focus:ring-2 focus:ring-blue-500 focus:outline-none"
173
173
  spellCheck={false}
174
174
  />
175
175
  <p className="mt-1 text-xs text-gray-500">
@@ -178,7 +178,7 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
178
178
  </div>
179
179
  </div>
180
180
 
181
- <div className="rounded-lg border border-gray-200 bg-white p-4 space-y-4">
181
+ <div className="space-y-4 rounded-lg border border-gray-200 bg-white p-4">
182
182
  <h3 className="text-sm font-semibold text-gray-900">Placement & Scope</h3>
183
183
 
184
184
  <div>
@@ -186,7 +186,7 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
186
186
  <select
187
187
  value={placement}
188
188
  onChange={(e) => setPlacement(e.target.value)}
189
- className="w-full rounded-lg border border-gray-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-blue-500"
189
+ className="w-full rounded-lg border border-gray-300 px-3 py-2 text-sm focus:ring-2 focus:ring-blue-500 focus:outline-none"
190
190
  >
191
191
  <option value="head">Head — inside {'<head>'}</option>
192
192
  <option value="body_open">Body Open — right after {'<body>'}</option>
@@ -205,7 +205,7 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
205
205
  <select
206
206
  value={scope}
207
207
  onChange={(e) => setScope(e.target.value)}
208
- className="w-full rounded-lg border border-gray-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-blue-500"
208
+ className="w-full rounded-lg border border-gray-300 px-3 py-2 text-sm focus:ring-2 focus:ring-blue-500 focus:outline-none"
209
209
  >
210
210
  <option value="site">Entire Website</option>
211
211
  <option value="parents">Specific Parent Pages (includes child pages)</option>
@@ -230,14 +230,14 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
230
230
  }
231
231
  }}
232
232
  placeholder="/services"
233
- className="flex-1 rounded-lg border border-gray-300 px-3 py-2 text-sm font-mono focus:outline-none focus:ring-2 focus:ring-blue-500"
233
+ className="flex-1 rounded-lg border border-gray-300 px-3 py-2 font-mono text-sm focus:ring-2 focus:ring-blue-500 focus:outline-none"
234
234
  />
235
235
  <button
236
236
  type="button"
237
237
  onClick={addPath}
238
- className="rounded-lg border border-gray-300 px-3 py-2 text-sm hover:bg-gray-50 transition-colors"
238
+ className="rounded-lg border border-gray-300 px-3 py-2 text-sm transition-colors hover:bg-gray-50"
239
239
  >
240
- <Plus className="w-4 h-4" />
240
+ <Plus className="h-4 w-4" />
241
241
  </button>
242
242
  </div>
243
243
  {scope === 'parents' && (
@@ -250,7 +250,7 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
250
250
  {targetPaths.map((p) => (
251
251
  <span
252
252
  key={p}
253
- className="inline-flex items-center gap-1 rounded-full bg-gray-100 px-3 py-1 text-xs font-mono text-gray-700"
253
+ className="inline-flex items-center gap-1 rounded-full bg-gray-100 px-3 py-1 font-mono text-xs text-gray-700"
254
254
  >
255
255
  {p}
256
256
  <button
@@ -258,7 +258,7 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
258
258
  onClick={() => removePath(p)}
259
259
  className="ml-0.5 text-gray-400 hover:text-gray-600"
260
260
  >
261
- <X className="w-3 h-3" />
261
+ <X className="h-3 w-3" />
262
262
  </button>
263
263
  </span>
264
264
  ))}
@@ -275,7 +275,7 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
275
275
  value={priority}
276
276
  onChange={(e) => setPriority(parseInt(e.target.value, 10) || 0)}
277
277
  min={0}
278
- className="w-full rounded-lg border border-gray-300 px-3 py-2 text-sm focus:outline-none focus:ring-2 focus:ring-blue-500"
278
+ className="w-full rounded-lg border border-gray-300 px-3 py-2 text-sm focus:ring-2 focus:ring-blue-500 focus:outline-none"
279
279
  />
280
280
  <p className="mt-1 text-xs text-gray-500">
281
281
  Lower numbers load first (e.g. 1 = first, 100 = default)
@@ -328,9 +328,9 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
328
328
  <button
329
329
  type="button"
330
330
  onClick={() => setShowDeleteConfirm(true)}
331
- className="flex items-center gap-1.5 text-sm text-red-600 hover:text-red-700 transition-colors"
331
+ className="flex items-center gap-1.5 text-sm text-red-600 transition-colors hover:text-red-700"
332
332
  >
333
- <Trash2 className="w-4 h-4" />
333
+ <Trash2 className="h-4 w-4" />
334
334
  Delete
335
335
  </button>
336
336
  )}
@@ -341,7 +341,7 @@ export function ScriptTagEditor({ tagId, onNavigate }: ScriptTagEditorProps) {
341
341
  <button
342
342
  type="button"
343
343
  onClick={() => onNavigate?.('/script-tags')}
344
- className="rounded-lg border border-gray-300 px-4 py-2 text-sm text-gray-700 hover:bg-gray-50 transition-colors"
344
+ className="rounded-lg border border-gray-300 px-4 py-2 text-sm text-gray-700 transition-colors hover:bg-gray-50"
345
345
  >
346
346
  Cancel
347
347
  </button>
@@ -72,8 +72,8 @@ export function ScriptTags({ onNavigate }: ScriptTagsProps) {
72
72
 
73
73
  if (loading) {
74
74
  return (
75
- <div className="p-3 pr-6 sm:p-4 sm:pr-8 flex items-center justify-center h-64">
76
- <Loader2 className="w-6 h-6 animate-spin text-blue-600" />
75
+ <div className="flex h-64 items-center justify-center p-3 pr-6 sm:p-4 sm:pr-8">
76
+ <Loader2 className="h-6 w-6 animate-spin text-blue-600" />
77
77
  </div>
78
78
  )
79
79
  }
@@ -82,11 +82,11 @@ export function ScriptTags({ onNavigate }: ScriptTagsProps) {
82
82
  <div className="p-3 pr-6 sm:p-4 sm:pr-8">
83
83
  {error && (
84
84
  <div className="mb-4 flex items-center gap-3 rounded-lg border border-red-200 bg-red-50 p-3">
85
- <AlertTriangle className="w-5 h-5 text-red-600 shrink-0" />
86
- <span className="text-sm text-red-800 flex-1">{error}</span>
85
+ <AlertTriangle className="h-5 w-5 shrink-0 text-red-600" />
86
+ <span className="flex-1 text-sm text-red-800">{error}</span>
87
87
  <button
88
88
  onClick={refetch}
89
- className="px-3 py-1 text-sm text-red-700 border border-red-300 rounded-lg hover:bg-red-100 transition-colors"
89
+ className="rounded-lg border border-red-300 px-3 py-1 text-sm text-red-700 transition-colors hover:bg-red-100"
90
90
  >
91
91
  Retry
92
92
  </button>
@@ -105,7 +105,7 @@ export function ScriptTags({ onNavigate }: ScriptTagsProps) {
105
105
  onClick={() => onNavigate?.('/script-tags/new')}
106
106
  className="flex items-center gap-2 rounded-lg bg-blue-600 px-4 py-2 text-sm font-medium text-white transition-colors hover:bg-blue-700"
107
107
  >
108
- <Plus className="w-4 h-4" />
108
+ <Plus className="h-4 w-4" />
109
109
  New Tag
110
110
  </button>
111
111
  </div>
@@ -122,12 +122,12 @@ export function ScriptTags({ onNavigate }: ScriptTagsProps) {
122
122
  onClick={() => onNavigate?.('/script-tags/new')}
123
123
  className="mt-4 inline-flex items-center gap-2 rounded-lg bg-blue-600 px-4 py-2 text-sm font-medium text-white transition-colors hover:bg-blue-700"
124
124
  >
125
- <Plus className="w-4 h-4" />
125
+ <Plus className="h-4 w-4" />
126
126
  Add Your First Tag
127
127
  </button>
128
128
  </div>
129
129
  ) : (
130
- <div className="rounded-lg border border-gray-200 bg-white overflow-hidden">
130
+ <div className="overflow-hidden rounded-lg border border-gray-200 bg-white">
131
131
  <table className="w-full text-sm">
132
132
  <thead>
133
133
  <tr className="border-b border-gray-200 bg-gray-50">
@@ -142,7 +142,7 @@ export function ScriptTags({ onNavigate }: ScriptTagsProps) {
142
142
  {tags.map((tag) => (
143
143
  <tr
144
144
  key={tag.id}
145
- className="border-b border-gray-100 last:border-0 hover:bg-gray-50 transition-colors"
145
+ className="border-b border-gray-100 transition-colors last:border-0 hover:bg-gray-50"
146
146
  >
147
147
  <td className="px-4 py-3">
148
148
  <button
@@ -161,7 +161,7 @@ export function ScriptTags({ onNavigate }: ScriptTagsProps) {
161
161
  </span>
162
162
  </td>
163
163
  <td className="px-4 py-3 text-gray-600">{scopeLabel(tag)}</td>
164
- <td className="px-4 py-3 text-center text-gray-600 font-mono">{tag.priority}</td>
164
+ <td className="px-4 py-3 text-center font-mono text-gray-600">{tag.priority}</td>
165
165
  <td className="px-4 py-3 text-center">
166
166
  <button
167
167
  type="button"