Deploy on 2026-06-05 17:47:27

This commit is contained in:
Hamza-Ayed
2026-06-05 17:47:27 +03:00
parent e5074451af
commit f468227019
15 changed files with 415 additions and 225 deletions

View File

@@ -1,5 +1,5 @@
<div class="page-header">
<h1><?= $contact ? 'Edit' : 'Add' ?> Contact</h1>
<h1><?= $contact ? 'تعديل' : 'إضافة' ?> جهة اتصال</h1>
</div>
<div class="glass-panel" style="max-width: 600px;">
@@ -10,30 +10,30 @@
<input type="hidden" name="_csrf" value="<?= $this->session->getCsrfToken() ?>">
<div class="form-group">
<label class="form-label">Name *</label>
<label class="form-label">الاسم *</label>
<input type="text" name="name" class="form-control" required value="<?= $contact ? $this->escape($contact['name']) : '' ?>">
</div>
<div class="form-row">
<div class="form-group">
<label class="form-label">Email</label>
<label class="form-label">البريد الإلكتروني</label>
<input type="email" name="email" class="form-control" value="<?= $contact ? $this->escape($contact['email'] ?? '') : '' ?>">
</div>
<div class="form-group">
<label class="form-label">Phone</label>
<label class="form-label">رقم الهاتف</label>
<input type="text" name="phone" class="form-control" value="<?= $contact ? $this->escape($contact['phone'] ?? '') : '' ?>">
</div>
</div>
<div class="form-group">
<label class="form-label">Position / Title</label>
<input type="text" name="position" class="form-control" placeholder="e.g. Partner, Director" value="<?= $contact ? $this->escape($contact['position'] ?? '') : '' ?>">
<label class="form-label">المسمى الوظيفي</label>
<input type="text" name="position" class="form-control" placeholder="مثال: شريك، مدير استثمار" value="<?= $contact ? $this->escape($contact['position'] ?? '') : '' ?>">
</div>
<div class="form-group">
<label class="form-label">Organization</label>
<label class="form-label">المنظمة / الجهة</label>
<select name="organization_id" class="form-control">
<option value="">No Organization</option>
<option value="">مستقل (بدون منظمة)</option>
<?php foreach ($organizations as $org): ?>
<option value="<?= $org['id'] ?>" <?= ($selectedOrgId == $org['id']) ? 'selected' : '' ?>><?= $this->escape($org['name']) ?></option>
<?php endforeach; ?>
@@ -41,13 +41,13 @@
</div>
<div class="form-group">
<label class="form-label">Notes</label>
<label class="form-label">ملاحظات</label>
<textarea name="notes" class="form-control" rows="3"><?= $contact ? $this->escape($contact['notes'] ?? '') : '' ?></textarea>
</div>
<div style="display: flex; gap: 12px; margin-top: 10px;">
<button type="submit" class="btn btn-primary"><?= $contact ? 'Update' : 'Create' ?> Contact</button>
<a href="/admin/contacts" class="btn btn-secondary">Cancel</a>
<button type="submit" class="btn btn-primary"><?= $contact ? 'تحديث' : 'إضافة' ?> جهة اتصال</button>
<a href="/admin/contacts" class="btn btn-secondary">إلغاء</a>
</div>
</form>
</div>

View File

@@ -1,9 +1,9 @@
<div class="page-header">
<div>
<h1>Contacts</h1>
<p>Manage your network of investor contacts and interactions</p>
<h1>جهات الاتصال</h1>
<p>إدارة شبكة جهات الاتصال والتفاعلات مع المستثمرين والشركاء</p>
</div>
<a href="/admin/contacts/create" class="btn btn-primary">+ Add Contact</a>
<a href="/admin/contacts/create" class="btn btn-primary">+ إضافة جهة اتصال</a>
</div>
<?php if ($flashSuccess = $this->session->getFlash('success')): ?>
@@ -12,8 +12,8 @@
<div class="filters-bar">
<form method="GET" class="filters-form">
<input type="text" name="search" class="form-control" placeholder="Search contacts..." value="<?= $this->escape($search) ?>">
<button type="submit" class="btn btn-secondary">Search</button>
<input type="text" name="search" class="form-control" placeholder="البحث عن جهات الاتصال..." value="<?= $this->escape($search) ?>">
<button type="submit" class="btn btn-secondary">بحث</button>
</form>
</div>
@@ -21,17 +21,17 @@
<table class="data-table">
<thead>
<tr>
<th>Name</th>
<th>Position</th>
<th>Organization</th>
<th>Email</th>
<th>Interactions</th>
<th>Actions</th>
<th>الاسم</th>
<th>المسمى الوظيفي</th>
<th>المنظمة / الجهة</th>
<th>البريد الإلكتروني</th>
<th>التفاعلات</th>
<th>الإجراءات</th>
</tr>
</thead>
<tbody>
<?php if (empty($contacts)): ?>
<tr><td colspan="6" style="text-align: center; padding: 40px; color: var(--text-muted);">No contacts yet.</td></tr>
<tr><td colspan="6" style="text-align: center; padding: 40px; color: var(--text-muted);">لا توجد جهات اتصال حالياً.</td></tr>
<?php else: ?>
<?php foreach ($contacts as $contact): ?>
<tr>
@@ -41,8 +41,8 @@
<td><?= $contact['email'] ? $this->escape($contact['email']) : '-' ?></td>
<td><?= $contact['interaction_count'] ?? 0 ?></td>
<td>
<a href="/admin/contacts/<?= $contact['id'] ?>" class="btn btn-sm btn-secondary">View</a>
<a href="/admin/contacts/<?= $contact['id'] ?>/edit" class="btn btn-sm btn-secondary">Edit</a>
<a href="/admin/contacts/<?= $contact['id'] ?>" class="btn btn-sm btn-secondary">عرض</a>
<a href="/admin/contacts/<?= $contact['id'] ?>/edit" class="btn btn-sm btn-secondary">تعديل</a>
</td>
</tr>
<?php endforeach; ?>
@@ -61,7 +61,7 @@
<style>
.data-table { width: 100%; border-collapse: collapse; }
.data-table th, .data-table td { padding: 12px 16px; text-align: left; border-bottom: 1px solid rgba(255,255,255,0.05); }
.data-table th, .data-table td { padding: 12px 16px; text-align: right; border-bottom: 1px solid rgba(255,255,255,0.05); }
.data-table th { font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-muted); font-weight: 600; }
.data-table tr:hover { background: rgba(255,255,255,0.02); }
</style>

View File

