How to Create and Edit Widgets in Sngine

0
253
0

A Practical Tutorial on Adding or Modifying Widgets in Sngine, with Real-World Examples

Widgets are essential components in Sngine, offering functionality and dynamic content to enhance your platform. They allow you to add interactive and informational elements like news feeds, friend suggestions, or advertisements. This tutorial provides a comprehensive, step-by-step guide to creating and editing widgets in Sngine, tailored specifically to help webmasters using Sngine.


Understanding Widgets in Sngine

Widgets in Sngine are modular components that can be added or modified to enhance user experience. They are typically represented as template files written in TPL format and paired with PHP logic in the backend. Widgets can display various data, including user activity, notifications, or even third-party content like advertisements.


Prerequisites for Creating and Editing Widgets

Before diving into widget creation or customization, ensure you have the following:

  1. A Working Sngine Installation: Either on a local environment like XAMPP/WAMP or a live server.
  2. Basic Understanding of PHP and TPL Files: Familiarity with Sngine's coding structure is crucial.
  3. A Code Editor: Tools like Visual Studio Code, Sublime Text, or PhpStorm work well.
  4. Backup Your Files: Always create a backup before making changes to your live site.

Step 1: Understanding the Widget Framework in Sngine

Widgets in Sngine primarily involve three components:

  • Frontend Display: Defined in .tpl files located in the theme folder.
  • Backend Logic: Managed in PHP, usually found in class-user.php or similar files.
  • Database Integration (if required): Data for widgets can be fetched from the database if dynamic content is needed.

Sngine Widget File Locations

  1. Frontend Files:
    • Path: /content/themes/default/templates/widgets
    • Files here define the appearance of widgets.
  2. Backend Files:
    • Path: /includes/
    • Logic to fetch or process data for widgets is coded here.

Step 2: Creating a New Widget

Here’s a detailed process to create a new widget in Sngine:

1. Plan Your Widget

Decide on the widget's purpose. For example, a "User Birthday Widget" that shows friends' birthdays on the dashboard.

2. Create the TPL File

Navigate to /content/themes/default/templates/widgets and create a new file:

bash
Copy code
fbirthday-widget.tpl

Example Content:

html
Copy code
<div class="widget"> <div class="widget-header"> <h3>Today's Birthdays</h3> </div> <div class="widget-body"> {if $friends_birthdays} {foreach from=$friends_birthdays item=friend} <div class="friend-birthday"> <img src="{$friend.picture}" alt="{$friend.name}"> <p>{$friend.name} - {$friend.birthdate}</p> </div> {/foreach} {else} <p>No birthdays today!</p> {/if} </div> </div>

3. Add Backend Logic

Open includes/class-user.php and add the following function:

php
Copy code
public function get_friends_birthdays($user_id) { global $db; $current_date = date('m-d'); $query = $db->query(" SELECT user_id, user_name, user_picture, user_birthdate FROM users WHERE DATE_FORMAT(user_birthdate, '%m-%d') = '$current_date' AND user_id IN ( SELECT user_two_id FROM friends WHERE user_one_id = $user_id AND status = '1' ) "); $birthdays = []; while ($row = $query->fetch_assoc()) { $row['user_picture'] = get_picture($row['user_picture']); $birthdays[] = $row; } return $birthdays; }

4. Connect Logic to Frontend

Open index.php or a relevant controller file and add:

php
Copy code
// Fetch Birthdays $friends_birthdays = $user->get_friends_birthdays($user->_data['user_id']); $smarty->assign('friends_birthdays', $friends_birthdays);

5. Include Widget in a Template

Open _sidebar.tpl or the desired page layout and include the widget:

tpl
Copy code
{include file='widgets/fbirthday-widget.tpl'}

6. Add Styling

Create a CSS file (if needed) in /content/themes/default/css and link it in _head.tpl:

html
Copy code
<link rel="stylesheet" href="{$system['system_url']}/content/themes/{$system['theme']}/css/custom-widgets.css">

Step 3: Editing an Existing Widget

To modify an existing widget:

  1. Locate the TPL file in /content/themes/default/templates/widgets.
  2. Edit the PHP logic in class-user.php or related files.
  3. Refresh the browser and test changes.

Example: To add a profile link to the "Friend Suggestions" widget:

  • Edit the widget TPL file:
    tpl
    Copy code
    <a href="{$system.url}/profile/{$friend.user_name}">{$friend.name}</a>

Step 4: Testing the Widget

  1. Clear the cache from the Sngine admin panel.
  2. Check if the widget displays correctly.
  3. Debug using browser developer tools or PHP error logs.

Step 5: Real-World Example: Ad Widget

Widgets can also be used for monetization:

  • Objective: Add an ad widget to display sponsored content.
  • Steps:
    • Create ad-widget.tpl in the widgets folder.
    • Add a database table for ads.
    • Fetch ad data in class-user.php and assign it to Smarty.

Step 6: Dynamic Widgets with Database Integration

Dynamic widgets fetch and display live data from the database. This step demonstrates how to build a widget that displays the latest posts from specific categories.

1. Database Query for Latest Posts

Add the following function to class-user.php:

