forked from 10up/retro-winamp-block
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathretro-webamp-block.php
144 lines (131 loc) · 3.58 KB
/
retro-webamp-block.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
135
136
137
138
139
140
141
142
143
144
<?php
/**
* Plugin Name: Retro Winamp Block
* Plugin URI: https://wordpress.org/plugins/retro-winamp-block/
* Description: A Winamp-styled audio block for all your retro music player needs.
* Version: 1.3.1
* Requires at least: 6.3
* Requires PHP: 7.4
* Author: 10up
* Author URI: https://10up.com
* License: GPL v2 or later
* License URI: https://www.gnu.org/licenses/gpl-2.0.html
* Text Domain: winamp-block
*
* @package tenup\Winamp_Block
*/
namespace RetroWinampBlock;
/**
* Get the minimum version of PHP required by this plugin.
*
* @since 1.3.1
*
* @return string Minimum version required.
*/
function minimum_php_requirement() {
return '7.4';
}
/**
* Whether PHP installation meets the minimum requirements
*
* @since 1.3.1
*
* @return bool True if meets minimum requirements, false otherwise.
*/
function site_meets_php_requirements() {
return version_compare( phpversion(), minimum_php_requirement(), '>=' );
}
// Try to load the plugin files, ensuring our PHP version is met first.
if ( ! site_meets_php_requirements() ) {
add_action(
'admin_notices',
function() {
?>
<div class="notice notice-error">
<p>
<?php
echo wp_kses_post(
sprintf(
/* translators: %s: Minimum required PHP version */
__( 'Retro Winamp Block requires PHP version %s or later. Please upgrade PHP or disable the plugin.', 'retro-winamp-block' ),
esc_html( minimum_php_requirement() )
)
);
?>
</p>
</div>
<?php
}
);
return;
}
/**
* Registers the block using the metadata loaded from the `block.json` file.
* Behind the scenes, it registers also all assets so they can be enqueued
* through the block editor in the corresponding context.
*
* @see https://developer.wordpress.org/block-editor/tutorials/block-tutorial/writing-your-first-block-type/
*/
add_action(
'init',
function () {
register_block_type(
__DIR__,
array(
'render_callback' => function( $attributes = array(), $content = '' ) {
// Replace src with data-src to avoid loading the file.
return str_replace( 'src="', 'data-src="', $content );
},
)
);
}
);
/**
* Register our script.
*/
add_action(
'wp_enqueue_scripts',
function () {
$asset_file = include plugin_dir_path( __FILE__ ) . 'build/frontend.asset.php';
wp_register_script(
'winamp-block-frontend',
plugins_url( 'build/frontend.js', __FILE__ ),
$asset_file['dependencies'],
$asset_file['version'],
true
);
}
);
add_filter(
'render_block',
function ( $block_content, $block, $instance ) {
if ( 'core/audio' !== $block['blockName'] ) {
return $block_content;
}
$attributes = isset( $block['attrs'] ) ? $block['attrs'] : array();
$attachment_id = isset( $attributes['id'] ) ? $attributes['id'] : 0;
$attachment = get_post( $attachment_id );
// Stop here if $attachment can't be found.
if ( ! $attachment ) {
return $block_content;
}
$metadata = wp_get_attachment_metadata( $attachment_id );
$artist = isset( $metadata['artist'] ) ? $metadata['artist'] : '';
$title = isset( $metadata['title'] ) ? $metadata['title'] : '';
$new_props = array(
'artist' => $artist,
'title' => $title,
);
$new_attributes = array_reduce(
array_keys( $new_props ),
function ( $carry, $key ) use ( $new_props ) {
$value = $new_props[ $key ];
// Only return set values.
return empty( $value ) ? $carry : "$carry data-$key=\"$value\"";
}
);
return str_replace( '<audio ', "<audio $new_attributes ", $block_content );
},
100,
3
);