# CMS Quick Start Guide A quick reference for setting up and using the Content Management System. ## What is the CMS? The CMS allows you to manage static content pages (About, Contact, FAQ, etc.) with: - **Platform defaults** - Base content for all stores - **Store overrides** - Custom content per store - **Automatic fallback** - Stores inherit platform defaults unless overridden ## Quick Setup ### 1. Create Default Content Pages After running migrations, create the default CMS pages: ```bash make create-cms-defaults ``` This creates 7 platform default pages: - About Us (`/about`) - Contact Us (`/contact`) - FAQ (`/faq`) - Shipping Policy (`/shipping`) - Return & Refund Policy (`/returns`) - Privacy Policy (`/privacy`) - Terms of Service (`/terms`) ### 2. Full Database Setup For a complete setup including CMS: ```bash make db-setup # Runs: migrations → admin user → CMS pages → demo data ``` ## Accessing Pages All CMS pages are accessible on your shop frontend: ``` # For domain/subdomain access https://orion.shop/about https://fashionhub.store/contact # For path-based access http://localhost:8000/store/orion/faq http://localhost:8000/stores/fashionhub/shipping ``` ## Managing Content ### Via Admin Panel 1. Log in to admin panel: `/admin/login` 2. Navigate to **Content Pages** section 3. Create/edit platform defaults (visible to all stores) ### Via Store Dashboard 1. Log in to store dashboard: `/store/{code}/login` 2. Navigate to **Content Pages** section 3. View platform defaults 4. Create store-specific overrides ### Via API **Admin - Create Platform Default:** ```bash POST /api/v1/admin/content-pages/platform { "slug": "about", "title": "About Us", "content": "
...
", "is_published": true, "show_in_footer": true } ``` **Store - Create Override:** ```bash POST /api/v1/store/{store_code}/content-pages { "slug": "about", "title": "About Our Store", "content": "Custom content...
", "is_published": true } ``` **Public - Retrieve Page:** ```bash GET /api/v1/storefront/content-pages/{slug} ``` ## How the Two-Tier System Works ### Lookup Priority When a customer visits `/about`: 1. **Check store override** - Does this store have a custom "about" page? 2. **Fallback to platform** - If not, use the platform default "about" page 3. **404 if neither** - Return 404 if no page exists ### Example Scenario **Platform Default:** - Slug: `about` - Title: "About Our Platform" - Content: Generic platform description **Orion Override:** - Slug: `about` - Title: "About Orion" - Content: Orion-specific content **Result:** - `orion.shop/about` → Shows Orion custom version - `fashionhub.store/about` → Shows platform default (no override) ## Footer Navigation Pages marked with `show_in_footer: true` automatically appear in the shop footer: ```html ``` ## Common Tasks ### Add a New Default Page ```bash python -c " from app.core.database import SessionLocal from app.services.content_page_service import content_page_service db = SessionLocal() content_page_service.create_page( db, slug='careers', title='Careers', content='