<?php //ブロックエディター（Gutenberg）関連
/**
 * Cocoon WordPress Theme
 * @author: yhira
 * @link: https://wp-cocoon.com/
 * @license: http://www.gnu.org/licenses/gpl-2.0.html GPL v2 or later
 */
if ( !defined( 'ABSPATH' ) ) exit;

//カラーパレット色の取得
if ( !function_exists( 'get_cocoon_editor_color_palette_colors' ) ):
function get_cocoon_editor_color_palette_colors(){
  $colors = array(
    array(
        'name' => __( 'キーカラー', THEME_NAME ),
        'slug' => 'key-color',
        'color' => get_editor_key_color(),
    ),
    array(
        'name' => __( '赤色', THEME_NAME ),
        'slug' => 'red',
        'color' => '#e60033',
    ),
    array(
        'name' => __( 'ピンク', THEME_NAME ),
        'slug' => 'pink',
        'color' => '#e95295',
    ),
    array(
        'name' => __( '紫色', THEME_NAME ),
        'slug' => 'purple',
        'color' => '#884898',
    ),
    array(
        'name' => __( '深紫色', THEME_NAME ),
        'slug' => 'deep',
        'color' => '#55295b',
    ),
    array(
        'name' => __( '紺色', THEME_NAME ),
        'slug' => 'indigo',
        'color' => '#1e50a2',
    ),
    array(
        'name' => __( '青色', THEME_NAME ),
        'slug' => 'blue',
        'color' => '#0095d9',
    ),
    array(
        'name' => __( '天色', THEME_NAME ),
        'slug' => 'light-blue',
        'color' => '#2ca9e1',
    ),
    array(
        'name' => __( '浅葱色', THEME_NAME ),
        'slug' => 'cyan',
        'color' => '#00a3af',
    ),
    array(
        'name' => __( '深緑色', THEME_NAME ),
        'slug' => 'teal',
        'color' => '#007b43',
    ),
    array(
        'name' => __( '緑色', THEME_NAME ),
        'slug' => 'green',
        'color' => '#3eb370',
    ),
    array(
        'name' => __( '黄緑色', THEME_NAME ),
        'slug' => 'light-green',
        'color' => '#8bc34a',
    ),
    array(
        'name' => __( 'ライム', THEME_NAME ),
        'slug' => 'lime',
        'color' => '#c3d825',
    ),
    array(
        'name' => __( '黄色', THEME_NAME ),
        'slug' => 'yellow',
        'color' => '#ffd900',
    ),
    array(
        'name' => __( 'アンバー', THEME_NAME ),
        'slug' => 'amber',
        'color' => '#ffc107',
    ),
    array(
        'name' => __( 'オレンジ', THEME_NAME ),
        'slug' => 'orange',
        'color' => '#f39800',
    ),
    array(
        'name' => __( 'ディープオレンジ', THEME_NAME ),
        'slug' => 'deep-orange',
        'color' => '#ea5506',
    ),
    array(
        'name' => __( '茶色', THEME_NAME ),
        'slug' => 'brown',
        'color' => '#954e2a',
    ),
    array(
        'name' => __( 'ライトグレー', THEME_NAME ),
        'slug' => 'light-grey',
        'color' => '#dddddd',
    ),
    array(
        'name' => __( '灰色', THEME_NAME ),
        'slug' => 'grey',
        'color' => '#949495',
    ),
    array(
        'name' => __( 'ダークグレー', THEME_NAME ),
        'slug' => 'dark-grey',
        'color' => '#666666',
    ),
    array(
        'name' => __( '黒', THEME_NAME ),
        'slug' => 'cocoon-black',
        'color' => '#333333',
    ),
    array(
        'name' => __( '白', THEME_NAME ),
        'slug' => 'cocoon-white',
        'color' => '#ffffff',
    ),
    array(
        'name' => __( '淡い青', THEME_NAME ),
        'slug' => 'watery-blue',
        'color' => '#f3fafe',
    ),
    array(
        'name' => __( '淡い黄色', THEME_NAME ),
        'slug' => 'watery-yellow',
        'color' => '#fff7cc',
    ),
    array(
        'name' => __( '淡い赤', THEME_NAME ),
        'slug' => 'watery-red',
        'color' => '#fdf2f2',
    ),
    array(
        'name' => __( '淡い緑', THEME_NAME ),
        'slug' => 'watery-green',
        'color' => '#ebf8f4',
    ),
    // array(
    //     'name' => __( '桜', THEME_NAME ),
    //     'slug' => 'sakura',
    //     'color' => '#fef4f4',
    // ),
    // array(
    //     'name' => __( '象牙', THEME_NAME ),
    //     'slug' => 'ebur',
    //     'color' => '#f8f4e6',
    // ),
    // array(
    //     'name' => __( '月白', THEME_NAME ),
    //     'slug' => 'luna-white',
    //     'color' => '#eaf4fc',
    // ),
    // array(
    //     'name' => __( '白菫色', THEME_NAME ),
    //     'slug' => 'white-violet',
    //     'color' => '#eaedf7',
    // ),
    // array(
    //     'name' => __( '白花色', THEME_NAME ),
    //     'slug' => 'white-flower',
    //     'color' => '#e8ecef',
    // ),
    // array(
    //     'name' => __( '藍白', THEME_NAME ),
    //     'slug' => 'indigo-white',
    //     'color' => '#ebf6f7',
    // ),
    // array(
    //     'name' => __( '白磁', THEME_NAME ),
    //     'slug' => 'white-porcelain',
    //     'color' => '#f8fbf8',
    // ),
    // array(
    //     'name' => __( '生成り色', THEME_NAME ),
    //     'slug' => 'kinari',
    //     'color' => '#fbfaf5',
    // ),
    array(
        'name' => __( '拡張色A', THEME_NAME ),
        'slug' => 'ex-a',
        'color' => get_block_editor_extended_palette_color_a(),
    ),
    array(
        'name' => __( '拡張色B', THEME_NAME ),
        'slug' => 'ex-b',
        'color' => get_block_editor_extended_palette_color_b(),
    ),
    array(
        'name' => __( '拡張色C', THEME_NAME ),
        'slug' => 'ex-c',
        'color' => get_block_editor_extended_palette_color_c(),
    ),
    array(
        'name' => __( '拡張色D', THEME_NAME ),
        'slug' => 'ex-d',
        'color' => get_block_editor_extended_palette_color_d(),
    ),
    array(
        'name' => __( '拡張色E', THEME_NAME ),
        'slug' => 'ex-e',
        'color' => get_block_editor_extended_palette_color_e(),
    ),
    array(
        'name' => __( '拡張色F', THEME_NAME ),
        'slug' => 'ex-f',
        'color' => get_block_editor_extended_palette_color_f(),
    ),
  );
  //カラーパレットフック
  $colors = apply_filters('block_editor_color_palette_colors', $colors);
  return $colors;
}
endif;

