Major features: - Add drag-and-drop photo gallery to Service create/edit modals - Add Resource Types management section to Settings (CRUD for custom types) - Add edit icon consistency to Resources table (pencil icon in actions) - Improve Services page with drag-to-reorder and customer preview mockup Backend changes: - Add photos JSONField to Service model with migration - Add ResourceType model with category (STAFF/OTHER), description fields - Add ResourceTypeViewSet with CRUD operations - Add service reorder endpoint for display order Frontend changes: - Services page: two-column layout, drag-reorder, photo upload - Settings page: Resource Types tab with full CRUD modal - Resources page: Edit icon in actions column instead of row click - Sidebar: Payments link visibility based on role and paymentsEnabled - Update types.ts with Service.photos and ResourceTypeDefinition Note: Removed photos from ResourceType (kept only for Service) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
88 lines
3.2 KiB
Python
88 lines
3.2 KiB
Python
from django.conf import settings
|
|
from django.conf.urls.static import static
|
|
from django.contrib import admin
|
|
from django.urls import include
|
|
from django.urls import path
|
|
from django.views import defaults as default_views
|
|
from django.views.decorators.csrf import csrf_exempt
|
|
from django.views.generic import TemplateView
|
|
from drf_spectacular.views import SpectacularAPIView
|
|
from drf_spectacular.views import SpectacularSwaggerView
|
|
from rest_framework.authtoken.views import obtain_auth_token
|
|
|
|
from smoothschedule.users.api_views import (
|
|
current_user_view, logout_view, send_verification_email, verify_email,
|
|
hijack_acquire_view, hijack_release_view
|
|
)
|
|
from schedule.api_views import current_business_view, update_business_view
|
|
|
|
urlpatterns = [
|
|
# Django Admin, use {% url 'admin:index' %}
|
|
path(settings.ADMIN_URL, admin.site.urls),
|
|
# User management
|
|
path("users/", include("smoothschedule.users.urls", namespace="users")),
|
|
path("accounts/", include("allauth.urls")),
|
|
# Django Hijack (masquerade) - for admin interface
|
|
path("hijack/", include("hijack.urls")),
|
|
# Your stuff: custom urls includes go here
|
|
# ...
|
|
# Media files
|
|
*static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT),
|
|
]
|
|
|
|
# API URLS
|
|
urlpatterns += [
|
|
# Schedule API
|
|
path("api/", include("schedule.urls")),
|
|
# Payments API
|
|
path("api/payments/", include("payments.urls")),
|
|
# Platform API
|
|
path("api/platform/", include("platform_admin.urls", namespace="platform")),
|
|
# Auth API
|
|
path("api/auth-token/", csrf_exempt(obtain_auth_token), name="obtain_auth_token"),
|
|
path("api/auth/me/", current_user_view, name="current_user"),
|
|
path("api/auth/logout/", logout_view, name="logout"),
|
|
path("api/auth/email/verify/send/", send_verification_email, name="send_verification_email"),
|
|
path("api/auth/email/verify/", verify_email, name="verify_email"),
|
|
# Hijack (masquerade) API
|
|
path("api/auth/hijack/acquire/", hijack_acquire_view, name="hijack_acquire"),
|
|
path("api/auth/hijack/release/", hijack_release_view, name="hijack_release"),
|
|
# Business API
|
|
path("api/business/current/", current_business_view, name="current_business"),
|
|
path("api/business/current/update/", update_business_view, name="update_business"),
|
|
# API Docs
|
|
path("api/schema/", SpectacularAPIView.as_view(), name="api-schema"),
|
|
path(
|
|
"api/docs/",
|
|
SpectacularSwaggerView.as_view(url_name="api-schema"),
|
|
name="api-docs",
|
|
),
|
|
]
|
|
|
|
if settings.DEBUG:
|
|
urlpatterns += [
|
|
path(
|
|
"400/",
|
|
default_views.bad_request,
|
|
kwargs={"exception": Exception("Bad Request!")},
|
|
),
|
|
path(
|
|
"403/",
|
|
default_views.permission_denied,
|
|
kwargs={"exception": Exception("Permission Denied")},
|
|
),
|
|
path(
|
|
"404/",
|
|
default_views.page_not_found,
|
|
kwargs={"exception": Exception("Page not Found")},
|
|
),
|
|
path("500/", default_views.server_error),
|
|
]
|
|
if "debug_toolbar" in settings.INSTALLED_APPS:
|
|
import debug_toolbar
|
|
|
|
urlpatterns = [
|
|
path("__debug__/", include(debug_toolbar.urls)),
|
|
*urlpatterns,
|
|
]
|