Run prettier

This commit is contained in:
3wc 2024-05-08 17:27:19 -03:00
parent d830e1c251
commit 985a3d07f9
3 changed files with 257 additions and 198 deletions

View File

@ -3,28 +3,32 @@
/**
* Equeue the child theme stylesheet.
*/
function mont58coffee_enqueue_styles() {
wp_enqueue_style('child-style',
function mont58coffee_enqueue_styles()
{
wp_enqueue_style(
"child-style",
get_stylesheet_uri(),
array( 'bridge' ),
wp_get_theme()->get( 'Version' )
["bridge"],
wp_get_theme()->get("Version")
);
}
add_action( 'wp_enqueue_scripts', 'mont58coffee_enqueue_styles' );
add_action("wp_enqueue_scripts", "mont58coffee_enqueue_styles");
add_filter( 'get_terms', 'ts_get_subcategory_terms', 10, 3 );
function ts_get_subcategory_terms( $terms, $taxonomies, $args ) {
$new_terms = array();
// if it is a product category and on the shop page
if ( in_array( 'product_cat', $taxonomies ) && ! is_admin() &&is_shop() ) {
foreach( $terms as $key => $term ) {
if ( !in_array( $term->slug, array( 'african-coffees' ) ) ) { //pass the slug name here
$new_terms[] = $term;
}}
$terms = $new_terms;
}
return $terms;
add_filter("get_terms", "ts_get_subcategory_terms", 10, 3);
function ts_get_subcategory_terms($terms, $taxonomies, $args)
{
$new_terms = [];
// if it is a product category and on the shop page
if (in_array("product_cat", $taxonomies) && !is_admin() && is_shop()) {
foreach ($terms as $key => $term) {
if (!in_array($term->slug, ["african-coffees"])) {
//pass the slug name here
$new_terms[] = $term;
}
}
$terms = $new_terms;
}
return $terms;
}
/**
@ -36,13 +40,19 @@ return $terms;
* License: GPL v2
*/
function eg_extend_subscription_period_intervals( $intervals ) {
$intervals[10] = sprintf( __( 'every %s', 'my-text-domain' ), WC_Subscriptions::append_numeral_suffix( 10 ) );
function eg_extend_subscription_period_intervals($intervals)
{
$intervals[10] = sprintf(
__("every %s", "my-text-domain"),
WC_Subscriptions::append_numeral_suffix(10)
);
return $intervals;
}
add_filter( 'woocommerce_subscription_period_interval_strings', 'eg_extend_subscription_period_intervals' );
add_filter(
"woocommerce_subscription_period_interval_strings",
"eg_extend_subscription_period_intervals"
);
/**
* Snippet Name: Mont58 Coffee Label
@ -51,15 +61,19 @@ add_filter( 'woocommerce_subscription_period_interval_strings', 'eg_extend_subsc
* Author: Autonomic Co-op
* Author URI: https://autonomic.zone/
* License: GPL2
*/
*/
function process_coffee_items($order, &$order_coffees, &$seen_subscriptions) {
function process_coffee_items($order, &$order_coffees, &$seen_subscriptions)
{
// Iterate through all items in the order
foreach ($order->get_items() as $order_item) {
// Check if the item is a subscription (based on name containing "subscription")
if (stripos($order_item->get_name(), "subscription") !== false) {
// Get the coffee list associated with the subscription item
$coffee_list = get_field("coffee_list", $order_item->get_product_id());
$coffee_list = get_field(
"coffee_list",
$order_item->get_product_id()
);
// TODO log or display this error
if (!$coffee_list) {
@ -81,7 +95,8 @@ function process_coffee_items($order, &$order_coffees, &$seen_subscriptions) {
$seen_subscriptions[$coffee_list_id]++;
// Calculate the index to select a coffee from the list
$index = $seen_subscriptions[$coffee_list_id];
$coffee = $coffees_in_list[$index % sizeof($coffees_in_list)];
$coffee =
$coffees_in_list[$index % sizeof($coffees_in_list)];
} else {
// If this coffee list is encountered for the first time in this order
$seen_subscriptions[$coffee_list_id] = 0;
@ -90,17 +105,21 @@ function process_coffee_items($order, &$order_coffees, &$seen_subscriptions) {
}
// Add the selected coffee with its associated coffee list to the order_coffees array
array_push($order_coffees, array("coffee_list" => $coffee_list, "coffee" => $coffee));
array_push($order_coffees, [
"coffee_list" => $coffee_list,
"coffee" => $coffee,
]);
}
}
}
}
// Handle new order creation event
function action_woocommerce_new_order($order_id, $order) {
function action_woocommerce_new_order($order_id, $order)
{
// Initialize arrays to store processed data
$order_coffees = array();
$seen_subscriptions = array();
$order_coffees = [];
$seen_subscriptions = [];
// Process coffee items in the new order
process_coffee_items($order, $order_coffees, $seen_subscriptions);
@ -109,12 +128,16 @@ function action_woocommerce_new_order($order_id, $order) {
update_field("coffees", $order_coffees, $order_id);
}
// Hook the above function to the 'woocommerce_new_order' action
add_action('woocommerce_new_order', 'action_woocommerce_new_order', 10, 2);
add_action("woocommerce_new_order", "action_woocommerce_new_order", 10, 2);
// Handle renewal order creation event
function action_wcs_renewal_order_created($order, $subscription) {
function action_wcs_renewal_order_created($order, $subscription)
{
// Retrieve related orders of the subscription excluding the current renewal order
$last_orders = wcs_get_subscription($subscription)->get_related_orders('ids', array('parent', 'renewal'));
$last_orders = wcs_get_subscription($subscription)->get_related_orders(
"ids",
["parent", "renewal"]
);
unset($last_orders[$order->get_ID()]);
// If there are previous orders related to the subscription
@ -126,12 +149,17 @@ function action_wcs_renewal_order_created($order, $subscription) {
$last_order_coffees = get_field("coffees", $last_order_id);
// Initialize arrays to store processed data for the current order
$order_coffees = array();
$seen_subscriptions = array();
$order_coffees = [];
$seen_subscriptions = [];
// Get the latest coffee seen in each coffee list from the previous order
foreach(array_reverse($last_order_coffees) as $last_order_coffee) {
if (array_key_exists($last_order_coffee["coffee_list"]->ID, $seen_subscriptions)) {
foreach (array_reverse($last_order_coffees) as $last_order_coffee) {
if (
array_key_exists(
$last_order_coffee["coffee_list"]->ID,
$seen_subscriptions
)
) {
continue;
}
$position_in_list = array_search(
@ -142,7 +170,9 @@ function action_wcs_renewal_order_created($order, $subscription) {
// ignore this, can't find it in list anymore
continue;
}
$seen_subscriptions[$last_order_coffee["coffee_list"]->ID] = $position_in_list;
$seen_subscriptions[
$last_order_coffee["coffee_list"]->ID
] = $position_in_list;
}
// Process coffee items based on the coffees in the last order
@ -153,47 +183,66 @@ function action_wcs_renewal_order_created($order, $subscription) {
}
}
// Hook the above function to the 'wcs_renewal_order_created' action
add_action('wcs_renewal_order_created', 'action_wcs_renewal_order_created', 10, 2);
add_action(
"wcs_renewal_order_created",
"action_wcs_renewal_order_created",
10,
2
);
// Add a sidepanel on WooCommerce order pages
add_action('add_meta_boxes', 'mont58_coffee_label_add_sidepanel');
add_action("add_meta_boxes", "mont58_coffee_label_add_sidepanel");
function mont58_coffee_label_add_sidepanel() {
function mont58_coffee_label_add_sidepanel()
{
add_meta_box(
'mont58_coffee_label_sidepanel',
'Coffee Label',
'mont58_coffee_label_render_sidepanel',
'shop_order',
'side',
'high'
"mont58_coffee_label_sidepanel",
"Coffee Label",
"mont58_coffee_label_render_sidepanel",
"shop_order",
"side",
"high"
);
}
function mont58_coffee_label_render_sidepanel($post) {
function mont58_coffee_label_render_sidepanel($post)
{
// Render the content of the sidepanel here
$order_ids = array($post->ID);
echo '<a href="' . add_query_arg("order_ids", $order_ids, "/coffee-label") . '" class="button button-primary" target="_blank">View Label</a>';
$order_ids = [$post->ID];
echo '<a href="' .
add_query_arg("order_ids", $order_ids, "/coffee-label") .
'" class="button button-primary" target="_blank">View Label</a>';
}
// Load custom template
function load_custom_template($template) {
if (is_page('coffee-label')) {
return plugin_dir_path(__FILE__) . 'template-order-label.php';
function load_custom_template($template)
{
if (is_page("coffee-label")) {
return plugin_dir_path(__FILE__) . "template-order-label.php";
}
return $template;
}
add_filter('template_include', 'load_custom_template');
add_filter("template_include", "load_custom_template");
add_filter('bulk_actions-edit-shop_order', function($bulk_actions) {
$bulk_actions['generate-label'] = __('Generate label', 'txtdomain');
add_filter("bulk_actions-edit-shop_order", function ($bulk_actions) {
$bulk_actions["generate-label"] = __("Generate label", "txtdomain");
return $bulk_actions;
});
add_filter('handle_bulk_actions-edit-shop_order', function($redirect_url, $action, $post_ids) {
if ($action == 'generate-label') {
$redirect_url = add_query_arg('order_ids', $post_ids, "/coffee-label");
add_filter(
"handle_bulk_actions-edit-shop_order",
function ($redirect_url, $action, $post_ids) {
if ($action == "generate-label") {
$redirect_url = add_query_arg(
"order_ids",
$post_ids,
"/coffee-label"
);
}
return $redirect_url;
}, 10, 3);
},
10,
3
);

View File

@ -1,4 +1,5 @@
<?php /* Template Name: Coffee Label */
<?php
/* Template Name: Coffee Label */
?>
<!DOCTYPE html>
<html lang="en">
@ -81,57 +82,61 @@
</head>
<body>
<div class="container">
<?php
foreach ($_GET['order_ids'] as $order_id) {
<?php foreach ($_GET["order_ids"] as $order_id) {
$order = wc_get_order($order_id);
$first_name = $order->get_billing_first_name();
$last_name = $order->get_billing_last_name();
$postcode = $order->get_billing_postcode();
$items = $order->get_items();
$roast_date = (new DateTime())->modify('-3 days')->format('d/m/Y');
$gift_message = $order->get_meta('_shipping_gift_message');
$roast_date = (new DateTime())->modify("-3 days")->format("d/m/Y");
$gift_message = $order->get_meta("_shipping_gift_message");
$order_subscription_coffees = get_field('coffees', $order_id);
$order_subscription_coffees = get_field("coffees", $order_id);
$j = 0; // Count order items
foreach ($items as $item) {
// checking if product is a coffee
$product_id = $item->get_product_id();
$product_categories = get_the_terms($product_id, 'product_cat');
$product_categories = get_the_terms($product_id, "product_cat");
$is_coffee = false;
$is_subscription = false;
if (!empty($product_categories) && !is_wp_error($product_categories)) {
if (
!empty($product_categories) &&
!is_wp_error($product_categories)
) {
foreach ($product_categories as $product_category) {
if ($product_category->slug == 'coffee') {
if ($product_category->slug == "coffee") {
$is_coffee = true;
break;
} else if ($product_category->slug == 'tasting') {
} elseif ($product_category->slug == "tasting") {
$is_subscription = true;
break;
}
}
}
if ((!$is_coffee) && (!$is_subscription)) {
if (!$is_coffee && !$is_subscription) {
continue;
}
$brew_method = $item->get_meta('pa_brew-method');
$weight = $item->get_meta('weight');
$brew_method = $item->get_meta("pa_brew-method");
$weight = $item->get_meta("weight");
if ($is_coffee) {
// Non-subscription order
$product_name = $item->get_name();
$roast = get_field('roast_level', $product_id);
$is_organic = get_field('is_organic', $product_id);
$roast = get_field("roast_level", $product_id);
$is_organic = get_field("is_organic", $product_id);
}
if ($is_subscription) {
$subscriptions = wcs_get_subscriptions_for_order($order_id, array( 'order_type' => 'any' ));
$subscriptions = wcs_get_subscriptions_for_order($order_id, [
"order_type" => "any",
]);
// TODO log / admin warning if there are >1 subscriptions
$subscription = array_pop($subscriptions);
$orders = $subscription->get_related_orders('ids', 'any');
$orders = $subscription->get_related_orders("ids", "any");
if (sizeof($orders) == 1) {
$is_new = true;
}
@ -140,10 +145,10 @@
$quantity = $item->get_quantity();
for ($i = 0; $i < $quantity; $i++) {
if ($is_subscription) {
$coffee = $order_subscription_coffees[$i+$j]["coffee"];
$coffee = $order_subscription_coffees[$i + $j]["coffee"];
$product_name = $coffee->post_title;
$roast = get_field('roast_level', $coffee->ID);
$is_organic = get_field('is_organic', $coffee->ID);
$roast = get_field("roast_level", $coffee->ID);
$is_organic = get_field("is_organic", $coffee->ID);
} ?>
<div class="label">
<div>
@ -153,7 +158,11 @@
<p class="bean-type"><?php echo $brew_method; ?></p>
<p class="roast"><?php echo $roast; ?> Roast</p>
<p class="date">Roasted on: <span><?php echo $roast_date; ?></span></p>
<p class="code"><?php echo $is_new ? 'N' : '' ?><?php echo $gift_message ? 'G' : '' ?><?php echo $is_organic ? 'O' : '' ?></p>
<p class="code"><?php
echo $is_new ? "N" : "";
echo $gift_message ? "G" : "";
echo $is_organic ? "O" : "";
?></p>
</div>
<div class="order-details">
<p class="customer-name"><?php echo "$first_name $last_name"; ?></p>
@ -162,10 +171,11 @@
</div>
</div>
</div>
<?php }
<?php
}
$j++; // increment counter
}
}?>
} ?>
</div>
</body>
</html>