Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Tweak: improves the templates number/date functions #660

Merged
merged 8 commits into from
Nov 27, 2023
Merged
51 changes: 38 additions & 13 deletions includes/documents/abstract-wcpdf-order-document-methods.php
Original file line number Diff line number Diff line change
Expand Up @@ -1160,35 +1160,60 @@ public function get_formatted_item_price ( $item, $type, $tax_display = '' ) {
return $item_price;
}

/**
* Legacy function (v3.7.2 or inferior)
MohamadNateqi marked this conversation as resolved.
Show resolved Hide resolved
* Use $this->get_number() instead.
*/
public function get_invoice_number() {
// Call the woocommerce_invoice_number filter and let third-party plugins set a number.
// Default is null, so we can detect whether a plugin has set the invoice number
$third_party_invoice_number = apply_filters( 'woocommerce_invoice_number', null, $this->order_id );
if ($third_party_invoice_number !== null) {
return $third_party_invoice_number;
}

if ( $invoice_number = $this->get_number('invoice') ) {
return $formatted_invoice_number = $invoice_number->get_formatted();
wcpdf_log_error( 'The method get_invoice_number() is deprecated since version 3.7.3, please use the method get_number() instead.' );

if ( is_callable( array( $this, 'get_formatted_number' ) ) ) {
alexmigf marked this conversation as resolved.
Show resolved Hide resolved
return $this->get_number( 'invoice', null, 'view', true );
} else {
return '';
}
}

/**
* Legacy function (v3.7.2 or inferior)
* Use $this->number( 'invoice' ) instead.
*/
public function invoice_number() {
echo $this->get_invoice_number();
wcpdf_log_error( 'The method invoice_number() is deprecated since version 3.7.3, please use the method number() instead.' );

if ( is_callable( array( $this, 'number' ) ) ) {
$this->number( 'invoice' );
} else {
echo '';
}
}

/**
* Legacy function (v3.7.2 or inferior)
* Use $this->get_date() instead.
*/
public function get_invoice_date() {
if ( $invoice_date = $this->get_date('invoice') ) {
return $invoice_date->date_i18n( wcpdf_date_format( $this, 'invoice_date' ) );
wcpdf_log_error( 'The method get_invoice_date() is deprecated since version 3.7.3, please use the method get_date() instead.' );

if ( is_callable( array( $this, 'get_formatted_date' ) ) ) {
alexmigf marked this conversation as resolved.
Show resolved Hide resolved
return $this->get_date( 'invoice', null, 'view', true );
} else {
return '';
}
}

/**
* Legacy function (v3.7.2 or inferior)
* Use $this->date( 'invoice' ) instead.
*/
public function invoice_date() {
echo $this->get_invoice_date();
wcpdf_log_error( 'The method invoice_date() is deprecated since version 3.7.3, please use the method date() instead.' );

if ( is_callable( array( $this, 'date' ) ) ) {
$this->date( 'invoice' );
} else {
echo '';
}
}

public function get_document_notes() {
Expand Down
42 changes: 37 additions & 5 deletions includes/documents/abstract-wcpdf-order-document.php
alexmigf marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
Expand Up @@ -491,12 +491,32 @@ public function get_data( $key, $document_type = '', $order = null, $context = '
return $value;
}

public function get_number( $document_type = '', $order = null, $context = 'view' ) {
return $this->get_data( 'number', $document_type, $order, $context );
public function get_number( $document_type = '', $order = null, $context = 'view', $formatted = false ) {
$number = $this->get_data( 'number', $document_type, $order, $context );

if ( $number && $formatted ) {
$number = $number->get_formatted();
}

return apply_filters( "wpo_wcpdf_{$this->slug}_number", $number, $document_type, $order, $context, $formatted, $this );
}

public function number( $document_type ) {
echo $this->get_number( $document_type, null, 'view', true );
}

public function get_date( $document_type = '', $order = null, $context = 'view', $formatted = false ) {
$date = $this->get_data( 'date', $document_type, $order, $context );

if ( $date && $formatted ) {
$date = $date->date_i18n( wcpdf_date_format( $this, 'document_date' ) );
}

return apply_filters( "wpo_wcpdf_{$this->slug}_date", $date, $document_type, $order, $context, $formatted, $this );
}

public function get_date( $document_type = '', $order = null, $context = 'view' ) {
return $this->get_data( 'date', $document_type, $order, $context );
public function date( $document_type ) {
echo $this->get_date( $document_type, null, 'view', true );
}

public function get_notes( $document_type = '', $order = null, $context = 'view' ) {
Expand All @@ -514,7 +534,7 @@ public function get_creation_trigger( $document_type = '', $order = null, $conte
public function get_title() {
return apply_filters( "wpo_wcpdf_{$this->slug}_title", $this->title, $this );
}

public function title() {
echo $this->get_title();
}
Expand All @@ -524,17 +544,29 @@ public function get_number_title() {
$number_title = sprintf( __( '%s Number:', 'woocommerce-pdf-invoices-packing-slips' ), $this->title );
return apply_filters( "wpo_wcpdf_{$this->slug}_number_title", $number_title, $this );
}

public function number_title() {
echo $this->get_number_title();
}

public function get_date_title() {
/* translators: %s: document name */
$date_title = sprintf( __( '%s Date:', 'woocommerce-pdf-invoices-packing-slips' ), $this->title );
return apply_filters( "wpo_wcpdf_{$this->slug}_date_title", $date_title, $this );
}

public function date_title() {
echo $this->get_date_title();
}

public function get_due_date_title() {
$due_date_title = __( 'Due Date:', 'woocommerce-pdf-invoices-packing-slips' );
return apply_filters( "wpo_wcpdf_{$this->slug}_due_date_title", $due_date_title, $this );
}

public function due_date_title() {
echo $this->get_due_date_title();
}

/*
|--------------------------------------------------------------------------
Expand Down
12 changes: 6 additions & 6 deletions templates/Simple/invoice.php
Original file line number Diff line number Diff line change
Expand Up @@ -64,14 +64,14 @@
<?php do_action( 'wpo_wcpdf_before_order_data', $this->get_type(), $this->order ); ?>
<?php if ( isset( $this->settings['display_number'] ) ) : ?>
<tr class="invoice-number">
<th><?php echo $this->get_number_title(); ?></th>
<td><?php $this->invoice_number(); ?></td>
<th><?php $this->number_title(); ?></th>
<td><?php $this->number( $this->get_type() ); ?></td>
</tr>
<?php endif; ?>
<?php if ( isset( $this->settings['display_date'] ) ) : ?>
<tr class="invoice-date">
<th><?php echo $this->get_date_title(); ?></th>
<td><?php $this->invoice_date(); ?></td>
<th><?php $this->date_title(); ?></th>
<td><?php $this->date( $this->get_type() ); ?></td>
</tr>
<?php endif; ?>
<tr class="order-number">
Expand All @@ -82,10 +82,10 @@
<th><?php _e( 'Order Date:', 'woocommerce-pdf-invoices-packing-slips' ); ?></th>
<td><?php $this->order_date(); ?></td>
</tr>
<?php if ( $payment_method = $this->get_payment_method() ) : ?>
<?php if ( $this->get_payment_method() ) : ?>
<tr class="payment-method">
<th><?php _e( 'Payment Method:', 'woocommerce-pdf-invoices-packing-slips' ); ?></th>
<td><?php echo $payment_method; ?></td>
<td><?php $this->payment_method(); ?></td>
</tr>
<?php endif; ?>
<?php do_action( 'wpo_wcpdf_after_order_data', $this->get_type(), $this->order ); ?>
Expand Down
Loading