Compare commits
1 Commits
install-sc
...
534fd666be
| Author | SHA1 | Date | |
|---|---|---|---|
|
534fd666be
|
109
includes/open-graph-tags.php
Normal file
109
includes/open-graph-tags.php
Normal file
@@ -0,0 +1,109 @@
|
|||||||
|
<?php
|
||||||
|
/*
|
||||||
|
Plugin Name: Custom Open Graph Tags with SportsPress Integration
|
||||||
|
Description: Adds custom Open Graph tags to posts based on their type, specifically handling sp_event post types with methods from the SportsPress SP_Event class.
|
||||||
|
Version: 1.0
|
||||||
|
Author: Your Name
|
||||||
|
*/
|
||||||
|
|
||||||
|
add_action('wp_head', 'custom_open_graph_tags_with_sportspress_integration');
|
||||||
|
|
||||||
|
function custom_open_graph_tags_with_sportspress_integration() {
|
||||||
|
if (is_single()) {
|
||||||
|
global $post;
|
||||||
|
if ($post->post_type === 'sp_event') {
|
||||||
|
// Instantiate SP_Event object
|
||||||
|
$event = new SP_Event($post->ID);
|
||||||
|
|
||||||
|
// Fetch details using SP_Event methods
|
||||||
|
$publish_date = get_the_date('F j, Y', $post);
|
||||||
|
$venue_terms = get_the_terms($post->ID, 'sp_venue');
|
||||||
|
$venue_name = $venue_terms ? $venue_terms[0]->name : 'No Venue Specified';
|
||||||
|
$results = $event->results(); // Using SP_Event method
|
||||||
|
$title = get_the_title() . " " . "(" . $publish_date . ")";
|
||||||
|
$sp_status = get_post_meta( $post->ID, 'sp_status', true );
|
||||||
|
$status = $event->status(); // Using SP_Event method
|
||||||
|
$publish_date_and_time = get_the_date('F j, Y g:i A', $post);
|
||||||
|
$description = "{$publish_date_and_time} at {$venue_name}.";
|
||||||
|
if ( 'postponed' == $sp_status ) {
|
||||||
|
$description = "POSTPONED" . " - " . $description;
|
||||||
|
$title = "POSTPONED" . " - " . $title;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( 'results' == $status ) { // checks if there is a final score
|
||||||
|
// Get event result data
|
||||||
|
$data = $event->results();
|
||||||
|
|
||||||
|
// The first row should be column labels
|
||||||
|
$labels = $data[0];
|
||||||
|
|
||||||
|
// Remove the first row to leave us with the actual data
|
||||||
|
unset( $data[0] );
|
||||||
|
|
||||||
|
$data = array_filter( $data );
|
||||||
|
|
||||||
|
if ( empty( $data ) ) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Initialize
|
||||||
|
$i = 0;
|
||||||
|
$result_string = '';
|
||||||
|
$title_string = '';
|
||||||
|
|
||||||
|
// Reverse teams order if the option "Events > Teams > Order > Reverse order" is enabled.
|
||||||
|
$reverse_teams = get_option( 'sportspress_event_reverse_teams', 'no' ) === 'yes' ? true : false;
|
||||||
|
if ( $reverse_teams ) {
|
||||||
|
$data = array_reverse( $data, true );
|
||||||
|
}
|
||||||
|
|
||||||
|
$teams_result_array = [];
|
||||||
|
|
||||||
|
foreach ( $data as $team_id => $result ) :
|
||||||
|
$outcomes = array();
|
||||||
|
$result_outcome = sp_array_value( $result, 'outcome' );
|
||||||
|
if ( ! is_array( $result_outcome ) ) :
|
||||||
|
$outcomes = array( '—' );
|
||||||
|
else :
|
||||||
|
foreach ( $result_outcome as $outcome ) :
|
||||||
|
$the_outcome = get_page_by_path( $outcome, OBJECT, 'sp_outcome' );
|
||||||
|
if ( is_object( $the_outcome ) ) :
|
||||||
|
$outcomes[] = $the_outcome->post_title;
|
||||||
|
endif;
|
||||||
|
endforeach;
|
||||||
|
endif;
|
||||||
|
|
||||||
|
unset( $result['outcome'] );
|
||||||
|
|
||||||
|
$team_name = sp_team_short_name( $team_id );
|
||||||
|
|
||||||
|
$outcome_abbreviation = get_post_meta( $the_outcome->ID, 'sp_abbreviation', true );
|
||||||
|
if ( ! $outcome_abbreviation ) {
|
||||||
|
$outcome_abbreviation = sp_substr( $the_outcome->post_title, 0, 1 );
|
||||||
|
}
|
||||||
|
|
||||||
|
array_push($teams_result_array, [
|
||||||
|
"result" => $result,
|
||||||
|
"outcome" => $the_outcome->post_title,
|
||||||
|
"outcome_abbreviation" => $outcome_abbreviation,
|
||||||
|
"team_name" => $team_name,
|
||||||
|
]
|
||||||
|
);
|
||||||
|
$i++;
|
||||||
|
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})";
|
||||||
|
$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;
|
||||||
|
$post_thumbnail = get_the_post_thumbnail_url($post->ID, 'thumbnail');
|
||||||
|
$image = $post_thumbnail ? $post_thumbnail : get_site_icon_url();
|
||||||
|
echo '<meta property="og:type" content="article" />' . "\n";
|
||||||
|
echo '<meta property="og:image" content="'. $image . '" />' . "\n";
|
||||||
|
echo '<meta property="og:title" content="' . $title . '" />' . "\n";
|
||||||
|
echo '<meta property="og:description" content="' . $description . '" />' . "\n";
|
||||||
|
echo '<meta property="og:url" content="' . get_permalink() . '" />' . "\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
?>
|
||||||
@@ -1,101 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
/*
|
|
||||||
Enhances the post management for 'sp_event' custom post type by adding custom
|
|
||||||
filters for events with or without outcomes
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Generates a meta query argument array for filtering 'sp_event' custom posts based on the presence or absence of outcomes.
|
|
||||||
*
|
|
||||||
* @param bool $has_outcome Whether to filter events with outcomes (true) or without outcomes (false). Default is true.
|
|
||||||
*
|
|
||||||
* @return array Meta query argument array for WP_Query.
|
|
||||||
*/
|
|
||||||
function get_sp_event_has_outcome_meta_query_args($has_outcome = true): array
|
|
||||||
{
|
|
||||||
if ($has_outcome) {
|
|
||||||
return [
|
|
||||||
"relation" => "AND",
|
|
||||||
[
|
|
||||||
"key" => "sp_results",
|
|
||||||
"value" => '"outcome"',
|
|
||||||
"compare" => "LIKE",
|
|
||||||
],
|
|
||||||
[
|
|
||||||
"key" => "sp_results",
|
|
||||||
"value" => 's:7:"outcome";a:0:{}', // i.e. a blank outcome
|
|
||||||
"compare" => "NOT LIKE",
|
|
||||||
],
|
|
||||||
];
|
|
||||||
} elseif (!$has_outcome) {
|
|
||||||
return [
|
|
||||||
"relation" => "OR",
|
|
||||||
[
|
|
||||||
"key" => "sp_results",
|
|
||||||
"value" => '"outcome"',
|
|
||||||
"compare" => "NOT LIKE",
|
|
||||||
],
|
|
||||||
[
|
|
||||||
"key" => "sp_results",
|
|
||||||
"value" => 's:7:"outcome";a:0:{}', // i.e. a blank outcome
|
|
||||||
"compare" => "LIKE",
|
|
||||||
],
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add the custom filter dropdown
|
|
||||||
function outcome_filter_dropdown()
|
|
||||||
{
|
|
||||||
$current_screen = get_current_screen();
|
|
||||||
|
|
||||||
if ($current_screen->id == "edit-sp_event") {
|
|
||||||
if (isset($_GET["has-outcome"])) {
|
|
||||||
switch ($_GET["has-outcome"]) {
|
|
||||||
case 'true':
|
|
||||||
$selected="has-outcome";break;
|
|
||||||
case 'false':
|
|
||||||
$selected="has-no-outcome";break;
|
|
||||||
case '':
|
|
||||||
$selected='';break;
|
|
||||||
}
|
|
||||||
}; ?>
|
|
||||||
<select name="has-outcome">
|
|
||||||
<option value="" <?php selected(
|
|
||||||
"",
|
|
||||||
$selected
|
|
||||||
); ?>>All Outcomes</option>
|
|
||||||
<option value="false" <?php selected(
|
|
||||||
"has-no-outcome",
|
|
||||||
$selected
|
|
||||||
); ?>>Missing Outcome</option>
|
|
||||||
<option value="true" <?php selected(
|
|
||||||
"has-outcome",
|
|
||||||
$selected
|
|
||||||
); ?>>Has Outcome</option>
|
|
||||||
</select>
|
|
||||||
<?php
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
add_action("restrict_manage_posts", "outcome_filter_dropdown");
|
|
||||||
|
|
||||||
// Modify the query based on the selected filter
|
|
||||||
function outcome_filter_query($query)
|
|
||||||
{
|
|
||||||
global $pagenow;
|
|
||||||
|
|
||||||
if ($pagenow == "edit.php" && isset($_GET["has-outcome"]) ) {
|
|
||||||
if ($_GET["has-outcome"] == "false") {
|
|
||||||
$meta_query = get_sp_event_has_outcome_meta_query_args(false);
|
|
||||||
$query->set("meta_query", $meta_query);
|
|
||||||
}
|
|
||||||
elseif ($_GET["has-outcome"] == "true") {
|
|
||||||
$meta_query = get_sp_event_has_outcome_meta_query_args(true);
|
|
||||||
$query->set("meta_query", $meta_query);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
add_action("pre_get_posts", "outcome_filter_query");
|
|
||||||
@@ -1,105 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
/*
|
|
||||||
Enhances the post management for 'sp_event' custom post type by adding custom
|
|
||||||
filters for events with or without outcomes
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Generates a meta query argument array for filtering 'sp_event' custom posts based on the presence or absence of outcomes.
|
|
||||||
*
|
|
||||||
* @param bool $has_outcome Whether to filter events with outcomes (true) or without outcomes (false). Default is true.
|
|
||||||
*
|
|
||||||
* @return array Meta query argument array for WP_Query.
|
|
||||||
*/
|
|
||||||
function get_sp_event_has_outcome_meta_query_args($has_outcome = true): array
|
|
||||||
{
|
|
||||||
if ($has_outcome) {
|
|
||||||
return [
|
|
||||||
"relation" => "AND",
|
|
||||||
[
|
|
||||||
"key" => "sp_results",
|
|
||||||
"value" => '"outcome"',
|
|
||||||
"compare" => "LIKE",
|
|
||||||
],
|
|
||||||
[
|
|
||||||
"key" => "sp_results",
|
|
||||||
"value" => 's:7:"outcome";a:0:{}', // i.e. a blank outcome
|
|
||||||
"compare" => "NOT LIKE",
|
|
||||||
],
|
|
||||||
];
|
|
||||||
} elseif (!$has_outcome) {
|
|
||||||
return [
|
|
||||||
"relation" => "OR",
|
|
||||||
[
|
|
||||||
"key" => "sp_results",
|
|
||||||
"value" => '"outcome"',
|
|
||||||
"compare" => "NOT LIKE",
|
|
||||||
],
|
|
||||||
[
|
|
||||||
"key" => "sp_results",
|
|
||||||
"value" => 's:7:"outcome";a:0:{}', // i.e. a blank outcome
|
|
||||||
"compare" => "LIKE",
|
|
||||||
],
|
|
||||||
];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
add_filter("views_edit-sp_event", "wp37_sp_event_does_not_have_outcome_filter");
|
|
||||||
function wp37_sp_event_does_not_have_outcome_filter($views)
|
|
||||||
|
|
||||||
{
|
|
||||||
if (is_admin() && $_GET["post_type"] == "sp_event") {
|
|
||||||
global $wp_query;
|
|
||||||
$filter_name = "Missing Results";
|
|
||||||
|
|
||||||
$result = new WP_Query([
|
|
||||||
"post_type" => "sp_event",
|
|
||||||
"meta_query" => [get_sp_event_has_outcome_meta_query_args(false)],
|
|
||||||
]);
|
|
||||||
|
|
||||||
// $link = add_query_arg("sp_event_has_outcome", "false");
|
|
||||||
$link="#";
|
|
||||||
// $link = admin_url( "edit.php?post_type=sp_event&sp_event_has_outcome=false" );
|
|
||||||
|
|
||||||
$sp_event_has_outcome =
|
|
||||||
get_query_var("sp_event_has_outcome") === "false";
|
|
||||||
$class = $sp_event_has_outcome === true ? ' class="current"' : "";
|
|
||||||
$views["sp_event_does_not_have_outcome"] = sprintf(
|
|
||||||
'<a href="%s"' . $class . ">" . $filter_name . " (%d)",
|
|
||||||
$link,
|
|
||||||
$result->found_posts
|
|
||||||
);
|
|
||||||
|
|
||||||
return $views;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
add_action("init", "wpse246143_register_sp_event_has_outcome");
|
|
||||||
function wpse246143_register_sp_event_has_outcome()
|
|
||||||
{
|
|
||||||
global $wp;
|
|
||||||
$wp->add_query_var("sp_event_has_outcome");
|
|
||||||
}
|
|
||||||
|
|
||||||
add_action("parse_query", "wpse246143_map_sp_event_has_outcome");
|
|
||||||
function wpse246143_map_sp_event_has_outcome($wp_query)
|
|
||||||
{
|
|
||||||
if (
|
|
||||||
isset($wp_query->query["post_type"]) and
|
|
||||||
$wp_query->query["post_type"] == "sp_event" and
|
|
||||||
$wp_query->get("sp_event_has_outcome")
|
|
||||||
) {
|
|
||||||
$sp_event_has_outcome =
|
|
||||||
get_query_var("sp_event_has_outcome") === "true";
|
|
||||||
|
|
||||||
if ($sp_event_has_outcome) {
|
|
||||||
$meta_query = get_sp_event_has_outcome_meta_query_args(true);
|
|
||||||
} elseif (!$sp_event_has_outcome) {
|
|
||||||
$meta_query = get_sp_event_has_outcome_meta_query_args(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
$wp_query->set("meta_query", $meta_query);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1,58 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
/*
|
|
||||||
Enhances the post management for 'sp_event' custom post type by adding custom
|
|
||||||
filters for event status
|
|
||||||
*/
|
|
||||||
|
|
||||||
// Add the custom filter dropdown
|
|
||||||
function sp_status_filter_dropdown()
|
|
||||||
{
|
|
||||||
$current_screen = get_current_screen();
|
|
||||||
|
|
||||||
if ($current_screen->id == "edit-sp_event") {
|
|
||||||
$selected = isset($_GET["sp_status"]) ? $_GET["sp_status"] : ""; ?>
|
|
||||||
<select name="sp_status">
|
|
||||||
<option value="" <?php selected(
|
|
||||||
"",
|
|
||||||
$selected
|
|
||||||
); ?>>All Status</option>
|
|
||||||
<option value="ok" <?php selected(
|
|
||||||
"ok",
|
|
||||||
$selected
|
|
||||||
); ?>>On Time</option>
|
|
||||||
<option value="tbd" <?php selected(
|
|
||||||
"tbd",
|
|
||||||
$selected
|
|
||||||
); ?>>TBD</option>
|
|
||||||
<option value="postponed" <?php selected(
|
|
||||||
"postponed",
|
|
||||||
$selected
|
|
||||||
); ?>>Postponed</option>
|
|
||||||
<option value="canceled" <?php selected(
|
|
||||||
"canceled",
|
|
||||||
$selected
|
|
||||||
); ?>>Canceled</option>
|
|
||||||
</select>
|
|
||||||
<?php
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
add_action("restrict_manage_posts", "sp_status_filter_dropdown");
|
|
||||||
|
|
||||||
// Modify the query based on the selected filter
|
|
||||||
function sp_status_filter_query($query)
|
|
||||||
{
|
|
||||||
global $pagenow;
|
|
||||||
|
|
||||||
if ($pagenow == "edit.php" && isset($_GET["sp_status"]) && $_GET["sp_status"] != '' ) {
|
|
||||||
$query->set("meta_query", [[
|
|
||||||
"key" => "sp_status",
|
|
||||||
"value" => $_GET["sp_status"],
|
|
||||||
"compare" => "=",
|
|
||||||
]]
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
add_action("pre_get_posts", "sp_status_filter_query");
|
|
||||||
@@ -1,70 +0,0 @@
|
|||||||
<?php
|
|
||||||
/*
|
|
||||||
Enhances the post management by adding custom providing a dropdown to
|
|
||||||
filter events based on different timeframes.
|
|
||||||
*/
|
|
||||||
// Add the custom filter dropdown
|
|
||||||
function timeframe_filter_dropdown()
|
|
||||||
{
|
|
||||||
$current_screen = get_current_screen();
|
|
||||||
|
|
||||||
if ($current_screen->id == "edit-sp_event") {
|
|
||||||
$selected = isset($_GET["timeframe"]) ? $_GET["timeframe"] : ""; ?>
|
|
||||||
<select name="timeframe">
|
|
||||||
<option value="" <?php selected(
|
|
||||||
"",
|
|
||||||
$selected
|
|
||||||
); ?>>All Timeframe</option>
|
|
||||||
<option value="last3days" <?php selected(
|
|
||||||
"last3days",
|
|
||||||
$selected
|
|
||||||
); ?>>Last 3 Days</option>
|
|
||||||
<option value="last7days" <?php selected(
|
|
||||||
"last7days",
|
|
||||||
$selected
|
|
||||||
); ?>>Last 7 Days</option>
|
|
||||||
<option value="plusminus3days" <?php selected(
|
|
||||||
"plusminus3days",
|
|
||||||
$selected
|
|
||||||
); ?>>+/- 3 Days</option>
|
|
||||||
</select>
|
|
||||||
<?php
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
add_action("restrict_manage_posts", "timeframe_filter_dropdown");
|
|
||||||
|
|
||||||
// Modify the query based on the selected filter
|
|
||||||
function timeframe_filter_query($query)
|
|
||||||
{
|
|
||||||
global $pagenow;
|
|
||||||
|
|
||||||
if ($pagenow == "edit.php" && isset($_GET["timeframe"]) ) {
|
|
||||||
if ($_GET["timeframe"] == "last3days") {
|
|
||||||
$date_query = [
|
|
||||||
[
|
|
||||||
"after" => date("Y-m-d", strtotime("-3 days")),
|
|
||||||
],
|
|
||||||
];
|
|
||||||
} elseif ($_GET["timeframe"] == "last7days") {
|
|
||||||
$date_query = [
|
|
||||||
[
|
|
||||||
"after" => date("Y-m-d", strtotime("-1 week")),
|
|
||||||
],
|
|
||||||
];
|
|
||||||
} elseif ($_GET["timeframe"] == "plusminus3days") {
|
|
||||||
$date_query = [
|
|
||||||
[
|
|
||||||
"after" => date("Y-m-d", strtotime("-3 days")),
|
|
||||||
"before" => date("Y-m-d", strtotime("+3 days")),
|
|
||||||
],
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!$_GET["timeframe"] == "") {
|
|
||||||
$query->set("date_query", $date_query);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
add_action("pre_get_posts", "timeframe_filter_query");
|
|
||||||
@@ -1,27 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
DOCKER_RUN_SCRIPT=../selig/cmbabaseball/docker-run.sh
|
|
||||||
|
|
||||||
# Check if the number of arguments is less than 1 (i.e., PLUGIN_NAME is not provided)
|
|
||||||
if [ "$#" -lt 1 ]; then
|
|
||||||
echo "Error: PLUGIN_NAME argument is missing."
|
|
||||||
echo "Usage: $0 PLUGIN_NAME"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Assign the first argument to PLUGIN_NAME variable
|
|
||||||
PLUGIN_NAME="$1"
|
|
||||||
PLUGIN_ZIP_FILENAME="${PLUGIN_NAME}_$(date +"%y%m%d-%H%M%S").zip"
|
|
||||||
TMPFILE=${TMPDIR}${PLUGIN_ZIP_FILENAME}
|
|
||||||
|
|
||||||
echo "Installing plugin $PLUGIN_NAME using ${DOCKER_RUN_SCRIPT} via $TMPFILE"
|
|
||||||
|
|
||||||
# Continue with your script...
|
|
||||||
cd src/plugins/${PLUGIN_NAME} && zip -r ../../../dist/${PLUGIN_ZIP_FILENAME} . && cd ../../.. && \
|
|
||||||
cp ./dist/${PLUGIN_ZIP_FILENAME} ${TMPFILE} &&
|
|
||||||
${DOCKER_RUN_SCRIPT} \
|
|
||||||
-v ${TMPFILE}:/${PLUGIN_ZIP_FILENAME} \
|
|
||||||
wordpress:cli \
|
|
||||||
wp plugin install /${PLUGIN_ZIP_FILENAME} --force --skip-plugins --activate
|
|
||||||
|
|
||||||
# End of the script
|
|
||||||
|
|
||||||
@@ -14,7 +14,4 @@
|
|||||||
|
|
||||||
|
|
||||||
// Include other files here
|
// Include other files here
|
||||||
// require_once plugin_dir_path(__FILE__) . 'includes/sp-event-has-outcome.php';
|
require_once plugin_dir_path(__FILE__) . 'includes/open-graph-tags.php';
|
||||||
require_once plugin_dir_path(__FILE__) . 'includes/sp-event-has-outcome-filter.php';
|
|
||||||
require_once plugin_dir_path(__FILE__) . 'includes/timeframe-filter.php';
|
|
||||||
require_once plugin_dir_path(__FILE__) . 'includes/sp-event-status-filter.php';
|
|
||||||
|
|||||||
Reference in New Issue
Block a user