Home / Politics / INEC Starts Uploading FCT...

INEC Starts Uploading FCT Council Election Results to IReV Portal

Left 10% AI estimate Right 10%
Nigeria
February 21, 2026 (Updated: March 11, 2026) 2 min read 1 source 0 Center Neutral General AI Assisted
INEC Starts Uploading FCT Council Election Results to IReV Portal
AI-Generated Content — Learn More

TheWkly Analysis

The Independent National Electoral Commission (INEC) has begun uploading election results for the FCT Council polls on its results viewing portal (IReV). Checks by Channels Television as of 9:04 pm showed results from polling units in the six local councils of the FCT trickling in hours after INEC conducted the elections. The Kwali chairmanship election results are 56.72% completed on the portal. The Gwagwalada area council chairmanship seat results are 65.68% uploaded. Aside from FCT chairmanship and councillorship posts, INEC is also uploading results of Kano and Rivers State bye-elections on the IReV portal.

Multiple perspectives analyzed from 0 sources
What this means for you:
  • FCT residents in Kwali gain clearer visibility into chairmanship results at 56.72% upload, enabling faster community planning around elected leaders.
  • Gwagwalada voters access 65.68% of area council results online, empowering them to verify outcomes and hold candidates accountable sooner.
  • Kano and Rivers bye-election participants track their results in real-time on IReV, reducing uncertainty and potential disputes for local stakeholders.
Your Wallet
This update on smooth election results in Nigeria signals political stability in a major oil-producing country, which could help keep global oil supplies steady and prevent gas prices from jumping up here at home. Lower gas prices mean more money in your pocket for commuting to work, groceries, or weekend drives. Even if it's far away, it helps control everyday costs like filling up your tank.

Multi-Perspective Analysis

Left-Leaning View

Emphasizes INEC's transparency efforts as a win for democratic accountability against elite capture in Nigerian politics.

Centrist View

Reports factual progress in result uploads without judgment, highlighting procedural updates across regions.

Right-Leaning View

Views digital uploads as practical steps strengthening electoral integrity and reducing fraud opportunities.

Source & Verification

Source: Channels TV RSS

Status: AI Processed

Want to dive deeper?

We've prepared an in-depth analysis of this story with additional context and background.

Featuring Our Experts' Perspectives in an easy-to-read format.

Future Snapshot

See how this story could impact your life in the coming months

Sign In to Generate

Exclusive Member Feature

Create a free account to access personalized Future Snapshots

Future Snapshots show you personalized visions of how insights from this story could positively impact your life in the next 6-12 months.

  • Tailored to your life indicators
  • Clear next steps and action items
  • Save snapshots to your profile

Related Roadmaps

Explore step-by-step guides related to this story, designed to help you apply this knowledge in your life.

Loading roadmaps...

Please wait while we find relevant roadmaps for you.

Your Opinion

No poll is available for this story.

Support Independent Journalism

If you found this story valuable, consider supporting TheWkly to help us continue delivering quality news.

Comments (0)

Add your comment

Commenting as Guest

No comments yet. Be the first to share your thoughts!

Related Stories

Moroccan Human Rights Coalition Denounces Price Surges, Wage Stagnation, and Attacks on Expression
Politics March 11, 2026

Moroccan Human Rights Coalition Denounces Price Surges, Wage Stagnation, and Attacks on Expression

The executive secretariat of the Moroccan Coalition of Human Rights Defense Organizations has...

Foreign Facebook pages promoting Australian One Nation party seek to stop
Politics March 11, 2026

Foreign Facebook pages promoting Australian One Nation party seek to stop

Foreign Facebook pages have been promoting One Nation. One Nation wants them to stop. The story...

Prime Minister Narendra Modi to flag off two Amrit Bharat trains, two express trains, and one passenger train from Tiruchirappalli, Tamil Nadu
Politics March 11, 2026

Prime Minister Narendra Modi to flag off two Amrit Bharat trains, two express trains, and one passenger train from Tiruchirappalli, Tamil Nadu

