<?php
/**
 * Class Trimming
 *
 * @link      https://github.com/googleforcreators/web-stories-wp
 *
 * @copyright 2021 Google LLC
 * @license   https://www.apache.org/licenses/LICENSE-2.0 Apache License 2.0
 */

/**
 * Copyright 2021 Google LLC
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     https://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

declare(strict_types = 1);

namespace Google\Web_Stories\Media\Video;

use Google\Web_Stories\Infrastructure\HasMeta;
use Google\Web_Stories\Infrastructure\PluginUninstallAware;
use Google\Web_Stories\Service_Base;

/**
 * Class Trimming
 */
class Trimming extends Service_Base implements HasMeta, PluginUninstallAware {

	/**
	 * The trim video post meta key.
	 */
	public const TRIM_POST_META_KEY = 'web_stories_trim_data';

	/**
	 * Is trim.
	 */
	public const TRIM_DATA_KEY = 'trim_data';

	/**
	 * Register.
	 *
	 * @since 1.12.0
	 */
	public function register(): void {
		$this->register_meta();

		add_filter( 'wp_prepare_attachment_for_js', [ $this, 'wp_prepare_attachment_for_js' ] );
	}

	/**
	 * Register meta for attachment post type.
	 *
	 * @since 1.12.0
	 */
	public function register_meta(): void {
		register_meta(
			'post',
			self::TRIM_POST_META_KEY,
			[
				'type'           => 'object',
				'description'    => __( 'Video trim data.', 'web-stories' ),
				'show_in_rest'   => [
					'schema' => [
						'properties' => [
							'original' => [
								'description' => __( 'Original attachment id', 'web-stories' ),
								'type'        => 'integer',
							],
							'start'    => [
								'description' => __( 'Start time.', 'web-stories' ),
								'type'        => 'string',
							],
							'end'      => [
								'description' => __( 'End time.', 'web-stories' ),
								'type'        => 'string',
							],
						],
					],
				],
				'default'        => [
					'original' => 0,
				],
				'single'         => true,
				'object_subtype' => 'attachment',
			]
		);
	}

	/**
	 * Filters the attachment data prepared for JavaScript.
	 *
	 * @since 1.12.0
	 *
	 * @param array|mixed $response Array of prepared attachment data.
	 * @return array|mixed Response data.
	 *
	 * @template T
	 *
	 * @phpstan-return ($response is array<T> ? array<T> : mixed)
	 */
	public function wp_prepare_attachment_for_js( $response ) {
		if ( ! \is_array( $response ) ) {
			return $response;
		}
		if ( 'video' === $response['type'] ) {
			/**
			 * Post ID.
			 *
			 * @var int $post_id
			 */
			$post_id = $response['id'];

			$response[ self::TRIM_DATA_KEY ] = get_post_meta( $post_id, self::TRIM_POST_META_KEY, true );
		}

		return $response;
	}

	/**
	 * Act on plugin uninstall.
	 *
	 * @since 1.26.0
	 */
	public function on_plugin_uninstall(): void {
		delete_post_meta_by_key( self::TRIM_POST_META_KEY );
	}
}