@@ -1,10 +1,10 @@
<div class="page-header">
<div>
<h1><?= $this->escape($contact['name']) ?></h1>
<p><?= $contact['position'] ? $this->escape($contact['position']) . ' • ' : '' ?><?= $contact['org_name'] ? $this->escape($contact['org_name']) : 'Independent' ?></p>
<p><?= $contact['position'] ? $this->escape($contact['position']) . ' • ' : '' ?><?= $contact['org_name'] ? $this->escape($contact['org_name']) : 'مستقل' ?></p>
</div>
<div style="display: flex; gap: 10px;">
<a href="/admin/contacts/<?= $contact['id'] ?>/edit" class="btn btn-secondary">Edit</a>
<a href="/admin/contacts/<?= $contact['id'] ?>/edit" class="btn btn-secondary">تعديل</a>
</div>
</div>
@@ -14,58 +14,67 @@
<div class="detail-grid">
<div class="glass-panel">
<h3 style="margin-bottom: 20px;">Contact Details</h3>
<h3 style="margin-bottom: 20px;">تفاصيل جهة الاتصال</h3>
<div class="detail-row">
<span class="detail-label">Email</span>
<span class="detail-label">البريد الإلكتروني</span>
<span><?= $contact['email'] ? $this->escape($contact['email']) : '-' ?></span>
</div>
<div class="detail-row">
<span class="detail-label">Phone</span>
<span class="detail-label">رقم الهاتف</span>
<span><?= $contact['phone'] ? $this->escape($contact['phone']) : '-' ?></span>
</div>
<div class="detail-row">
<span class="detail-label">Position</span>
<span class="detail-label">المسمى الوظيفي</span>
<span><?= $this->escape($contact['position'] ?? '-') ?></span>
</div>
<div class="detail-row">
<span class="detail-label">Organization</span>
<span class="detail-label">المنظمة / الجهة</span>
<span><?= $contact['org_id'] ? '<a href="/admin/organizations/' . $contact['org_id'] . '">' . $this->escape($contact['org_name']) . '</a>' : '-' ?></span>
</div>
<div class="detail-row" style="flex-direction: column; align-items: flex-start;">
<span class="detail-label">Notes</span>
<p style="margin-top: 8px; line-height: 1.6;"><?= $this->escape($contact['notes'] ?? 'No notes') ?></p>
<span class="detail-label">ملاحظات</span>
<p style="margin-top: 8px; line-height: 1.6;"><?= $this->escape($contact['notes'] ?? 'لا توجد ملاحظات') ?></p>
</div>
</div>
<div>
<!-- Interactions -->
<div class="glass-panel" style="margin-bottom: 20px;">
<h3 style="margin-bottom: 16px;">Interactions (<?= count($interactions) ?>)</h3>
<h3 style="margin-bottom: 16px;">التفاعلات (<?= count($interactions) ?>)</h3>
<form action="/admin/contacts/<?= $contact['id'] ?>/interaction" method="POST" style="display: flex; flex-direction: column; gap: 10px; margin-bottom: 20px;">
<input type="hidden" name="_csrf" value="<?= $this->session->getCsrfToken() ?>">
<div class="form-row" style="display: flex; gap: 10px;">
<select name="type" class="form-control" style="flex: 0 0 120px;">
<option value="note">Note</option>
<option value="email">Email</option>
<option value="call">Call</option>
<option value="meeting">Meeting</option>
<option value="note">ملاحظة</option>
<option value="email">بريد إلكتروني</option>
<option value="call">مكالمة هاتفية</option>
<option value="meeting">اجتماع</option>
</select>
<input type="text" name="notes" class="form-control" placeholder="Add interaction note..." required>
<button type="submit" class="btn btn-primary">Log</button>
<input type="text" name="notes" class="form-control" placeholder="إضافة تفاصيل التفاعل..." required>
<button type="submit" class="btn btn-primary">تسجيل</button>
</div>
</form>
<?php if (empty($interactions)): ?>
<p style="color: var(--text-muted);">No interactions logged yet.</p>
<p style="color: var(--text-muted);">لم يتم تسجيل أي تفاعلات بعد.</p>
<?php else: ?>
<?php foreach ($interactions as $interaction): ?>
<?php
$interTrans = [
'note' => 'ملاحظة',
'email' => 'بريد إلكتروني',
'call' => 'مكالمة هاتفية',
'meeting' => 'اجتماع'
];
$transType = $interTrans[$interaction['type']] ?? $interaction['type'];
?>
<div class="list-item">
<div style="display: flex; justify-content: space-between; align-items: center;">
<span class="badge" style="background: rgba(56, 189, 248, 0.2); color: #38bdf8;"><?= $this->escape($interaction['type']) ?></span>
<small style="color: var(--text-muted);"><?= date('M j, g:i a', strtotime($interaction['created_at'])) ?></small>
<div style="display: flex; justify-content: space-between; align-items: center; flex-direction: row-reverse;">
<span class="badge" style="background: rgba(56, 189, 248, 0.2); color: #38bdf8;"><?= $this->escape($transType) ?></span>
<small style="color: var(--text-muted);"><?= date('Y-m-d H:i', strtotime($interaction['created_at'])) ?></small>
</div>
<p style="margin-top: 8px; line-height: 1.5;"><?= $this->escape($interaction['notes']) ?></p>
<p style="margin-top: 8px; line-height: 1.5; text-align: right;"><?= $this->escape($interaction['notes']) ?></p>
</div>
<?php endforeach; ?>
<?php endif; ?>

View File

