django-cfg 1.2.27__py3-none-any.whl → 1.2.31__py3-none-any.whl

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 (138) hide show
  1. django_cfg/__init__.py +1 -1
  2. django_cfg/apps/payments/admin/__init__.py +3 -2
  3. django_cfg/apps/payments/admin/balance_admin.py +18 -18
  4. django_cfg/apps/payments/admin/currencies_admin.py +319 -131
  5. django_cfg/apps/payments/admin/payments_admin.py +15 -4
  6. django_cfg/apps/payments/config/module.py +2 -2
  7. django_cfg/apps/payments/config/utils.py +2 -2
  8. django_cfg/apps/payments/decorators.py +2 -2
  9. django_cfg/apps/payments/management/commands/README.md +95 -127
  10. django_cfg/apps/payments/management/commands/currency_stats.py +5 -24
  11. django_cfg/apps/payments/management/commands/manage_currencies.py +229 -0
  12. django_cfg/apps/payments/management/commands/manage_providers.py +235 -0
  13. django_cfg/apps/payments/managers/__init__.py +3 -2
  14. django_cfg/apps/payments/managers/balance_manager.py +2 -2
  15. django_cfg/apps/payments/managers/currency_manager.py +272 -49
  16. django_cfg/apps/payments/managers/payment_manager.py +161 -13
  17. django_cfg/apps/payments/middleware/api_access.py +2 -2
  18. django_cfg/apps/payments/middleware/rate_limiting.py +8 -18
  19. django_cfg/apps/payments/middleware/usage_tracking.py +20 -17
  20. django_cfg/apps/payments/migrations/0002_network_providercurrency_and_more.py +241 -0
  21. django_cfg/apps/payments/migrations/0003_add_usd_rate_cache.py +30 -0
  22. django_cfg/apps/payments/models/__init__.py +3 -2
  23. django_cfg/apps/payments/models/currencies.py +187 -71
  24. django_cfg/apps/payments/models/payments.py +3 -2
  25. django_cfg/apps/payments/serializers/__init__.py +3 -2
  26. django_cfg/apps/payments/serializers/currencies.py +20 -12
  27. django_cfg/apps/payments/services/cache/simple_cache.py +2 -2
  28. django_cfg/apps/payments/services/core/balance_service.py +2 -2
  29. django_cfg/apps/payments/services/core/fallback_service.py +2 -2
  30. django_cfg/apps/payments/services/core/payment_service.py +3 -6
  31. django_cfg/apps/payments/services/core/subscription_service.py +4 -7
  32. django_cfg/apps/payments/services/internal_types.py +171 -7
  33. django_cfg/apps/payments/services/monitoring/api_schemas.py +58 -204
  34. django_cfg/apps/payments/services/monitoring/provider_health.py +2 -2
  35. django_cfg/apps/payments/services/providers/base.py +144 -43
  36. django_cfg/apps/payments/services/providers/cryptapi/__init__.py +4 -0
  37. django_cfg/apps/payments/services/providers/cryptapi/config.py +8 -0
  38. django_cfg/apps/payments/services/providers/cryptapi/models.py +192 -0
  39. django_cfg/apps/payments/services/providers/cryptapi/provider.py +439 -0
  40. django_cfg/apps/payments/services/providers/cryptomus/__init__.py +4 -0
  41. django_cfg/apps/payments/services/providers/cryptomus/models.py +176 -0
  42. django_cfg/apps/payments/services/providers/cryptomus/provider.py +429 -0
  43. django_cfg/apps/payments/services/providers/cryptomus/provider_v2.py +564 -0
  44. django_cfg/apps/payments/services/providers/models/__init__.py +34 -0
  45. django_cfg/apps/payments/services/providers/models/currencies.py +190 -0
  46. django_cfg/apps/payments/services/providers/nowpayments/__init__.py +4 -0
  47. django_cfg/apps/payments/services/providers/nowpayments/models.py +196 -0
  48. django_cfg/apps/payments/services/providers/nowpayments/provider.py +380 -0
  49. django_cfg/apps/payments/services/providers/registry.py +294 -11
  50. django_cfg/apps/payments/services/providers/stripe/__init__.py +4 -0
  51. django_cfg/apps/payments/services/providers/stripe/models.py +184 -0
  52. django_cfg/apps/payments/services/providers/stripe/provider.py +109 -0
  53. django_cfg/apps/payments/services/security/error_handler.py +6 -8
  54. django_cfg/apps/payments/services/security/payment_notifications.py +2 -2
  55. django_cfg/apps/payments/services/security/webhook_validator.py +3 -4
  56. django_cfg/apps/payments/signals/api_key_signals.py +2 -2
  57. django_cfg/apps/payments/signals/payment_signals.py +11 -5
  58. django_cfg/apps/payments/signals/subscription_signals.py +2 -2
  59. django_cfg/apps/payments/static/payments/css/payments.css +340 -0
  60. django_cfg/apps/payments/static/payments/js/notifications.js +202 -0
  61. django_cfg/apps/payments/static/payments/js/payment-utils.js +318 -0
  62. django_cfg/apps/payments/static/payments/js/theme.js +86 -0
  63. django_cfg/apps/payments/tasks/webhook_processing.py +2 -2
  64. django_cfg/apps/payments/templates/admin/payments/currency/change_list.html +50 -0
  65. django_cfg/apps/payments/templates/payments/base.html +182 -0
  66. django_cfg/apps/payments/templates/payments/components/payment_card.html +201 -0
  67. django_cfg/apps/payments/templates/payments/components/payment_qr_code.html +109 -0
  68. django_cfg/apps/payments/templates/payments/components/progress_bar.html +43 -0
  69. django_cfg/apps/payments/templates/payments/components/provider_stats.html +40 -0
  70. django_cfg/apps/payments/templates/payments/components/status_badge.html +34 -0
  71. django_cfg/apps/payments/templates/payments/components/status_overview.html +148 -0
  72. django_cfg/apps/payments/templates/payments/dashboard.html +258 -0
  73. django_cfg/apps/payments/templates/payments/dashboard_simple_test.html +35 -0
  74. django_cfg/apps/payments/templates/payments/payment_create.html +579 -0
  75. django_cfg/apps/payments/templates/payments/payment_detail.html +373 -0
  76. django_cfg/apps/payments/templates/payments/payment_list.html +354 -0
  77. django_cfg/apps/payments/templates/payments/stats.html +261 -0
  78. django_cfg/apps/payments/templates/payments/test.html +213 -0
  79. django_cfg/apps/payments/templatetags/__init__.py +1 -0
  80. django_cfg/apps/payments/templatetags/payments_tags.py +315 -0
  81. django_cfg/apps/payments/urls.py +3 -1
  82. django_cfg/apps/payments/urls_admin.py +58 -0
  83. django_cfg/apps/payments/utils/__init__.py +1 -3
  84. django_cfg/apps/payments/utils/billing_utils.py +2 -2
  85. django_cfg/apps/payments/utils/config_utils.py +2 -8
  86. django_cfg/apps/payments/utils/validation_utils.py +2 -2
  87. django_cfg/apps/payments/views/__init__.py +3 -2
  88. django_cfg/apps/payments/views/currency_views.py +31 -20
  89. django_cfg/apps/payments/views/payment_views.py +2 -2
  90. django_cfg/apps/payments/views/templates/__init__.py +25 -0
  91. django_cfg/apps/payments/views/templates/ajax.py +451 -0
  92. django_cfg/apps/payments/views/templates/base.py +212 -0
  93. django_cfg/apps/payments/views/templates/dashboard.py +60 -0
  94. django_cfg/apps/payments/views/templates/payment_detail.py +102 -0
  95. django_cfg/apps/payments/views/templates/payment_management.py +158 -0
  96. django_cfg/apps/payments/views/templates/qr_code.py +174 -0
  97. django_cfg/apps/payments/views/templates/stats.py +244 -0
  98. django_cfg/apps/payments/views/templates/utils.py +181 -0
  99. django_cfg/apps/payments/views/webhook_views.py +2 -2
  100. django_cfg/apps/payments/viewsets.py +3 -2
  101. django_cfg/apps/tasks/urls.py +0 -2
  102. django_cfg/apps/tasks/urls_admin.py +14 -0
  103. django_cfg/apps/urls.py +6 -3
  104. django_cfg/core/config.py +35 -0
  105. django_cfg/models/payments.py +2 -8
  106. django_cfg/modules/django_currency/__init__.py +16 -11
  107. django_cfg/modules/django_currency/clients/__init__.py +4 -4
  108. django_cfg/modules/django_currency/clients/coinpaprika_client.py +289 -0
  109. django_cfg/modules/django_currency/clients/yahoo_client.py +157 -0
  110. django_cfg/modules/django_currency/core/__init__.py +1 -7
  111. django_cfg/modules/django_currency/core/converter.py +18 -23
  112. django_cfg/modules/django_currency/core/models.py +122 -11
  113. django_cfg/modules/django_currency/database/__init__.py +4 -4
  114. django_cfg/modules/django_currency/database/database_loader.py +190 -309
  115. django_cfg/modules/django_unfold/dashboard.py +7 -2
  116. django_cfg/registry/core.py +1 -0
  117. django_cfg/template_archive/.gitignore +1 -0
  118. django_cfg/template_archive/django_sample.zip +0 -0
  119. django_cfg/templates/admin/components/action_grid.html +9 -9
  120. django_cfg/templates/admin/components/metric_card.html +5 -5
  121. django_cfg/templates/admin/components/status_badge.html +2 -2
  122. django_cfg/templates/admin/layouts/dashboard_with_tabs.html +152 -24
  123. django_cfg/templates/admin/snippets/components/quick_actions.html +3 -3
  124. django_cfg/templates/admin/snippets/components/system_health.html +1 -1
  125. django_cfg/templates/admin/snippets/tabs/overview_tab.html +49 -52
  126. {django_cfg-1.2.27.dist-info → django_cfg-1.2.31.dist-info}/METADATA +13 -18
  127. {django_cfg-1.2.27.dist-info → django_cfg-1.2.31.dist-info}/RECORD +130 -83
  128. django_cfg/apps/payments/management/commands/populate_currencies.py +0 -246
  129. django_cfg/apps/payments/management/commands/update_currencies.py +0 -336
  130. django_cfg/apps/payments/services/providers/cryptapi.py +0 -273
  131. django_cfg/apps/payments/services/providers/cryptomus.py +0 -310
  132. django_cfg/apps/payments/services/providers/nowpayments.py +0 -293
  133. django_cfg/apps/payments/services/validators/__init__.py +0 -8
  134. django_cfg/modules/django_currency/clients/coingecko_client.py +0 -257
  135. django_cfg/modules/django_currency/clients/yfinance_client.py +0 -246
  136. {django_cfg-1.2.27.dist-info → django_cfg-1.2.31.dist-info}/WHEEL +0 -0
  137. {django_cfg-1.2.27.dist-info → django_cfg-1.2.31.dist-info}/entry_points.txt +0 -0
  138. {django_cfg-1.2.27.dist-info → django_cfg-1.2.31.dist-info}/licenses/LICENSE +0 -0