php
Copy code
public function get_latest_posts($limit = 5) { global $db; $query = $db->query(" SELECT posts.post_id, posts.post_text, posts.post_created, users.user_id, users.user_name, users.user_picture FROM posts INNER JOIN users ON posts.user_id = users.user_id ORDER BY posts.post_created DESC LIMIT $limit "); $latest_posts = []; while ($row = $query->fetch_assoc()) { $row['user_picture'] = get_picture($row['user_picture']); $latest_posts[] = $row; } return $latest_posts; }

2. Create TPL for the Widget

Add a new file, latest-posts-widget.tpl, in the widgets folder:

tpl
Copy code
<div class="widget"> <div class="widget-header"> <h3>Latest Posts</h3> </div> <div class="widget-body"> {if $latest_posts} {foreach from=$latest_posts item=post} <div class="post-snippet"> <img src="{$post.user_picture}" alt="{$post.user_name}"> <div> <a href="{$system.url}/post/{$post.post_id}">{$post.post_text|truncate:50}</a> <p>by <a href="{$system.url}/profile/{$post.user_name}">{$post.user_name}</a> on {$post.post_created|date_format:"%B %d, %Y"}</p> </div> </div> {/foreach} {else} <p>No posts available.</p> {/if} </div> </div>

3. Backend Assignment

Update the controller file (e.g., index.php) to fetch and assign data:

php
Copy code
// Fetch Latest Posts $latest_posts = $user->get_latest_posts(); $smarty->assign('latest_posts', $latest_posts);

4. Include the Widget

Add the widget to the desired location, such as _sidebar.tpl:

tpl
Copy code
{include file='widgets/latest-posts-widget.tpl'}

Step 7: Using Widgets for Monetization

Widgets can also serve as ad slots, enabling monetization. This example outlines creating a Sponsored Ads Widget.

1. Database Setup

Add a table for storing ad data:

sql
Copy code
CREATE TABLE sponsored_ads ( ad_id INT AUTO_INCREMENT PRIMARY KEY, ad_image VARCHAR(255) NOT NULL, ad_link VARCHAR(255) NOT NULL, ad_position VARCHAR(50) NOT NULL, ad_active TINYINT(1) DEFAULT 1 );

2. Fetch Ads Data

Add a function to class-user.php:

php
Copy code
public function get_active_ads($position) { global $db; $query = $db->query(" SELECT ad_image, ad_link FROM sponsored_ads WHERE ad_position = '$position' AND ad_active = 1 "); $ads = []; while ($row = $query->fetch_assoc()) { $ads[] = $row; } return $ads; }

3. Create TPL for Ad Widget

Add a file, ad-widget.tpl, in the widgets folder:

tpl
Copy code
<div class="widget sponsored-ads"> <div class="widget-header"> <h3>Sponsored Ads</h3> </div> <div class="widget-body"> {foreach from=$sponsored_ads item=ad} <a href="{$ad.ad_link}" target="_blank"> <img src="{$ad.ad_image}" alt="Sponsored Ad"> </a> {/foreach} </div> </div>

4. Include the Widget

Add this widget to a specific location in _sidebar.tpl:

tpl
Copy code
{include file='widgets/ad-widget.tpl'}

Step 8: Debugging and Troubleshooting

Common Issues:

  1. Widget Not Displaying:
    • Check the TPL file path and include statement.
    • Verify data assignment in the controller file.
  2. Data Not Fetching:
    • Ensure the database query is correct and the required table exists.
    • Debug using print_r or var_dump to confirm data retrieval.
  3. CSS Issues:
    • Verify that custom styles are included in _head.tpl.

Debugging Tools:

  • Browser Developer Tools: For inspecting HTML and debugging CSS.
  • PHP Error Logs: Check error_log files for PHP errors.

Conclusion

Widgets are a powerful tool in Sngine, offering endless possibilities for customization and user engagement. Whether you're adding simple informational widgets or complex, database-driven ones, this guide equips you to build and enhance widgets effectively.

By integrating monetization strategies, dynamic content, and user-centric design, you can take full advantage of Sngine's modular system. Regular updates, user feedback, and continuous improvement will ensure your widgets remain relevant and engaging.


Căutare
Sponsor
Categorii
Citeste mai mult
Development and Coding
How to Set Up XAMPP for Local Sngine Development
Setting up a local development environment for Sngine is a critical first step for any webmaster...
By MakeMyTheme Admin 2025-01-13 03:27:00 0 174
Noțiuni de bază
How to Enable Social Media Login on Sngine – Google Login Setup
In the world of modern social networking, convenience and security go hand-in-hand. For your...
By MakeMyTheme Admin 2024-12-30 07:27:31 0 308
Noțiuni de bază
Installing Sngine on Localhost: A Beginner’s Tutorial
Setting up Sngine on a localhost environment is a crucial step for developers and website...
By MakeMyTheme Admin 2024-12-30 07:50:12 0 356
Community Building
Building a Thriving Online Community on a Budget using Sngine Social Networking Platfrom
Creating a successful online community doesn’t have to break the bank. Whether you’re...
By MakeMyTheme Admin 2025-01-04 11:51:27 0 331
Noțiuni de bază
Essential Features of Sngine That Every User Should Know
Sngine is not just another social networking script; it is a complete platform designed to...
By MakeMyTheme Admin 2024-12-30 06:49:47 0 328