fix: frontend consistency audit — 55 files cleaned up

Consistency fixes:
- Extract getThisWeekRange/getThisMonthRange to shared lib/utils/dateRanges.ts
  (removed 4 identical copy-pasted definitions)
- Add error boundaries for behavior, cdn, search, pagespeed pages
  (4 new error.tsx files — previously fell through to generic parent error)
- Add "View setup guide" CTA to empty states on journeys and behavior pages
  (previously showed text with no actionable button)
- Fix non-lazy useState initializer in funnel detail page
- Fix Bot & Spam settings header from text-xl to text-2xl (matches all other sections)
- Add useMinimumLoading to PageSpeed skeleton (consistent with all other pages)

Cleanup:
- Remove 438 redundant dark: class prefixes (app is dark-mode only)
  text-neutral-500 dark:text-neutral-400 → text-neutral-400 (206 occurrences)
  text-neutral-900 dark:text-white → text-white (232 occurrences)
- Remove dead @stripe/react-stripe-js and @stripe/stripe-js packages
  (billing migrated to Polar, no code imports Stripe)
- Remove duplicate motion package (framer-motion is the one actually used)
This commit is contained in:
Usman Baig
2026-03-23 19:50:16 +01:00
parent eca21bf627
commit a3c1af7c95
55 changed files with 560 additions and 530 deletions

View File

@@ -105,7 +105,7 @@ export default function VerificationModal({ isOpen, onClose, site, onVerified }:
>
{/* Header */}
<div className="flex items-center justify-between px-6 py-4 border-b border-neutral-100 dark:border-neutral-800">
<h3 className="font-semibold text-neutral-900 dark:text-white">
<h3 className="font-semibold text-white">
Verify Installation
</h3>
<button
@@ -148,10 +148,10 @@ export default function VerificationModal({ isOpen, onClose, site, onVerified }:
<div className="absolute inset-0 w-16 h-16 border-4 border-brand-orange border-t-transparent rounded-full animate-spin" />
</div>
<div className="text-center space-y-1">
<h4 className="font-medium text-neutral-900 dark:text-white">
<h4 className="font-medium text-white">
Checking connection...
</h4>
<p className="text-sm text-neutral-500 dark:text-neutral-400">
<p className="text-sm text-neutral-400">
Waiting for signal from {site.domain}
</p>
</div>
@@ -164,10 +164,10 @@ export default function VerificationModal({ isOpen, onClose, site, onVerified }:
<CheckCircleIcon className="w-8 h-8" />
</div>
<div className="text-center space-y-1">
<h4 className="text-xl font-bold text-neutral-900 dark:text-white">
<h4 className="text-xl font-bold text-white">
You're all set!
</h4>
<p className="text-neutral-500 dark:text-neutral-400">
<p className="text-neutral-400">
We are successfully receiving data from your website.
</p>
</div>
@@ -189,7 +189,7 @@ export default function VerificationModal({ isOpen, onClose, site, onVerified }:
</div>
<div className="p-4 bg-neutral-50 dark:bg-neutral-800/50 rounded-xl border border-neutral-100 dark:border-neutral-800">
<p className="text-sm font-medium text-neutral-900 dark:text-white mb-2">
<p className="text-sm font-medium text-white mb-2">
Troubleshooting Checklist:
</p>
<ul className="text-sm text-neutral-600 dark:text-neutral-400 space-y-1 list-disc list-inside">