Files
friend-links-manager/includes/shortcode.php
2025-11-30 19:46:48 +08:00

62 lines
2.3 KiB
PHP

<?php
// 注册短代码
add_shortcode('friend_links', 'flm_display_friend_links');
function flm_display_friend_links($atts) {
global $wpdb;
$table_name = $wpdb->prefix . 'friend_links';
// 完全使用后台设置,忽略用户传递的参数
$random_display = get_option('flm_random_display', 1);
$desktop_columns = get_option('flm_desktop_columns', 3);
$show_descriptions = get_option('flm_show_descriptions', 1);
$order_by = $random_display ? 'RAND()' : 'sort_order ASC';
$links = $wpdb->get_results("SELECT * FROM $table_name ORDER BY $order_by");
if (empty($links)) {
return '';
}
ob_start();
?>
<div class="flm-links-container" data-columns="<?php echo $desktop_columns; ?>">
<?php foreach ($links as $link): ?>
<div class="flm-link-card">
<a href="<?php echo esc_url($link->url); ?>" target="_blank" rel="noopener noreferrer">
<div class="flm-link-icon-container">
<img src="<?php echo $link->icon ?: FLM_PLUGIN_URL . 'assets/images/default-icon.png'; ?>"
alt="<?php echo esc_attr($link->name); ?>"
class="flm-link-icon">
</div>
<div class="flm-link-name"><?php echo esc_html($link->name); ?></div>
<?php if ($show_descriptions && !empty($link->description)): ?>
<div class="flm-link-description"><?php echo esc_html($link->description); ?></div>
<?php endif; ?>
</a>
</div>
<?php endforeach; ?>
</div>
<style>
/* 默认桌面端布局 - 使用CSS变量 */
.flm-links-container {
--flm-columns: <?php echo $desktop_columns; ?>;
grid-template-columns: repeat(var(--flm-columns), 1fr) !important;
}
/* 平板端响应式 */
@media (max-width: 1024px) {
.flm-links-container {
grid-template-columns: repeat(min(var(--flm-columns), 2), 1fr) !important;
}
}
/* 手机端响应式 */
@media (max-width: 600px) {
.flm-links-container {
grid-template-columns: 1fr !important;
}
}
</style>
<?php
return ob_get_clean();
}