Código de WordPress - Poner un menú con opciones en la administración de Wordpress para nuestro tema

<<>>
Imágen de perfil

Poner un menú con opciones en la administración de Wordpress para nuestro temagráfica de visualizaciones


WordPress

Actualizado el 13 de Agosto del 2015 por xve (Creado el 12 de Agosto del 2015)
1.412 visualizaciones desde el 12 de Agosto del 2015. Una media de 21 por semana
Este código, muestra como crear un menú de opciones en la administración de Wordpress (wp-admin) para, en este caso, solicitar las urls de las redes sociales para posteriormente añadirlas a nuestro tema.

wordpress-opciones-admin

Nota: Este código es para los que desarrollan temas (theme) para Wordpress

Requerimientos

Para Wordpress 4 en adelante

Versión 1.0

Actualizado el 13 de Agosto del 2015 (Creado el 12 de Agosto del 2015)gráfica de visualizaciones de la versión: Versión 1.0
1.413 visualizaciones desde el 12 de Agosto del 2015. Una media de 21 por semana
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella

En el archivo funcions.php añadir entre los tags de php:
1
require_once("socialNetwork.php");

Para mostrar las direcciones de las redes sociales en nuestro tema, hay que poner en el footer.php o donde se desee algo así:
1
2
3
4
5
6
7
8
9
10
11
<?php
if(get_option("rs_show")=="si")
{
	if(get_option("rs_facebook"))
		echo "<a href='".get_option("rs_facebook")."' target='_blank'>Facebook</a>";
	if(get_option("rs_twitter"))
		echo "<a href='".get_option("rs_twitter")."' target='_blank'>Twitter</a>";
	if(get_option("rs_google"))
		echo "<a href='".get_option("rs_google")."' target='_blank'>Google+</a>";
}
?>


Es necesario copiar este código dentro de nuestro tema (theme) con el nombre: socialNetwork.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
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
<?php
// Define el titulo del menu
$themename = "Redes Sociales";
// Define un nombre corto. Este nombre sera utilizado para definir las variables 
$shortname = "rs";
// Definimos el array de valores que tiene que mostrarse en el formulario
$options = array (
	array(
		"name" => $themename,
		"type" => "title"
	),
	array(
		"name" => "Facebook",
		"desc" => "Indica tu url de Facebook (https://www.facebook.com/...)",
		"id" => $shortname."_facebook",
		"type" => "text",
		"default" => ""
	),
	array(
		"name" => "Twitter",
		"desc" => "Indica tu url de Twitter (https://twitter.com/...)",
		"id" => $shortname."_twitter",
		"type" => "text",
		"default" => ""
	),
	array(
		"name" => "Google+",
		"desc" => "Indica tu url de Google+ (http://plus.google.com/...)",
		"id" => $shortname."_google",
		"type" => "text",
		"default" => ""
	),
	array(
		"name" => "Mostrar las redes sociales?",
		"id" => $shortname."_show",
		"type" => "select",
		"options" => array("si", "no"),
		"default" => "si"
	),
);
 
add_action('admin_menu', 'panel_menu');
 
/**
 * Funcion que define el menu y guarda los datos si se han modificado
 */
function panel_menu()
{
	global $themename, $shortname, $options;
	$page="redesSociales";
 
	saveFormTheme_admin($options, $page);
	add_menu_page(
		'Titulo mi submenu opciones',
		$themename, 		//Nombre a mostrar submenu opciones
		'manage_options',	//nivel de usuario que puede ver el panel
		$page, 				//identificador de mi panel dentro de wordpress
		'panel_options_menu'//función a la que llamar y que mostrará las opciones dentro del panel
	);
}
 
/**
 * Función que muestra el formulario y indica si se han guardado los datos.
 */
function panel_options_menu()
{
	global $themename, $shortname, $options;
	if ( isset($_POST['save'])) echo '<p><strong>'.$themename.' ha sido guardado...</strong></p>';
	showFormTheme_admin($options);
}
 
/**
 * Funcion encargada de guardar los valores del formulario o actualizar-los en
 * la base de datos
 */
function saveFormTheme_admin($options,$page)
{
	if(isset($_GET['page']) && $_GET['page']==$page)
	{
		if(isset($_POST['save']))
		{
			echo "<br>".$_GET['page'];
			foreach ($options as $value)
			{
				if(isset($value['id']))
					update_option($value['id'], $_POST[$value['id']]);
			}
			foreach($options as $value)
			{
				if(isset($value['id']))
				{
					if(isset($_POST[$value['id']]))
					{
						update_option($value['id'], $_POST[$value['id']]);
					} else {
						delete_option($value['id']);
					}
				}
			}
		}
	}
}
 
/**
 * Funcion que muestra el formulario con los valores recibidos en el array
 * $options
 */
function showFormTheme_admin($options)
{
	?>
	<div class="form-wrap">
		<form method="post">
			<?php
			foreach ($options as $value)
			{
				if($value['type']=="title"){
					?>
					<h2><?php echo $value['name']; ?></h2>
					<?php
				}elseif($value['type']=="text"){
					?>
					<div class="form-field">
						<label><?php echo $value['name']; ?></label>
						<input name="<?php echo $value['id']; ?>" id="<?php echo $value['id']; ?>" type="<?php echo $value['type']; ?>" value="<?php if ( get_option( $value['id'] ) != "") { echo get_option( $value['id'] ); } else { echo $value['default']; } ?>">
						<p><?php if(isset($value['desc'])) echo $value['desc']; ?></p>
					</div>
					<?php
				}elseif($value['type']=='textarea'){
					?>
					<div class="form-field">
						<label><?php echo $value['name']; ?></label>
						<textarea name="<?php echo $value['id']; ?>" style="width:400px; height:200px;" type="<?php echo $value['type']; ?>" cols="" rows=""><?php if ( get_option( $value['id'] ) != "") { echo get_option( $value['id'] ); } else { echo $value['default']; } ?></textarea>
						<p><?php if(isset($value['desc'])) echo $value['desc']; ?></p>
					</div>
					<?php
				}elseif($value['type']=='select'){
					?>
					<div class="form-field">
						<label><?php echo $value['name']; ?></label>
						<select name="<?php echo $value['id']; ?>" id="<?php echo $value['id']; ?>">
						<?php
						foreach ($value['options'] as $option)
						{
							?>
							<option<?php if ( get_option( $value['id'] ) == $option) { echo ' selected="selected"'; } elseif ($option == $value['default']) { echo ' selected="selected"'; } ?>><?php echo $option; ?></option>
							<?php
						}
						?>
						</select>
						<p><?php if(isset($value['desc'])) echo $value['desc']; ?></p>
					</div>
					<?php
				}elseif($value['type']=='checkbox'){
					?>
					<div class="form-field">
						<label><?php echo $value['name']; ?></label>
						<?php
						if(get_option($value['id']))
						{
							$checked = "checked=\"checked\"";
						}else{
							$checked = "";
						}
						?>
						<input type="checkbox" name="<?php echo $value['id']; ?>" id="<?php echo $value['id']; ?>" value="true" <?php echo $checked; ?>>
						<p><?php if(isset($value['desc'])) echo $value['desc']; ?></p>
					</div>
					<?php
				}
			}
			?>
			<p class="submit">
				<input name="save" type="submit" id="submit" class="button button-primary" value="Save changes">
			</p>
		</form>
	</div>
	<?php
}
?>



Comentarios sobre la versión: Versión 1.0 (0)


No hay comentarios
 

Comentar la versión: Versión 1.0

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios

http://lwp-l.com/s3242