{
  "name": "Coding Interview Take-home Projects",
  "order": 4,
  "time": "",
  "helpRoom": "HelpFrontEnd",
  "challenges": [
    {
      "id": "bd7158d8c442eddfaeb5bd10",
      "title": "Show the Local Weather",
      "description": [
        "Objective: Build a CodePen.io app that is functionally similar to this: http://codepen.io/freeCodeCamp/full/bELRjV.",
        "Fulfill the below user stories. Use whichever libraries or APIs you need. Give it your own personal style.",
        "User Story: I can see the weather in my current location.",
        "User Story: I can see a different icon or background image (e.g. snowy mountain, hot desert) depending on the weather.",
        "User Story: I can push a button to toggle between Fahrenheit and Celsius.",
        "We recommend using the Open Weather API. This will require creating a free API key. Normally you want to avoid exposing API keys on CodePen, but we haven't been able to find a keyless API for weather.",
        "Remember to use Read-Search-Ask if you get stuck.",
        "When you are finished, click the \"I've completed this challenge\" button and include a link to your CodePen.",
        "You can get feedback on your project by sharing it with your friends on Facebook."
      ],
      "challengeSeed": [
        "GCLiJU-vvVc"
      ],
      "tests": [],
      "type": "zipline",
      "challengeType": 3,
      "isRequired": false,
      "translations": {
        "es": {
          "title": "Muestra el clima local",
          "description": [
            "Objetivo: Crea una aplicación con CodePen.io cuya funcionalidad sea similar a la de esta: http://codepen.io/freeCodeCamp/full/bELRjV.",
            "Satisface las siguientes historias de usuario. Usa cualquier librería o APIs que necesites.",
            "Historia de usuario: Pedo obtener información acerca del clima en mi localización actual.",
            "Historia de usuario: Puedo ver un icono diferente o una imagen de fondo diferente (e.g. montaña con nieve, desierto caliente) dependiendo del clima.",
            "Historia de usuario: Puedo pulsar un botón para cambiar la unidad de temperatura de grados Fahrenheit a Celsius y viceversa.",
            "Recomendamos utilizar Open Weather API. Al utilizarlo tendrás que crear una llave API gratuita. Normalmente debes evitar exponer llaves de API en CodePen, pero por el momento no hemos encontrado un API de clima que no requiera llave.",
            "Recuerda utilizar Leer-Buscar-Preguntar si te sientes atascado.",
            "Cuando hayas terminado, pulsa el botón de \"I've completed this challenge\" e incluye un enlace a tu CodePen.",
            "Puedes obtener retroalimentación sobre tu proyecto por parte de otros campistas, compartiendolo en nuestra Sala de chat para revisión de código. También puedes compartirlo en Twitter y en el campamento de tu ciudad (en Facebook)."
          ]
        },
        "ru": {
          "title": "Покажите местную погоду",
          "description": [
            "Задание: Создайте CodePen.io который успешно копирует вот этот: http://codepen.io/freeCodeCamp/full/bELRjV.",
            "Правило #1: Не подсматривайте код приведенного на CodePen примера. Напишите его самостоятельно.",
            "Правило #2: Можете использовать любые библиотеки или API, которые потребуются.",
            "Правило #3: Воссоздайте функционал приведенного примера и не стесняйтесь добавить что-нибудь от себя.",
            "Реализуйте следующие пользовательские истории, сделайте также бонусные по желанию:",
            "Пользовательская история: В качестве пользователя, я могу узнать погоду с учетом моего текущего местоположения.",
            "Бонусная пользовательская история: В качестве пользователя, я могу в зависимости от погоды видеть различные температурные значки.",
            "Бонусная пользовательская история: В качестве пользователя, я могу в зависимости от погоды видеть различные фоновые изображения (снежные горы, знойная пустыня).",
            "Бонусная пользовательская история: В качестве пользователя, я могу нажать на кнопку чтобы переключится между градусами по Цельсию или по Фаренгейту.",
            "Если что-то не получается, воспользуйтесь Read-Search-Ask.",
            "Когда выполните задание кликните кнопку \"I've completed this challenge\" и добавьте ссылку на ваш CodePen. Если вы программировали с кем-то в паре, также добавьте имя вашего напарника.",
            "Если вы хотите получить немедленную оценку вашего проекта, нажмите эту кнопку и добавьте ссылку на ваш CodePen. В противном случае мы проверим его перед тем как вы приступите к проектам для некоммерческих организаций.
Click here then add your link to your tweet's text"
          ]
        }
      }
    },
    {
      "id": "bd7158d8c442eddfaeb5bd19",
      "title": "Build a Wikipedia Viewer",
      "description": [
        "Objective: Build a CodePen.io app that is functionally similar to this: https://codepen.io/freeCodeCamp/full/wGqEga/.",
        "Fulfill the below user stories. Use whichever libraries or APIs you need. Give it your own personal style.",
        "User Story: I can search Wikipedia entries in a search box and see the resulting Wikipedia entries.",
        "User Story: I can click a button to see a random Wikipedia entry.",
        "Hint #1: Here's a URL you can use to get a random Wikipedia article: https://en.wikipedia.org/wiki/Special:Random.",
        "Hint #2: Here's an entry on using Wikipedia's API: https://www.mediawiki.org/wiki/API:Main_page.",
        "Hint #3: Use this link to experiment with Wikipedia's API.",
        "Remember to use Read-Search-Ask if you get stuck.",
        "When you are finished, click the \"I've completed this challenge\" button and include a link to your CodePen.",
        "You can get feedback on your project by sharing it with your friends on Facebook."
      ],
      "challengeSeed": [
        "wJhcPwVYA1g"
      ],
      "tests": [],
      "type": "zipline",
      "challengeType": 3,
      "isRequired": false,
      "translations": {
        "es": {
          "title": "Crea un buscador de Wikipedia",
          "description": [
            "Objetivo: Crea una aplicación con CodePen.io cuya funcionalidad sea similar a la de esta: https://codepen.io/freeCodeCamp/full/wGqEga/.",
            "Satisface las siguientes historias de usuario. Usa cualquier librería o APIs que necesites. Dale tu estilo personal.",
            "Historia de usuario: Pedo obtener información acerca del clima en mi localización actual.",
            "Historia de usuario: Puedo ver un icono diferente o una imagen de fondo diferente (e.g. montaña con nieve, desierto caliente) dependiendo del clima.",
            "Historia de usuario: Puedo pulsar un botón para cambiar la unidad de temperatura de grados Fahrenheit a Celsius y viceversa.",
            "Historia de usuario: Puedo buscar entradas en Wikipedia en un cuadro de búsqueda y ver las entradas de Wikipedia resultantes.",
            "Historia de usuario:Puedo pulsar un botón para ver un artículo aleatorio de Wikipedia.",
            "Pista 1: Aquí está una URL donde puedes ver una entrada aleatoria de Wikipedia: https://en.wikipedia.org/wiki/Special:Random<.",
            "Pista 2: Este es un artículo muy útil relativo al uso del API de Wikipedia: https://www.mediawiki.org/wiki/API:Main_page.",
            "Pista 3: Usa este enlace para experimentar con el API de Wikipedia.",
            "Recuerda utilizar Leer-Buscar-Preguntar si te sientes atascado.",
            "Cuando hayas terminado, pulsa el botón de \"I've completed this challenge\" e incluye un enlace a tu CodePen.",
            "Puedes obtener retroalimentación sobre tu proyecto por parte de otros campistas, compartiendolo en nuestra Sala de chat para revisión de código. También puedes compartirlo en Twitter y en el campamento de tu ciudad (en Facebook)."
          ]
        }
      }
    },
    {
      "id": "bd7158d8c442eddfaeb5bd1f",
      "title": "Use the Twitch.tv JSON API",
      "description": [
        "Objective: Build a CodePen.io app that is functionally similar to this: https://codepen.io/freeCodeCamp/full/Myvqmo/.",
        "Fulfill the below user stories. Use whichever libraries or APIs you need. Give it your own personal style.",
        "User Story: I can see whether freeCodeCamp is currently streaming on Twitch.tv.",
        "User Story: I can click the status output and be sent directly to the freeCodeCamp's Twitch.tv channel.",
        "User Story: if a Twitch user is currently streaming, I can see additional details about what they are streaming.",
        "User Story: I will see a placeholder notification if a streamer has closed their Twitch account (or the account never existed). You can verify this works by adding brunofin and comster404 to your array of Twitch streamers.",
        "Hint: See an example call to Twitch.tv's JSONP API at http://forum.freeCodeCamp.com/t/use-the-twitchtv-json-api/19541.",
        "Hint: The relevant documentation about this API call is here: https://github.com/justintv/Twitch-API/blob/master/v3_resources/streams.md#get-streamschannel.",
        "Hint: Here's an array of the Twitch.tv usernames of people who regularly stream: [\"ESL_SC2\", \"OgamingSC2\", \"cretetion\", \"freecodecamp\", \"storbeck\", \"habathcx\", \"RobotCaleb\", \"noobs2ninjas\"]",
        "Remember to use Read-Search-Ask if you get stuck.",
        "When you are finished, click the \"I've completed this challenge\" button and include a link to your CodePen.",
        "You can get feedback on your project by sharing it with your friends on Facebook."
      ],
      "challengeSeed": [
        "6WrbY1d-IHI"
      ],
      "tests": [],
      "type": "zipline",
      "challengeType": 3,
      "isRequired": false,
      "translations": {
        "es": {
          "title": "Usa el API JSON de Twitch.tv",
          "description": [
            "Objetivo: Crea una aplicación con CodePen.io cuya funcionalidad sea similar a la de esta: https://codepen.io/freeCodeCamp/full/Myvqmo/.",
            "Satisface las siguientes historias de usuario. Usa cualquier librería o APIs que necesites. Dale tu estilo personal.",
            "Historia de usuario: Puedo verificar si freeCodeCamp está transmitiendo actualmente en Twitch.tv",
            "Historia de usuario: Puedo pulsar el estatus y ser enviado directamente al canal de freeCodeCamp en Twitch.tv.",
            "Historia de usuario: Si un usuario Twitch está transmitiendo actualmente, puedo ver detalles adicionales acerca del contenido que están transmitiendo.",
            "Historia de usuario: Puedo ver una notificación si el usuario ha cerrado su cuenta de Twitch (o si la cuenta nunca ha existido). Puedes verificar si esto funciona agregando brunofin y comster404 a tu vector de usuarios de Twitch.",
            "Pista: Obseva una llamada de ejemplo al API JSONP de Twitch.tv en http://forum.freeCodeCamp.com/t/use-the-twitchtv-json-api/19541.",
            "Pista: La documentación relevante sobre esta llamada al API está aquí: https://github.com/justintv/Twitch-API/blob/master/v3_resources/streams.md#get-streamschannel.",
            "Pista: Aquí está un vector de usuarios en Twitch.tv que regularmente transmiten sobre programación: [\"ESL_SC2\", \"OgamingSC2\", \"cretetion\", \"freecodecamp\", \"storbeck\", \"habathcx\", \"RobotCaleb\", \"noobs2ninjas\"]",
            "Recuerda utilizar Leer-Buscar-Preguntar si te sientes atascado.",
            "Cuando hayas terminado, pulsa el botón de \"I've completed this challenge\" e incluye un enlace a tu CodePen.",
            "Puedes obtener retroalimentación sobre tu proyecto por parte de otros campistas, compartiendolo en nuestra Sala de chat para revisión de código. También puedes compartirlo en Twitter y en el campamento de tu ciudad (en Facebook)."
          ]
        },
        "ru": {
          "title": "Используйте Twitch.tv JSON API",
          "description": [
            "Задание: Создайте CodePen.io который успешно копирует вот этот: https://codepen.io/freeCodeCamp/full/Myvqmo/.",
            "Правило #1: Не подсматривайте код приведенного на CodePen примера. Напишите его самостоятельно.",
            "Правило #2: Можете использовать любые библиотеки или API, которые потребуются.",
            "Правило #3: Воссоздайте функционал приведенного примера и не стесняйтесь добавить что-нибудь от себя.",
            "Реализуйте следующие пользовательские истории, сделайте также бонусные по желанию:",
            "Пользовательская история: В качестве пользователя, я могу увидеть идет ли в данный момент на Twitch.tv трансляция freeCodeCamp.",
            "Пользовательская история: В качестве пользователя, я могу, кликнув на описание трансляции, перейти на канал freeCodeCamp.",
            "Пользовательская история: В качестве пользователя, я могу видеть дополнительную информацию о текущей трансляции freeCodeCamp.",
            "Бонусная пользовательская история: В качестве пользователя, я могу произвести поиск среди перечисленных каналов.",
            "Бонусная пользовательская история: В качестве пользователя, я могу видеть уведомление, если создатель канала закрыл свой аккаунт на Twitch.tv. Добавьте в массив имена пользователей brunofin и comster404, чтобы убедиться, что эта функция реализована правильно.",
            "Подсказка: Пример запроса к Twitch.tv JSON API: https://api.twitch.tv/kraken/streams/freecodecamp.",
            "Подсказка: Документацию об этом запросе можно найти по ссылке: https://github.com/justintv/Twitch-API/blob/master/v3_resources/streams.md#get-streamschannel.",
            "Подсказка: В этом массиве приведены имена пользователей, которые регулярно пишут код онлайн: [\"ESL_SC2\", \"OgamingSC2\", \"cretetion\", \"freecodecamp\", \"storbeck\", \"habathcx\", \"RobotCaleb\", \"noobs2ninjas\"]",
            "Если что-то не получается, воспользуйтесь Read-Search-Ask.",
            "Когда выполните задание кликните кнопку \"I've completed this challenge\" и добавьте ссылку на ваш CodePen. Если вы программировали с кем-то в паре, также добавьте имя вашего напарника.",
            "Если вы хотите получить немедленную оценку вашего проекта, нажмите эту кнопку и добавьте ссылку на ваш CodePen. В противном случае мы проверим его перед тем как вы приступите к проектам для некоммерческих организаций.
Click here then add your link to your tweet's text"
          ]
        }
      }
    },
    {
      "id": "bd7158d8c442eedfaeb5bd1c",
      "title": "Build a Tic Tac Toe Game",
      "description": [
        "Objective: Build a CodePen.io app that is functionally similar to this: https://codepen.io/freeCodeCamp/full/KzXQgy/.",
        "Fulfill the below user stories. Use whichever libraries or APIs you need. Give it your own personal style.",
        "User Story: I can play a game of Tic Tac Toe with the computer.",
        "User Story: My game will reset as soon as it's over so I can play again.",
        "User Story: I can choose whether I want to play as X or O.",
        "Remember to use Read-Search-Ask if you get stuck.",
        "When you are finished, click the \"I've completed this challenge\" button and include a link to your CodePen.",
        "You can get feedback on your project by sharing it with your friends on Facebook."
      ],
      "challengeSeed": [
        "Ia69O1ZNGEg"
      ],
      "tests": [],
      "type": "zipline",
      "challengeType": 3,
      "isRequired": false,
      "translations": {
        "es": {
          "title": "Crea un juego de Tic Tac Toe",
          "description": [
            "Objetivo: Construye una aplicación en CodePen.io cuya funcionalidad sea similar a la de esta: https://codepen.io/freeCodeCamp/full/KzXQgy/.",
            "Satisface las siguientes historias de usuario. Usa cualquier librería o APIs que necesites. Dale tu estilo personal.",
            "Historia de usuario: Puedo jugar un juego de Tic Tac Toe contra el computador.",
            "Historia de usuario: Mi juego se reiniciará tan pronto como termine para poder jugar de nuevo.",
            "Historia de usuario: Puedo elegir si quiero jugar como X o como O.",
            "Recuerda utilizar Leer-Buscar-Preguntar si te sientes atascado.",
            "Cuando hayas terminado, pulsa el botón de \"I've completed this challenge\" e incluye un enlace a tu CodePen.",
            "Puedes obtener retroalimentación sobre tu proyecto por parte de otros campistas, compartiéndolo en nuestra Sala de chat para revisión de código. También puedes compartirlo en Twitter y en el campamento de tu ciudad (en Facebook)."
          ]
        }
      }
    },
    {
      "id": "bd7158d8c442eddfaeb5bd1c",
      "title": "Build a Simon Game",
      "description": [
        "Objective: Build a CodePen.io app that is functionally similar to this: https://codepen.io/freeCodeCamp/full/obYBjE.",
        "Fulfill the below user stories. Use whichever libraries or APIs you need. Give it your own personal style.",
        "User Story: I am presented with a random series of button presses.",
        "User Story: Each time I input a series of button presses correctly, I see the same series of button presses but with an additional step.",
        "User Story: I hear a sound that corresponds to each button both when the series of button presses plays, and when I personally press a button.",
        "User Story: If I press the wrong button, I am notified that I have done so, and that series of button presses starts again to remind me of the pattern so I can try again.",
        "User Story: I can see how many steps are in the current series of button presses.",
        "User Story: If I want to restart, I can hit a button to do so, and the game will return to a single step.",
        "User Story: I can play in strict mode where if I get a button press wrong, it notifies me that I have done so, and the game restarts at a new random series of button presses.",
        "User Story: I can win the game by getting a series of 20 steps correct. I am notified of my victory, then the game starts over.",
        "Hint: Here are mp3s you can use for each button: https://s3.amazonaws.com/freecodecamp/simonSound1.mp3, https://s3.amazonaws.com/freecodecamp/simonSound2.mp3, https://s3.amazonaws.com/freecodecamp/simonSound3.mp3, https://s3.amazonaws.com/freecodecamp/simonSound4.mp3.",
        "Remember to use Read-Search-Ask if you get stuck.",
        "When you are finished, click the \"I've completed this challenge\" button and include a link to your CodePen.",
        "You can get feedback on your project by sharing it with your friends on Facebook."
      ],
      "challengeSeed": [
        "tAPut8a47bA"
      ],
      "tests": [],
      "type": "zipline",
      "challengeType": 3,
      "isRequired": false,
      "translations": {
        "es": {
          "title": "Construye un juego de Simon",
          "description": [
            "Objetivo: Construye una aplicación en CodePen.io cuya funcionalidad sea similar a la de esta: https://codepen.io/Em-Ant/full/QbRyqq/.",
            "Satisface las siguientes historias de usuario. Usa cualquier librería o APIs que necesites. Dale tu estilo personal.",
            "Historia de usuario: Se me presenta una serie aleatoria de pulsaciones a botones.",
            "Historia de usuario: Cada vez que presiono una secuencia de pulsaciones correctamente, veo que vuelve a ejecutarse la misma serie de pulsaciones con un paso adicional.",
            "Historia de usuario: Escucho un sonido que corresponde a cada botón cuando se ejecuta una secuencia de pulsaciones, así como cuando yo presiono un botón.",
            "Historia de usuario: Si presiono el botón equivocado, se me notifica sobre mi error, y se ejecuta de nuevo la serie correcta de pulsaciones para recordarme cuál es la secuencia correcta, tras lo cual puedo intentar de nuevo.",
            "Historia de usuario: Puedo ver cuántos pasos hay en la serie de pulsaciones actual.",
            "Historia de usuario: Si deseo reiniciar, puedo pulsar un botón para hacerlo, y el juego comenzará desde una secuencia con un solo paso.",
            "Historia de usuario: Puedo jugar en modo estricto donde si presiono el botón equivocado, se me notifica de mi error, y el juego vuelve a comenzar con una nueva serie aleatoria de colores.",
            "Historia de usuario: Puedo ganar el juego si completo 20 pasos correctos. Se me notifica sobre mi victoria, tras lo cual el juego se reinicia.",
            "Pista: Aquí hay algunos mp3s que puedes utilizar para tus botones: https://s3.amazonaws.com/freecodecamp/simonSound1.mp3, https://s3.amazonaws.com/freecodecamp/simonSound2.mp3, https://s3.amazonaws.com/freecodecamp/simonSound3.mp3, https://s3.amazonaws.com/freecodecamp/simonSound4.mp3.",
            "Recuerda utilizar Leer-Buscar-Preguntar si te sientes atascado.",
            "Cuando hayas terminado, pulsa el botón de \"I've completed this challenge\" e incluye un enlace a tu CodePen.",
            "Puedes obtener retroalimentación sobre tu proyecto por parte de otros campistas, compartiéndolo en nuestra Sala de chat para revisión de código. También puedes compartirlo en Twitter y en el campamento de tu ciudad (en Facebook)."
          ]
        }
      }
    },
    {
      "id": "bd7156d8c242eddfaeb5bd13",
      "title": "Build a Camper Leaderboard",
      "description": [
        "Objective: Build a CodePen.io app that is functionally similar to this: https://codepen.io/freeCodeCamp/full/eZGMjp/.",
        "Fulfill the below user stories. Use whichever libraries or APIs you need. Give it your own personal style.",
        "User Story: I can see a table of the freeCodeCamp campers who've earned the most brownie points in the past 30 days.",
        "User Story: I can see how many brownie points they've earned in the past 30 days, and how many they've earned total.",
        "User Story: I can toggle between sorting the list by how many brownie points they've earned in the past 30 days and by how many brownie points they've earned total.",
        "Hint: To get the top 100 campers for the last 30 days: https://fcctop100.herokuapp.com/api/fccusers/top/recent.",
        "Hint: To get the top 100 campers of all time: https://fcctop100.herokuapp.com/api/fccusers/top/alltime.",
        "Remember to use Read-Search-Ask if you get stuck.",
        "When you are finished, click the \"I've completed this challenge\" button and include a link to your CodePen. ",
        "You can get feedback on your project by sharing it with your friends on Facebook."
      ],
      "releasedOn": "January 1, 2016",
      "challengeSeed": [
        "LJQcFNo_-QY"
      ],
      "tests": [],
      "type": "zipline",
      "isRequired": false,
      "challengeType": 3,
      "translations": {
        "es": {
          "title": "Crea un marcador para los campistas",
          "description": [
            "Objetivo: Construye una aplicación en CodePen.io que funcione de forma similar al siguiente ejemplo: https://codepen.io/freeCodeCamp/full/eZGMjp/.",
            "Satisface las siguientes historias de usuario. Usa cualquier librería o API que sea necesaria. ¡Ponle un toque personal!.",
            "Historia de usuario: Puedo ver un tablero con los campistas de freeCodeCamp que han ganado más puntos de brownie en los últimos 30 días.",
            "Historia de usuario: Puedo ver cuántos puntos de brownie han ganado en los últimos 30 días, y cuántos han ganado en total.",
            "Historia de usuario: Puedo elegir entre dos formas de organizar la lista: 1) En base a cuántos puntos de brownie se han ganado en los últimos 30 días. 2) En base al número de puntos de brownie que han ganado en total.",
            "Pista: Para obtener los 100 mejores campistas para los últimos 30 días: https://fcctop100.herokuapp.com/api/fccusers/top/recent.",
            "Pista: Para obtener los 100 mejores campistas de toda la historia: http://fcctop100.herokuapp.com/api/fccusers/top/alltime.",
            "Recuerda utilizar Read-Search-Ask si te sientes atascado.",
            "Cuando termines, haz clic en el botón de \"I've completed this challenge\" e incluye el vínculo de tu proyecto en CodePen. ",
            "Puedes obtener retroalimentación acerca de tu proyecto de parte de tus compañeros campistas compartiéndolo en nuestro Cuarto de revisión de código. También puedes compartirlo en Twitter y en el campamento de tu ciudad (en Facebook)."
          ]
        },
        "ru": {
          "title": "Создайте таблицу Кемперов-Лидеров",
          "description": [
            "Задание: Создайте приложение CodePen.io, функционал которого схож с этим: https://codepen.io/freeCodeCamp/full/eZGMjp/.",
            "Приложение должно удовлетворять нижеприведённым пользовательским историям. Используйте любые библиотеки или API, которые потребуются. Придайте ему свой личный стиль.",
            "Пользовательская история: Я могу видеть таблицу кемперов freeCodeCamp, которые получили наибольшее количество очков за последние 30 дней.",
            "Пользовательская история: Я могу видеть сколько очков они получили за последние 30 дней, и сколько они получили их всего.",
            "Пользовательская история: Я могу отсортировать список по количеству очков, которые они получили за последние 30 дней, и по общему количеству полученных очков.",
            "Подсказка: Ссылка на топ 100 кемперов за последние 30 дней в формате JSON: https://fcctop100.herokuapp.com/api/fccusers/top/recent.",
            "Подсказка: Ссылка на топ 100 кемперов за все время в формате JSON: http://fcctop100.herokuapp.com/api/fccusers/top/alltime.",
            "Если что-то не получается, не забывайте пользоваться методом Читай-Ищи-Спрашивай.",
            "Когда закончите, нажмите кнопку \"I've completed this challenge\" и укажите ссылку на вашу работу на CodePen.",
            "Вы можете получить отзыв о вашем проекте от коллег, поделившись ссылкой на него в нашем чате для рассмотрения кода. Также вы можете поделиться ею через Twitter и на странице freeCodeCamp вашего города на Facebook."
          ]
        }
      }
    },
    {
      "id": "bd7155d8c242eddfaeb5bd13",
      "title": "Build a Recipe Box",
      "description": [
        "Objective: Build a CodePen.io app that is functionally similar to this: https://codepen.io/freeCodeCamp/full/dNVazZ/.",
        "Fulfill the below user stories. Use whichever libraries or APIs you need. Give it your own personal style.",
        "User Story: I can create recipes that have names and ingredients.",
        "User Story: I can see an index view where the names of all the recipes are visible.",
        "User Story: I can click into any of those recipes to view it.",
        "User Story: I can edit these recipes.",
        "User Story: I can delete these recipes.",
        "User Story: All new recipes I add are saved in my browser's local storage. If I refresh the page, these recipes will still be there.",
        "Hint:  You should prefix your local storage keys on CodePen, i.e. _username_recipes",
        "Remember to use Read-Search-Ask if you get stuck.",
        "When you are finished, click the \"I've completed this challenge\" button and include a link to your CodePen.",
        "You can get feedback on your project by sharing it with your friends on Facebook."
      ],
      "releasedOn": "January 1, 2016",
      "challengeSeed": [
        "6tZ4c-Bxstg"
      ],
      "tests": [],
      "type": "zipline",
      "isRequired": false,
      "challengeType": 3,
      "titleRu": "Создайте хранилище рецептов",
      "descriptionRu": [
        "Задание: Создайте приложение CodePen.io, функционал которого схож с этим: https://codepen.io/freeCodeCamp/full/dNVazZ/.",
        "Правило #1: Не подсматривайте код приложения-примера. Напишите его самостоятельно.",
        "Правило #2: Приложение должно удовлетворять нижеприведённым пользовательским историям. Используйте любые библиотеки или API, которые потребуются. Придайте ему свой личный стиль.",
        "Правило #3: Для создания этого проекта вы должны использовать Sass и React.",
        "Пользовательская история: Я могу создавать рецепты, содержащие название и ингредиенты.",
        "Пользовательская история: Я могу просмотреть корневой вид, на котором видны все рецепты.",
        "Пользовательская история: Я могу нажать на имя каждого из рецептов для просмотра содержимого.",
        "Пользовательская история: Я могу отредактировать эти рецепты.",
        "Пользовательская история: Я могу удалить эти рецепты.",
        "Пользовательская история: Все новые рецепты, которые я добавил, сохранены в локальном хранилище моего браузера. Если я обновлю страницу, эти рецепты будут всё ещё там.",
        "Если что-то не получается, не забывайте пользоваться методом Читай-Ищи-Спрашивай.",
        "Когда закончите, нажмите кнопку \"I've completed this challenge\" и укажите ссылку на вашу работу на CodePen.",
        "Вы можете получить отзыв о вашем проекте от коллег, поделившись ссылкой на него в нашем чате для рассмотрения кода. Также вы можете поделиться ею через Twitter и на странице Free Code Camp вашего города на Facebook."
      ],
      "titleEs": "Crea una caja de recetas",
      "descriptionEs": [
        "Objetivo: Construye una aplicación en CodePen.io que funcione de forma similar al siguiente ejemplo: https://codepen.io/freeCodeCamp/full/dNVazZ/.",
        "Regla #1: No veas el código del proyecto de ejemplo. Encuentra la forma de hacerlo por tu cuenta.",
        "Regla #2: Satisface las siguientes historias de usuario. Usa cualquier librería o API que sea necesaria. ¡Ponle un toque personal!.",
        "Rule #3: Debes utilizar ambos Sass y React para construir este proyecto.",
        "Historia de usuario: Puedo crear recetas a las que les puedo poner un nombre y los ingredientes necesarios.",
        "Historia de usuario: Puedo ver un índice que contenga los nombres de todas las recetas.",
        "Historia de usuario: Puedo pulsar cualquiera de las recetas para verla.",
        "Historia de usuario: Puedo editar las recetas.",
        "Historia de usuario: Puedo eliminar las recetas.",
        "Historia de usuario: Las recetas que voy agregando deben guardarse en el almacenamiento local de mi navegador. Las recetas deben seguir allí si refresco la página.",
        "Recuerda utilizar Read-Search-Ask si te sientes atascado.",
        "Cuando termines, haz clic en el botón de \"I've completed this challenge\" e incluye el vínculo de tu proyecto en CodePen. ",
        "Puedes obtener retroalimentación acerca de tu proyecto de parte de tus compañeros campistas compartiéndolo en nuestro Cuarto de revisión de código. También puedes compartirlo en Twitter y en el campamento de tu ciudad (en Facebook)."
      ]
    },
    {
      "id": "bd7154d8c242eddfaeb5bd13",
      "title": "Build the Game of Life",
      "description": [
        "Objective: Build a CodePen.io app that is functionally similar to this: https://codepen.io/freeCodeCamp/full/BpwMZv/.",
        "Fulfill the below user stories. Use whichever libraries or APIs you need. Give it your own personal style.",
        "User Story: When I first arrive at the game, it will randomly generate a board and start playing.",
        "User Story: I can start and stop the board.",
        "User Story: I can set up the board.",
        "User Story: I can clear the board.",
        "User Story: When I press start, the game will play out.",
        "User Story: Each time the board changes, I can see how many generations have gone by.",
        "Hint: Here's an explanation of Conway's Game of Life from John Conway himself: https://www.youtube.com/watch?v=E8kUJL04ELA",
        "Hint: Here's an overview of Conway's Game of Life with rules for your reference: https://en.wikipedia.org/wiki/Conway%27s_Game_of_Life",
        "Remember to use Read-Search-Ask if you get stuck.",
        "When you are finished, click the \"I've completed this challenge\" button and include a link to your CodePen. ",
        "You can get feedback on your project by sharing it with your friends on Facebook."
      ],
      "releasedOn": "January 1, 2016",
      "challengeSeed": [
        "5Ajcjs3OmjA"
      ],
      "tests": [],
      "type": "zipline",
      "isRequired": false,
      "challengeType": 3,
      "titleRu": "Создайте игру \"Жизнь\"",
      "descriptionRu": [
        "Задание: Создайте приложение CodePen.io, функционал которого схож с этим: https://codepen.io/freeCodeCamp/full/BpwMZv/.",
        "Правило #1: Не подсматривайте код приложения-примера. Напишите его самостоятельно.",
        "Правило #2: Приложение должно удовлетворять нижеприведённым пользовательским историям. Используйте любые библиотеки или API, которые потребуются. Придайте ему свой личный стиль.",
        "Правило #3: Для создания этого проекта вы должны использовать Sass и React.",
        "Пользовательская история: Когда я впервые запускаю игру, она генерирует доску случайным образом и начинает игру.",
        "Пользовательская история: Я могу запустить и остановить игру.",
        "Пользовательская история: Я могу настроить доску.",
        "Пользовательская история: Я могу очистить доску.",
        "Пользовательская история: Когда я нажимаю начать, игра начинает воспроизведение.",
        "Пользовательская история: Каждый раз, когда доска меняется, я могу видеть сколько поколений прошло.",
        "Подсказка: Вот объяснение игры \"Жизнь\" от её создателя Джона Конвея: https://www.youtube.com/watch?v=E8kUJL04ELA",
        "Подсказка: Вот обзор правил игры \"Жизнь\" для вашего сведения: https://ru.wikipedia.org/wiki/Жизнь_(игра)",
        "Если что-то не получается, не забывайте пользоваться методом Читай-Ищи-Спрашивай.",
        "Когда закончите, нажмите кнопку \"I've completed this challenge\" и укажите ссылку на вашу работу на CodePen.",
        "Вы можете получить отзыв о вашем проекте от коллег, поделившись ссылкой на него в нашем чате для рассмотрения кода. Также вы можете поделиться ею через Twitter и на странице Free Code Camp вашего города на Facebook."
      ],
      "titleEs": "Crea un Juego de la vida",
      "descriptionEs": [
        "Objetivo: Construye una aplicación en CodePen.io que funcione de forma similar al siguiente ejemplo: https://codepen.io/freeCodeCamp/full/BpwMZv/.",
        "Regla #1: No veas el código del proyecto de ejemplo. Encuentra la forma de hacerlo por tu cuenta.",
        "Regla #2: Satisface las siguientes historias de usuario. Usa cualquier librería o API que sea necesaria. ¡Ponle un toque personal!.",
        "Rule #3: Debes utilizar ambos Sass y React para construir este proyecto.",
        "Historia de usuario: La aplicación debe generar aleatoriamente un tablero y comenzar a jugar cuando entro al juego por primera vez.",
        "Historia de usuario: Puedo iniciar y detener el tablero.",
        "Historia de usuario: Puedo preparar el tablero.",
        "Historia de usuario: Puedo limpiar el tablero.",
        "Historia de usuario: El juego inicia cuando presiono un botón de inicio.",
        "Historia de usuario: Puedo ver cuántas generaciones han pasado cada vez que el tablero cambia.",
        "Pista: Puedes encontrar una explicación del Juego de la vida de Conway de parte del mismísimo John Conway aquí: https://www.youtube.com/watch?v=E8kUJL04ELA",
        "Pista: Puedes referirte al siguiente enlace para obtener información general acerca del Juego de la vida de Conway incluyendo las reglas del juego: https://en.wikipedia.org/wiki/Conway%27s_Game_of_Life",
        "Recuerda utilizar Read-Search-Ask si te sientes atascado.",
        "Cuando termines, haz clic en el botón de \"I've completed this challenge\" e incluye el vínculo de tu proyecto en CodePen. ",
        "Puedes obtener retroalimentación acerca de tu proyecto de parte de tus compañeros campistas compartiéndolo en nuestro Cuarto de revisión de código. También puedes compartirlo en Twitter y en el campamento de tu ciudad (en Facebook)."
      ]
    },
    {
      "id": "bd7153d8c242eddfaeb5bd13",
      "title": "Build a Roguelike Dungeon Crawler Game",
      "description": [
        "Objective: Build a CodePen.io app that is functionally similar to this: https://codepen.io/freeCodeCamp/full/apLXEJ/.",
        "Fulfill the below user stories. Use whichever libraries or APIs you need. Give it your own personal style.",
        "User Story: I have health, a level, and a weapon. I can pick up a better weapon. I can pick up health items.",
        "User Story: All the items and enemies on the map are arranged at random.",
        "User Story: I can move throughout a map, discovering items.",
        "User Story: I can move anywhere within the map's boundaries, but I can't move through an enemy until I've beaten it.",
        "User Story: Much of the map is hidden. When I take a step, all spaces that are within a certain number of spaces from me are revealed.",
        "User Story: When I beat an enemy, the enemy goes away and I get XP, which eventually increases my level.",
        "User Story: When I fight an enemy, we take turns damaging each other until one of us loses. I do damage based off of my level and my weapon. The enemy does damage based off of its level. Damage is somewhat random within a range.",
        "User Story: When I find and beat the boss, I win.",
        "User Story: The game should be challenging, but theoretically winnable.",
        "Remember to use Read-Search-Ask if you get stuck.",
        "When you are finished, click the \"I've completed this challenge\" button and include a link to your CodePen. ",
        "You can get feedback on your project by sharing it with your friends on Facebook."
      ],
      "releasedOn": "January 1, 2016",
      "challengeSeed": [
        "BwyKI9iePUQ"
      ],
      "tests": [],
      "type": "zipline",
      "isRequired": false,
      "challengeType": 3,
      "translations": {
        "es": {
          "title": "Crea un juego de dragones al estilo Rogue",
          "description": [
            "Objetivo: Construye una aplicación en CodePen.io que funcione de forma similar al siguiente ejemplo: https://codepen.io/freeCodeCamp/full/apLXEJ/.",
            "Satisface las siguientes historias de usuario. Usa cualquier librería o API que sea necesaria. ¡Ponle un toque personal!.",
            "Historia de usuario: Tengo energía, nivel de habilidad y un arma. Puedo recoger un arma mejor. Puedo recoger ítems que recuperan mi energía.",
            "Historia de usuario: Todos los ítems y los enemigos en el mapa están colocados aleatoriamente.",
            "Historia de usuario: Puedo moverme a lo largo de un mapa y descubrir ítems.",
            "Historia de usuario: Puedo moverme hacia cualquier parte dentro de los límites del mapa, pero no puedo moverme sobre un enemigo hasta que lo haya vencido.",
            "Historia de usuario: Gran parte del mapa está escondido. Cuando doy un paso, todos los espacios que están a cierto número de espacios de distancia de mi son revelados.",
            "Historia de usuario: Cuando venzo un enemigo, este desaparece y yo gano puntos de experiencia (XP), lo que eventualmente me permite aumentar de nivel.",
            "Historia de usuario: Cuando peleo con un enemigo, tomamos turnos haciéndonos daño hasta que uno de los dos pierde. El daño que hago está basado en mi nivel de experiencia y en el arma que estoy utilizando. El enemigo hace daño basado en su nivel. El daño es aleatorio dentro de cierto márgen.",
            "Historia de usuario: Gano el juego cuando encuentre y venza al jefe.",
            "Historia de usuario: El juego debe representar un reto, pero ganar debe ser teóricamente posible.",
            "Recuerda utilizar Read-Search-Ask si te sientes atascado.",
            "Cuando termines, haz clic en el botón de \"I've completed this challenge\" e incluye el vínculo de tu proyecto en CodePen. ",
            "Puedes obtener retroalimentación acerca de tu proyecto de parte de tus compañeros campistas compartiéndolo en nuestro Cuarto de revisión de código. También puedes compartirlo en Twitter y en el campamento de tu ciudad (en Facebook)."
          ]
        },
        "ru": {
          "title": "Создайте Roguelike-подобную игру Подземелье",
          "description": [
            "Задание: Создайте приложение CodePen.io, функционал которого схож с этим: https://codepen.io/freeCodeCamp/full/apLXEJ/.",
            "Приложение должно удовлетворять нижеприведённым пользовательским историям. Используйте любые библиотеки или API, которые потребуются. Придайте ему свой личный стиль.",
            "Пользовательская история: У меня есть жизни, уровень и оружие. Я могу подобрать оружие получше. Я могу подобрать очки здоровья.",
            "Пользовательская история: Все предметы и враги располагаются на карте случайным образом.",
            "Пользовательская история: Я могу передвигаться по карте, обнаруживая новые предметы.",
            "Пользовательская история: Я могу двигаться куда угодно в рамках карты, но не могу продвинуться дальше врага, пока он не будет побежден.",
            "Пользовательская история: Большая часть карты скрыта. Когда я делаю шаг, все клетки в определенном количестве клеток от меня становятся видимы.",
            "Пользовательская история: Когда я побеждаю врага, враг исчезает, а я получаю очки опыта (XP), что увеличивает мой уровень.",
            "Пользовательская история: Когда я веду бой с врагом, мы поочередно наносим друг-другу повреждения, до тех пор пока кто-нибудь не победит. Я наношу повреждения, которые зависят от моего уровня и моего оружия. Враг наносит повреждения, которые зависят от его уровня. Значение повреждений распределено случайным образом в некотором диапазоне.",
            "Пользовательская история: Когад я нахожу и побеждаю босса, я выигрываю игру.",
            "Пользовательская история: Игра должна быть интересной и достаточно сложной, но теоретически проходимой.",
            "Если что-то не получается, не забывайте пользоваться методом Читай-Ищи-Спрашивай.",
            "Когда закончите, нажмите кнопку \"I've completed this challenge\" и укажите ссылку на вашу работу на CodePen.",
            "Вы можете получить отзыв о вашем проекте от коллег, поделившись ссылкой на него в нашем чате для рассмотрения кода. Также вы можете поделиться ею через Twitter и на странице freeCodeCamp вашего города на Facebook."
          ]
        }
      }
    },
    {
      "id": "bd7150d8c442eddfafb5bd1c",
      "title": "P2P Video Chat Application",
      "description": [
        "Objective: Build a Gomix app that is functionally similar to this: https://unequaled-cement.gomix.me.",
        "Fulfill the below user stories. Use whichever libraries or APIs you need. Give it your own personal style.",
        "User Story: Upon arriving, the browser will prompt me to access my camera and microphone. ",
        "User Story: After I give it permission, I am prompted to type in a room name.",
        "User Story: Once I type in the room name, a room will be created if no room of that name existed before. ",
        "User Story: A friend of mine can subsequently go to the same website, type in the same room I entered, and join the same room, then enter into a video chat with me. ",
        "User Story: If I type in a room name, and there are already two people in that room, I get a notification that the room is full. ",
        "User Story: Anyone can create or join any room. And there can be any number of rooms, but all of them must have unique names. ",
        "User Story: I can choose to not permit the site to access my microphone and webcam. If I choose not to do this, if some other driver problem occurs, I see an error message saying these are required. ",
        "User Story: When I choose to cancel the room name input step, or if I type in no name, or just spaces, it should again ask me again to type in a valid room name. ",
        "User Story: If one of the two people in the room get disconnected, they can reconnect to the same room and continue chatting.",
        "Remember to use Read-Search-Ask if you get stuck.",
        "When you are finished, click the \"I've completed this challenge\" button and include a link to your Gomix App.",
        "You can get feedback on your project by sharing it with your friends on Facebook."
      ],
      "challengeSeed": [],
      "tests": [],
      "type": "zipline",
      "challengeType": 3,
      "isRequired": false,
      "releasedOn": "January 1, 2016"
    },
    {
      "id": "bd7198d8c242eddfaeb5bd13",
      "title": "Show National Contiguity with a Force Directed Graph",
      "description": [
        "Objective: Build a CodePen.io app that is functionally similar to this: https://codepen.io/freeCodeCamp/full/xVopBo.",
        "Fulfill the following user stories. Use whichever libraries or APIs you need. Give it your own personal style.",
        "User Story: I can see a Force-directed Graph that shows which countries share borders.",
        "User Story: I can see each country's flag on its node.",
        "Hint: Here's a dataset you can use to build this: https://raw.githubusercontent.com/DealPete/forceDirected/master/countries.json",
        "Hint: You can create a spritesheet of national flags at https://www.flag-sprites.com.",
        "Remember to use Read-Search-Ask if you get stuck.",
        "When you are finished, click the \"I've completed this challenge\" button and include a link to your CodePen. ",
        "You can get feedback on your project by sharing it with your friends on Facebook."
      ],
      "challengeSeed": [
        "etBaP3IdlIE"
      ],
      "tests": [],
      "isRequired": false,
      "releasedOn": "January 1, 2016",
      "type": "zipline",
      "challengeType": 3,
      "translations": {
        "es": {
          "title": "Muestra asociaciones utilizando un gráfico de fuerzas dirigidas",
          "description": [
            "Objetivo: Construye una aplicación en CodePen.io que funcione de forma similar al siguiente ejemplo: https://codepen.io/freeCodeCamp/full/KVNNXY.",
            "Regla #1: No veas el código del proyecto de ejemplo. Encuentra la forma de hacerlo por tu cuenta.",
            "Regla #2: Satisface las siguientes historias de usuario. Usa cualquier librería o API que sea necesaria. ¡Ponle un toque personal!.",
            "Regla #3: Debes utilizar D3.js para construir este proyecto.",
            "Historia de usuario: Puedo ver un gráfico de fuerza dirigida que muestra qué campistas están publicando enlaces en Camper News hacia qué dominios.",
            "Historia de usuario: Puedo ver el icono de cada campista en su nodo respectivo.",
            "Historia de usuario: Puedo ver la relación entre los campistas y los dominios que publican.",
            "Historia de usuario: Puedo conocer aproximadamente cuántas veces los campistas han enlazado un dominio en particular a partir del tamaño del nodo respectivo.",
            "Historia de usuario: Puedo conocer aproximadamente cuántas veces un campista específico ha publicado un enlace a partir del tamaño de su nodo.",
            "Pista: La siguiente es la ruta del API de noticias de Camper News: http://www.freeCodeCamp.com/news/hot.",
            "Recuerda utilizar Read-Search-Ask si te sientes atascado.",
            "Cuando termines, haz clic en el botón de \"I've completed this challenge\" e incluye el vínculo de tu proyecto en CodePen. ",
            "Puedes obtener retroalimentación acerca de tu proyecto de parte de tus compañeros campistas compartiéndolo en nuestro Cuarto de revisión de código. También puedes compartirlo en Twitter y en el campamento de tu ciudad (en Facebook)."
          ]
        }
      }
    },
    {
      "id": "bd7108d8c242eddfaeb5bd13",
      "title": "Map Data Across the Globe",
      "description": [
        "Objective: Build a CodePen.io app that is functionally similar to this: https://codepen.io/freeCodeCamp/full/mVEJag.",
        "Fulfill the following user stories. Use whichever libraries or APIs you need. Give it your own personal style.",
        "User Story: I can see where all Meteorites landed on a world map.",
        "User Story: I can tell the relative size of the meteorite, just by looking at the way it's represented on the map.",
        "User Story: I can mouse over the meteorite's data point for additional data.",
        "Hint: Here's a dataset you can use to build this: https://raw.githubusercontent.com/freeCodeCamp/ProjectReferenceData/master/meteorite-strike-data.json",
        "Remember to use Read-Search-Ask if you get stuck.",
        "When you are finished, click the \"I've completed this challenge\" button and include a link to your CodePen. ",
        "You can get feedback on your project by sharing it with your friends on Facebook."
      ],
      "challengeSeed": [
        "kSAqct10gA0"
      ],
      "tests": [],
      "isRequired": false,
      "releasedOn": "January 1, 2016",
      "type": "zipline",
      "challengeType": 3,
      "translations": {
        "es": {
          "title": "Mapea datos a lo largo del Globo",
          "description": [
            "Objetivo: Construye una aplicación en CodePen.io que funcione de forma similar al siguiente ejemplo: https://codepen.io/freeCodeCamp/full/mVEJag.",
            "Regla #1: No veas el código del proyecto de ejemplo. Encuentra la forma de hacerlo por tu cuenta.",
            "Regla #2: Satisface las siguientes historias de usuario. Usa cualquier librería o API que sea necesaria. ¡Ponle un toque personal!.",
            "Regla #3: Debes utilizar D3.js para construir este proyecto.",
            "Historia de usuario: Puedo ver a dónde cayeron todos los meteoritos en un mapa mundi.",
            "Historia de usuario: Puedo distinguir el tamaño relativo de cada meteorito simplemente viendo la forma en que está representado en el mapa.",
            "Historia de usuario: Puedo mover el ratón sobre el dato de cada meteorito para obtener información adicional.",
            "Pista: Puedes utilizar el siguiente conjunto de datos para construir tu proyecto: https://raw.githubusercontent.com/freeCodeCamp/ProjectReferenceData/master/meteorite-strike-data.json",
            "Recuerda utilizar Read-Search-Ask si te sientes atascado.",
            "Cuando termines, haz clic en el botón de \"I've completed this challenge\" e incluye el vínculo de tu proyecto en CodePen. ",
            "Puedes obtener retroalimentación acerca de tu proyecto de parte de tus compañeros campistas compartiéndolo en nuestro Cuarto de revisión de código. También puedes compartirlo en Twitter y en el campamento de tu ciudad (en Facebook)."
          ]
        }
      }
    },
    {
      "id": "bd7158d8c443eddfaeb5bd0f",
      "title": "Manage a Book Trading Club",
      "description": [
        "Objective: Build a full stack JavaScript app that is functionally similar to this: http://bookjump.herokuapp.com/ and deploy it to Heroku.",
        "Note that for each project, you should create a new GitHub repository and a new Heroku project. If you can't remember how to do this, revisit https://freecodecamp.com/challenges/get-set-for-our-dynamic-web-application-projects.",
        "Here are the specific user stories you should implement for this project:",
        "User Story: I can view all books posted by every user.",
        "User Story: I can add a new book.",
        "User Story: I can update my settings to store my full name, city, and state.",
        "User Story: I can propose a trade and wait for the other user to accept the trade.",
        "Once you've finished implementing these user stories, click the \"I've completed this challenge\" button and enter the URLs for both your GitHub repository and your live app running on Heroku.",
        "You can get feedback on your project by sharing it with your friends on Facebook."
      ],
      "challengeSeed": [
        "mzElFmbGqQI"
      ],
      "tests": [],
      "type": "basejump",
      "challengeType": 4,
      "descriptionEs": [
        "Objetivo: Construye una aplicación de pila completa (full stack) en JavaScript que funcione de forma similar al siguiente proyecto: http://bookjump.herokuapp.com/ y despliégalo en Heroku.",
        "Ten en cuenta que para cada proyecto, debes crear un nuevo repositorio en GitHub y un nuevo proyecto en Heroku. Si no recuerdas cómo hacerlo, visita de nuevo https://freecodecamp.com/challenges/get-set-for-our-dynamic-web-application-projects.",
        "Estas son las Historias de usuario que debes satisfacer para este Basejump:",
        "Historia de usuario: Puedo ver todos los libros agregados por cada usuario.",
        "Historia de usuario: Puedo agregar un nuevo libro.",
        "Historia de usuario: Puedo actualizar mi configuración para que almacene mi nombre completo, ciudad y Estado.",
        "Historia de usuario: Puedo proponer un intercambio y esperar a que algún otro usuario acepte el trato.",
        "Una vez hayas terminado de implementar estas historias de usuario, pulsa el botón de \"I've completed this challenge\" e incluye las URLs de tu repositorio GitHub y de tu aplicación corriendo en Heroku.",
        "Puedes obtener retroalimentación acerca de tu proyecto de parte de tus compañeros campistas compartiéndolo en nuestro Cuarto de revisión de código. También puedes compartirlo en Twitter y en el campamento de tu ciudad (en Facebook)."
      ],
      "isRequired": false,
      "titleEs": "Administra un club de intercambio de libros"
    },
    {
      "id": "bd7158d8c443eddfaeb5bdee",
      "title": "Build a Pinterest Clone",
      "description": [
        "Objective: Build a full stack JavaScript app that is functionally similar to this: https://midnight-dust.hyperdev.space and deploy it to Heroku.",
        "Note that for each project, you should create a new GitHub repository and a new Heroku project. If you can't remember how to do this, revisit https://freecodecamp.com/challenges/get-set-for-our-dynamic-web-application-projects.",
        "Here are the specific user stories you should implement for this project:",
        "User Story: As an unauthenticated user, I can login with Twitter.",
        "User Story: As an authenticated user, I can link to images.",
        "User Story: As an authenticated user, I can delete images that I've linked to.",
        "User Story: As an authenticated user, I can see a Pinterest-style wall of all the images I've linked to.",
        "User Story: As an unauthenticated user, I can browse other users' walls of images.",
        "User Story: As an authenticated user, if I upload an image that is broken, it will be replaced by a placeholder image. (can use jQuery broken image detection)",
        "Hint: Masonry.js is a library that allows for Pinterest-style image grids.",
        "Once you've finished implementing these user stories, click the \"I've completed this challenge\" button and enter the URLs for both your GitHub repository and your live app running on Heroku.",
        "You can get feedback on your project by sharing it with your friends on Facebook."
      ],
      "challengeSeed": [
        "adrOtJCVP04"
      ],
      "tests": [],
      "type": "basejump",
      "challengeType": 4,
      "descriptionEs": [
        "Objetivo: Construye una aplicación de pila completa (full stack) en JavaScript que funcione de forma similar al siguiente proyecto: https://midnight-dust.hyperdev.space/ y despliégalo en Heroku.",
        "Ten en cuenta que para cada proyecto, debes crear un nuevo repositorio en GitHub y un nuevo proyecto en Heroku. Si no recuerdas cómo hacerlo, visita de nuevo https://freecodecamp.com/challenges/get-set-for-our-dynamic-web-application-projects.",
        "Estas son las Historias de usuario que debes satisfacer para este Basejump:",
        "Historia de usuario: Como usuario autenticado, puedo acceder a mi cuenta con Twitter.",
        "Historia de usuario: Como usuario autenticado, puedo agregar enlaces a imágenes.",
        "Historia de usuario: Como usuario autenticado, puedo elimiar imágenes que he agregado.",
        "Historia de usuario: Como usuario autenticado, puedo ver un muro al estilo de Pinterest con todas las imágenes para las que he agregado un enlace.",
        "Historia de usuario: Como usuario no autenticado, puedo navegar los muros de imágenes de otros usuarios.",
        "Historia de usuario: Como usuario autenticado, si agrego una imagen corrupta, será reemplazada por una imagen predeterminada. (Puedes utilizar la detección de imágenes corruptas de jQuery)",
        "Pista: Masonry.js es una librería que permite crear cuadrículas de imágenes al estilo de Pinterest.",
        "Una vez hayas terminado de implementar estas historias de usuario, pulsa el botón de \"I've completed this challenge\" e incluye las URLs de tu repositorio GitHub y de tu aplicación corriendo en Heroku.",
        "Puedes obtener retroalimentación acerca de tu proyecto de parte de tus compañeros campistas compartiéndolo en nuestro Cuarto de revisión de código. También puedes compartirlo en Twitter y en el campamento de tu ciudad (en Facebook)."
      ],
      "isRequired": false,
      "titleEs": "Crea un clon de Pinterest"
    }
  ]
}