HEX
Server: nginx/1.24.0
System: Linux server 6.12.74+deb13+1-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.12.74-2 (2026-03-08) x86_64
User: www (1001)
PHP: 8.5.2
Disabled: passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
Upload Files
File: /www/wwwroot/claudiayancor.duckdns.org/wp-content/plugins/photonic/Options/Google.php
<?php

namespace Photonic_Plugin\Options;

use Photonic_Plugin\Core\Utilities;

class Google extends Option_Tab {
	private static $instance;

	private function __construct() {
		$this->options = [
			[
				'name'     => 'Google Photos settings',
				'desc'     => 'Control settings for Google Photos',
				'category' => 'google-settings',
				'type'     => 'section',
			],

			/*
			['name' => 'Use own Google Client ID?',
					'desc' => "Photonic can perform authentication with its own Client ID. Select this option if you want to use your own Client ID instead.
						Creating a Google Client ID can take at least 15-30 minutes, but can save you from potential API quota issues if too many people start using Photonic's ID.
						<strong>Note that if you have already defined a Client ID and Secret below they will be used regardless of this option.</strong>
						",
					'id' => 'google_google_use_own_keys',
					'grouping' => 'google-settings',
					'type' => 'checkbox'],
			*/

			[
				'name'     => 'Google Client ID',
				'desc'     => "Enter your Google Client ID. You can get / create one from Google's <a href='https://console.developers.google.com/apis/'>API Manager</a>.
			The <a href='https://aquoid.com/plugins/photonic/google-photos/#api-key'>documentation page</a> can help you with further instructions.
			If you have previously obtained a Client ID for Picasa you can use that here, provided you follow the additional instructions in the documentation.
			<ol>
				<li>Use the option for 'OAuth Client ID', and subsequently pick 'Web applications'.</li>
				<li>Make sure that you add these as your Redirect URIs:
					<ol>
						<li>" . site_url() . "</li>
						<li>" . esc_url(admin_url('admin.php?page=photonic-auth&source=google')) . "</li>
					</ol>
				<strong>Without the above your authentication will not work.</strong>
				</li>
			</ol>",
				'id'       => 'google_client_id',
				'grouping' => 'google-settings',
				'type'     => 'text'
			],

			[
				'name'     => 'Google Client Secret',
				'desc'     => "Enter your Google Client Secret.",
				'id'       => 'google_client_secret',
				'grouping' => 'google-settings',
				'type'     => 'text'
			],

			[
				'name'     => 'Refresh Token (for Back-end / Server-side Authentication)',
				'desc'     => "To access any content in Google Photos you need to get a token. To get your token go to
			<em>Photonic &rarr; Authentication &rarr; Google Photos &rarr; Google Photos Refresh Token Getter</em>, and authenticate.",
				'id'       => 'google_refresh_token',
				'grouping' => 'google-settings',
				'type'     => 'text'
			],

			[
				'name'     => 'Media to show',
				'desc'     => 'You can choose to include photos as well as videos in your output. This can be overridden by the <code>media</code> parameter in the shortcode:',
				'id'       => 'google_media',
				'grouping' => 'google-settings',
				'type'     => 'select',
				'options'  => Utilities::media_options()
			],

			[
				'name'     => "Hide Photo Count in Album Title Display",
				'desc'     => "This will hide the number of photos in your Album's title.",
				'id'       => 'google_hide_album_photo_count_display',
				'grouping' => 'google-settings',
				'type'     => 'checkbox'
			],

			[
				'name'     => "Photo titles and captions for the galleries / slideshows",
				'desc'     => "What do you want to show as the photo title in the gallery / slideshow? This is used for the tooltips and title displays.",
				'id'       => 'google_title_caption',
				'grouping' => 'google-settings',
				'type'     => 'select',
				'options'  => [
					'none'  => esc_html__('No title / caption / description', 'photonic'),
					'title' => esc_html__('Always use the photo title, even if blank', 'photonic'),
				]
			],

			[
				'name'     => "Chain queries",
				'desc'     => "When you use Photonic to display a selected list of albums, Photonic will only display the matches from the first page of results. Select this option to let it display albums from later pages.",
				'id'       => 'google_chain_queries',
				'grouping' => 'google-settings',
				'type'     => 'checkbox'
			],

			[
				'name'     => "Layout processing mode",
				'desc'     => "When possible, Photonic tries to use CSS to build the advanced layouts (like Justified Grids). 
					This has the advantage of being fast and can work well with lazy-loading and AJAX-based plugins, particularly if the loading mode (<em>Photonic &rarr; Settings &rarr; Generic Options &rarr; Advanced &rarr; Loading Mode</em>) is PHP. 
					<br/><br/>The downside is that CSS-based rendering is occasionally incorrect, particularly if the source has incorrect sizes. 
					If this is a frequent issue, you can default to a JS-generated layout (which is always more accurate). This can be managed individually for each gallery.
					<br/><br/>Pick your default processor:",
				'id'       => 'google_layout_engine',
				'grouping' => 'google-settings',
				'type'     => 'select',
				'options'  => [
					'css' => 'Use CSS unless overridden by a gallery individually',
					'js'  => 'Use JS unless overridden by a gallery individually',
				]
			],

			[
				'name'     => "Photos (Main Page)",
				'desc'     => "Control settings for photos from Google Photos when displayed in your page",
				'category' => 'google-photos',
				'type'     => 'section',
			],

			[
				'name'     => "What is this section?",
				'desc'     => "Options in this section are in effect when you use the shortcode format <code>[gallery type='google' view='photos']</code>. In other words, the photos are printed directly on the page.",
				'grouping' => 'google-photos',
				'type'     => "blurb",
			],

			[
				'name'     => "Photo Title Display",
				'desc'     => "How do you want the title of the photos?",
				'id'       => 'google_photo_title_display',
				'grouping' => 'google-photos',
				'type'     => 'radio',
				'options'  => $this->title_styles()
			],

			[
				'name'     => "Constrain Photos Per Row",
				'desc'     => "How do you want the control the number of photo thumbnails per row by default? This can be overridden by adding the '<code>columns</code>' parameter to the '<code>gallery</code>' shortcode.",
				'id'       => 'google_photos_per_row_constraint',
				'grouping' => 'google-photos',
				'type'     => 'select',
				'options'  => [
					'padding' => 'Fix the padding around the thumbnails',
					'count'   => 'Fix the number of thumbnails per row',
				]
			],

			[
				'name'     => "Constrain by padding",
				'desc'     => " If you have constrained by padding above, enter the number of pixels here to pad the thumbs by",
				'id'       => 'google_photos_constrain_by_padding',
				'grouping' => 'google-photos',
				'type'     => 'text',
				'hint'     => "Enter the number of pixels here (don't enter 'px'). Non-integers will be ignored."
			],

			[
				'name'     => "Constrain by number of thumbnails",
				'desc'     => " If you have constrained by number of thumbnails per row above, enter the number of thumbnails",
				'id'       => 'google_photos_constrain_by_count',
				'grouping' => 'google-photos',
				'type'     => 'select',
				'options'  => $this->selection_range(1, 10)
			],

			[
				'name'     => "Photos (Overlaid Popup Panel)",
				'desc'     => "Control settings for photos from Google Photos when displayed in a popup",
				'category' => 'google-photos-pop',
				'type'     => 'section',
			],

			[
				'name'     => "What is this section?",
				'desc'     => "Options in this section are in effect when you use the shortcode format <code>[gallery type='google' view='albums']</code>, then click on an album to show an overlaid panel. In other words, the photos are printed directly in the overlaid panel.",
				'grouping' => 'google-photos-pop',
				'type'     => "blurb",
			],

			[
				'name'     => "Photo Title Display",
				'desc'     => "How do you want the title of the photos?",
				'id'       => 'google_photo_pop_title_display',
				'grouping' => 'google-photos-pop',
				'type'     => 'radio',
				'options'  => $this->title_styles()
			],
		];
	}

	public static function get_instance() {
		if (null === self::$instance) {
			self::$instance = new Google();
		}
		return self::$instance;
	}
}