Fix the Windows Phone Recovery Tool error 0x80091007

e0ed68f3-d9ae-4d25-8409-c2cc80248344

The fix process:

  1. Download this pack of files:聽http://1drv.ms/1LKvCnq
  2. Run EVERY installation inside EVERY folder EXCEPT the WPRTInstaller.msi from the Packages folder.
  3. Run the oficial Windows Phone Recovery Tool installation, you can聽download it from this link: http://bit.ly/1E6pYnX
    1. If it works, run the program and follow the steps.
    2. If it not works, run the WPRTInstaller.
  4. Finally, if nothing works, run the WindowsPhoneRecoveryTool.exe inside the Windows Phone Recovery Tool folder as administrator. If a message is shown, cr茅ate the folder in the place it says. (commonly, C:\Program Files\Microsoft\Care Suite).

Where did this files come from?

I searched where the official installation puts the files needed to install, so, thats why you need to run EVERY installation inside EVERY folder, except the WPRTInstaller.msi.

It worked for me, after so many suggestions that did not work.

If it was useful, give me a comment 馃槈

Generaci贸n autom谩tica de getters, setters y constructores en C#

Una de las caracter铆sticas que m谩s me gustan de Netbeans es su posibilidad de generar c贸digo repetitivo autom谩ticamente utilizando funciones de generaci贸n de c贸digo automatizadas presionando alt+insertar en el cuerpo de la clase, tales como la generaci贸n de los Inspectores (Getters), Modificadores (Setters) y Constructores, que ahorran tiempo considerablemente y m谩s cuando queremos solo completar la definici贸n de una clase de forma elegante.

En C#, sabemos que los getters y setters se pueden declarar r谩pidamente en una propiedad (es decir, atributo p煤blico cuya asignaci贸n o lectura no requerir谩 de un m茅todo particular) usando cualquiera de estos m茅todos:

//Declaraci贸n abreviada
public tipo nombre{get; set;}

//Declaraci贸n con miembro privado
private tipo micampo;

public tipo acceso_micampo
{
get{ return micampo; }
set{ micampo = value; }
}

Durante mucho tiempo, pens茅 que Visual Studio no permit铆a acelerar esta tarea, ya que aunque es bastante corta la manera de declarar dichos m茅todos, siempre se agradece no tener que estar copiando y pegando algo que se mantendr谩 constante para todas las propiedades de una clase. Ademas, a la hora de crear diversos constructores, hab铆a que escribirlos a mano, lo cual quita del mismo modo, bastante tiempo.

Para simplificar la generaci贸n de c贸digo de las propiedades, utilizaremos la funci贸n Insertar Fragmento de C贸digo, haciendo clic derecho sobre cualquier parte dentro de una clase y seleccionando C# y luego prop, propg o propfull.

Notar que basta con escribir estas instrucciones en nuestro c贸digo y seguido a ello, presionar tab, lo que llamar谩 a la autocompletaci贸n de c贸digo en plantilla.

//Escribiendo prop + TAB
public TYPE Type { get; set; }

//Escribiendo propg + TAB
public int I { get; private set; }

//Escribiendo propfull + TAB
private int myVar;

public int MyProperty
{
get { return myVar; }
set { myVar = value; }
}

Para la generaci贸n de un Constructor, desgraciadamente, Visual Studio no incluye un generador o plantilla que pueda servirnos, pero si utilizamos un plugin como ReSharper (de pago, a no ser que seas un MVP), su generaci贸n es muy simple, basta con ir al men煤 de ReSharper, seleccionar Edit y finalmente Generate Code.

Se abrir谩 un peque帽o men煤 contextual como el de Netbeans en el cual seleccionamos Constructor y luego, un asistente nos guiar谩 en el resto del proceso.

Llenar de manera as铆ncrona un combobox (o DropDownList en Razor) en ASP.NET MVC4 a partir de otro combobox

Es com煤n que cualquier formulario que utilicemos en un sitio web llene los combos de selectores de datos a partir de informaci贸n llenada previamente.

Para este ejemplo, agradezco la ayuda de Camilo Ramirez, quien tiene vasta experiencia en MVC4.