@@ -41,20 +41,20 @@
<!-- Metrics Row -->
<div class="metrics-grid" style="margin-top: 24px;">
<div class="glass-panel metric-card">
<span class="metric-title"><?= $t['total_organizations'] ?? 'Organizations' ?></span>
<span class="metric-title"><?= $t['total_organizations'] ?? 'المنظمات' ?></span>
<span class="metric-value"><?= $stats['organizations'] ?></span>
<span class="metric-footer">
<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5"><polyline points="23 6 13.5 15.5 8.5 10.5 1 18"></polyline><polyline points="17 6 23 6 23 12"></polyline></svg>
<span><?= $stats['vc'] ?> VC • <?= $stats['accelerators'] ?> Accelerators</span>
<span><?= $stats['vc'] ?> استثمار جريء • <?= $stats['accelerators'] ?> مسرعات</span>
</span>
</div>
<div class="glass-panel metric-card">
<span class="metric-title"><?= $t['total_opportunities'] ?? 'Opportunities' ?></span>
<span class="metric-title"><?= $t['total_opportunities'] ?? 'الفرص' ?></span>
<span class="metric-value"><?= $stats['opportunities'] ?></span>
<span class="metric-footer">
<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5"><polyline points="23 6 13.5 15.5 8.5 10.5 1 18"></polyline><polyline points="17 6 23 6 23 12"></polyline></svg>
<span><?= $stats['today'] ?> new today</span>
<span><?= $stats['today'] ?> جديدة اليوم</span>
</span>
</div>
@@ -68,11 +68,11 @@
</div>
<div class="glass-panel metric-card">
<span class="metric-title"><?= $t['active_sources'] ?? 'Sources' ?></span>
<span class="metric-title"><?= $t['active_sources'] ?? 'مصادر البيانات' ?></span>
<span class="metric-value"><?= $stats['sources'] ?></span>
<span class="metric-footer">
<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5"><circle cx="12" cy="12" r="10"></circle><polyline points="12 6 12 12 16 14"></polyline></svg>
<span>RSS feeds active</span>
<span>مصادر RSS نشطة</span>
</span>
</div>
</div>
@@ -80,14 +80,14 @@
<!-- Charts Row -->
<div class="charts-grid" style="margin-top: 24px;">
<div class="glass-panel chart-card">
<span class="chart-title">Opportunities by Category</span>
<span class="chart-title">الفرص حسب التصنيف</span>
<div style="flex: 1; position: relative;">
<canvas id="categoryChart"></canvas>
</div>
</div>
<div class="glass-panel chart-card">
<span class="chart-title">Monthly Growth & Ingestion</span>
<span class="chart-title">النمو الشهري وتجميع البيانات</span>
<div style="flex: 1; position: relative;">
<canvas id="growthChart"></canvas>
</div>
@@ -103,7 +103,7 @@
</div>
<div style="max-height: 400px; overflow-y: auto;">
<?php if (empty($recent_opportunities)): ?>
<p style="color: var(--text-muted); text-align: center; padding: 40px;">No opportunities yet. Run the collector to start gathering data.</p>
<p style="color: var(--text-muted); text-align: center; padding: 40px;">لا توجد فرص حتى الآن. قم بتشغيل جامع البيانات لبدء جمع البيانات.</p>
<?php else: ?>
<?php foreach ($recent_opportunities as $opp): ?>
<div class="list-item">
@@ -112,7 +112,7 @@
<a href="/admin/opportunities/<?= $opp['id'] ?>" style="font-weight: 600;"><?= $this->escape(mb_substr($opp['title'], 0, 80)) ?></a>
<div style="display: flex; gap: 8px; margin-top: 4px; flex-wrap: wrap;">
<span class="badge badge-type"><?= $this->escape($opp['type']) ?></span>
<span style="font-size: 0.8rem; color: var(--text-muted);">Score: <?= $opp['score'] ?></span>
<span style="font-size: 0.8rem; color: var(--text-muted);">درجة الأهمية: <?= $opp['score'] ?></span>
</div>
</div>
<small style="color: var(--text-muted); white-space: nowrap;"><?= date('M j', strtotime($opp['created_at'])) ?></small>
@@ -130,7 +130,7 @@
</div>
<div style="max-height: 400px; overflow-y: auto;">
<?php if (empty($recent_activities)): ?>
<p style="color: var(--text-muted); text-align: center; padding: 40px;">No recent activity.</p>
<p style="color: var(--text-muted); text-align: center; padding: 40px;">لا توجد نشاطات حديثة.</p>
<?php else: ?>
<?php foreach ($recent_activities as $activity): ?>
<div class="list-item">
@@ -168,17 +168,17 @@
const categoryLabels = hasCategoryData
? Object.keys(categoriesData).map(k => {
const trans = {
'grant': '<?= $t['grant'] ?? 'Grants' ?>',
'competition': '<?= $t['competition'] ?? 'Competitions' ?>',
'demo_day': '<?= $t['demo_day'] ?? 'Demo Days' ?>',
'event': '<?= $t['event'] ?? 'Events' ?>',
'partnership': '<?= $t['partnership'] ?? 'Partnerships' ?>',
'investment': '<?= $t['investment'] ?? 'Investments' ?>',
'other': '<?= $t['other'] ?? 'Other' ?>'
'grant': '<?= $t['grant'] ?? 'المنح' ?>',
'competition': '<?= $t['competition'] ?? 'المسابقات' ?>',
'demo_day': '<?= $t['demo_day'] ?? 'أيام العروض' ?>',
'event': '<?= $t['event'] ?? 'الفعاليات' ?>',
'partnership': '<?= $t['partnership'] ?? 'الشراكات' ?>',
'investment': '<?= $t['investment'] ?? 'الاستثمارات' ?>',
'other': '<?= $t['other'] ?? 'أخرى' ?>'
};
return trans[k] || k.charAt(0).toUpperCase() + k.slice(1);
})
: ['Mobility & Logistics', 'AI & Automation', 'SaaS', 'Fintech', 'Marketplaces'];
: ['تنقل ولوجستيات', 'ذكاء اصطناعي وأتمتة', 'برمجيات خدمية', 'تكنولوجيا مالية', 'منصات تجارية'];
const categoryValues = hasCategoryData
? Object.values(categoriesData)

View File