@@ -0,0 +1,258 @@
1
+ {% extends 'payments/base.html' %}
2
+ {% load payments_tags %}
3
+ {% load static %}
4
+
5
+ {% block title %}Payment Dashboard - Django CFG{% endblock %}
6
+
7
+ {% block header_title %}Payment Dashboard{% endblock %}
8
+ {% block header_subtitle %}Monitor and manage payment transactions in real-time{% endblock %}
9
+
10
+ {% block content %}
11
+ <div class="space-y-6">
12
+ <!-- Debug Info (Collapsible) -->
13
+ <div class="bg-yellow-50 dark:bg-yellow-900/20 border border-yellow-200 dark:border-yellow-800 rounded-lg mb-6">
14
+ <button onclick="toggleDebug()" class="w-full px-4 py-3 text-left flex items-center justify-between text-yellow-800 dark:text-yellow-200 hover:bg-yellow-100 dark:hover:bg-yellow-900/30 transition-colors duration-200">
15
+ <span class="font-medium">🐛 Debug Information</span>
16
+ <span id="debug-icon" class="material-icons text-sm transform transition-transform duration-200">expand_more</span>
17
+ </button>
18
+ <div id="debug-content" class="hidden px-4 pb-3 text-yellow-700 dark:text-yellow-300 text-sm">
19
+ <div class="space-y-1">
20
+ <p><strong>Payments:</strong> {{ payments|length }}</p>
21
+ <p><strong>Payment Stats:</strong> {{ payment_stats }}</p>
22
+ <p><strong>Provider Stats:</strong> {{ provider_stats|length }}</p>
23
+ <p><strong>Context Keys:</strong> {{ view|default:"no view" }}</p>
24
+ </div>
25
+ </div>
26
+ </div>
27
+
28
+ <!-- Status Overview -->
29
+ {% include 'payments/components/status_overview.html' %}
30
+
31
+ <!-- Main Dashboard Grid -->
32
+ <div class="grid grid-cols-1 lg:grid-cols-3 gap-6">
33
+ <!-- Recent Payments -->
34
+ <div class="lg:col-span-2">
35
+ <div class="bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700 rounded-lg shadow-sm">
36
+ <div class="p-6 border-b border-gray-200 dark:border-gray-700">
37
+ <div class="flex items-center justify-between">
38
+ <h3 class="text-lg font-semibold text-gray-900 dark:text-white">Recent Payments</h3>
39
+ <a href="/admin/django_cfg_payments/universalpayment/"
40
+ class="text-blue-600 dark:text-blue-400 hover:text-blue-700 dark:hover:text-blue-300 text-sm font-medium">
41
+ View All →
42
+ </a>
43
+ </div>
44
+ </div>
45
+
46
+ <div class="p-6">
47
+ <!-- Debug: Payments Section -->
48
+ <div class="bg-blue-50 dark:bg-blue-900/20 border border-blue-200 dark:border-blue-800 text-blue-800 dark:text-blue-200 px-4 py-3 rounded mb-4">
49
+ <strong>Payments Debug:</strong> Count={{ payments|length }}
50
+ {% if payments %}
51
+ <br><strong>First payment:</strong> {{ payments.0.user.email }} - ${{ payments.0.amount_usd }}
52
+ {% endif %}
53
+ </div>
54
+
55
+ {% if payments %}
56
+ <div class="space-y-4">
57
+ {% for payment in payments %}
58
+ <div class="flex items-center justify-between p-4 bg-gray-50 dark:bg-gray-800 rounded-lg border border-gray-200 dark:border-gray-700">
59
+ <div class="flex items-center space-x-4">
60
+ <div class="w-3 h-3 rounded-full
61
+ {% if payment.provider == 'cryptapi' %}bg-orange-500
62
+ {% elif payment.provider == 'cryptomus' %}bg-blue-500
63
+ {% elif payment.provider == 'stripe' %}bg-purple-500
64
+ {% elif payment.provider == 'nowpayments' %}bg-green-500
65
+ {% else %}bg-gray-500{% endif %}">
66
+ </div>
67
+ <div>
68
+ <p class="text-sm font-medium text-gray-900 dark:text-white">
69
+ ${{ payment.amount_usd|floatformat:2 }}
70
+ </p>
71
+ <p class="text-xs text-gray-500 dark:text-gray-400">
72
+ {{ payment.user.email }} • {{ payment.provider|capfirst }}
73
+ </p>
74
+ </div>
75
+ </div>
76
+ <div class="flex items-center space-x-3">
77
+ <span class="px-2 py-1 text-xs rounded-full bg-warning-100 text-warning-800 dark:bg-warning-900 dark:text-warning-200">
78
+ {{ payment.status|capfirst }}
79
+ </span>
80
+ <span class="text-xs text-gray-500 dark:text-gray-400">
81
+ {{ payment.created_at|timesince }} ago
82
+ </span>
83
+ </div>
84
+ </div>
85
+ {% endfor %}
86
+ </div>
87
+ {% else %}
88
+ <div class="text-center py-8">
89
+ <div class="text-gray-400 mb-2">💳</div>
90
+ <p class="text-gray-600 dark:text-gray-400">No payments found</p>
91
+ <a href="/admin/django_cfg_payments/universalpayment/add/"
92
+ class="text-blue-600 dark:text-blue-400 hover:text-blue-700 dark:hover:text-blue-300 text-sm font-medium">
93
+ Create first payment
94
+ </a>
95
+ </div>
96
+ {% endif %}
97
+ </div>
98
+ </div>
99
+ </div>
100
+
101
+ <!-- Sidebar Stats -->
102
+ <div class="space-y-6">
103
+ <!-- Provider Performance -->
104
+ <div class="bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700 rounded-lg shadow-sm">
105
+ <div class="p-6 border-b border-gray-200 dark:border-gray-700">
106
+ <h4 class="text-lg font-semibold text-gray-900 dark:text-white">Provider Status</h4>
107
+ </div>
108
+ <div class="p-6">
109
+ {% if provider_stats %}
110
+ <div class="space-y-3">
111
+ {% for provider in provider_stats %}
112
+ <div class="flex items-center justify-between">
113
+ <div class="flex items-center space-x-2">
114
+ <div class="w-2 h-2 rounded-full
115
+ {% if provider.provider == 'cryptapi' %}bg-orange-500
116
+ {% elif provider.provider == 'cryptomus' %}bg-blue-500
117
+ {% elif provider.provider == 'stripe' %}bg-purple-500
118
+ {% elif provider.provider == 'nowpayments' %}bg-green-500
119
+ {% else %}bg-gray-500{% endif %}">
120
+ </div>
121
+ <span class="text-sm text-gray-700 dark:text-gray-300 capitalize">{{ provider.provider }}</span>
122
+ </div>
123
+ <span class="text-xs text-gray-500 dark:text-gray-400">
124
+ {{ provider.count|default:"0" }} payments
125
+ </span>
126
+ </div>
127
+ {% endfor %}
128
+ </div>
129
+ {% else %}
130
+ <p class="text-sm text-gray-500 dark:text-gray-400 text-center">No provider data</p>
131
+ {% endif %}
132
+ </div>
133
+ </div>
134
+
135
+ <!-- System Status -->
136
+ <div class="bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700 rounded-lg shadow-sm">
137
+ <div class="p-6 border-b border-gray-200 dark:border-gray-700">
138
+ <h4 class="text-lg font-semibold text-gray-900 dark:text-white">System Status</h4>
139
+ </div>
140
+ <div class="p-6">
141
+ <div class="space-y-3">
142
+ <div class="flex items-center justify-between">
143
+ <span class="text-sm text-gray-700 dark:text-gray-300">API Status</span>
144
+ <span class="inline-flex items-center px-2 py-1 rounded-full text-xs font-medium bg-green-100 text-green-800 dark:bg-green-900 dark:text-green-200">
145
+ Online
146
+ </span>
147
+ </div>
148
+ <div class="flex items-center justify-between">
149
+ <span class="text-sm text-gray-700 dark:text-gray-300">Webhook Queue</span>
150
+ <span class="inline-flex items-center px-2 py-1 rounded-full text-xs font-medium bg-blue-100 text-blue-800 dark:bg-blue-900 dark:text-blue-200">
151
+ Processing
152
+ </span>
153
+ </div>
154
+ <div class="flex items-center justify-between">
155
+ <span class="text-sm text-gray-700 dark:text-gray-300">Database</span>
156
+ <span class="inline-flex items-center px-2 py-1 rounded-full text-xs font-medium bg-green-100 text-green-800 dark:bg-green-900 dark:text-green-200">
157
+ Connected
158
+ </span>
159
+ </div>
160
+ </div>
161
+ </div>
162
+ </div>
163
+
164
+ <!-- Quick Actions -->
165
+ <div class="bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700 rounded-lg shadow-sm">
166
+ <div class="p-6 border-b border-gray-200 dark:border-gray-700">
167
+ <h4 class="text-lg font-semibold text-gray-900 dark:text-white">Quick Actions</h4>
168
+ </div>
169
+ <div class="p-6">
170
+ <div class="space-y-3">
171
+ <a href="/cfg/admin/django_cfg_payments/admin/stats/"
172
+ class="block w-full text-center px-3 py-2 bg-blue-600 hover:bg-blue-700 dark:bg-blue-500 dark:hover:bg-blue-600 text-white rounded-md text-sm font-medium transition-colors duration-200">
173
+ View Analytics
174
+ </a>
175
+ <a href="/cfg/admin/django_cfg_payments/admin/test/"
176
+ class="block w-full text-center px-3 py-2 bg-gray-600 hover:bg-gray-700 dark:bg-gray-500 dark:hover:bg-gray-600 text-white rounded-md text-sm font-medium transition-colors duration-200">
177
+ Test Providers
178
+ </a>
179
+ <a href="/admin/django_cfg_payments/universalpayment/add/"
180
+ class="block w-full text-center px-3 py-2 border border-gray-300 dark:border-gray-500 text-gray-700 dark:text-gray-200 bg-white dark:bg-gray-700 hover:bg-gray-50 dark:hover:bg-gray-600 rounded-md text-sm font-medium transition-colors duration-200">
181
+ Create Payment
182
+ </a>
183
+ </div>
184
+ </div>
185
+ </div>
186
+ </div>
187
+ </div>
188
+ </div>
189
+ {% endblock %}
190
+
191
+ {% block extra_js %}
192
+ <script>
193
+ // Simplified dashboard JavaScript
194
+ document.addEventListener('DOMContentLoaded', function() {
195
+ console.log('Payment Dashboard loaded');
196
+
197
+ // Initialize any tooltips or interactive elements
198
+ initializeDashboard();
199
+ });
200
+
201
+ function initializeDashboard() {
202
+ // Add click handlers for any interactive elements
203
+ const copyButtons = document.querySelectorAll('[data-copy]');
204
+ copyButtons.forEach(button => {
205
+ button.addEventListener('click', function() {
206
+ const text = this.getAttribute('data-copy');
207
+ if (window.paymentUtils) {
208
+ window.paymentUtils.copyToClipboard(text);
209
+ }
210
+ });
211
+ });
212
+
213
+ // Auto-refresh timestamp every minute
214
+ setInterval(updateTimestamps, 60000);
215
+ }
216
+
217
+ function updateTimestamps() {
218
+ const timestampElements = document.querySelectorAll('[data-timestamp]');
219
+ timestampElements.forEach(element => {
220
+ const timestamp = element.getAttribute('data-timestamp');
221
+ if (timestamp && window.paymentUtils) {
222
+ element.textContent = window.paymentUtils.timeAgo(timestamp);
223
+ }
224
+ });
225
+ }
226
+
227
+ // Quick action functions (from status_overview.html)
228
+ function createNewPayment() {
229
+ window.location.href = '/admin/django_cfg_payments/universalpayment/add/';
230
+ }
231
+
232
+ function refreshPayments() {
233
+ location.reload();
234
+ }
235
+
236
+ function exportPayments() {
237
+ if (window.notificationManager) {
238
+ window.notificationManager.info('Export functionality coming soon');
239
+ }
240
+ }
241
+
242
+ // Debug panel toggle
243
+ function toggleDebug() {
244
+ const content = document.getElementById('debug-content');
245
+ const icon = document.getElementById('debug-icon');
246
+
247
+ if (content.classList.contains('hidden')) {
248
+ content.classList.remove('hidden');
249
+ icon.textContent = 'expand_less';
250
+ icon.classList.add('rotate-180');
251
+ } else {
252
+ content.classList.add('hidden');
253
+ icon.textContent = 'expand_more';
254
+ icon.classList.remove('rotate-180');
255
+ }
256
+ }
257
+ </script>
258
+ {% endblock %}
@@ -0,0 +1,35 @@
1
+ {% extends 'payments/base.html' %}
2
+
3
+ {% block title %}Payment Dashboard - Simple Test{% endblock %}
4
+
5
+ {% block header_title %}Payment Dashboard - Test{% endblock %}
6
+ {% block header_subtitle %}Simple test version{% endblock %}
7
+
8
+ {% block content %}
9
+ <div style="background: yellow; padding: 20px; margin: 20px; border: 2px solid red;">
10
+ <h1 style="color: black;">🔥 DASHBOARD TEST 🔥</h1>
11
+ <p style="color: black;"><strong>Payments count:</strong> {{ payments|length }}</p>
12
+ <p style="color: black;"><strong>Payment stats:</strong> {{ payment_stats }}</p>
13
+ <p style="color: black;"><strong>Provider stats:</strong> {{ provider_stats|length }}</p>
14
+
15
+ {% if payments %}
16
+ <h2 style="color: black;">Payments List:</h2>
17
+ <ul style="color: black;">
18
+ {% for payment in payments %}
19
+ <li>{{ payment.user.email }} - ${{ payment.amount_usd }} ({{ payment.status }})</li>
20
+ {% endfor %}
21
+ </ul>
22
+ {% else %}
23
+ <p style="color: red; font-size: 20px;">❌ NO PAYMENTS FOUND</p>
24
+ {% endif %}
25
+
26
+ {% if payment_stats %}
27
+ <h2 style="color: black;">Stats:</h2>
28
+ <p style="color: black;">Total: {{ payment_stats.total_payments_count }}</p>
29
+ <p style="color: black;">Pending: {{ payment_stats.pending_payments_count }}</p>
30
+ <p style="color: black;">Volume: ${{ payment_stats.total_volume }}</p>
31
+ {% else %}
32
+ <p style="color: red; font-size: 20px;">❌ NO STATS FOUND</p>
33
+ {% endif %}
34
+ </div>
35
+ {% endblock %}