-
Notifications
You must be signed in to change notification settings - Fork 0
/
enable-marker-color.php
134 lines (111 loc) · 2.88 KB
/
enable-marker-color.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
<?php
/**
* Plugin Name: Enable Marker Color
* Description: Add settings to the List block to change marker color.
* Version: 1.0.0
* Author: Toro_Unit,HAMWORKS
* Author URI: https://torounit.com
* License: GPL2 or Later
* License URI: https://www.gnu.org/licenses/gpl-2.0.html
* Text Domain: enable-marker-color
* Requires at least: 6.4
* Requires PHP: 8.0
*
* @package EnableMarkerColor
*/
namespace EnableMarkerColor;
if ( ! defined( 'ABSPATH' ) ) {
exit;
}
/**
* Plugin main class.
*/
class Plugin {
const ASSET_HANDLE = 'enable-marker-color';
const TEXT_DOMAIN = 'enable-marker-color';
/**
* Constructor.
*/
public function __construct() {
add_action( 'init', array( $this, 'register_assets' ), 100 );
add_action( 'enqueue_block_assets', array( $this, 'enqueue_block_assets' ) );
add_action( 'enqueue_block_editor_assets', array( $this, 'enqueue_block_editor_assets' ) );
}
/**
* Register assets.
*
* @return void
*/
public function register_assets(): void {
wp_set_script_translations(
self::ASSET_HANDLE,
self::TEXT_DOMAIN,
);
//phpcs:ignore WordPress.WP.EnqueuedResourceParameters.MissingVersion
wp_register_style( self::ASSET_HANDLE, false );
wp_add_inline_style( self::ASSET_HANDLE, $this->get_inline_styles() );
if ( file_exists( plugin_dir_path( __FILE__ ) . 'build/index.asset.php' ) ) {
$asset = include plugin_dir_path( __FILE__ ) . 'build/index.asset.php';
wp_register_script(
self::ASSET_HANDLE,
plugin_dir_url( __FILE__ ) . 'build/index.js',
$asset['dependencies'],
$asset['version'],
array(
'in_footer' => true,
)
);
}
wp_set_script_translations( self::ASSET_HANDLE, self::TEXT_DOMAIN );
}
/**
* Get CSS.
*
* @return string
*/
private function get_inline_styles(): string {
$colors = $this->get_colors();
$css = '';
foreach ( $colors as $color ) {
$selector = ".has-{$color['slug']}-marker-color";
$css .= <<<CSS
{$selector} li::marker {
color: {$color['color']};
}
CSS;
}
return $css;
}
/**
* Get colors.
*
* @return array{name: string, slug: string, color: string}
*/
public function get_colors(): array {
$tree = \WP_Theme_JSON_Resolver::get_merged_data();
$palette = $tree->get_settings()['color']['palette'];
if ( $tree->get_settings()['color']['defaultPalette'] ) {
$colors = array_merge( $palette['default'], $palette['theme'] );
} else {
$colors = $palette['theme'];
}
if ( ! empty( $palette['custom'] ) ) {
$colors = array_merge( $colors, $palette['custom'] );
}
return $colors;
}
/**
* Enqueue assets.
*/
public function enqueue_block_assets(): void {
wp_enqueue_style( self::ASSET_HANDLE );
}
/**
* Enqueue block editor assets.
*/
public function enqueue_block_editor_assets(): void {
wp_enqueue_style( self::ASSET_HANDLE );
wp_enqueue_script( self::ASSET_HANDLE );
}
}
new Plugin();