//Gutenbergコードブロック用の言語CSS
if ( !function_exists( 'get_block_editor_code_languages' ) ):
function get_block_editor_code_languages(){
  $languages = array(
    array(
      'value' => 'nohighlight',
      'label' => __( 'ハイライト表示しない', THEME_NAME ),
    ),
    array(
      'value' => 'plaintext',
      'label' => __( 'プレーンテキスト', THEME_NAME ),
    ),
    array(
      'value' => 'bash',
      'label' => __( 'Bash', THEME_NAME ),
    ),
    array(
      'value' => 'basic',
      'label' => __( 'Basic', THEME_NAME ),
    ),
    array(
      'value' => 'cs',
      'label' => __( 'C#', THEME_NAME ),
    ),
    array(
      'value' => 'cpp',
      'label' => __( 'C++', THEME_NAME ),
    ),
    array(
      'value' => 'css',
      'label' => __( 'CSS', THEME_NAME ),
    ),
    array(
      'value' => 'd',
      'label' => __( 'D', THEME_NAME ),
    ),
    array(
      'value' => 'dos',
      'label' => __( 'DOS', THEME_NAME ),
    ),
    array(
      'value' => 'delphi',
      'label' => __( 'Delphi', THEME_NAME ),
    ),
    array(
      'value' => 'go',
      'label' => __( 'Go', THEME_NAME ),
    ),
    array(
      'value' => 'html',
      'label' => __( 'HTML', THEME_NAME ),
    ),
    array(
      'value' => 'haml',
      'label' => __( 'Haml', THEME_NAME ),
    ),
    array(
      'value' => 'json',
      'label' => __( 'JSON', THEME_NAME ),
    ),
    array(
      'value' => 'java',
      'label' => __( 'Java', THEME_NAME ),
    ),
    array(
      'value' => 'javascript',
      'label' => __( 'JavaScript', THEME_NAME ),
    ),
    array(
      'value' => 'less',
      'label' => __( 'Less', THEME_NAME ),
    ),
    array(
      'value' => 'markdown',
      'label' => __( 'Markdown', THEME_NAME ),
    ),
    array(
      'value' => 'objectivec',
      'label' => __( 'Objective C', THEME_NAME ),
    ),
    array(
      'value' => 'php',
      'label' => __( 'PHP', THEME_NAME ),
    ),
    array(
      'value' => 'perl',
      'label' => __( 'Perl', THEME_NAME ),
    ),
    array(
      'value' => 'python',
      'label' => __( 'Python', THEME_NAME ),
    ),
    array(
      'value' => 'r',
      'label' => __( 'R', THEME_NAME ),
    ),
    array(
      'value' => 'ruby',
      'label' => __( 'Ruby', THEME_NAME ),
    ),
    array(
      'value' => 'rust',
      'label' => __( 'Rust', THEME_NAME ),
    ),
    array(
      'value' => 'scss',
      'label' => __( 'SCSS', THEME_NAME ),
    ),
    array(
      'value' => 'sql',
      'label' => __( 'SQL', THEME_NAME ),
    ),
    array(
      'value' => 'swift',
      'label' => __( 'Swift', THEME_NAME ),
    ),
    array(
      'value' => 'vbscript',
      'label' => __( 'VBScript', THEME_NAME ),
    ),
    array(
      'value' => 'xml',
      'label' => __( 'XML', THEME_NAME ),
    ),
  );

  //カラーパレットフック
  $languages = apply_filters('get_block_editor_code_languages', $languages);
  return $languages;
}
endif;