@@ -1,39 +1,63 @@
<div class="page-header">
<div>
<h1>Opportunities</h1>
<p>Grants, competitions, events, partnerships and investment opportunities</p>
<h1>الفرص الاستثمارية</h1>
<p>المنح، المسابقات، الفعاليات، الشراكات وفرص الاستثمار</p>
</div>
</div>
<!-- Filters -->
<div class="filters-bar">
<form method="GET" class="filters-form">
<input type="text" name="search" class="form-control" placeholder="Search opportunities..." value="<?= $this->escape($search) ?>">
<input type="text" name="search" class="form-control" placeholder="البحث عن الفرص..." value="<?= $this->escape($search) ?>">
<select name="type" class="form-control">
<option value="">All Types</option>
<?php foreach ($types as $t): ?>
<option value="<?= $t ?>" <?= $type === $t ? 'selected' : '' ?>><?= ucfirst($t) ?></option>
<option value="">جميع الأنواع</option>
<?php foreach ($types as $t_key): ?>
<?php
$trans = [
'grant' => 'المنح',
'competition' => 'المسابقات',
'demo_day' => 'أيام العروض',
'event' => 'الفعاليات',
'partnership' => 'الشراكات',
'investment' => 'الاستثمارات',
'other' => 'أخرى'
];
$transName = $trans[$t_key] ?? ucfirst($t_key);
?>
<option value="<?= $t_key ?>" <?= $type === $t_key ? 'selected' : '' ?>><?= $transName ?></option>
<?php endforeach; ?>
</select>
<select name="status" class="form-control">
<option value="">All Statuses</option>
<?php foreach ($statuses as $s): ?>
<option value="<?= $s ?>" <?= $status === $s ? 'selected' : '' ?>><?= ucfirst($s) ?></option>
<option value="">جميع الحالات</option>
<?php foreach ($statuses as $s_key): ?>
<option value="<?= $s_key ?>" <?= $status === $s_key ? 'selected' : '' ?>><?= $s_key === 'active' ? 'نشط' : ($s_key === 'inactive' ? 'غير نشط' : $s_key) ?></option>
<?php endforeach; ?>
</select>
<button type="submit" class="btn btn-secondary">Filter</button>
<button type="submit" class="btn btn-secondary">تصفية</button>
</form>
</div>
<!-- Type Summary -->
<div class="metrics-grid" style="margin-bottom: 20px;">
<div class="glass-panel metric-card">
<span class="metric-title">Total</span>
<span class="metric-title">الإجمالي</span>
<span class="metric-value"><?= $total ?></span>
</div>
<?php foreach ($typeCounts as $t => $c): ?>
<?php foreach ($typeCounts as $t_key => $c): ?>
<?php
$trans = [
'grant' => 'المنح',
'competition' => 'المسابقات',
'demo_day' => 'أيام العروض',
'event' => 'الفعاليات',
'partnership' => 'الشراكات',
'investment' => 'الاستثمارات',
'other' => 'أخرى'
];
$transName = $trans[$t_key] ?? ucfirst($t_key);
?>
<div class="glass-panel metric-card">
<span class="metric-title"><?= ucfirst($t) ?></span>
<span class="metric-title"><?= $transName ?></span>
<span class="metric-value"><?= $c ?></span>
</div>
<?php endforeach; ?>
@@ -44,20 +68,35 @@
<table class="data-table">
<thead>
<tr>
<th>Title</th>
<th>Type</th>
<th>Source</th>
<th>Score</th>
<th>Status</th>
<th>Created</th>
<th>العنوان</th>
<th>النوع</th>
<th>المصدر/الشركة</th>
<th>التقييم</th>
<th>الحالة</th>
<th>تاريخ الإضافة</th>
<th></th>
</tr>
</thead>
<tbody>
<?php if (empty($opportunities)): ?>
<tr><td colspan="7" style="text-align: center; padding: 40px; color: var(--text-muted);">No opportunities yet. Run the collector first.</td></tr>
<tr><td colspan="7" style="text-align: center; padding: 40px; color: var(--text-muted);">لا توجد فرص استثمارية حالياً. يرجى تشغيل جامع البيانات أولاً.</td></tr>
<?php else: ?>
<?php foreach ($opportunities as $opp): ?>
<?php
$trans = [
'grant' => 'المنح',
'competition' => 'المسابقات',
'demo_day' => 'أيام العروض',
'event' => 'الفعاليات',
'partnership' => 'الشراكات',
'investment' => 'الاستثمارات',
'other' => 'أخرى',
'vc_funding' => 'تمويل رأس مال جريء',
'accelerator' => 'مسرعة أعمال',
'incubator' => 'حاضنة أعمال'
];
$transType = $trans[$opp['type']] ?? $opp['type'];
?>
<tr>
<td>
<a href="/admin/opportunities/<?= $opp['id'] ?>" style="font-weight: 600;"><?= $this->escape(mb_substr($opp['title'], 0, 60)) ?></a>
@@ -65,12 +104,12 @@
<br><small style="color: var(--text-muted);"><?= $this->escape(implode(', ', explode(',', $opp['tag_names']))) ?></small>
<?php endif; ?>
</td>
<td><span class="badge badge-type-<?= $opp['type'] ?>"><?= $this->escape($opp['type']) ?></span></td>
<td><span class="badge badge-type-<?= $opp['type'] ?>"><?= $this->escape($transType) ?></span></td>
<td><?= $opp['org_name'] ? $this->escape($opp['org_name']) : '-' ?></td>
<td><span class="badge" style="background: rgba(251, 191, 36, 0.2); color: #fbbf24;"><?= $opp['score'] ?></span></td>
<td><?= $this->escape($opp['status']) ?></td>
<td><?= date('M j', strtotime($opp['created_at'])) ?></td>
<td><a href="<?= $this->escape($opp['url']) ?>" target="_blank" class="btn btn-sm btn-secondary">Open</a></td>
<td><span class="badge" style="background: rgba(251, 191, 36, 0.2); color: #fbbf24;"><?= $opp['score'] ?>/100</span></td>
<td><?= $opp['status'] === 'active' ? 'نشط' : 'غير نشط' ?></td>
<td><?= date('Y-m-d', strtotime($opp['created_at'])) ?></td>
<td><a href="<?= $this->escape($opp['url']) ?>" target="_blank" class="btn btn-sm btn-secondary">فتح</a></td>
</tr>
<?php endforeach; ?>
<?php endif; ?>
@@ -98,4 +137,7 @@
.badge-type-event { background: rgba(56, 189, 248, 0.2); color: #38bdf8; }
.badge-type-demo_day { background: rgba(248, 113, 113, 0.2); color: #f87171; }
.badge-type-partnership { background: rgba(167, 139, 250, 0.2); color: #c4b5fd; }
.badge-type-vc_funding { background: rgba(139, 92, 246, 0.2); color: #a78bfa; }
.badge-type-accelerator { background: rgba(251, 191, 36, 0.2); color: #fbbf24; }
.badge-type-incubator { background: rgba(52, 211, 153, 0.2); color: #34d399; }
</style>

View File

@@ -1,49 +1,64 @@
<?php
$trans = [
'grant' => 'المنح',
'competition' => 'المسابقات',
'demo_day' => 'أيام العروض',
'event' => 'الفعاليات',
'partnership' => 'الشراكات',
'investment' => 'الاستثمارات',
'other' => 'أخرى',
'vc_funding' => 'تمويل رأس مال جريء',
'accelerator' => 'مسرعة أعمال',
'incubator' => 'حاضنة أعمال'
];
$transType = $trans[$opportunity['type']] ?? $opportunity['type'];
?>
<div class="page-header">
<div>
<h1><?= $this->escape(mb_substr($opportunity['title'], 0, 80)) ?></h1>
<p>
<span class="badge badge-type-<?= $opportunity['type'] ?>"><?= $this->escape($opportunity['type']) ?></span>
<span class="badge" style="background: rgba(251, 191, 36, 0.2); color: #fbbf24;">Score: <?= $opportunity['score'] ?></span>
<p style="margin-top: 10px; display: flex; gap: 8px;">
<span class="badge badge-type-<?= $opportunity['type'] ?>"><?= $this->escape($transType) ?></span>
<span class="badge" style="background: rgba(251, 191, 36, 0.2); color: #fbbf24;">التقييم: <?= $opportunity['score'] ?>/100</span>
</p>
</div>
</div>
<div class="detail-grid">
<div class="glass-panel">
<h3 style="margin-bottom: 20px;">Details</h3>
<h3 style="margin-bottom: 20px;">التفاصيل</h3>
<div class="detail-row">
<span class="detail-label">Status</span>
<span><?= $this->escape($opportunity['status']) ?></span>
<span class="detail-label">الحالة</span>
<span><?= $opportunity['status'] === 'active' ? 'نشط' : 'غير نشط' ?></span>
</div>
<?php if ($opportunity['org_name']): ?>
<div class="detail-row">
<span class="detail-label">Organization</span>
<span class="detail-label">الجهة/الشركة</span>
<span><a href="/admin/organizations/<?= $opportunity['organization_id'] ?>"><?= $this->escape($opportunity['org_name']) ?></a></span>
</div>
<?php endif; ?>
<div class="detail-row">
<span class="detail-label">URL</span>
<span><a href="<?= $this->escape($opportunity['url']) ?>" target="_blank">Open Link →</a></span>
<span class="detail-label">الرابط</span>
<span><a href="<?= $this->escape($opportunity['url']) ?>" target="_blank">فتح الرابط ←</a></span>
</div>
<?php if ($opportunity['deadline']): ?>
<div class="detail-row">
<span class="detail-label">Deadline</span>
<span><?= date('M j, Y', strtotime($opportunity['deadline'])) ?></span>
<span class="detail-label">الموعد النهائي</span>
<span><?= date('Y-m-d', strtotime($opportunity['deadline'])) ?></span>
</div>
<?php endif; ?>
<?php if ($opportunity['amount']): ?>
<div class="detail-row">
<span class="detail-label">Amount</span>
<span class="detail-label">المبلغ</span>
<span>$<?= number_format($opportunity['amount']) ?></span>
</div>
<?php endif; ?>
<div class="detail-row">
<span class="detail-label">Created</span>
<span><?= date('M j, Y', strtotime($opportunity['created_at'])) ?></span>
<span class="detail-label">تاريخ الإضافة</span>
<span><?= date('Y-m-d', strtotime($opportunity['created_at'])) ?></span>
</div>
<?php if ($opportunity['tag_names']): ?>
<div class="detail-row" style="flex-direction: column; align-items: flex-start;">
<span class="detail-label">Tags</span>
<span class="detail-label">الوسوم</span>
<div style="display: flex; gap: 6px; flex-wrap: wrap; margin-top: 6px;">
<?php foreach (explode(',', $opportunity['tag_names']) as $tag): ?>
<span class="badge" style="background: rgba(139, 92, 246, 0.2); color: #c4b5fd;"><?= $this->escape(trim($tag)) ?></span>
@@ -52,21 +67,21 @@
</div>
<?php endif; ?>
<div class="detail-row" style="flex-direction: column; align-items: flex-start;">
<span class="detail-label">Description</span>
<p style="margin-top: 8px; line-height: 1.6;"><?= $this->escape($opportunity['description']) ?></p>
<span class="detail-label">الوصف ونقاط القوة</span>
<p style="margin-top: 8px; line-height: 1.6; text-align: justify;"><?= $this->escape($opportunity['description']) ?></p>
</div>
</div>
<div>
<div class="glass-panel">
<h3 style="margin-bottom: 16px;">Applications (<?= count($applications) ?>)</h3>
<h3 style="margin-bottom: 16px;">الطلبات المتتبعة (<?= count($applications) ?>)</h3>
<?php if (empty($applications)): ?>
<p style="color: var(--text-muted);">No applications tracked yet.</p>
<p style="color: var(--text-muted);">لا توجد طلبات متتبعة حالياً لهذه الفرصة.</p>
<?php else: ?>
<?php foreach ($applications as $app): ?>
<div class="list-item">
<div style="display: flex; justify-content: space-between;">
<span><?= date('M j', strtotime($app['created_at'])) ?></span>
<span><?= date('Y-m-d', strtotime($app['created_at'])) ?></span>
<span class="badge" style="background: rgba(56, 189, 248, 0.2); color: #38bdf8;"><?= $this->escape($app['status']) ?></span>
</div>
<?php if ($app['notes']): ?>
@@ -85,4 +100,13 @@
.detail-label { font-size: 0.85rem; color: var(--text-muted); font-weight: 600; }
.list-item { padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,0.05); }
@media (max-width: 768px) { .detail-grid { grid-template-columns: 1fr; } }
.badge-type-grant { background: rgba(52, 211, 153, 0.2); color: #34d399; }
.badge-type-competition { background: rgba(251, 191, 36, 0.2); color: #fbbf24; }
.badge-type-investment { background: rgba(139, 92, 246, 0.2); color: #a78bfa; }
.badge-type-event { background: rgba(56, 189, 248, 0.2); color: #38bdf8; }
.badge-type-demo_day { background: rgba(248, 113, 113, 0.2); color: #f87171; }
.badge-type-partnership { background: rgba(167, 139, 250, 0.2); color: #c4b5fd; }
.badge-type-vc_funding { background: rgba(139, 92, 246, 0.2); color: #a78bfa; }
.badge-type-accelerator { background: rgba(251, 191, 36, 0.2); color: #fbbf24; }
.badge-type-incubator { background: rgba(52, 211, 153, 0.2); color: #34d399; }
</style>

View File

@@ -1,5 +1,5 @@
<div class="page-header">
<h1><?= $org ? 'Edit' : 'Add' ?> Organization</h1>
<h1><?= $org ? 'تعديل' : 'إضافة' ?> منظمة / جهة استثمارية</h1>
</div>
<?php if ($flashError = $this->session->getFlash('error')): ?>
@@ -15,29 +15,49 @@
<div class="form-row">
<div class="form-group">
<label class="form-label">Name *</label>
<label class="form-label">الاسم *</label>
<input type="text" name="name" class="form-control" required value="<?= $org ? $this->escape($org['name']) : '' ?>">
</div>
<div class="form-group">
<label class="form-label">Domain</label>
<label class="form-label">النطاق (Domain)</label>
<input type="text" name="domain" class="form-control" placeholder="example.com" value="<?= $org ? $this->escape($org['domain'] ?? '') : '' ?>">
</div>
</div>
<div class="form-row">
<div class="form-group">
<label class="form-label">Type</label>
<label class="form-label">النوع</label>
<select name="type" class="form-control">
<?php
$typeTrans = [
'vc' => 'رأس مال جريء',
'angel' => 'مستثمر ملائكي',
'accelerator' => 'مسرعة أعمال',
'incubator' => 'حاضنة أعمال',
'venture_studio' => 'استوديو مشاريع',
'partner' => 'شريك',
'other' => 'أخرى'
];
?>
<?php foreach ($types as $t): ?>
<option value="<?= $t ?>" <?= ($org && $org['type'] === $t) ? 'selected' : '' ?>><?= ucfirst($t) ?></option>
<option value="<?= $t ?>" <?= ($org && $org['type'] === $t) ? 'selected' : '' ?>><?= $typeTrans[$t] ?? ucfirst($t) ?></option>
<?php endforeach; ?>
</select>
</div>
<div class="form-group">
<label class="form-label">CRM Status</label>
<label class="form-label">الحالة في CRM</label>
<select name="crm_status" class="form-control">
<?php
$crmTrans = [
'New' => 'جديد',
'Researching' => 'قيد البحث',
'Contacted' => 'تم التواصل',
'Invested' => 'تم الاستثمار',
'Rejected' => 'مرفوض'
];
?>
<?php foreach ($statuses as $s): ?>
<option value="<?= $s ?>" <?= ($org && $org['crm_status'] === $s) ? 'selected' : '' ?>><?= $s ?></option>
<option value="<?= $s ?>" <?= ($org && $org['crm_status'] === $s) ? 'selected' : '' ?>><?= $crmTrans[$s] ?? $s ?></option>
<?php endforeach; ?>
</select>
</div>
@@ -45,33 +65,33 @@
<div class="form-row">
<div class="form-group">
<label class="form-label">Country</label>
<input type="text" name="country" class="form-control" placeholder="e.g. UAE" value="<?= $org ? $this->escape($org['country'] ?? '') : '' ?>">
<label class="form-label">الدولة</label>
<input type="text" name="country" class="form-control" placeholder="مثال: الإمارات" value="<?= $org ? $this->escape($org['country'] ?? '') : '' ?>">
</div>
<div class="form-group">
<label class="form-label">City</label>
<input type="text" name="city" class="form-control" placeholder="e.g. Dubai" value="<?= $org ? $this->escape($org['city'] ?? '') : '' ?>">
<label class="form-label">المدينة</label>
<input type="text" name="city" class="form-control" placeholder="مثال: دبي" value="<?= $org ? $this->escape($org['city'] ?? '') : '' ?>">
</div>
</div>
<div class="form-group">
<label class="form-label">Website URL</label>
<label class="form-label">رابط الموقع الإلكتروني</label>
<input type="url" name="website_url" class="form-control" placeholder="https://example.com" value="<?= $org ? $this->escape($org['website_url'] ?? '') : '' ?>">
</div>
<div class="form-group">
<label class="form-label">Funding Stage</label>
<input type="text" name="funding_stage" class="form-control" placeholder="e.g. Seed, Series A" value="<?= $org ? $this->escape($org['funding_stage'] ?? '') : '' ?>">
<label class="form-label">مرحلة التمويل</label>
<input type="text" name="funding_stage" class="form-control" placeholder="مثال: Seed، Series A" value="<?= $org ? $this->escape($org['funding_stage'] ?? '') : '' ?>">
</div>
<div class="form-group">
<label class="form-label">Description</label>
<label class="form-label">الوصف</label>
<textarea name="description" class="form-control" rows="4"><?= $org ? $this->escape($org['description'] ?? '') : '' ?></textarea>
</div>
<div style="display: flex; gap: 12px; margin-top: 20px;">
<button type="submit" class="btn btn-primary"><?= $org ? 'Update' : 'Create' ?> Organization</button>
<a href="/admin/organizations" class="btn btn-secondary">Cancel</a>
<button type="submit" class="btn btn-primary"><?= $org ? 'تحديث' : 'إنشاء' ?> المنظمة</button>
<a href="/admin/organizations" class="btn btn-secondary">إلغاء</a>
</div>
</form>
</div>

View File

@@ -1,9 +1,9 @@
<div class="page-header">
<div>
<h1>Organizations</h1>
<p>Manage VCs, accelerators, incubators and investors</p>
<h1>المنظمات والجهات الاستثمارية</h1>
<p>إدارة صناديق الاستثمار، مسرعات الأعمال، الحاضنات والمستثمرين</p>
</div>
<a href="/admin/organizations/create" class="btn btn-primary">+ Add Organization</a>
<a href="/admin/organizations/create" class="btn btn-primary">+ إضافة منظمة</a>
</div>
<?php if ($flashSuccess = $this->session->getFlash('success')): ?>
@@ -16,21 +16,33 @@
<!-- Filters -->
<div class="filters-bar">
<form method="GET" class="filters-form">
<input type="text" name="search" class="form-control" placeholder="Search organizations..." value="<?= $this->escape($search) ?>">
<input type="text" name="search" class="form-control" placeholder="البحث عن المنظمات..." value="<?= $this->escape($search) ?>">
<select name="type" class="form-control">
<option value="">All Types</option>
<?php foreach ($types as $t): ?>
<option value="<?= $t ?>" <?= $type === $t ? 'selected' : '' ?>><?= ucfirst($t) ?></option>
<option value="">جميع الأنواع</option>
<?php foreach ($types as $t_key): ?>
<?php
$trans = [
'vc' => 'رأس مال جريء',
'angel' => 'مستثمر ملائكي',
'accelerator' => 'مسرعة أعمال',
'incubator' => 'حاضنة أعمال',
'venture_studio' => 'استوديو مشاريع',
'partner' => 'شريك',
'other' => 'أخرى'
];
$transName = $trans[$t_key] ?? ucfirst($t_key);
?>
<option value="<?= $t_key ?>" <?= $type === $t_key ? 'selected' : '' ?>><?= $transName ?></option>
<?php endforeach; ?>
</select>
<button type="submit" class="btn btn-secondary">Filter</button>
<button type="submit" class="btn btn-secondary">تصفية</button>
</form>
</div>
<!-- Stats Summary -->
<div class="metrics-grid" style="margin-bottom: 20px;">
<div class="glass-panel metric-card">
<span class="metric-title">Total Organizations</span>
<span class="metric-title">إجمالي المنظمات والجهات</span>
<span class="metric-value"><?= $total ?></span>
</div>
</div>
@@ -40,20 +52,41 @@
<table class="data-table">
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th>Country</th>
<th>CRM Status</th>
<th>Opportunities</th>
<th>Updated</th>
<th>Actions</th>
<th>الاسم</th>
<th>النوع</th>
<th>الدولة</th>
<th>حالة CRM</th>
<th>الفرص المرتبطة</th>
<th>آخر تحديث</th>
<th>إجراءات</th>
</tr>
</thead>
<tbody>
<?php if (empty($organizations)): ?>
<tr><td colspan="7" style="text-align: center; padding: 40px; color: var(--text-muted);">No organizations found. Run the collector or add one manually.</td></tr>
<tr><td colspan="7" style="text-align: center; padding: 40px; color: var(--text-muted);">لا توجد منظمات أو جهات استثمارية حالياً. يرجى تشغيل جامع البيانات أو إضافة جهة يدوياً.</td></tr>
<?php else: ?>
<?php foreach ($organizations as $org): ?>
<?php
$trans = [
'vc' => 'رأس مال جريء',
'angel' => 'مستثمر ملائكي',
'accelerator' => 'مسرعة أعمال',
'incubator' => 'حاضنة أعمال',
'venture_studio' => 'استوديو مشاريع',
'partner' => 'شريك',
'other' => 'أخرى'
];
$transType = $trans[$org['type']] ?? $org['type'];
$crmTrans = [
'New' => 'جديد',
'Researching' => 'قيد البحث',
'Contacted' => 'تم التواصل',
'Invested' => 'تم الاستثمار',
'Rejected' => 'مرفوض'
];
$transCrmStatus = $crmTrans[$org['crm_status']] ?? $org['crm_status'];
?>
<tr>
<td>
<a href="/admin/organizations/<?= $org['id'] ?>" style="font-weight: 600;">
@@ -63,15 +96,15 @@
<br><small style="color: var(--text-muted);"><?= $this->escape($org['domain']) ?></small>
<?php endif; ?>
</td>
<td><span class="badge badge-<?= $org['type'] ?>"><?= $this->escape($org['type']) ?></span></td>
<td><span class="badge badge-<?= $org['type'] ?>"><?= $this->escape($transType) ?></span></td>
<td><?= $this->escape($org['country'] ?? '-') ?></td>
<td><span class="badge badge-status-<?= strtolower(str_replace(' ', '-', $org['crm_status'])) ?>"><?= $this->escape($org['crm_status']) ?></span></td>
<td><span class="badge badge-status-<?= strtolower(str_replace(' ', '-', $org['crm_status'])) ?>"><?= $this->escape($transCrmStatus) ?></span></td>
<td><?= $org['opportunities_count'] ?? 0 ?></td>
<td><?= date('M j', strtotime($org['updated_at'])) ?></td>
<td><?= date('Y-m-d', strtotime($org['updated_at'])) ?></td>
<td>
<a href="/admin/organizations/<?= $org['id'] ?>" class="btn btn-sm btn-secondary">View</a>
<a href="/admin/organizations/<?= $org['id'] ?>/edit" class="btn btn-sm btn-secondary">Edit</a>
<a href="/admin/contacts/create?organization_id=<?= $org['id'] ?>" class="btn btn-sm btn-secondary">+ Contact</a>
<a href="/admin/organizations/<?= $org['id'] ?>" class="btn btn-sm btn-secondary">عرض</a>
<a href="/admin/organizations/<?= $org['id'] ?>/edit" class="btn btn-sm btn-secondary">تعديل</a>
<a href="/admin/contacts/create?organization_id=<?= $org['id'] ?>" class="btn btn-sm btn-secondary">+ جهة اتصال</a>
</td>
</tr>
<?php endforeach; ?>
@@ -95,7 +128,7 @@
.filters-form { display: flex; gap: 12px; flex-wrap: wrap; }
.filters-form .form-control { min-width: 200px; }
.data-table { width: 100%; border-collapse: collapse; }
.data-table th, .data-table td { padding: 12px 16px; text-align: left; border-bottom: 1px solid rgba(255,255,255,0.05); }
.data-table th, .data-table td { padding: 12px 16px; border-bottom: 1px solid rgba(255,255,255,0.05); }
.data-table th { font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.5px; color: var(--text-muted); font-weight: 600; }
.data-table tr:hover { background: rgba(255,255,255,0.02); }
.badge { display: inline-block; padding: 4px 10px; border-radius: 12px; font-size: 0.78rem; font-weight: 600; }

View File

@@ -1,11 +1,32 @@
<?php
$trans = [
'vc' => 'رأس مال جريء',
'angel' => 'مستثمر ملائكي',
'accelerator' => 'مسرعة أعمال',
'incubator' => 'حاضنة أعمال',
'venture_studio' => 'استوديو مشاريع',
'partner' => 'شريك',
'other' => 'أخرى'
];
$transType = $trans[$org['type']] ?? $org['type'];
$crmTrans = [
'New' => 'جديد',
'Researching' => 'قيد البحث',
'Contacted' => 'تم التواصل',
'Invested' => 'تم الاستثمار',
'Rejected' => 'مرفوض'
];
$transCrmStatus = $crmTrans[$org['crm_status']] ?? $org['crm_status'];
?>
<div class="page-header">
<div>
<h1><?= $this->escape($org['name']) ?></h1>
<p><?= $this->escape(ucfirst($org['type'])) ?> • <?= $this->escape($org['country'] ?? 'Unknown location') ?></p>
<p><?= $this->escape($transType) ?> • <?= $this->escape($org['country'] ?? 'موقع غير محدد') ?></p>
</div>
<div style="display: flex; gap: 10px;">
<a href="/admin/organizations/<?= $org['id'] ?>/edit" class="btn btn-secondary">Edit</a>
<a href="/admin/contacts/create?organization_id=<?= $org['id'] ?>" class="btn btn-primary">+ Add Contact</a>
<a href="/admin/organizations/<?= $org['id'] ?>/edit" class="btn btn-secondary">تعديل</a>
<a href="/admin/contacts/create?organization_id=<?= $org['id'] ?>" class="btn btn-primary">+ إضافة جهة اتصال</a>
</div>
</div>
@@ -16,55 +37,70 @@
<div class="detail-grid">
<!-- Left: Details -->
<div class="glass-panel">
<h3 style="margin-bottom: 20px;">Details</h3>
<h3 style="margin-bottom: 20px;">التفاصيل</h3>
<div class="detail-row">
<span class="detail-label">Domain</span>
<span class="detail-label">النطاق</span>
<span><?= $org['domain'] ? $this->escape($org['domain']) : '-' ?></span>
</div>
<div class="detail-row">
<span class="detail-label">Website</span>
<span class="detail-label">الموقع الإلكتروني</span>
<span><?= $org['website_url'] ? '<a href="' . $this->escape($org['website_url']) . '" target="_blank">' . $this->escape($org['website_url']) . '</a>' : '-' ?></span>
</div>
<div class="detail-row">
<span class="detail-label">Country</span>
<span class="detail-label">الدولة</span>
<span><?= $this->escape($org['country'] ?? '-') ?></span>
</div>
<div class="detail-row">
<span class="detail-label">City</span>
<span class="detail-label">المدينة</span>
<span><?= $this->escape($org['city'] ?? '-') ?></span>
</div>
<div class="detail-row">
<span class="detail-label">CRM Status</span>
<span><span class="badge badge-status-<?= strtolower(str_replace(' ', '-', $org['crm_status'])) ?>"><?= $this->escape($org['crm_status']) ?></span></span>
<span class="detail-label">الحالة في CRM</span>
<span><span class="badge badge-status-<?= strtolower(str_replace(' ', '-', $org['crm_status'])) ?>"><?= $this->escape($transCrmStatus) ?></span></span>
</div>
<div class="detail-row">
<span class="detail-label">Funding Stage</span>
<span class="detail-label">مرحلة التمويل</span>
<span><?= $this->escape($org['funding_stage'] ?? '-') ?></span>
</div>
<div class="detail-row">
<span class="detail-label">Created</span>
<span><?= date('M j, Y', strtotime($org['created_at'])) ?></span>
<span class="detail-label">تاريخ الإضافة</span>
<span><?= date('Y-m-d', strtotime($org['created_at'])) ?></span>
</div>
<div class="detail-row" style="flex-direction: column; align-items: flex-start;">
<span class="detail-label">Description</span>
<p style="margin-top: 8px; line-height: 1.6;"><?= $this->escape($org['description'] ?? 'No description') ?></p>
<span class="detail-label">الوصف</span>
<p style="margin-top: 8px; line-height: 1.6; text-align: justify;"><?= $this->escape($org['description'] ?? 'لا يوجد وصف حالياً') ?></p>
</div>
</div>
<!-- Right: Opportunities & Contacts -->
<div>
<div class="glass-panel" style="margin-bottom: 20px;">
<h3 style="margin-bottom: 16px;">Opportunities (<?= count($opportunities) ?>)</h3>
<h3 style="margin-bottom: 16px;">الفرص المرتبطة (<?= count($opportunities) ?>)</h3>
<?php if (empty($opportunities)): ?>
<p style="color: var(--text-muted);">No opportunities linked to this organization yet.</p>
<p style="color: var(--text-muted);">لا توجد فرص مرتبطة بهذه المنظمة حتى الآن.</p>
<?php else: ?>
<?php foreach ($opportunities as $opp): ?>
<?php
$oppTrans = [
'grant' => 'المنح',
'competition' => 'المسابقات',
'demo_day' => 'أيام العروض',
'event' => 'الفعاليات',
'partnership' => 'الشراكات',
'investment' => 'الاستثمارات',
'other' => 'أخرى',
'vc_funding' => 'تمويل رأس مال جريء',
'accelerator' => 'مسرعة أعمال',
'incubator' => 'حاضنة أعمال'
];
$transOppType = $oppTrans[$opp['type']] ?? $opp['type'];
?>
<div class="list-item">
<div>
<a href="/admin/opportunities/<?= $opp['id'] ?>" style="font-weight: 600;"><?= $this->escape($opp['title']) ?></a>
<div style="display: flex; gap: 8px; margin-top: 6px;">
<span class="badge badge-type-<?= $opp['type'] ?>"><?= $this->escape($opp['type']) ?></span>
<span class="badge" style="background: rgba(251, 191, 36, 0.2); color: #fbbf24;">Score: <?= $opp['score'] ?></span>
<span class="badge badge-type-<?= $opp['type'] ?>"><?= $this->escape($transOppType) ?></span>
<span class="badge" style="background: rgba(251, 191, 36, 0.2); color: #fbbf24;">التقييم: <?= $opp['score'] ?>/100</span>
</div>
</div>
</div>
@@ -73,9 +109,9 @@
</div>
<div class="glass-panel">
<h3 style="margin-bottom: 16px;">Contacts (<?= count($contacts) ?>)</h3>
<h3 style="margin-bottom: 16px;">جهات الاتصال (<?= count($contacts) ?>)</h3>
<?php if (empty($contacts)): ?>
<p style="color: var(--text-muted);">No contacts added yet.</p>
<p style="color: var(--text-muted);">لم يتم إضافة جهات اتصال بعد.</p>
<?php else: ?>
<?php foreach ($contacts as $contact): ?>
<div class="list-item">
@@ -104,5 +140,19 @@
.badge-type-investment { background: rgba(139, 92, 246, 0.2); color: #a78bfa; }
.badge-type-event { background: rgba(56, 189, 248, 0.2); color: #38bdf8; }
.badge-type-partnership { background: rgba(167, 139, 250, 0.2); color: #c4b5fd; }
.badge-type-vc_funding { background: rgba(139, 92, 246, 0.2); color: #a78bfa; }
.badge-type-accelerator { background: rgba(251, 191, 36, 0.2); color: #fbbf24; }
.badge-type-incubator { background: rgba(52, 211, 153, 0.2); color: #34d399; }
.badge-vc { background: rgba(139, 92, 246, 0.2); color: #a78bfa; }
.badge-angel { background: rgba(251, 191, 36, 0.2); color: #fbbf24; }
.badge-accelerator { background: rgba(52, 211, 153, 0.2); color: #34d399; }
.badge-incubator { background: rgba(56, 189, 248, 0.2); color: #38bdf8; }
.badge-venture_studio { background: rgba(248, 113, 113, 0.2); color: #f87171; }
.badge-partner { background: rgba(167, 139, 250, 0.2); color: #a78bfa; }
.badge-status-new { background: rgba(96, 165, 250, 0.2); color: #60a5fa; }
.badge-status-researching { background: rgba(251, 191, 36, 0.2); color: #fbbf24; }
.badge-status-contacted { background: rgba(52, 211, 153, 0.2); color: #34d399; }
.badge-status-invested { background: rgba(34, 197, 94, 0.2); color: #22c55e; }
.badge-status-rejected { background: rgba(239, 68, 68, 0.2); color: #ef4444; }
@media (max-width: 768px) { .detail-grid { grid-template-columns: 1fr; } }
</style>

View File

@@ -43,15 +43,15 @@
<!-- Help Info -->
<div class="glass-panel">
<h3 style="margin-bottom: 16px;">How to set up Telegram</h3>
<ol style="line-height: 2; padding-left: 20px; color: var(--text-muted);">
<li>Create a bot via <a href="https://t.me/BotFather" target="_blank">@BotFather</a> on Telegram</li>
<li>Copy the bot token (e.g., <code>123456:ABC-DEF1234ghIkl</code>)</li>
<li>Add the bot to your group/channel</li>
<li>Send any message in the group</li>
<li>Visit <code>https://api.telegram.org/bot<TOKEN>/getUpdates</code></li>
<li>Copy your Chat ID from the response</li>
<li>Click "Send Test" to verify</li>
<h3 style="margin-bottom: 16px;">كيفية إعداد تيليجرام</h3>
<ol style="line-height: 2; padding-right: 20px; padding-left: 0; color: var(--text-muted); list-style-position: inside;">
<li>أنشئ بوتًا جديدًا عبر البحث عن <a href="https://t.me/BotFather" target="_blank">@BotFather</a> على تيليجرام</li>
<li>انسخ رمز البوت الخاص بك (Bot Token) (مثال: <code>123456:ABC-DEF1234ghIkl</code>)</li>
<li>أضف البوت إلى قناتك أو مجموعتك</li>
<li>أرسل أي رسالة في القناة/المجموعة لتفعيلها</li>
<li>افتح الرابط التالي بعد استبدال رمز البوت: <code>https://api.telegram.org/bot&lt;TOKEN&gt;/getUpdates</code></li>
<li>انسخ معرف المحادثة (Chat ID) وضعه في الحقل المخصص</li>
<li>انقر على "إرسال تجربة" للتحقق من التفعيل</li>
</ol>
</div>
</div>

View File

@@ -1,5 +1,5 @@
<div class="page-header">
<h1><?= $source ? 'Edit' : 'Add' ?> Source</h1>
<h1><?= $source ? 'تعديل' : 'إضافة' ?> مصدر</h1>
</div>
<div class="glass-panel" style="max-width: 600px;">
@@ -10,32 +10,32 @@
<input type="hidden" name="_csrf" value="<?= $this->session->getCsrfToken() ?>">
<div class="form-group">
<label class="form-label">Name</label>
<label class="form-label">الاسم</label>
<input type="text" name="name" class="form-control" required value="<?= $source ? $this->escape($source['name']) : '' ?>">
</div>
<div class="form-group">
<label class="form-label">URL</label>
<label class="form-label">الرابط</label>
<input type="url" name="url" class="form-control" required value="<?= $source ? $this->escape($source['url']) : '' ?>" placeholder="https://example.com/rss">
</div>
<div class="form-row">
<div class="form-group">
<label class="form-label">Type</label>
<label class="form-label">النوع</label>
<select name="type" class="form-control">
<option value="rss" <?= $source && $source['type'] === 'rss' ? 'selected' : '' ?>>RSS Feed</option>
<option value="api" <?= $source && $source['type'] === 'api' ? 'selected' : '' ?>>API</option>
<option value="rss" <?= $source && $source['type'] === 'rss' ? 'selected' : '' ?>>خلاصة RSS</option>
<option value="api" <?= $source && $source['type'] === 'api' ? 'selected' : '' ?>>واجهة برمجة تطبيقات (API)</option>
</select>
</div>
<div class="form-group">
<label class="form-label">Status</label>
<label class="form-label">الحالة</label>
<select name="status" class="form-control">
<option value="active" <?= $source && $source['status'] === 'active' ? 'selected' : '' ?>>Active</option>
<option value="inactive" <?= $source && $source['status'] === 'inactive' ? 'selected' : '' ?>>Inactive</option>
<option value="active" <?= $source && $source['status'] === 'active' ? 'selected' : '' ?>>نشط</option>
<option value="inactive" <?= $source && $source['status'] === 'inactive' ? 'selected' : '' ?>>غير نشط</option>
</select>
</div>
</div>
<div style="display: flex; gap: 12px; margin-top: 10px;">
<button type="submit" class="btn btn-primary">Save Source</button>
<a href="/admin/sources" class="btn btn-secondary">Cancel</a>
<button type="submit" class="btn btn-primary">حفظ المصدر</button>
<a href="/admin/sources" class="btn btn-secondary">إلغاء</a>
</div>
</form>
</div>

View File

@@ -1,9 +1,9 @@
<div class="page-header">
<div>
<h1>Data Sources</h1>
<p>Manage RSS feeds and API sources for data collection</p>
<h1>مصادر البيانات</h1>
<p>إدارة خلاصات RSS ومصادر واجهة برمجة التطبيقات (API) لجمع البيانات</p>
</div>
<a href="/admin/sources/create" class="btn btn-primary">+ Add Source</a>
<a href="/admin/sources/create" class="btn btn-primary">+ إضافة مصدر</a>
</div>
<?php if ($flashSuccess = $this->session->getFlash('success')): ?>
@@ -17,16 +17,16 @@
<table class="data-table">
<thead>
<tr>
<th>Name</th>
<th>URL</th>
<th>Type</th>
<th>Status</th>
<th>Actions</th>
<th>الاسم</th>
<th>الرابط</th>
<th>النوع</th>
<th>الحالة</th>
<th>إجراءات</th>
</tr>
</thead>
<tbody>
<?php if (empty($sources)): ?>
<tr><td colspan="5" style="text-align: center; padding: 40px; color: var(--text-muted);">No data sources configured.</td></tr>
<tr><td colspan="5" style="text-align: center; padding: 40px; color: var(--text-muted);">لا توجد مصادر بيانات مهيأة.</td></tr>
<?php else: ?>
<?php foreach ($sources as $source): ?>
<tr>
@@ -35,11 +35,11 @@
<a href="<?= $this->escape($source['url']) ?>" target="_blank" style="font-size: 0.85rem;"><?= $this->escape($source['url']) ?></a>
</td>
<td><span class="badge badge-source-<?= $source['type'] ?>"><?= $this->escape($source['type']) ?></span></td>
<td><span class="badge <?= $source['status'] === 'active' ? 'badge-active' : 'badge-inactive' ?>"><?= $this->escape($source['status']) ?></span></td>
<td><span class="badge <?= $source['status'] === 'active' ? 'badge-active' : 'badge-inactive' ?>"><?= $source['status'] === 'active' ? 'نشط' : 'غير نشط' ?></span></td>
<td>
<a href="/admin/sources/<?= $source['id'] ?>/run" class="btn btn-sm btn-primary" onclick="return confirm('Run collector on this source?')">Run</a>
<a href="/admin/sources/<?= $source['id'] ?>/edit" class="btn btn-sm btn-secondary">Edit</a>
<a href="/admin/sources/<?= $source['id'] ?>/delete" class="btn btn-sm btn-secondary" onclick="return confirm('Delete this source?')">Delete</a>
<a href="/admin/sources/<?= $source['id'] ?>/run" class="btn btn-sm btn-primary" onclick="return confirm('هل تريد تشغيل جامع البيانات على هذا المصدر؟')">تشغيل</a>
<a href="/admin/sources/<?= $source['id'] ?>/edit" class="btn btn-sm btn-secondary">تعديل</a>
<a href="/admin/sources/<?= $source['id'] ?>/delete" class="btn btn-sm btn-secondary" onclick="return confirm('هل أنت متأكد من حذف هذا المصدر؟')">حذف</a>
</td>
</tr>
<?php endforeach; ?>