Compare commits
1 Commits
v0.1.2
...
49f6c5c129
| Author | SHA1 | Date | |
|---|---|---|---|
|
49f6c5c129
|
51
.github/workflows/release.yml
vendored
51
.github/workflows/release.yml
vendored
@@ -1,37 +1,48 @@
|
|||||||
name: Release Plugin Zip
|
name: Create Release ZIP
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
tags:
|
tags:
|
||||||
- "v*"
|
- 'v*'
|
||||||
|
|
||||||
permissions:
|
permissions:
|
||||||
contents: write
|
contents: write
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
release:
|
build-and-release:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Build plugin zip
|
- name: Build ZIP
|
||||||
id: build
|
id: build_zip
|
||||||
run: |
|
run: |
|
||||||
set -euo pipefail
|
set -e
|
||||||
PLUGIN_SLUG="${GITHUB_REPOSITORY##*/}"
|
TAG=${GITHUB_REF##*/}
|
||||||
TAG="${GITHUB_REF_NAME}"
|
ZIP_NAME="${GITHUB_REPOSITORY##*/}-$TAG.zip"
|
||||||
ZIP_NAME="${PLUGIN_SLUG}-${TAG}.zip"
|
echo "Creating $ZIP_NAME"
|
||||||
|
zip -r "$ZIP_NAME" . -x ".git/*" "node_modules/*" ".github/*" "tests/*" "*.zip"
|
||||||
|
echo "zip_name=$ZIP_NAME" >> $GITHUB_OUTPUT
|
||||||
|
|
||||||
mkdir -p dist
|
- name: Create GitHub Release
|
||||||
git archive --format=zip --prefix="${PLUGIN_SLUG}/" -o "dist/${ZIP_NAME}" HEAD
|
id: create_release
|
||||||
|
uses: actions/create-release@v1
|
||||||
echo "zip_path=dist/${ZIP_NAME}" >> "$GITHUB_OUTPUT"
|
env:
|
||||||
echo "zip_name=${ZIP_NAME}" >> "$GITHUB_OUTPUT"
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
|
||||||
- name: Create or update release and upload zip
|
|
||||||
uses: softprops/action-gh-release@v2
|
|
||||||
with:
|
with:
|
||||||
files: ${{ steps.build.outputs.zip_path }}
|
tag_name: ${{ github.ref_name }}
|
||||||
fail_on_unmatched_files: true
|
release_name: ${{ github.ref_name }}
|
||||||
|
body: Release ${{ github.ref_name }}
|
||||||
|
draft: false
|
||||||
|
prerelease: false
|
||||||
|
|
||||||
|
- name: Upload Release Asset
|
||||||
|
uses: actions/upload-release-asset@v1
|
||||||
|
env:
|
||||||
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
with:
|
||||||
|
upload_url: ${{ steps.create_release.outputs.upload_url }}
|
||||||
|
asset_path: ${{ steps.build_zip.outputs.zip_name }}
|
||||||
|
asset_name: ${{ steps.build_zip.outputs.zip_name }}
|
||||||
|
asset_content_type: application/zip
|
||||||
|
|||||||
@@ -8,55 +8,6 @@ Author: Your Name
|
|||||||
|
|
||||||
add_action('wp_head', 'custom_open_graph_tags_with_sportspress_integration');
|
add_action('wp_head', 'custom_open_graph_tags_with_sportspress_integration');
|
||||||
|
|
||||||
function asc_generate_sp_event_title( $post ) {
|
|
||||||
// See https://github.com/ThemeBoy/SportsPress/blob/770fa8c6654d7d6648791e877709c2428677635b/includes/admin/post-types/class-sp-admin-cpt-event.php#L99C40-L99C55
|
|
||||||
if ( is_numeric( $post ) ) {
|
|
||||||
$post = get_post( $post );
|
|
||||||
}
|
|
||||||
if ( ! $post || $post->post_type !== 'sp_event' ) {
|
|
||||||
return get_the_title();
|
|
||||||
}
|
|
||||||
|
|
||||||
$teams = get_post_meta( $post->ID, 'sp_team', false );
|
|
||||||
$teams = array_filter( $teams );
|
|
||||||
|
|
||||||
$team_names = array();
|
|
||||||
foreach ( $teams as $team ) {
|
|
||||||
while ( is_array( $team ) ) {
|
|
||||||
$team = array_shift( array_filter( $team ) );
|
|
||||||
}
|
|
||||||
if ( $team > 0 ) {
|
|
||||||
$team_names[] = sp_team_short_name( $team );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$team_names = array_unique( $team_names );
|
|
||||||
|
|
||||||
if ( get_option( 'sportspress_event_reverse_teams', 'no' ) === 'yes' ) {
|
|
||||||
$team_names = array_reverse( $team_names );
|
|
||||||
}
|
|
||||||
|
|
||||||
$delimiter = ' ' . get_option( 'sportspress_event_teams_delimiter', 'vs' ) . ' ';
|
|
||||||
|
|
||||||
return implode( $delimiter, $team_names );
|
|
||||||
}
|
|
||||||
|
|
||||||
function asc_generate_short_date( $post, $withTime = true ) {
|
|
||||||
$formatted_date = get_the_date('D n/j/y', $post);
|
|
||||||
|
|
||||||
if (!$withTime){
|
|
||||||
return $formatted_date;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( get_the_date('i', $post) == "00") {
|
|
||||||
$formatted_time = get_the_date('gA', $post);
|
|
||||||
} else {
|
|
||||||
$formatted_time = get_the_date('g:iA', $post);
|
|
||||||
}
|
|
||||||
return $formatted_date . " " . $formatted_time ;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
function custom_open_graph_tags_with_sportspress_integration() {
|
function custom_open_graph_tags_with_sportspress_integration() {
|
||||||
if (is_single()) {
|
if (is_single()) {
|
||||||
global $post;
|
global $post;
|
||||||
@@ -67,22 +18,16 @@ function custom_open_graph_tags_with_sportspress_integration() {
|
|||||||
// Fetch details using SP_Event methods
|
// Fetch details using SP_Event methods
|
||||||
$publish_date = get_the_date('F j, Y', $post);
|
$publish_date = get_the_date('F j, Y', $post);
|
||||||
$venue_terms = get_the_terms($post->ID, 'sp_venue');
|
$venue_terms = get_the_terms($post->ID, 'sp_venue');
|
||||||
$venue_name = $venue_terms ? $venue_terms[0]->name : 'Venue TBD';
|
$venue_name = $venue_terms ? $venue_terms[0]->name : 'No Venue Specified';
|
||||||
$results = $event->results(); // Using SP_Event method
|
$results = $event->results(); // Using SP_Event method
|
||||||
$title = asc_generate_sp_event_title($post);
|
$title = get_the_title() . " " . "(" . $publish_date . ")";
|
||||||
$sp_status = get_post_meta( $post->ID, 'sp_status', true );
|
$sp_status = get_post_meta( $post->ID, 'sp_status', true );
|
||||||
$status = $event->status(); // Using SP_Event method
|
$status = $event->status(); // Using SP_Event method
|
||||||
$publish_date_and_time = get_the_date('F j, Y g:i A', $post);
|
$publish_date_and_time = get_the_date('F j, Y g:i A', $post);
|
||||||
$description = "{$publish_date_and_time} at {$venue_name}.";
|
$description = "{$publish_date_and_time} at {$venue_name}.";
|
||||||
|
if ( 'postponed' == $sp_status ) {
|
||||||
if ( 'postponed' == $sp_status || 'cancelled' == $sp_status || 'tbd' == $sp_status) {
|
$description = "POSTPONED" . " - " . $description;
|
||||||
$description = strtoupper($sp_status) . " — " . $description;
|
$title = "POSTPONED" . " - " . $title;
|
||||||
$title = strtoupper($sp_status) . " — " . $title . " — " . asc_generate_short_date($post) . " — " . $venue_name;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( 'future' == $status ) {
|
|
||||||
$description = $description;
|
|
||||||
$title = $title . " — " . asc_generate_short_date($post) . " — " . $venue_name;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( 'results' == $status ) { // checks if there is a final score
|
if ( 'results' == $status ) { // checks if there is a final score
|
||||||
@@ -131,7 +76,6 @@ function custom_open_graph_tags_with_sportspress_integration() {
|
|||||||
unset( $result['outcome'] );
|
unset( $result['outcome'] );
|
||||||
|
|
||||||
$team_name = sp_team_short_name( $team_id );
|
$team_name = sp_team_short_name( $team_id );
|
||||||
$team_abbreviation = sp_team_abbreviation( $team_id );
|
|
||||||
|
|
||||||
$outcome_abbreviation = get_post_meta( $the_outcome->ID, 'sp_abbreviation', true );
|
$outcome_abbreviation = get_post_meta( $the_outcome->ID, 'sp_abbreviation', true );
|
||||||
if ( ! $outcome_abbreviation ) {
|
if ( ! $outcome_abbreviation ) {
|
||||||
@@ -143,37 +87,15 @@ function custom_open_graph_tags_with_sportspress_integration() {
|
|||||||
"outcome" => $the_outcome->post_title,
|
"outcome" => $the_outcome->post_title,
|
||||||
"outcome_abbreviation" => $outcome_abbreviation,
|
"outcome_abbreviation" => $outcome_abbreviation,
|
||||||
"team_name" => $team_name,
|
"team_name" => $team_name,
|
||||||
"team_abbreviation" => $team_abbreviation
|
|
||||||
]
|
]
|
||||||
);
|
);
|
||||||
$i++;
|
$i++;
|
||||||
endforeach;
|
endforeach;
|
||||||
$publish_date = asc_generate_short_date($post, false);
|
$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})";
|
||||||
$special_result_suffix_abbreviation = '';
|
$description .= " " . "{$teams_result_array[0]['team_name']} ({$teams_result_array[0]['outcome']}), {$teams_result_array[1]['team_name']} ({$teams_result_array[1]['outcome']}).";;
|
||||||
$special_result_suffix= '';
|
|
||||||
|
|
||||||
foreach ( $teams_result_array as $team ) {
|
|
||||||
$outcome_abbreviation = strtoupper( $team['outcome_abbreviation'] ); // Normalize case
|
|
||||||
|
|
||||||
if ( $outcome_abbreviation === 'TF-W' ) {
|
|
||||||
$special_result_suffix_abbreviation = 'TF-W';
|
|
||||||
$special_result_suffix = 'Technical Forfeit Win';
|
|
||||||
break;
|
|
||||||
} elseif ( $outcome_abbreviation === 'TF-L' ) {
|
|
||||||
$special_result_suffix_abbreviation = 'TF';
|
|
||||||
$special_result_suffix = 'Technical Forfeit';
|
|
||||||
break;
|
|
||||||
} elseif ( $outcome_abbreviation === 'F-W' || $outcome_abbreviation === 'F-L' ) {
|
|
||||||
$special_result_suffix_abbreviation = 'Forfeit';
|
|
||||||
$special_result_suffix = 'Forfeit';
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$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}" . ($special_result_suffix ? "({$special_result_suffix_abbreviation})" : "");
|
|
||||||
$description .= " " . "{$teams_result_array[0]['team_name']} ({$teams_result_array[0]['outcome']}), {$teams_result_array[1]['team_name']} ({$teams_result_array[1]['outcome']})." ;
|
|
||||||
}
|
|
||||||
$description .= " " . $post->post_content;
|
$description .= " " . $post->post_content;
|
||||||
$image = get_site_url() . "/head-to-head?post={$post->ID}";
|
$image = get_site_url() . "/head-to-head?post={$post->ID}";
|
||||||
echo '<meta property="og:type" content="article" />' . "\n";
|
echo '<meta property="og:type" content="article" />' . "\n";
|
||||||
|
|||||||
@@ -1,220 +0,0 @@
|
|||||||
<?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' );
|
|
||||||
37
readme.md
37
readme.md
@@ -1,37 +0,0 @@
|
|||||||
# Tony's SportsPress Enhancements
|
|
||||||
|
|
||||||
Suite of enhancements for the SportsPress plugin, including custom event permalinks, Open Graph tags, and automatic featured image generation for events.
|
|
||||||
|
|
||||||
## Description
|
|
||||||
|
|
||||||
Tony's SportsPress Enhancements is a collection of add-ons for the [SportsPress](https://wordpress.org/plugins/sportspress/) plugin. It provides:
|
|
||||||
|
|
||||||
- **Custom event permalinks** for `sp_event` post types, including season and team slugs.
|
|
||||||
- **Open Graph meta tags** for events, with dynamic titles, descriptions, and images.
|
|
||||||
- **Automatic featured image generation** for events, combining team colors and logos into a shareable image.
|
|
||||||
|
|
||||||
## Features
|
|
||||||
|
|
||||||
- Custom rewrite rules and permalinks for SportsPress events.
|
|
||||||
- Open Graph integration for better social sharing.
|
|
||||||
- Dynamic, cached event images based on team data.
|
|
||||||
- Compatible with WordPress 4.5+ and PHP 5.6+.
|
|
||||||
|
|
||||||
## Installation
|
|
||||||
|
|
||||||
1. Upload the plugin files to the `/wp-content/plugins/tonys-sportspress-enhancements/` directory, or install via the WordPress plugin repository.
|
|
||||||
2. Activate the plugin through the 'Plugins' menu in WordPress.
|
|
||||||
3. Make sure the [SportsPress](https://wordpress.org/plugins/sportspress/) plugin is installed and activated.
|
|
||||||
|
|
||||||
## Frequently Asked Questions
|
|
||||||
|
|
||||||
**Q: Does this plugin require SportsPress?**
|
|
||||||
A: Yes, it extends the functionality of the SportsPress plugin.
|
|
||||||
|
|
||||||
**Q: How are event images generated?**
|
|
||||||
A: When an event is viewed or shared, a featured image is generated using the primary colors and logos of the participating teams.
|
|
||||||
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
*This plugin is not affiliated with or endorsed by ThemeBoy or the official SportsPress plugin.*
|
|
||||||
115
readme.txt
Normal file
115
readme.txt
Normal file
@@ -0,0 +1,115 @@
|
|||||||
|
=== Tonys Sportspress Enhancements ===
|
||||||
|
Contributors: (this should be a list of wordpress.org userid's)
|
||||||
|
Donate link: https://example.com/
|
||||||
|
Tags: comments, spam
|
||||||
|
Requires at least: 4.5
|
||||||
|
Tested up to: 6.5.3
|
||||||
|
Requires PHP: 5.6
|
||||||
|
Stable tag: 0.1.0
|
||||||
|
License: GPLv2 or later
|
||||||
|
License URI: https://www.gnu.org/licenses/gpl-2.0.html
|
||||||
|
|
||||||
|
Here is a short description of the plugin. This should be no more than 150 characters. No markup here.
|
||||||
|
|
||||||
|
== Description ==
|
||||||
|
|
||||||
|
This is the long description. No limit, and you can use Markdown (as well as in the following sections).
|
||||||
|
|
||||||
|
For backwards compatibility, if this section is missing, the full length of the short description will be used, and
|
||||||
|
Markdown parsed.
|
||||||
|
|
||||||
|
A few notes about the sections above:
|
||||||
|
|
||||||
|
* "Contributors" is a comma separated list of wp.org/wp-plugins.org usernames
|
||||||
|
* "Tags" is a comma separated list of tags that apply to the plugin
|
||||||
|
* "Requires at least" is the lowest version that the plugin will work on
|
||||||
|
* "Tested up to" is the highest version that you've *successfully used to test the plugin*. Note that it might work on
|
||||||
|
higher versions... this is just the highest one you've verified.
|
||||||
|
* Stable tag should indicate the Subversion "tag" of the latest stable version, or "trunk," if you use `/trunk/` for
|
||||||
|
stable.
|
||||||
|
|
||||||
|
Note that the `readme.txt` of the stable tag is the one that is considered the defining one for the plugin, so
|
||||||
|
if the `/trunk/readme.txt` file says that the stable tag is `4.3`, then it is `/tags/4.3/readme.txt` that'll be used
|
||||||
|
for displaying information about the plugin. In this situation, the only thing considered from the trunk `readme.txt`
|
||||||
|
is the stable tag pointer. Thus, if you develop in trunk, you can update the trunk `readme.txt` to reflect changes in
|
||||||
|
your in-development version, without having that information incorrectly disclosed about the current stable version
|
||||||
|
that lacks those changes -- as long as the trunk's `readme.txt` points to the correct stable tag.
|
||||||
|
|
||||||
|
If no stable tag is provided, it is assumed that trunk is stable, but you should specify "trunk" if that's where
|
||||||
|
you put the stable version, in order to eliminate any doubt.
|
||||||
|
|
||||||
|
== Installation ==
|
||||||
|
|
||||||
|
This section describes how to install the plugin and get it working.
|
||||||
|
|
||||||
|
e.g.
|
||||||
|
|
||||||
|
1. Upload `plugin-name.php` to the `/wp-content/plugins/` directory
|
||||||
|
1. Activate the plugin through the 'Plugins' menu in WordPress
|
||||||
|
1. Place `<?php do_action('plugin_name_hook'); ?>` in your templates
|
||||||
|
|
||||||
|
== Frequently Asked Questions ==
|
||||||
|
|
||||||
|
= A question that someone might have =
|
||||||
|
|
||||||
|
An answer to that question.
|
||||||
|
|
||||||
|
= What about foo bar? =
|
||||||
|
|
||||||
|
Answer to foo bar dilemma.
|
||||||
|
|
||||||
|
== Screenshots ==
|
||||||
|
|
||||||
|
1. This screen shot description corresponds to screenshot-1.(png|jpg|jpeg|gif). Note that the screenshot is taken from
|
||||||
|
the /assets directory or the directory that contains the stable readme.txt (tags or trunk). Screenshots in the /assets
|
||||||
|
directory take precedence. For example, `/assets/screenshot-1.png` would win over `/tags/4.3/screenshot-1.png`
|
||||||
|
(or jpg, jpeg, gif).
|
||||||
|
2. This is the second screen shot
|
||||||
|
|
||||||
|
== Changelog ==
|
||||||
|
|
||||||
|
= 1.0 =
|
||||||
|
* A change since the previous version.
|
||||||
|
* Another change.
|
||||||
|
|
||||||
|
= 0.5 =
|
||||||
|
* List versions from most recent at top to oldest at bottom.
|
||||||
|
|
||||||
|
== Upgrade Notice ==
|
||||||
|
|
||||||
|
= 1.0 =
|
||||||
|
Upgrade notices describe the reason a user should upgrade. No more than 300 characters.
|
||||||
|
|
||||||
|
= 0.5 =
|
||||||
|
This version fixes a security related bug. Upgrade immediately.
|
||||||
|
|
||||||
|
== Arbitrary section ==
|
||||||
|
|
||||||
|
You may provide arbitrary sections, in the same format as the ones above. This may be of use for extremely complicated
|
||||||
|
plugins where more information needs to be conveyed that doesn't fit into the categories of "description" or
|
||||||
|
"installation." Arbitrary sections will be shown below the built-in sections outlined above.
|
||||||
|
|
||||||
|
== A brief Markdown Example ==
|
||||||
|
|
||||||
|
Ordered list:
|
||||||
|
|
||||||
|
1. Some feature
|
||||||
|
1. Another feature
|
||||||
|
1. Something else about the plugin
|
||||||
|
|
||||||
|
Unordered list:
|
||||||
|
|
||||||
|
* something
|
||||||
|
* something else
|
||||||
|
* third thing
|
||||||
|
|
||||||
|
Here's a link to [WordPress](https://wordpress.org/ "Your favorite software") and one to [Markdown's Syntax Documentation][markdown syntax].
|
||||||
|
Titles are optional, naturally.
|
||||||
|
|
||||||
|
[markdown syntax]: https://daringfireball.net/projects/markdown/syntax
|
||||||
|
"Markdown is what the parser uses to process much of the readme file"
|
||||||
|
|
||||||
|
Markdown uses email style notation for blockquotes and I've been told:
|
||||||
|
> Asterisks for *emphasis*. Double it up for **strong**.
|
||||||
|
|
||||||
|
`<?php code(); // goes in backticks ?>`
|
||||||
@@ -1,13 +1,13 @@
|
|||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* Plugin Name: Tonys SportsPress Enhancements
|
* Plugin Name: Tonys SportsPress Enhancements
|
||||||
* Plugin URI: https://github.com/anthonyscorrea/tonys-sportspress-enhancements
|
* Plugin URI: PLUGIN SITE HERE
|
||||||
* Description: Suite of SportsPress Enhancements
|
* Description: Suite of SportsPress Enhancements
|
||||||
* Author: Tony Correa
|
* Author: YOUR NAME HERE
|
||||||
* Author URI: https://github.com/anthonyscorrea/
|
* Author URI: YOUR SITE HERE
|
||||||
* Text Domain: tonys-sportspress-enhancements
|
* Text Domain: tonys-sportspress-enhancements
|
||||||
* Domain Path: /languages
|
* Domain Path: /languages
|
||||||
* Version: 0.1.2
|
* Version: 0.1.0
|
||||||
*
|
*
|
||||||
* @package Tonys_Sportspress_Enhancements
|
* @package Tonys_Sportspress_Enhancements
|
||||||
*/
|
*/
|
||||||
@@ -16,4 +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';
|
require_once plugin_dir_path(__FILE__) . 'includes/sp-event-permalink.php';
|
||||||
Reference in New Issue
Block a user