Prime Minister Shri Narendra Modi will flag off two Amrit Bharat railgaadis (Amrit Bharat...

Share this story
// Function to create a roadmap using our consolidated approach function createRoadmap(storyId) { // Show a loading indicator const loadingHtml = `

Creating your roadmap...

This may take a moment

`; document.body.insertAdjacentHTML('beforeend', loadingHtml); // Make the API call to create the roadmap using the enhanced unified approach fetch(`/api/roadmaps/create/${storyId}`, { method: 'POST', headers: { 'Content-Type': 'application/json', 'X-CSRFToken': 'IjllZWY2YzMwYzFhYTQyMGU5ZGJjZDE4ODNhM2VmY2VjZjI2MTkyOTEi.abD3Bg.BVEdxLALg60eumV1F2oaq5TLnYU' } }) .then(response => response.json()) .then(data => { // Remove the loading indicator document.getElementById('loading-overlay').remove(); if (data.success) { // Show success message const successHtml = `

Roadmap Created!

Your learning path has been successfully created.

`; document.body.insertAdjacentHTML('beforeend', successHtml); } else { // Show error message const errorHtml = `

Error

${data.message || 'An error occurred while creating the roadmap.'}

`; document.body.insertAdjacentHTML('beforeend', errorHtml); } }) .catch(error => { // Remove the loading indicator document.getElementById('loading-overlay').remove(); // Show error message const errorHtml = `

Error

An unexpected error occurred. Please try again later.

`; document.body.insertAdjacentHTML('beforeend', errorHtml); console.error('Error creating roadmap:', error); }); } document.addEventListener('DOMContentLoaded', function() { // Auto-mark as read after 10 seconds // Function to load related roadmaps function loadRelatedRoadmaps() { // Load related roadmaps for this story console.log('Loading related roadmaps for story ID: 15443'); fetch('/api/stories/15443/related-roadmaps') .then(response => { if (!response.ok) { throw new Error(`HTTP error! Status: ${response.status}`); } return response.json(); }) .then(data => { console.log('Related roadmaps API response:', data); const container = document.getElementById('roadmaps-container'); if (!container) { console.error('Roadmaps container not found in DOM'); return; } // Clear the loading indicator container.innerHTML = ''; if (data.roadmaps && data.roadmaps.length > 0) { console.log(`Found ${data.roadmaps.length} roadmaps to display`); // Render each roadmap card data.roadmaps.forEach(roadmap => { console.log(`Processing roadmap ID ${roadmap.id}: ${roadmap.title}`); const card = document.createElement('div'); card.className = 'p-4 bg-white rounded-lg border border-blue-200 hover:shadow-md transition-shadow'; let iconType = 'map'; if (roadmap.type === 'career') iconType = 'briefcase'; else if (roadmap.type === 'personal') iconType = 'user'; else if (roadmap.type === 'learning') iconType = 'graduation-cap'; else if (roadmap.type === 'financial') iconType = 'chart-line'; card.innerHTML = `

${roadmap.title}

${roadmap.description || 'Interactive step-by-step guide'}

${roadmap.step_count ? ` ${roadmap.step_count} steps` : ''} ${roadmap.created_by ? ` ${roadmap.created_by}` : ''}
`; container.appendChild(card); }); } else { console.log('No roadmaps found for this story'); // Show "no roadmaps" message with different content for logged in vs not logged in users const isLoggedIn = false; if (isLoggedIn) { container.innerHTML = `

No roadmaps found for this story yet.

Be the first to create one!

`; } else { container.innerHTML = `

Create your own roadmaps!

Sign up to create interactive step-by-step guides for this story and others.

`; } } }) .catch(error => { console.error('Error loading roadmaps:', error); const container = document.getElementById('roadmaps-container'); if (container) { container.innerHTML = `

Unable to load roadmaps at this time.

Error: ${error.message}

`; } }); } // Load roadmaps when page loads loadRelatedRoadmaps(); // Check for "roadmap_created" or "roadmap_updated" URL parameter and reload roadmaps if present const urlParams = new URLSearchParams(window.location.search); if (urlParams.has('roadmap_created') || urlParams.has('roadmap_updated')) { // Small delay to ensure the UI is ready setTimeout(loadRelatedRoadmaps, 500); } // Add event listeners to roadmap creation links to append return parameters document.querySelectorAll('a[href*="create_roadmap_from_story"], a[href*="create-roadmap-from-plan"]').forEach(link => { link.addEventListener('click', function(e) { // Store the current URL to return to this page const returnUrl = window.location.href.split('?')[0] + '?roadmap_created=true'; // Store in sessionStorage sessionStorage.setItem('roadmapReturnUrl', returnUrl); }); }); // Handle reaction buttons const reactionButtons = document.querySelectorAll('.reaction-btn'); reactionButtons.forEach(button => { button.addEventListener('click', function() { const reaction = this.dataset.reaction; const storyId = this.dataset.storyId; // Send reaction to server fetch(`/api/stories/${storyId}/reactions`, { method: 'POST', headers: { 'Content-Type': 'application/json', 'X-CSRFToken': 'IjllZWY2YzMwYzFhYTQyMGU5ZGJjZDE4ODNhM2VmY2VjZjI2MTkyOTEi.abD3Bg.BVEdxLALg60eumV1F2oaq5TLnYU' }, body: JSON.stringify({ reaction_type: reaction }) }) .then(response => response.json()) .then(data => { if (data.success) { // Toggle active state if (data.added) { this.classList.add('border-blue-500', 'bg-blue-50', 'text-blue-700'); } else { this.classList.remove('border-blue-500', 'bg-blue-50', 'text-blue-700'); } // Update count if available const countElement = this.querySelector('.reaction-count'); if (data.count > 0) { if (countElement) { countElement.textContent = `(${data.count})`; } else { const countSpan = document.createElement('span'); countSpan.className = 'reaction-count'; countSpan.textContent = `(${data.count})`; const textElement = this.querySelector('span:not(.text-lg)'); textElement.appendChild(countSpan); } } else if (countElement) { countElement.remove(); } } }) .catch(error => { console.error('Error updating reaction:', error); }); }); }); });