woothemes/woocommerce

View on GitHub
includes/abstracts/abstract-wc-integration.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php
/**
 * Abstract Integration class
 *
 * Extension of the Settings API which in turn gets extended
 * by individual integrations to offer additional functionality.
 *
 * @class       WC_Settings_API
 * @version     2.6.0
 * @package     WooCommerce\Abstracts
 */

if ( ! defined( 'ABSPATH' ) ) {
    exit;
}

/**
 * Abstract Integration Class
 *
 * Extended by individual integrations to offer additional functionality.
 *
 * @class    WC_Integration
 * @extends  WC_Settings_API
 * @version  2.6.0
 * @package  WooCommerce\Abstracts
 */
abstract class WC_Integration extends WC_Settings_API {

    /**
     * Yes or no based on whether the integration is enabled.
     *
     * @var string
     */
    public $enabled = 'yes';

    /**
     * Integration title.
     *
     * @var string
     */
    public $method_title = '';

    /**
     * Integration description.
     *
     * @var string
     */
    public $method_description = '';

    /**
     * Return the title for admin screens.
     *
     * @return string
     */
    public function get_method_title() {
        return apply_filters( 'woocommerce_integration_title', $this->method_title, $this );
    }

    /**
     * Return the description for admin screens.
     *
     * @return string
     */
    public function get_method_description() {
        return apply_filters( 'woocommerce_integration_description', $this->method_description, $this );
    }

    /**
     * Output the gateway settings screen.
     */
    public function admin_options() {
        echo '<h2>' . esc_html( $this->get_method_title() ) . '</h2>';
        echo wp_kses_post( wpautop( $this->get_method_description() ) );
        echo '<div><input type="hidden" name="section" value="' . esc_attr( $this->id ) . '" /></div>';
        parent::admin_options();
    }

    /**
     * Init settings for gateways.
     */
    public function init_settings() {
        parent::init_settings();
        $this->enabled = ! empty( $this->settings['enabled'] ) && 'yes' === $this->settings['enabled'] ? 'yes' : 'no';
    }
}