Por ejemplo, al seleccionar un pa铆s en un combobox (o select o DropDownList, etc茅tera), lo esperable es que otro combobox llene las ciudades a partir del pa铆s seleccionado en el primer combobox.

En MVC4 tenemos dos formas de hacerlo; la forma sincron铆a es enviar el valor del primer combo a un controlador, que llene una segunda lista y se env铆e a la vista dentro del modelo para desplegar los datos. El problema de esta forma, es que recargaremos la p谩gina completa, por lo que si no enviamos los datos ya llenados por el usuario, deberemos generar las rutinas para que los valores de todos los campos se llenen de modo autom谩tico.

La segunda forma es hacer que el valor sea env铆ado a una acci贸n del controlador de manera as铆ncrona, y los valores sean devueltos utilizando AJAX. Veamos como se hace:

En la Vista, consideremos el siguiente bloque que genera un combo primera-lista a partir de la variable primeraLista:

@{
var primeraLista = new List<object> {new {nombre = "primero", id = 1}, new {nombre = "segundo", id = 2}, new {nombre = "tercero", id = 3}};
}

@Html.DropDownList("primera-lista", new SelectList(primeraLista, "id", "nombre"), new { @id = "primera-lista" })
<select id="segunda-lista"></select>

El siguiente c贸digo javascript se encarga de “escuchar” cuando el valor de la lista primera-lista sea cambiado, lo que har谩 que el valor sea enviado utilizando AJAX a una acci贸n del controlador que alterar谩 el c贸digo de la p谩gina web de manera as铆ncrona con los valores retornados:

<script src="~/Scripts/jquery-1.8.2.js"></script>
<script type="text/javascript">
    $(document).on("ready", function() {
        $("#primera-lista").change(function() {
            idSelected = $(this).val();
            $.ajax({
                url: '@Url.Action("GetSecondValues")'+"?id=" + idSelected,
                type: "POST",
                success: function (data) {
                    var options = "";
                    $.each(data, function(index, value) {
                        options += '<option value="' + value.id + '">' + value.nombre + '</option>';
                    });
                    $("#segunda-lista").html(options);
                },
                error:function() {
                    alert("error...");
                }
            });
        });
    });
</script>

En el controlador generamos una acci贸n con ActionResult que reciba como retorno un objeto JSON con la lista de elementos a cargar dependiendo del valor enviado desde el combo primera-lista. Notar que la lista se crea en este momento, por lo que podemos invocar un webservice o rutina a una base de datos para llenar esta lista:

 public ActionResult GetSecondValues(int id)
        {
            List<object> devolver;
            switch (id)
            {
                case 1:
                    devolver = new List<object>
                                   {
                                       new {nombre = "hola1.1", id = 1},
                                       new {nombre = "hola1.2", id = 2},
                                       new {nombre = "hola1.3", id = 3}
                                   };
                    break;
                case 2:
                    devolver = new List<object>
                                   {
                                       new {nombre = "hola2.1", id = 1},
                                       new {nombre = "hola2.2", id = 2},
                                       new {nombre = "hola3.3", id = 3}
                                   };
                    break;
                case 3:
                    devolver = new List<object>
                                   {
                                       new {nombre = "hola3.1", id = 1},
                                       new {nombre = "hola3.2", id = 2},
                                       new {nombre = "hola3.3", id = 3}
                                   };
                    break;
                default:
                    devolver = new List<object>
                                   {
                                       new {nombre = "default1", id = 1},
                                       new {nombre = "default2", id = 2},
                                       new {nombre = "default3", id = 3}
                                   };
                    break;
            }
            return Json(devolver);
        }

Insertar la caja de comentarios de Facebook en WordPress

Una integraci贸n simple y siempre muy solicitada es la de la caja de comentarios de Facebook en los sitios WordPress, que es el CMS m谩s utilizado a nivel mundial dada su simplicidad de uso y mantenci贸n.

Para lograr esta integraci贸n, no requerimos de una Application ID de Facebook, ya que, al igual que los botones Like, funciona “en caliente”, sin requerir tokens ni nada.

Continue reading