Compare commits
9 Commits
5361b0da90
...
v0.1.1
| Author | SHA1 | Date | |
|---|---|---|---|
|
00f7b7979e
|
|||
|
9fbce23828
|
|||
|
b4b31f8123
|
|||
|
3ecb7ea937
|
|||
|
78bf5207ab
|
|||
|
47433a939c
|
|||
|
6a373208dd
|
|||
| a9a6ab3207 | |||
|
8c0b1e3c19
|
37
.github/workflows/release.yml
vendored
Normal file
37
.github/workflows/release.yml
vendored
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
name: Release Plugin Zip
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
- "v*"
|
||||||
|
|
||||||
|
permissions:
|
||||||
|
contents: write
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
release:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Checkout
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Build plugin zip
|
||||||
|
id: build
|
||||||
|
run: |
|
||||||
|
set -euo pipefail
|
||||||
|
PLUGIN_SLUG="${GITHUB_REPOSITORY##*/}"
|
||||||
|
TAG="${GITHUB_REF_NAME}"
|
||||||
|
ZIP_NAME="${PLUGIN_SLUG}-${TAG}.zip"
|
||||||
|
|
||||||
|
mkdir -p dist
|
||||||
|
git archive --format=zip --prefix="${PLUGIN_SLUG}/" -o "dist/${ZIP_NAME}" HEAD
|
||||||
|
|
||||||
|
echo "zip_path=dist/${ZIP_NAME}" >> "$GITHUB_OUTPUT"
|
||||||
|
echo "zip_name=${ZIP_NAME}" >> "$GITHUB_OUTPUT"
|
||||||
|
|
||||||
|
- name: Create or update release and upload zip
|
||||||
|
uses: softprops/action-gh-release@v2
|
||||||
|
with:
|
||||||
|
files: ${{ steps.build.outputs.zip_path }}
|
||||||
|
fail_on_unmatched_files: true
|
||||||
@@ -6,8 +6,6 @@ Version: 1.0
|
|||||||
Author: Your Name
|
Author: Your Name
|
||||||
*/
|
*/
|
||||||
|
|
||||||
add_action('save_post_sp_event', 'generate_event_featured_image', 10, 3);
|
|
||||||
|
|
||||||
function generate_bisected_image($color1, $color2, $logo1_path, $logo2_path) {
|
function generate_bisected_image($color1, $color2, $logo1_path, $logo2_path) {
|
||||||
$width = 1200;
|
$width = 1200;
|
||||||
$height = 628;
|
$height = 628;
|
||||||
@@ -184,6 +182,17 @@ add_action('template_redirect', 'handle_image_request');
|
|||||||
|
|
||||||
function serve_image($image_path) {
|
function serve_image($image_path) {
|
||||||
header('Content-Type: image/png');
|
header('Content-Type: image/png');
|
||||||
|
if (file_exists($image_path)) {
|
||||||
|
status_header( 200 );
|
||||||
|
} else {
|
||||||
|
status_header( 404 );
|
||||||
|
die("Image not found.");
|
||||||
|
}
|
||||||
|
|
||||||
|
// Clear all output buffering to prevent any extra output
|
||||||
|
while (ob_get_level()) {
|
||||||
|
ob_end_clean();
|
||||||
|
}
|
||||||
readfile($image_path);
|
readfile($image_path);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -91,7 +91,8 @@ function custom_open_graph_tags_with_sportspress_integration() {
|
|||||||
);
|
);
|
||||||
$i++;
|
$i++;
|
||||||
endforeach;
|
endforeach;
|
||||||
$title = "{$teams_result_array[0]['team_name']} {$teams_result_array[0]['result']['r']} - {$teams_result_array[1]['result']['r']} {$teams_result_array[1]['team_name']} ({$publish_date})";
|
$publish_date = get_the_date('F j, Y', $post);
|
||||||
|
$title = "{$teams_result_array[0]['team_name']} {$teams_result_array[0]['result']['r']}-{$teams_result_array[1]['result']['r']} {$teams_result_array[1]['team_name']} ({$publish_date})";
|
||||||
$description .= " " . "{$teams_result_array[0]['team_name']} ({$teams_result_array[0]['outcome']}), {$teams_result_array[1]['team_name']} ({$teams_result_array[1]['outcome']}).";;
|
$description .= " " . "{$teams_result_array[0]['team_name']} ({$teams_result_array[0]['outcome']}), {$teams_result_array[1]['team_name']} ({$teams_result_array[1]['outcome']}).";;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
220
includes/sp-event-admin-week-filter.php
Normal file
220
includes/sp-event-admin-week-filter.php
Normal file
@@ -0,0 +1,220 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Admin week filter for SportsPress events.
|
||||||
|
*
|
||||||
|
* Adds a week selector in wp-admin for `sp_event` and filters events by
|
||||||
|
* Monday-start week (Monday 00:00:00 through Sunday 23:59:59).
|
||||||
|
*/
|
||||||
|
|
||||||
|
if ( ! defined( 'ABSPATH' ) ) {
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Parse an ISO week input (e.g. 2026-W07) from the request.
|
||||||
|
*
|
||||||
|
* @return array{year:int,week:int}|null
|
||||||
|
*/
|
||||||
|
function tony_sportspress_parse_admin_week_filter() {
|
||||||
|
if ( empty( $_GET['sp_week_filter'] ) ) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
$raw = sanitize_text_field( wp_unslash( $_GET['sp_week_filter'] ) );
|
||||||
|
if ( ! preg_match( '/^(\d{4})-W(0[1-9]|[1-4][0-9]|5[0-3])$/', $raw, $matches ) ) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
$year = (int) $matches[1];
|
||||||
|
$week = (int) $matches[2];
|
||||||
|
|
||||||
|
return array(
|
||||||
|
'year' => $year,
|
||||||
|
'week' => $week,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Render week filter control in event admin list.
|
||||||
|
*
|
||||||
|
* @param string $post_type Current post type.
|
||||||
|
*/
|
||||||
|
function tony_sportspress_render_admin_week_filter( $post_type ) {
|
||||||
|
if ( 'sp_event' !== $post_type ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$value = '';
|
||||||
|
if ( ! empty( $_GET['sp_week_filter'] ) ) {
|
||||||
|
$value = sanitize_text_field( wp_unslash( $_GET['sp_week_filter'] ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
$summary_text = __( 'Select a week', 'tonys-sportspress-enhancements' );
|
||||||
|
$parsed = tony_sportspress_parse_admin_week_filter();
|
||||||
|
if ( is_array( $parsed ) ) {
|
||||||
|
$timezone = wp_timezone();
|
||||||
|
$monday = ( new DateTimeImmutable( 'now', $timezone ) )->setISODate( $parsed['year'], $parsed['week'], 1 )->setTime( 0, 0, 0 );
|
||||||
|
$sunday = $monday->modify( '+6 days' )->setTime( 23, 59, 59 );
|
||||||
|
/* translators: 1: Monday label/date, 2: Sunday label/date. */
|
||||||
|
$summary_text = sprintf(
|
||||||
|
__( '%1$s to %2$s', 'tonys-sportspress-enhancements' ),
|
||||||
|
wp_date( 'D M j, Y', $monday->getTimestamp(), $timezone ),
|
||||||
|
wp_date( 'D M j, Y', $sunday->getTimestamp(), $timezone )
|
||||||
|
);
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
<label for="sp_week_filter" class="screen-reader-text"><?php esc_html_e( 'Filter by week', 'tonys-sportspress-enhancements' ); ?></label>
|
||||||
|
<input
|
||||||
|
type="week"
|
||||||
|
id="sp_week_filter"
|
||||||
|
name="sp_week_filter"
|
||||||
|
class="sp-week-filter-field"
|
||||||
|
value="<?php echo esc_attr( $value ); ?>"
|
||||||
|
title="<?php esc_attr_e( 'Week (Monday start)', 'tonys-sportspress-enhancements' ); ?>"
|
||||||
|
/>
|
||||||
|
<span id="sp-week-filter-summary" class="sp-week-filter-summary"><?php echo esc_html( $summary_text ); ?></span>
|
||||||
|
<?php
|
||||||
|
}
|
||||||
|
add_action( 'restrict_manage_posts', 'tony_sportspress_render_admin_week_filter' );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add responsive admin styles so filters stay visible on narrow widths.
|
||||||
|
*/
|
||||||
|
function tony_sportspress_admin_week_filter_styles() {
|
||||||
|
$screen = get_current_screen();
|
||||||
|
if ( ! $screen || 'edit-sp_event' !== $screen->id ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
<style>
|
||||||
|
@media (max-width: 1200px) {
|
||||||
|
.post-type-sp_event .tablenav.top .alignleft.actions:not(.bulkactions) {
|
||||||
|
display: flex;
|
||||||
|
flex-wrap: wrap;
|
||||||
|
gap: 6px;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
.post-type-sp_event .tablenav.top .alignleft.actions:not(.bulkactions) > * {
|
||||||
|
float: none;
|
||||||
|
margin-right: 0;
|
||||||
|
}
|
||||||
|
.post-type-sp_event .tablenav.top .alignleft.actions:not(.bulkactions) .sp-week-filter-field {
|
||||||
|
min-width: 145px;
|
||||||
|
}
|
||||||
|
.post-type-sp_event .tablenav.top .alignleft.actions:not(.bulkactions) .sp-week-filter-summary {
|
||||||
|
display: block;
|
||||||
|
width: 100%;
|
||||||
|
margin-top: 2px;
|
||||||
|
color: #50575e;
|
||||||
|
font-size: 12px;
|
||||||
|
line-height: 1.4;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
<?php
|
||||||
|
}
|
||||||
|
add_action( 'admin_head-edit.php', 'tony_sportspress_admin_week_filter_styles' );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Update week summary text when week input changes.
|
||||||
|
*/
|
||||||
|
function tony_sportspress_admin_week_filter_script() {
|
||||||
|
$screen = get_current_screen();
|
||||||
|
if ( ! $screen || 'edit-sp_event' !== $screen->id ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
?>
|
||||||
|
<script>
|
||||||
|
(function() {
|
||||||
|
const input = document.getElementById('sp_week_filter');
|
||||||
|
const summary = document.getElementById('sp-week-filter-summary');
|
||||||
|
if (!input || !summary) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
function updateSummary() {
|
||||||
|
const raw = (input.value || '').trim();
|
||||||
|
const match = raw.match(/^(\d{4})-W(\d{2})$/);
|
||||||
|
if (!match) {
|
||||||
|
summary.textContent = 'Select a week';
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const year = parseInt(match[1], 10);
|
||||||
|
const week = parseInt(match[2], 10);
|
||||||
|
|
||||||
|
const jan4 = new Date(Date.UTC(year, 0, 4));
|
||||||
|
const jan4Day = jan4.getUTCDay() || 7;
|
||||||
|
const mondayWeek1 = new Date(jan4);
|
||||||
|
mondayWeek1.setUTCDate(jan4.getUTCDate() - jan4Day + 1);
|
||||||
|
|
||||||
|
const monday = new Date(mondayWeek1);
|
||||||
|
monday.setUTCDate(mondayWeek1.getUTCDate() + (week - 1) * 7);
|
||||||
|
const sunday = new Date(monday);
|
||||||
|
sunday.setUTCDate(monday.getUTCDate() + 6);
|
||||||
|
|
||||||
|
const fmt = new Intl.DateTimeFormat(undefined, {
|
||||||
|
weekday: 'short',
|
||||||
|
month: 'short',
|
||||||
|
day: 'numeric',
|
||||||
|
year: 'numeric',
|
||||||
|
timeZone: 'UTC'
|
||||||
|
});
|
||||||
|
|
||||||
|
summary.textContent = fmt.format(monday) + ' to ' + fmt.format(sunday);
|
||||||
|
}
|
||||||
|
|
||||||
|
input.addEventListener('change', updateSummary);
|
||||||
|
updateSummary();
|
||||||
|
})();
|
||||||
|
</script>
|
||||||
|
<?php
|
||||||
|
}
|
||||||
|
add_action( 'admin_footer-edit.php', 'tony_sportspress_admin_week_filter_script' );
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Apply Monday-start week date query to event admin list.
|
||||||
|
*
|
||||||
|
* @param WP_Query $query Main query.
|
||||||
|
*/
|
||||||
|
function tony_sportspress_apply_admin_week_filter( $query ) {
|
||||||
|
if ( ! is_admin() || ! $query->is_main_query() ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$post_type = $query->get( 'post_type' );
|
||||||
|
if ( 'sp_event' !== $post_type ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$parsed = tony_sportspress_parse_admin_week_filter();
|
||||||
|
if ( null === $parsed ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
$timezone = wp_timezone();
|
||||||
|
$monday = ( new DateTimeImmutable( 'now', $timezone ) )->setISODate( $parsed['year'], $parsed['week'], 1 )->setTime( 0, 0, 0 );
|
||||||
|
$sunday = $monday->modify( '+6 days' )->setTime( 23, 59, 59 );
|
||||||
|
|
||||||
|
$date_query = $query->get( 'date_query' );
|
||||||
|
if ( ! is_array( $date_query ) ) {
|
||||||
|
$date_query = array();
|
||||||
|
}
|
||||||
|
|
||||||
|
$date_query[] = array(
|
||||||
|
'after' => array(
|
||||||
|
'year' => (int) $monday->format( 'Y' ),
|
||||||
|
'month' => (int) $monday->format( 'n' ),
|
||||||
|
'day' => (int) $monday->format( 'j' ),
|
||||||
|
),
|
||||||
|
'before' => array(
|
||||||
|
'year' => (int) $sunday->format( 'Y' ),
|
||||||
|
'month' => (int) $sunday->format( 'n' ),
|
||||||
|
'day' => (int) $sunday->format( 'j' ),
|
||||||
|
),
|
||||||
|
'inclusive' => true,
|
||||||
|
);
|
||||||
|
|
||||||
|
$query->set( 'date_query', $date_query );
|
||||||
|
}
|
||||||
|
add_action( 'pre_get_posts', 'tony_sportspress_apply_admin_week_filter' );
|
||||||
89
includes/sp-event-permalink.php
Normal file
89
includes/sp-event-permalink.php
Normal file
@@ -0,0 +1,89 @@
|
|||||||
|
<?php
|
||||||
|
/*
|
||||||
|
Plugin Name: Custom Event Permalinks
|
||||||
|
Description: Adds a custom permalink structure for the sp_event post type.
|
||||||
|
Version: 1.0
|
||||||
|
Author: Your Name
|
||||||
|
*/
|
||||||
|
|
||||||
|
if ( ! defined( 'ABSPATH' ) ) {
|
||||||
|
exit; // Exit if accessed directly
|
||||||
|
}
|
||||||
|
|
||||||
|
// Register custom rewrite rules
|
||||||
|
function custom_event_rewrite_rules() {
|
||||||
|
add_rewrite_rule(
|
||||||
|
'(?:event|game)/.*?[/]?([0-9]+)[/]?$',
|
||||||
|
'index.php?post_type=sp_event&p=$matches[1]',
|
||||||
|
'top'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
add_action('init', 'custom_event_rewrite_rules');
|
||||||
|
|
||||||
|
// Customize the permalink structure
|
||||||
|
function custom_event_permalink($permalink, $post) {
|
||||||
|
if ($post->post_type !== 'sp_event') {
|
||||||
|
return $permalink;
|
||||||
|
}
|
||||||
|
|
||||||
|
$event = new SP_Event($post->ID);
|
||||||
|
$teams = get_post_meta($post->ID,'sp_team', false);
|
||||||
|
$format = get_post_meta($post->ID,'sp_format', true);
|
||||||
|
sort($teams);
|
||||||
|
$seasons = get_the_terms($post->ID, 'sp_season', true );
|
||||||
|
if ($seasons) {
|
||||||
|
$seasons_slug = implode(
|
||||||
|
"-",
|
||||||
|
array_map(function($season){return $season->slug;},$seasons),
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
$seasons_slug = "no-season";
|
||||||
|
};
|
||||||
|
|
||||||
|
// Get the teams associated with the event
|
||||||
|
$team_1 = get_post($teams[0]);
|
||||||
|
$team_2 = get_post($teams[1]);
|
||||||
|
|
||||||
|
switch ($format) {
|
||||||
|
case 'league':
|
||||||
|
$format_string = 'game';
|
||||||
|
break;
|
||||||
|
case 'tournament':
|
||||||
|
$format_string = 'game';
|
||||||
|
break;
|
||||||
|
case 'friendly':
|
||||||
|
$format_string = 'event';
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
$format_string = 'event';
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($team_1 && $team_2) {
|
||||||
|
$permalink = home_url($format_string ."/". $seasons_slug . '/' . $team_1->post_name . '-' . $team_2->post_name . '/' . $post->ID);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $permalink;
|
||||||
|
}
|
||||||
|
add_filter('post_type_link', 'custom_event_permalink', 10, 2);
|
||||||
|
|
||||||
|
// Flush rewrite rules on activation and deactivation
|
||||||
|
function custom_event_rewrite_flush() {
|
||||||
|
custom_event_rewrite_rules();
|
||||||
|
flush_rewrite_rules();
|
||||||
|
}
|
||||||
|
register_activation_hook(__FILE__, 'custom_event_rewrite_flush');
|
||||||
|
register_deactivation_hook(__FILE__, 'flush_rewrite_rules');
|
||||||
|
|
||||||
|
// Modify the query to handle custom permalinks and include future posts
|
||||||
|
function custom_event_parse_request($query) {
|
||||||
|
$post_type = sp_array_value( $query->query, 'post_type', null );
|
||||||
|
if (isset($query->query_vars['post_type']) && $query->query_vars['post_type'] === 'sp_event') {
|
||||||
|
if (isset($query->query_vars['p'])) {
|
||||||
|
$query->set('post_type', 'sp_event');
|
||||||
|
$query->set('p', $query->query_vars['p']);
|
||||||
|
$query->set('post_status', array('publish', 'future'));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
add_action('pre_get_posts', 'custom_event_parse_request');
|
||||||
@@ -16,3 +16,4 @@
|
|||||||
// Include other files here
|
// Include other files here
|
||||||
require_once plugin_dir_path(__FILE__) . 'includes/open-graph-tags.php';
|
require_once plugin_dir_path(__FILE__) . 'includes/open-graph-tags.php';
|
||||||
require_once plugin_dir_path(__FILE__) . 'includes/featured-image-generator.php';
|
require_once plugin_dir_path(__FILE__) . 'includes/featured-image-generator.php';
|
||||||
|
require_once plugin_dir_path(__FILE__) . 'includes/sp-event-permalink.php';require_once plugin_dir_path(__FILE__) . 'includes/sp-event-admin-week-filter.php';
|
||||||
|
|||||||
Reference in New Issue
Block a user