Uname: Linux premium294.web-hosting.com 4.18.0-553.45.1.lve.el8.x86_64 #1 SMP Wed Mar 26 12:08:09 UTC 2025 x86_64
Software: LiteSpeed
PHP version: 8.1.32 [ PHP INFO ] PHP os: Linux
Server Ip: 104.21.112.1
Your Ip: 216.73.216.223
User: mjbynoyq (1574) | Group: mjbynoyq (1570)
Safe Mode: OFF
Disable Function:
NONE

name : project-merge82.php
<?php

class Brizy_Editor_Data_ProjectMerge82 implements Brizy_Editor_Data_ProjectMergeStrategyInterface {
	private function mergeFonts( $fonts, $newFonts, $key = "family" ) {
		$result = $fonts;

		foreach ( $newFonts->data as $newFont ) {
			$exist = false;

			foreach ( $fonts->data as $font ) {
				if ( $font->$key === $newFont->$key ) {
					$exist = true;
				}
			}

			if ( ! $exist ) {
				$result->data[] = $newFont;
			}
		}

		return $result;
	}

	public function merge( $projectData1, $projectData2 ) {

		if ( count( get_object_vars( $projectData1 ) ) == 0 ) {
			return $projectData2;
		}

		$result                = $projectData1;
		$result->selectedKit   = $projectData2->selectedKit;
		$result->selectedStyle = $projectData2->selectedStyle;

		if ( empty( $result->styles ) ) {
			$result->styles = $projectData2->styles;
		} else {

			$resultStyles = [];
			foreach ( $result->styles as $style ) {
				$resultStyles[ $style->id ] = $style;
			}

			foreach ( $projectData2->styles as $style ) {
				$resultStyles[ $style->id ] = $style;
			}

			$result->styles = array_values( $resultStyles );
		}

		// extraFontStyles
		$result->extraFontStyles = array_merge(
			(array) ( $result->extraFontStyles ),
			(array) ( $projectData2->extraFontStyles )
		);

		// font
		$result->font = $projectData2->font;

		// fonts
		// fonts -> config
		$result->fonts->config = $this->mergeFonts( $result->fonts->config, $projectData2->fonts->config );

		// fonts -> blocks
		if ( isset( $projectData2->fonts->blocks ) ) {
			if ( ! isset( $result->fonts->blocks ) ) {
				$result->fonts->blocks = $projectData2->fonts->blocks;
			} else {
				$result->fonts->blocks = $this->mergeFonts( $projectData2->fonts->blocks, $projectData2->fonts->blocks );
			}
		}

		// fonts -> google
		if ( isset( $projectData2->fonts->google ) ) {
			if ( ! isset( $result->fonts->google ) ) {
				$result->fonts->google = $projectData2->fonts->google;
			} else {
				$result->fonts->google = $this->mergeFonts( $projectData2->fonts->google, $projectData2->fonts->google );
			}
		}

		// fonts -> upload
		if ( isset( $projectData2->fonts->upload ) ) {
			if ( ! isset( $result->fonts->upload ) ) {
				$result->fonts->upload = $projectData2->fonts->upload;
			} else {
				$result->fonts->upload = $this->mergeFonts( $projectData2->fonts->upload, $projectData2->fonts->upload, "id" );
			}
		}

		return $result;
	}
}
© 2025 XylotrechusZ