aristath/kirki

View on GitHub
packages/kirki-framework/control-upload/README.md

Summary

Maintainability
Test Coverage
# control-upload

## Installation

First, install the package using composer:

```bash
composer require kirki-framework/control-upload
```

Make sure you include the autoloader:
```php
require_once get_parent_theme_file_path( 'vendor/autoload.php' );
```

To add a control using the customizer API:

```php
/**
 * Registers the control and whitelists it for JS templating.
 *
 * @since 1.0
 * @param WP_Customize_Manager $wp_customize The WP_Customize_Manager object.
 * @return void
 */
add_action( 'customize_register', function( $wp_customize ) {
    $wp_customize->register_control_type( '\Kirki\Control\Upload' );
} );

/**
 * Add Customizer settings & controls.
 * 
 * @since 1.0
 * @param WP_Customize_Manager $wp_customize The WP_Customize_Manager object.
 * @return void
 */
add_action( 'customize_register', function( $wp_customize ) {

    // Add settings.
    $wp_customize->add_setting( 'my_control', [
        'type'              => 'theme_mod',
        'capability'        => 'edit_theme_options',
        'default'           => 'option-1',
        'transport'         => 'refresh', // Or postMessage.
        'sanitize_callback' => 'esc_url_raw',
        'default'           => '',
    ] );

    // Add controls.
    $wp_customize->add_control( new \Kirki\Control\Upload( $wp_customize, 'my_control', [
        'label'   => esc_html__( 'My Control', 'theme_textdomain' ),
        'section' => 'my_section',
    ] ) );
} );
```