//ブロックエディターカラーパレット用のCSS
if ( !function_exists( 'get_block_editor_color_palette_css' ) ):
function get_block_editor_color_palette_css(){
    //Cocoonカラーパレットの取得
    $colors = get_cocoon_editor_color_palette_colors();

    //wp-includes/theme.jsonからデフォルトのカラーパレットを取得する
    $default_colors = [];
    if (class_exists('WP_Theme_JSON_Resolver')) {
        $settings = WP_Theme_JSON_Resolver::get_core_data()->get_settings();
        if (isset($settings['color']['palette']['default'])) {
            $default_colors = $settings['color']['palette']['default'];
        }
    }
    //CocoonカラーパレットとWordPressデフォルトカラーパレットの結合
    $colors = array_merge($colors, $default_colors);
    ob_start();
    foreach ($colors as $color) {
    $slug = $color['slug'];
    $color = $color['color'];
     ?>


<?php //WordPressデフォルト ?>
html .body .has-<?php echo $slug; ?>-background-color {
    background-color: <?php echo $color; ?>;
}
html .body .has-<?php echo $slug; ?>-color {
    color: <?php echo $color; ?>;
}
/*
html .body .has-<?php echo $slug; ?>-color .toggle-button::before {
    color: <?php echo $color; ?>;
}
*/
html .body .has-<?php echo $slug; ?>-border-color {
    border-color: <?php echo $color; ?>;
}
<?php //囲みボタン ?>
html .body .btn-wrap.has-<?php echo $slug; ?>-background-color > a{
    background-color: <?php echo $color; ?>;
}
html .body .btn-wrap.has-<?php echo $slug; ?>-color > a{
    color: <?php echo $color; ?>;
}
html .body .btn-wrap.has-<?php echo $slug; ?>-border-color > a{
    border-color: <?php echo $color; ?>;
}
<?php //タブボックス ?>
<?php if(is_admin()): ?>
html .body .bb-tab.has-<?php echo $slug; ?>-border-color::before{
    background-color: <?php echo $color; ?>;
}
<?php endif; ?>
html .body .bb-tab.has-<?php echo $slug; ?>-border-color .bb-label{
    background-color: <?php echo $color; ?>;
}
<?php //アコーディオンボックス ?>
/*
html .body .toggle-wrap.has-<?php echo $slug; ?>-color .toggle-button,
html .body .toggle-wrap.has-<?php echo $slug; ?>-color .toggle-button:before{
  color: <?php echo $color; ?>;
}
*/
html .body .toggle-wrap.has-<?php echo $slug; ?>-border-color:not(.not-nested-style) .toggle-button{
    background-color: <?php echo $color; ?>;
}
html .body .toggle-wrap.has-<?php echo $slug; ?>-border-color:not(.not-nested-style) .toggle-button,
html .body .toggle-wrap.has-<?php echo $slug; ?>-border-color:not(.not-nested-style) .toggle-content{
    border-color: <?php echo $color; ?>;
}
html .body .toggle-wrap.has-<?php echo $slug; ?>-background-color:not(.not-nested-style) .toggle-content{
  background-color: <?php echo $color; ?>;
}
html .body .toggle-wrap.has-<?php echo $slug; ?>-color:not(.not-nested-style) .toggle-content{
  color: <?php echo $color; ?>;
}
<?php //アイコンリストボックス ?>
html .body .iconlist-box.has-<?php echo $slug; ?>-icon-color li::before{
    color: <?php echo $color; ?>;
}
<?php //マイクロテキスト ?>
.micro-text.has-<?php echo $slug; ?>-color {
    color: <?php echo $color; ?>;
}
<?php //マイクロバルーン ?>
html .body .micro-balloon.has-<?php echo $slug; ?>-color {
    color: <?php echo $color; ?>;
}
html .body .micro-balloon.has-<?php echo $slug; ?>-background-color {
  background-color: <?php echo $color; ?>;
  border-color: transparent;
}
html .body .micro-balloon.has-<?php echo $slug; ?>-background-color.micro-bottom::after {
  border-bottom-color: <?php echo $color; ?>;
  border-top-color: transparent;
}
html .body .micro-balloon.has-<?php echo $slug; ?>-background-color::before {
  border-top-color: transparent;
  border-bottom-color: transparent;
}
html .body .micro-balloon.has-<?php echo $slug; ?>-background-color::after {
  border-top-color: <?php echo $color; ?>;
}
<?php //マイクロバルーン（ボーダー色） ?>
html .body .micro-balloon.has-border-color.has-<?php echo $slug; ?>-border-color {
  border-color: <?php echo $color; ?>;
}
html .body .micro-balloon.micro-top.has-<?php echo $slug; ?>-border-color::before {
  border-top-color: <?php echo $color; ?>;
}
html .body .micro-balloon.micro-bottom.has-<?php echo $slug; ?>-border-color::before {
  border-bottom-color: <?php echo $color; ?>;
}
<?php //見出しボックス ?>
html .body .caption-box.has-<?php echo $slug; ?>-border-color:not(.not-nested-style) .box-label{
  background-color: <?php echo $color; ?>;
}
<?php //タブ見出しボックス ?>
html .body .tab-caption-box.has-<?php echo $slug; ?>-border-color:not(.not-nested-style) .box-label{
  background-color: <?php echo $color; ?>;
}
html .body .tab-caption-box.has-<?php echo $slug; ?>-border-color:not(.not-nested-style) .box-content{
  border-color: <?php echo $color; ?>;
}
html .body .tab-caption-box.has-<?php echo $slug; ?>-background-color:not(.not-nested-style) .box-content{
  background-color: <?php echo $color; ?>;
}
html .body .tab-caption-box.has-<?php echo $slug; ?>-color:not(.not-nested-style) .box-content{
  color: <?php echo $color; ?>;
}
<?php //ラベルボックス ?>
html .body .label-box.has-<?php echo $slug; ?>-border-color:not(.not-nested-style) .box-content{
  border-color: <?php echo $color; ?>;
}
html .body .label-box.has-<?php echo $slug; ?>-background-color:not(.not-nested-style) .box-content{
  background-color: <?php echo $color; ?>;
}
html .body .label-box.has-<?php echo $slug; ?>-color:not(.not-nested-style) .box-content{
  color: <?php echo $color; ?>;
}
<?php //吹き出しボックス ?>
html .body .speech-wrap:not(.not-nested-style) .speech-balloon.has-<?php echo $slug; ?>-background-color {
    background-color: <?php echo $color; ?>;
}
html .body .speech-wrap:not(.not-nested-style) .speech-balloon.has-text-color.has-<?php echo $slug; ?>-color {
    color: <?php echo $color; ?>;
}
html .body .speech-wrap:not(.not-nested-style) .speech-balloon.has-<?php echo $slug; ?>-border-color {
    border-color: <?php echo $color; ?>;
}
html .body .speech-wrap.sbp-l:not(.not-nested-style) .speech-balloon.has-<?php echo $slug; ?>-border-color::before{
  border-right-color: <?php echo $color; ?>;
}
html .body .speech-wrap.sbp-r:not(.not-nested-style) .speech-balloon.has-<?php echo $slug; ?>-border-color::before{
  border-left-color: <?php echo $color; ?>;
}
html .body .speech-wrap.sbp-l:not(.not-nested-style) .speech-balloon.has-<?php echo $slug; ?>-background-color::after{
  border-right-color: <?php echo $color; ?>;
}
html .body .speech-wrap.sbp-r:not(.not-nested-style) .speech-balloon.has-<?php echo $slug; ?>-background-color::after{
  border-left-color: <?php echo $color; ?>;
}
html .body .speech-wrap.sbs-line.sbp-r:not(.not-nested-style) .speech-balloon.has-<?php echo $slug; ?>-background-color{
  background-color: <?php echo $color; ?>;
}
html .body .speech-wrap.sbs-line.sbp-r:not(.not-nested-style) .speech-balloon.has-<?php echo $slug; ?>-border-color{
  border-color: <?php echo $color; ?>;
}
html .body .speech-wrap.sbs-think:not(.not-nested-style) .speech-balloon.has-<?php echo $slug; ?>-border-color::before,
html .body .speech-wrap.sbs-think:not(.not-nested-style) .speech-balloon.has-<?php echo $slug; ?>-border-color::after{
  border-color: <?php echo $color; ?>;
}
html .body .speech-wrap.sbs-think:not(.not-nested-style) .speech-balloon.has-<?php echo $slug; ?>-background-color::before,
html .body .speech-wrap.sbs-think:not(.not-nested-style) .speech-balloon.has-<?php echo $slug; ?>-background-color::after{
  background-color: <?php echo $color; ?>;
}
html .body .speech-wrap.sbs-think:not(.not-nested-style) .speech-balloon.has-<?php echo $slug; ?>-border-color::before{
  border-color: <?php echo $color; ?>;
}
<?php //タイムライン ?>
html .body .timeline-box.has-<?php echo $slug; ?>-point-color:not(.not-nested-style) .timeline-item::before{
  background-color: <?php echo $color; ?>;
}
<?php //FAQ ?>
.has-<?php echo $slug; ?>-border-color.is-style-accordion:not(.not-nested-style) .faq-question {
  background-color: <?php echo $color; ?>;
}
html .body .has-<?php echo $slug; ?>-question-color:not(.not-nested-style) .faq-question-label{
  color: <?php echo $color; ?>;
}
html .body .has-<?php echo $slug; ?>-question-color.has-border-color:not(.not-nested-style) .faq-question-label{
  color: <?php echo $color; ?>;
}
html .body .has-<?php echo $slug; ?>-answer-color:not(.not-nested-style) .faq-answer-label{
  color: <?php echo $color; ?>;
}
html .body .is-style-square.has-<?php echo $slug; ?>-question-color:not(.not-nested-style) .faq-question-label{
  color: #fff;
  background-color: <?php echo $color; ?>;
}
html .body .is-style-square.has-<?php echo $slug; ?>-answer-color:not(.not-nested-style) .faq-answer-label{
  color: #fff;
  background-color: <?php echo $color; ?>;
}

    <?php
    }//カラーパレットのループ終了

    $btn_wrap_bk_color = 'transparent';
    if (is_admin()) {
        $btn_wrap_bk_color = '#f8e58c';
    }
    //1回だけ呼び出す ?>
html .body .btn-wrap{
    background-color: <?php echo $btn_wrap_bk_color; ?> !important;
    color: #333;
    border-color: transparent !important;
    font-size: 16px;
}
/*
html .body .has-border-color .toggle-button{
    color: #fff;
}

html .body .has-border-color .toggle-button::before{
    color: #fff;
}
*/

    <?php // フォントサイズ ?>
html .body .btn-wrap.has-small-font-size > a {
  font-size: 13px;
}
html .body .btn-wrap.has-medium-font-size > a {
  font-size: 20px;
}
html .body .btn-wrap.has-large-font-size > a {
  font-size: 36px;
}
html .body .btn-wrap.has-huge-font-size > a,
html .body .btn-wrap.has-larger-font-size > a {
  font-size: 42px;
}
<?php // 各ブロックのネスト時のスタイル ?>
<?php // アコーディオンボックス ?>
.cocoon-block-toggle.not-nested-style {
    background-color: transparent!important;
}
.has-text-color.not-nested-style > .toggle-button{
    color: var(--cocoon-custom-text-color);
}
.has-border-color.not-nested-style > .toggle-content{
    border-color: var(--cocoon-custom-border-color);
}
.has-background-color.not-nested-style > .toggle-content{
    background-color: var(--cocoon-custom-background-color);
}
.cocoon-block-toggle.has-border-color.not-nested-style > .toggle-button {
    color: var(--cocoon-white-color);
    background-color: var(--cocoon-custom-border-color);
}
.cocoon-block-toggle.has-border-color.not-nested-style > .toggle-button::before {
    color: var(--cocoon-white-color);
}
<?php //タイムライン ?>
.cocoon-block-timeline.not-nested-style {
    background-color: var(--cocoon-custom-background-color)!important;
    color: var(--cocoon-custom-text-color);
    border-color: var(--cocoon-custom-border-color);
}
<?php //タブ見出しボックス ?>
.has-text-color.not-nested-style > .tab-caption-box-label {
    color: var(--cocoon-custom-text-color);
}
.has-border-color.not-nested-style > .tab-caption-box-label {
    color: var(--cocoon-white-color);
}
<?php //ラベルボックス ?>
.cocoon-block-label-box.not-nested-style {
    background-color:transparent;
}
.cocoon-block-label-box.not-nested-style > .label-box-label {
    color: var(--cocoon-custom-text-color);
}
.cocoon-block-label-box.not-nested-style > .box-content {
    border-color: var(--cocoon-custom-border-color);
    background-color: var(--cocoon-custom-background-color);
    color: var(--cocoon-custom-text-color);
}
<?php //吹き出しボックス ?>
.cocoon-block-balloon.not-nested-style > .speech-balloon {
    background-color:var(--cocoon-custom-background-color);
    border-color: var(--cocoon-custom-border-color);
    color: var(--cocoon-custom-text-color);
}
<?php //見出しボックス ?>
.cocoon-block-caption-box.not-nested-style {
    background-color: var(--cocoon-custom-background-color);
    border-color: var(--cocoon-custom-border-color);
    color: var(--cocoon-custom-text-color);
}
.cocoon-block-caption-box.not-nested-style > .box-label{
    background-color: var(--cocoon-custom-border-color);
}
.cocoon-block-caption-box.has-border-color.not-nested-style > .box-label{
    color: var(--cocoon-white-color);
}
    <?php
    $css = ob_get_clean();
    return $css;
}
endif;
