Merge remote-tracking branch 'codecombat/master' into translation

This commit is contained in:
AkaKaras 2015-09-11 17:56:21 -04:00
commit 467dd4079b
50 changed files with 1584 additions and 1008 deletions

3
.gitignore vendored
View file

@ -94,4 +94,7 @@ login.coffee
npm-debug.log*
temp/
Dockerfile
### If you add something here, copy it to the end of .npmignore, too. ###

View file

@ -103,6 +103,7 @@ temp/
# local settings
login.coffee
Dockerfile
# debugging
*.heapsnapshot

View file

@ -1,26 +1,35 @@
sudo: false
language: node_js
node_js:
- 0.10
addons:
apt:
sources:
- mongodb-upstart
packages:
- mongodb-org-server
cache:
directories:
- node_modules
- bower_components
before_install:
- "sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 7F0CEB10"
- "echo 'deb http://downloads-distro.mongodb.org/repo/ubuntu-upstart dist 10gen' | sudo tee /etc/apt/sources.list.d/mongodb.list"
- "sudo apt-get update"
- "sudo apt-get install mongodb-org-server"
- npm install -g npm@latest
before_script:
- "npm install"
- export DISPLAY=:99.0
- export COCO_TRAVIS_TEST=1
- sh -e /etc/init.d/xvfb start
- "./node_modules/.bin/bower install"
- "gem install sass"
- "./node_modules/.bin/brunch b"
- "mkdir mongo"
- "mongod --dbpath=./mongo --fork --logpath ./mongodb.log"
- "node index.js --unittest &"
- "sleep 10" # to give node a chance to start
script:
- "./node_modules/jasmine-node/bin/jasmine-node test/server/ --coffee --captureExceptions"
# - "./node_modules/karma/bin/karma start --browsers Firefox --single-run --reporters progress"
- "./node_modules/karma/bin/karma start --browsers Firefox --single-run --reporters progress"

View file

@ -3,6 +3,7 @@
window.userObject = {_id:'1'}
window.StripeCheckout = {configure: function (){}}
initialize = require('core/initialize');
initialize.init();
console.debug = function() {}; // Karma conf doesn't seem to work? Debug messages are still emitted when they shouldn't be.

View file

@ -256,12 +256,7 @@ class CodeTreema extends TreemaNode.nodeMap.ace
constructor: ->
super(arguments...)
@workingSchema.aceTabSize = 4
buildValueForEditing: (valEl, data) ->
super(valEl, data)
if not @workingSchema.aceMode and mode = codeLanguages[@keyForParent]
@editor.getSession().setMode mode
valEl
@workingSchema.aceMode ?= mode if mode = codeLanguages[@keyForParent]
class CoffeeTreema extends CodeTreema
constructor: ->

View file

@ -206,3 +206,40 @@ module.exports.getCoursesPrice = getSponsoredSubsAmount = (courses, seats=20) ->
else
pricePerSeat = parseInt(totalPricePerSeat)
seats * pricePerSeat
module.exports.getCoursePraise = getCoursePraise = ->
praise = [
{
quote: "The kids love it."
source: "Leo Joseph Tran, Athlos Leadership Academy"
},
{
quote: "My students have been using the site for a couple of weeks and they love it."
source: "Scott Hatfield, Computer Applications Teacher, School Technology Coordinator, Eastside Middle School"
},
{
quote: "Thanks for the captivating site. My eighth graders love it."
source: "Janet Cook, Ansbach Middle/High School"
},
{
quote: "My students have started working on CodeCombat and love it! I love that they are learning coding and problem solving skills without them even knowing it!!"
source: "Kristin Huff, Special Education Teacher, Webb City School District"
},
{
quote: "I recently introduced Code Combat to a few of my fifth graders and they are loving it!"
source: "Shauna Hamman, Fifth Grade Teacher, Four Peaks Elementary School"
},
{
quote: "Overall I think it's a fantastic service. Variables, arrays, loops, all covered in very fun and imaginative ways. Every kid who has tried it is a fan."
source: "Aibinder Andrew, Technology Teacher"
},
{
quote: "I love what you have created. The kids are so engaged."
source: "Desmond Smith, 4KS Academy"
},
{
quote: "My students love the website and I hope on having content structured around it in the near future."
source: "Michael Leonard, Science Teacher, Clearwater Central Catholic High School"
}
]
praise[_.random(0, praise.length - 1)]

View file

@ -42,7 +42,7 @@ module.exports = LayerAdapter = class LayerAdapter extends CocoClass
buildAutomatically: true
buildAsync: true
resolutionFactor: SPRITE_RESOLUTION_FACTOR
defaultActions: ['idle', 'die', 'move', 'move', 'attack']
defaultActions: ['idle', 'die', 'move', 'attack']
numThingsLoading: 0
lanks: null
spriteSheet: null
@ -147,9 +147,6 @@ module.exports = LayerAdapter = class LayerAdapter extends CocoClass
#- Adding, removing children for WebGL layers.
addLank: (lank) ->
# TODO: Move this into the production DB rather than setting it dynamically.
if lank.thangType?.get('name') is 'Highlight'
lank.thangType.set('spriteType', 'segmented')
lank.options.resolutionFactor = @resolutionFactor
lank.layer = @

View file

@ -413,20 +413,20 @@ module.exports = nativeDescription: "български език", englishDescri
subscribe_title: "Абонирай се"
unsubscribe: "Прекрати абонамента"
confirm_unsubscribe: "Подтвърди прекратяване на абонамента"
# never_mind: "Never Mind, I Still Love You"
# thank_you_months_prefix: "Thank you for supporting us these last"
# thank_you_months_suffix: "months."
# thank_you: "Thank you for supporting CodeCombat."
# sorry_to_see_you_go: "Sorry to see you go! Please let us know what we could have done better."
never_mind: "Няма значение, аз все още те обичам!"
thank_you_months_prefix: "Благодарим за помоща ви през последните"
thank_you_months_suffix: "месеци."
thank_you: "Благодарим ви че подкрепихте CodeCombat."
sorry_to_see_you_go: "Съжалиаваме че ни напускате! Моля да ни предложите какво бихме могли да подобрим."
unsubscribe_feedback_placeholder: "O, къде сбъркахме?"
# parent_button: "Ask your parent"
# parent_email_description: "We'll email them so they can buy you a CodeCombat subscription."
# parent_email_input_invalid: "Email address invalid."
# parent_email_input_label: "Parent email address"
# parent_email_input_placeholder: "Enter parent email"
# parent_email_send: "Send Email"
# parent_email_sent: "Email sent!"
# parent_email_title: "What's your parent's email?"
parent_button: "Попитай родител"
parent_email_description: "Ще ги уведомим с email така че ще могат да ти купят абонамент за CodeCombat."
parent_email_input_invalid: "Email адресът е невалиден."
parent_email_input_label: "Родителски email адрес"
parent_email_input_placeholder: "Въведи email на родител"
parent_email_send: "Изпрати Email"
parent_email_sent: "Email изпратен!"
parent_email_title: "Въведете email на родител?"
parents: "За Родители"
parents_title: "Скъпи Родители: Вашето дете се учи да програмира. Ще му помогнете ли да продължи?"
parents_blurb1: "Вашето дете изигра __nLevels__ нива и научи основи на програмирането. Развийте интереса у тях като им купите абонамент - така те ще могат да продължат с игрите."
@ -485,46 +485,46 @@ module.exports = nativeDescription: "български език", englishDescri
# subscribe_prepaid: "Click Subscribe to use prepaid code"
# using_prepaid: "Using prepaid code for monthly subscription"
# choose_hero:
# choose_hero: "Choose Your Hero"
# programming_language: "Programming Language"
# programming_language_description: "Which programming language do you want to use?"
# default: "Default"
# experimental: "Experimental"
# python_blurb: "Simple yet powerful, great for beginners and experts."
# javascript_blurb: "The language of the web. (Not the same as Java.)"
# coffeescript_blurb: "Nicer JavaScript syntax."
# clojure_blurb: "A modern Lisp."
# lua_blurb: "Game scripting language."
# io_blurb: "Simple but obscure."
# status: "Status"
# hero_type: "Type"
# weapons: "Weapons"
# weapons_warrior: "Swords - Short Range, No Magic"
# weapons_ranger: "Crossbows, Guns - Long Range, No Magic"
# weapons_wizard: "Wands, Staffs - Long Range, Magic"
# attack: "Damage" # Can also translate as "Attack"
# health: "Health"
# speed: "Speed"
# regeneration: "Regeneration"
# range: "Range" # As in "attack or visual range"
# blocks: "Blocks" # As in "this shield blocks this much damage"
# backstab: "Backstab" # As in "this dagger does this much backstab damage"
# skills: "Skills"
# attack_1: "Deals"
# attack_2: "of listed"
# attack_3: "weapon damage."
# health_1: "Gains"
# health_2: "of listed"
# health_3: "armor health."
# speed_1: "Moves at"
# speed_2: "meters per second."
# available_for_purchase: "Available for Purchase" # Shows up when you have unlocked, but not purchased, a hero in the hero store
# level_to_unlock: "Level to unlock:" # Label for which level you have to beat to unlock a particular hero (click a locked hero in the store to see)
# restricted_to_certain_heroes: "Only certain heroes can play this level."
choose_hero:
choose_hero: "Избери си герой"
programming_language: "Език за програмиране"
programming_language_description: "Кой език за програмиране би искал да използваш?"
default: "По подразбиране"
experimental: "Експериментално"
python_blurb: "Прост,но мощен, идеален за начинаещи и експерти."
javascript_blurb: "Езикът на мрежата. (Не е същия като Java.)"
coffeescript_blurb: "По-добър синтаксис от JavaScript."
clojure_blurb: "Модерен Lisp."
lua_blurb: "Скриптен език за игри."
io_blurb: "Прост, но неизвестен."
status: "Статус"
hero_type: "Тип"
weapons: "Оръжия"
weapons_warrior: "Мечове - Къс Обсег, Без Магия"
weapons_ranger: "Арбалети, Пистолети - Далечен Обсег, Без магия"
weapons_wizard: "Жезли, Принадлежности - Далечен Обсег, Магия"
attack: "Щета" # Може също да се преведе като "Атака"
health: "Здраве"
speed: "Скорост"
regeneration: "Възстановяване"
range: "Обсег" # както в "обсег на атаката или визуален обсег"
blocks: "Защита" # както в "този щит може да те защити от много удари"
backstab: "Удар в гърба" # както в "тази кама може да е много опасна при удар в гърба"
skills: "Умения"
attack_1: "Количество"
attack_2: "на изброените"
attack_3: "щети от оръжия."
health_1: "Печалби"
health_2: "от изброените"
health_3: "защитни брони."
speed_1: "Движения"
speed_2: "в метри за секунда"
available_for_purchase: "На разположение за закупуване" # Показва се когато сте достигнали, но не сте закупили герой от магазина за герои "
level_to_unlock: "Ниво на отключване:" # Етикет за нивото, което трябва да достигнеш за да отключиш определен герой (кликни на заключения герой в магазина за да видиш)
restricted_to_certain_heroes: "Само определени герои могат да играят това ниво."
# skill_docs:
# writable: "writable" # Hover over "attack" in Your Skills while playing a level to see most of this
# writable: "writable" # Hover over "attack" in Your Skils while playing a level to see most of this
# read_only: "read-only"
# action_name: "name"
# action_cooldown: "Takes"

View file

@ -410,6 +410,7 @@
feature7: "Private <strong>Clans</strong>"
free: "Free"
month: "month"
must_be_logged: "You must be logged in first. Please create an account or log in from the menu above."
subscribe_title: "Subscribe"
unsubscribe: "Unsubscribe"
confirm_unsubscribe: "Confirm Unsubscribe"
@ -613,6 +614,7 @@
free_1: "There are 110+ FREE levels which cover every concept."
free_2: "A monthly subscription provides access to video tutorials and extra practice levels."
teacher_subs_title: "Teachers get free subscriptions!"
teacher_subs_0: "We offer free subscriptions to teachers for evaluation purposes."
teacher_subs_1: "Please fill out our"
teacher_subs_2: "Teacher Survey"
teacher_subs_3: "to set up your subscription."

View file

@ -255,8 +255,8 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
victory_new_item: "Objeto Nuevo"
victory_viking_code_school: "Santo cielo, Holy smokes, el nivel que acabas de pasar era dificil! Si todavía no eres un desarrollador de software, deberías serlo. Acabas de conseguir una aceptación por vía rápida con la Escuela Vikinga de Có, donde tú puedes llevar tus habilidades al siguiente nivel y convertirteen un desarrollador web profesional en 14 semanas."
victory_become_a_viking: "Conviértete en un Vikingo"
# victory_bloc: "Great work! Your skills are improving, and someone's taking notice. If you've considered becoming a software developer, this may be your lucky day. Bloc is an online bootcamp that pairs you 1-on-1 with an expert mentor who will help train you into a professional developer! By beating A Mayhem of Munchkins, you're now eligible for a $500 price reduction with the code: CCRULES"
# victory_bloc_cta: "Meet your mentor learn about Bloc"
# victory_bloc: "¡Buen trabajo! Tus habilidades están mejorando, y alguien ya se dió cuenta. Si has considerado convertirte en un desarrollador de software, este podría ser tu día de suerte. Bloc es un online bootcamp que te pairs 1-on-1 with an expert mentor who will help train you into a professional developer! By beating A Mayhem of Munchkins, you're now eligible for a $500 price reduction with the code: CCRULES"
victory_bloc_cta: "Conoce a tu mentor aprende acerca de Bloc"
guide_title: "Guía"
tome_minion_spells: "Hechizos de tus Secuaces" # Only in old-style levels.
tome_read_only_spells: "Hechizos de Sólo Lectura" # Only in old-style levels.
@ -438,19 +438,19 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
payment_methods_blurb1: "Actualmente aceptamos tarjetas de credito y Alipay."
payment_methods_blurb2: "Si necesitas una forma alternativa de pago, por favor contactarse"
# sale_already_subscribed: "You're already subscribed!"
# sale_blurb1: "Save 35%"
sale_blurb1: "Ahorra 35%"
# sale_blurb2: "off regular subscription price of $120 for a whole year!" # {changed}
# sale_button: "Sale!"
# sale_button_title: "Save 35% when you purchase a 1 year subscription"
# sale_click_here: "Click Here"
# sale_ends: "Ends"
sale_click_here: "Haz Click Aquí"
sale_ends: "Termina"
# sale_extended: "*Existing subscriptions will be extended by 1 year."
# sale_feature_here: "Here's what you'll get:"
# sale_feature2: "Access to 9 powerful <strong>new heroes</strong> with unique skills!"
# sale_feature4: "<strong>42,000 bonus gems</strong> awarded immediately!"
# sale_continue: "Ready to continue adventuring?"
# sale_limited_time: "Limited time offer!"
# sale_new_heroes: "New heroes!"
sale_limited_time: "¡Oferta por tiempo limitado!"
sale_new_heroes: "¡Nuevos héroes!"
# sale_title: "Back to School Sale"
# sale_view_button: "Buy 1 year subscription for"
stripe_description: "Suscripción Mensual"
@ -547,7 +547,7 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
options:
general_options: "Opciones Generales" # Check out the Options tab in the Game Menu while playing a level
volume_label: "Volumen"
volume_label: "Volúmen"
music_label: "Música"
music_description: "Música encendida/apagada."
editor_config: "Config. de Editor"
@ -582,7 +582,7 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
press_paragraph_1_link: "paquete de prensa"
press_paragraph_1_suffix: ". Todos los logos e imágenes pueden ser usados sin contactarnos directamente."
team: "Equipo"
george_title: "CEO" # {change}
george_title: "Director Ejecutivo"
george_blurb: "Negociante"
scott_title: "Programador" # {change}
scott_blurb: "Razonable"
@ -665,10 +665,10 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
denied_2: "denegada."
contact_1: "Por favor contáctenos"
contact_2: "si tiene más preguntas."
# description_1: "We offer free subscriptions to teachers for evaluation purposes. You can find more information on our"
# description_1: "Ofrecemos free subscriptions to teachers for evaluation purposes. You can find more information on our"
description_2: "página"
description_3: "de maestros."
# description_4: "Please fill out this quick survey and well email you setup instructions."
# description_4: "Por favor fill out this quick survey and well email you setup instructions."
email: "Dirección de email"
school: "Nombre del colegio"
location: "Nombre de la ciudad"
@ -688,7 +688,7 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
cla_url: "CLA"
cla_suffix: "."
cla_agree: "ACEPTO"
# owner_approve: "An owner will need to approve it before your changes will become visible."
owner_approve: "Un dueño necesitará aprobarlo antes de que tus cambios puedan ser visibles."
contact:
contact_us: "Contacta a CodeCombat"
@ -779,12 +779,12 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
introduction: "Mira las maneras en las que puedes involucrarte adelante y decide qué es más divertido. ¡Queremos trabajar contigo!"
level_editor_prefix: "Usar CodeCombat"
level_editor_suffix: "para crear y editar niveles. Los han creado niveles para sus clases, amigos, hackatones, estudiantes, familiares. Si crear un nuevo juego luce intimidante puedes ¡comenzar con base en uno nuestro!"
thang_editor_prefix: "Nosotros llamamos a las unidades del juego 'thangs'. Usa el"
thang_editor_prefix: "Nosotros llamamos a las unidades del juego 'Tiliches'. Usa el"
thang_editor_suffix: "para modificar el arte de CodeCombat. Permite a las unidades lanzar proyectiles, altera la dirección de una animación, cambia los puntos de vida de una unidad o sube tu propio sprite de vectores."
article_editor_prefix: "¿Ves algún error en nuestros documentos? ¿Quieres hacer algunas instrucciones para tus propias creaciones? Revisa el"
article_editor_suffix: "y ayuda a los jugadores de CodeCombat conseguir lo más posible de su tiempo jugando."
find_us: "Encuentranos en etsos sitios"
# social_github: "Check out all our code on GitHub"
social_github: "Checa todo nuestro código en el GitHub"
social_blog: "Lee el blog de CodeCombat en Sett"
social_discource: "Unite a la discusión en nuestro foro"
social_facebook: "Me Gusta CodeCombat en Facebook"
@ -806,7 +806,7 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
my_clans: "Mis Clanes"
clan_name: "Nombre del clan"
name: "Nombre"
# chieftain: "Chieftain"
chieftain: "Cacique/Líder" #Chieftain/Leader literally
type: "Tipo"
edit_clan_name: "Editar el nombre del Clan"
edit_clan_description: "Editar descripción del clan"
@ -836,7 +836,7 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
latest_achievement: "último logro"
playtime: "Tiempo de juego"
last_played: "Último jugado"
# leagues_explanation: "Play in a league against other clan members in these multiplayer arena instances."
# leagues_explanation: "Juega en una liga contra otros miembros del clan en these multiplayer arena instances."
classes:
archmage_title: "Archimago"
@ -861,7 +861,7 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
editor:
main_title: "Editor de CodeCombat"
article_title: "Editor de Artículo"
thang_title: "Editor de Thangs"
thang_title: "Editor de Tiliches"
level_title: "Editor de Nivel"
achievement_title: "Editor de logros"
poll_title: "Editor de Encuesta"
@ -884,23 +884,23 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
wiki: "Wiki"
live_chat: "Chat en vivo"
thang_main: "Principal"
thang_spritesheets: "Spritesheets"
thang_spritesheets: "Hojas de figuras( para animaciones )"
thang_colors: "Colores"
level_some_options: "¿Algunas opciones?"
level_tab_thangs: "Thangs"
level_tab_thangs: "Tiliches" #Verificar cual es mejor: Cachivache, Tiliche, Artilugio, Bagatela, Cosa
level_tab_scripts: "Scripts"
level_tab_settings: "Opciones"
level_tab_components: "Componentes"
level_tab_systems: "Sistemas"
level_tab_docs: "Documentación"
level_tab_thangs_title: "Thangs Actuales"
level_tab_thangs_title: "Tiliches Actuales"
level_tab_thangs_all: "Todo"
level_tab_thangs_conditions: "Condiciones Iniciales"
level_tab_thangs_add: "Agregar Thangs"
# level_tab_thangs_search: "Search thangs"
level_tab_thangs_add: "Agregar Tiliches"
level_tab_thangs_search: "Buscar thangs"
add_components: "Agregar Componentes"
component_configs: "Configuraciones del Componente"
config_thang: "Doble clic para configurar un thang"
config_thang: "Doble clic para configurar un Tiliche"
delete: "Borrar"
duplicate: "Duplicar"
stop_duplicate: "Parar de Duplicar"
@ -911,7 +911,7 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
level_systems_tab_title: "Sistemas Actuales"
level_systems_btn_new: "Crear Nuevo Sistema"
level_systems_btn_add: "Agregar Sistema"
level_components_title: "Regresar a todos los Thangs"
level_components_title: "Regresar a todos los Tiliches"
level_components_type: "Tipo"
level_component_edit_title: "Editar Componente"
level_component_config_schema: "Config Schema"
@ -921,17 +921,17 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
new_component_title: "Crear Nuevo Componente"
new_component_field_system: "Sistema"
new_article_title: "Crear un Nuevo Artículo"
new_thang_title: "Crear un Nuevo tipo de Thang"
new_thang_title: "Crear un Nuevo tipo de Tiliche"
new_level_title: "Crear un Nuevo Nivel"
new_article_title_login: "Ingresa para Crear un Nuevo Artículo"
new_thang_title_login: "Ingresa para crear un nuevo tipo de Thang"
new_thang_title_login: "Ingresa para crear un nuevo tipo de Tiliche"
new_level_title_login: "Ingresa para Crear un Nuevo Nivel"
new_achievement_title: "Crear un Nuevo Logro"
new_achievement_title_login: "Ingresa para Crear un Nuevo Logro"
new_poll_title: "Crear una nueva encuesta"
new_poll_title_login: "Ingresa para crear una nueva encuesta"
article_search_title: "Buscar Artículos aquí"
thang_search_title: "Buscar tipos de Thang aquí"
thang_search_title: "Buscar tipos de Tiliche aquí"
level_search_title: "Buscar Niveles aquí"
achievement_search_title: "Buscar logros"
poll_search_title: "Buscar Encuesta"
@ -943,8 +943,8 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
pop_i18n: "Poblar I18N"
tasks: "Tareas"
clear_storage: "Borrar tus cambios locales"
# add_system_title: "Add Systems to Level"
# done_adding: "Done Adding"
add_system_title: "Agregar Sistemas al Level"
done_adding: "Se terminó de agregar"
article:
edit_btn_preview: "Vista previa"
@ -1026,7 +1026,7 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
my_matches: "Mis Partidas"
simulate: "Simular"
simulation_explanation: "¡Simulando tus juegos puedes mejorar tu posición más rápido!"
# simulation_explanation_leagues: "You will mainly help simulate games for allied players in your clans and courses."
# simulation_explanation_leagues: "Principalmente ayudarás a simular juegos for allied players in your clans and courses."
simulate_games: "¡Simular Juegos!"
simulate_all: "REINICIAR Y SIMULAR JUEGOS"
games_simulated_by: "Juegos simulados por ti:"
@ -1047,7 +1047,7 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
rank_failed: "Fallo al Clasificar"
rank_being_ranked: "Juego Siendo Clasificado"
rank_last_submitted: "Presentado"
help_simulate: "Ayudar simulando juego?"
help_simulate: "¿Ayudar simulando juego?"
code_being_simulated: "Tu nuevo código está siendo simulado por otros jugadores para clasificación. Esto se refrescará a medida que vengan nuevas partidas."
no_ranked_matches_pre: "Sin partidas clasificadas para el "
no_ranked_matches_post: " equipo! Juega en contra de algunos competidores y luego vuelve aquí para ver tu juego clasificado."
@ -1077,7 +1077,7 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
tournament_blurb_blog: "en nuestro blog"
rules: "Reglas"
winners: "Ganadores"
# league: "League"
league: "Liga"
user:
stats: "Estados"
@ -1093,7 +1093,7 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
no_achievements: "Sin Logros todavía."
favorite_prefix: "Idioma favorito "
favorite_postfix: "."
not_member_of_clans: "No se es miembro de ningún clan todavía."
not_member_of_clans: "No eres miembro de ningún clan todavía."
achievements:
last_earned: "Último Ganado"
@ -1118,7 +1118,7 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
no_recent_games: "No juegos jugados duramente las últimas dos semanas."
payments: "Pagos"
purchased: "Comprado"
# sale: "Sale"
sale: "Venta"
subscription: "Suscripción"
invoices: "Facturas"
service_apple: "Apple"
@ -1128,14 +1128,14 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
price: "Precio"
gems: "Gemas"
active: "Activo"
subscribed: "Suscripto"
unsubscribed: "Insuscripto"
subscribed: "Suscrito"
unsubscribed: "Desuscrito"
active_until: "Activo Hasta"
cost: "Costo"
next_payment: "Próximo Pago"
card: "Tarjeta"
status_unsubscribed_active: "No estas suscripto y no se te cobrará, pero tu cuenta está activa por ahora."
status_unsubscribed: "Obtén acceso a nuevos niveles, heroés, items y gemas extras con la suscripción a CodeCombat!"
status_unsubscribed_active: "No estas suscrito y no se te cobrará, pero tu cuenta está activa por ahora."
status_unsubscribed: "¡Obtén acceso a nuevos niveles, héroes, items y gemas extras con la suscripción a CodeCombat!"
account_invoices:
amount: "Cantidad en dólares."
@ -1181,13 +1181,13 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
systems: "Sistemas"
component: "Componente"
components: "Componentes"
thang: "Thang"
thangs: "Thangs"
thang: "Tiliche"
thangs: "Tiliches"
level_session: "Tu Sesión"
opponent_session: "Sesión del Oponente"
article: "Artícule"
user_names: "Nombres de usuario"
thang_names: "Nombres de thang"
thang_names: "Nombres de Tiliche"
files: "Archivos"
top_simulators: "Mejores simuladores"
source_document: "Documento fuente"
@ -1211,35 +1211,35 @@ module.exports = nativeDescription: "Español (América Latina)", englishDescrip
poll: "Encuesta"
user_polls_record: "Historia de Visitas de Encuestas"
# concepts:
# advanced_strings: "Advanced Strings"
# algorithms: "Algorithms"
# arguments: "Arguments"
# arithmetic: "Arithmetic"
# arrays: "Arrays"
# basic_syntax: "Basic Syntax"
# boolean_logic: "Boolean Logic"
concepts:
advanced_strings: "Manipulación Avanzada de Cadenas" #used Advanced Strings Handling instead of Advanced Strings
algorithms: "Algoritmos"
arguments: "Argumentos"
arithmetic: "Aritmética"
arrays: "Arreglos"
basic_syntax: "Sintaxis Básica"
boolean_logic: "Lógica Booleana"
# break_statements: "Break Statements"
# classes: "Classes"
classes: "Clases"
# continue_statements: "Continue Statements"
# for_loops: "For Loops"
# functions: "Functions"
# graphics: "Graphics"
for_loops: "Ciclos For"
functions: "Funciones"
graphics: "Gráficos"
# if_statements: "If Statements"
# input_handling: "Input Handling"
# math_operations: "Math Operations"
math_operations: "Operaciones Matemáticas"
# object_literals: "Object Literals"
# parameters: "Parameters"
# strings: "Strings"
# variables: "Variables"
# vectors: "Vectors"
# while_loops: "Loops"
# recursion: "Recursion"
parameters: "Parámetros"
strings: "Cadenas"
variables: "Variables"
vectors: "Vectores"
while_loops: "Ciclos While"
recursion: "Recursividad"
delta:
added: "Agregado"
modified: "Modificado"
# not_modified: "Not Modified"
not_modified: "No Modificado"
deleted: "Borrado"
moved_index: "Índice movido"
text_diff: "Diferir Texto"

View file

@ -180,7 +180,7 @@ module.exports = nativeDescription: "suomi", englishDescription: "Finnish", tran
password: "Salasana"
message: "Viesti"
code: "Koodi"
ladder: "Sarja"
ladder: "Liiga"
when: "Kun"
opponent: "Vastustaja"
rank: "Arvo"
@ -242,7 +242,7 @@ module.exports = nativeDescription: "suomi", englishDescription: "Finnish", tran
victory_sign_up: "Kirjaudu"
victory_sign_up_poke: "Haluatko tallettaa koodisi? Luo ilmainen tili!"
# victory_rate_the_level: "Rate the level: " # Only in old-style levels.
victory_return_to_ladder: "Palaa sarjaan"
victory_return_to_ladder: "Palaa liigaan"
victory_play_continue: "Jatka"
victory_saving_progress: "Tallennetaan edistymisesi"
victory_go_home: "Takaisin kotiin"
@ -1097,70 +1097,70 @@ module.exports = nativeDescription: "suomi", englishDescription: "Finnish", tran
favorite_postfix: "."
not_member_of_clans: "Ei klaanien jäsenyyksiä."
# achievements:
# last_earned: "Last Earned"
# amount_achieved: "Amount"
# achievement: "Achievement"
# category_contributor: "Contributor"
# category_ladder: "Ladder"
# category_level: "Level"
# category_miscellaneous: "Miscellaneous"
# category_levels: "Levels"
# category_undefined: "Uncategorized"
# current_xp_prefix: ""
# current_xp_postfix: " in total"
# new_xp_prefix: ""
# new_xp_postfix: " earned"
# left_xp_prefix: ""
# left_xp_infix: " until level "
# left_xp_postfix: ""
achievements:
last_earned: "Viimeisin saavutus"
amount_achieved: "Yhteensä"
achievement: "Saavutus"
category_contributor: "Avustamiset"
category_ladder: "Liiga"
category_level: "Taso"
category_miscellaneous: "Muut"
category_levels: "Tasot"
category_undefined: "Kategorisoimattomat"
current_xp_prefix: ""
current_xp_postfix: " yhteensä"
new_xp_prefix: ""
new_xp_postfix: " ansaittu"
left_xp_prefix: ""
left_xp_infix: " jäljellä tasoon "
left_xp_postfix: ""
# account:
# recently_played: "Recently Played"
# no_recent_games: "No games played during the past two weeks."
# payments: "Payments"
# purchased: "Purchased"
# sale: "Sale"
# subscription: "Subscription"
# invoices: "Invoices"
# service_apple: "Apple"
# service_web: "Web"
# paid_on: "Paid On"
# service: "Service"
# price: "Price"
# gems: "Gems"
# active: "Active"
# subscribed: "Subscribed"
# unsubscribed: "Unsubscribed"
# active_until: "Active Until"
# cost: "Cost"
# next_payment: "Next Payment"
# card: "Card"
# status_unsubscribed_active: "You're not subscribed and won't be billed, but your account is still active for now."
# status_unsubscribed: "Get access to new levels, heroes, items, and bonus gems with a CodeCombat subscription!"
account:
recently_played: "Viimeisin peli"
no_recent_games: "Ei pelejä viimeisen kahden viikon aikana."
payments: "Ostot"
purchased: "Ostettu"
sale: "Alennus"
subscription: "Kuukausitilaus"
invoices: "Laskut"
service_apple: "Apple"
service_web: "Netti"
paid_on: "Maksettu"
service: "Palvelu"
price: "Hinta"
gems: "Jalokivet"
active: "Voimassa"
subscribed: "Kirjautunut"
unsubscribed: "Ei kirjautunut"
active_until: "Voimassa asti"
cost: "Hinta"
next_payment: "Seuraava maksu"
card: "Kortti"
status_unsubscribed_active: "Tilauksesi ei ole aktiivinen ja sinua ei laskuteta, mutta etusi ovat vielä voimassa."
status_unsubscribed: "Hanki käyttöösi uusia tasoja, sankareita, esineitä ja lisää jalokiviä CodeCombat kuukausitilauskella!"
# account_invoices:
# amount: "Amount in US dollars"
# declined: "Your card was declined"
# invalid_amount: "Please enter a US dollar amount."
# not_logged_in: "Log in or create an account to access invoices."
# pay: "Pay Invoice"
# purchasing: "Purchasing..."
# retrying: "Server error, retrying."
# success: "Successfully paid. Thanks!"
account_invoices:
amount: "Hinta US dollareina"
declined: "Luottokorttisimaksu hylätty"
invalid_amount: "Ole hyvä ja syötä määrä US dollareina."
not_logged_in: "Kirjaudu sisään tai luo tili katosaksi laskujanne."
pay: "Suorita maksu"
purchasing: "Käsitellään..."
retrying: "Palvelinvirhe, yritetään uudelleen."
success: "Maksu onnistui. Kiitos!"
# loading_error:
# could_not_load: "Error loading from server"
# connection_failure: "Connection failed."
# unauthorized: "You need to be signed in. Do you have cookies disabled?"
# forbidden: "You do not have the permissions."
# not_found: "Not found."
# not_allowed: "Method not allowed."
# timeout: "Server timeout."
# conflict: "Resource conflict."
# bad_input: "Bad input."
# server_error: "Server error."
# unknown: "Unknown error."
loading_error:
could_not_load: "Virhe ladattaessa tietoja palvelimelta"
connection_failure: "Yhteysvirhe."
unauthorized: "Teidän tulee olla kirjautuneena sisään. Ovatko evästeet sallittuna?"
forbidden: "Ei käyttöoikeuttta."
not_found: "Ei löydetty."
not_allowed: "Toiminto ei sallittu."
timeout: "Toiminto aikakatkaistu."
conflict: "Resurssiristiriita."
bad_input: "Virheellinen syöte."
server_error: "Palvelinvirhe."
unknown: "Tuntematon virhe."
# resources:
# sessions: "Sessions"

View file

@ -99,13 +99,13 @@ module.exports = nativeDescription: "Português do Brasil", englishDescription:
authenticate_gplus: "Autenticar com G+"
load_profile: "Carregar Perfil do G+"
finishing: "Terminando"
sign_in_with_facebook: "Conectar com Facebook"
sign_in_with_gplus: "Conectar com G+"
sign_in_with_facebook: "Conectar com o Facebook"
sign_in_with_gplus: "Conectar com o G+"
signup_switch: "Deseja Criar uma Conta?"
signup:
email_announcements: "Receber notícias por email."
creating: "Criando a nova conta..."
creating: "Criando uma nova conta..."
sign_up: "Criar conta"
log_in: "Entre com a senha"
social_signup: "Ou, você pode fazer login pelo Facebook ou G+:"
@ -137,7 +137,7 @@ module.exports = nativeDescription: "Português do Brasil", englishDescription:
publish: "Publicar"
create: "Criar"
manual: "Manual"
fork: "Fork"
fork: "Fork" # When used as a verb, like "To fork a repository"
play: "Jogar" # When used as an action verb, like "Play next level"
retry: "Tente novamente"
actions: "Ações"
@ -239,7 +239,7 @@ module.exports = nativeDescription: "Português do Brasil", englishDescription:
victory: "Vitória"
victory_title_prefix: " Vitória "
victory_title_suffix: " Completado!"
victory_sign_up: "Assine para atualizações"
victory_sign_up: "Assine para receber atualizações"
victory_sign_up_poke: "Quer receber as últimas novidades por email? Crie uma conta grátis e nós o manteremos informado!"
victory_rate_the_level: "Avalie o estágio: " # Only in old-style levels.
victory_return_to_ladder: "Retornar para a progressão"
@ -251,7 +251,7 @@ module.exports = nativeDescription: "Português do Brasil", englishDescription:
victory_hour_of_code_done: "Terminou?"
victory_hour_of_code_done_yes: "Sim, eu terminei minha Hora da Programação!"
victory_experience_gained: "XP ganho"
victory_gems_gained: "Gems ganhas"
victory_gems_gained: "Gemas ganhas"
victory_new_item: "Novo item"
victory_viking_code_school: "Pelas barbas do profeta, esse foi um nível difícil! Se você ainda não é um desenvolvedor de software, você deveria ser. Você acaba de ser priorizado para aceitação na Viking Code School, onde você pode aprender mais e se tornar um desenvolvedor web profissional em 14 semanas."
victory_become_a_viking: "Torne-se um viking"
@ -288,15 +288,15 @@ module.exports = nativeDescription: "Português do Brasil", englishDescription:
infinite_loop_title: "Loop Infinito Detectado"
infinite_loop_description: "O código inicial para construir o mundo nunca parou de rodar. Talvez seja muito lento ou tenha um loop infinito. Ou talvez tenha um bug. Você pode tentar rodar este código novamente ou resetá-lo para o estado inicial. Se isto não consertá-lo, avise-nos por favor."
check_dev_console: "Você também pode abrir o terminal do desenvolvedor para ver o que pode estar dando errado."
check_dev_console_link: "(instruções)"
check_dev_console_link: "(Instruções)"
infinite_loop_try_again: "Tentar novamente"
infinite_loop_reset_level: "Resetar nível"
infinite_loop_comment_out: "Comentar Meu Código"
tip_toggle_play: "Alterne entre rodando/pausado com Ctrl+P."
tip_scrub_shortcut: "Ctrl+[ e Ctrl+] rebobina e avança." # {change}
tip_guide_exists: "Clique no guia no topo da página para informações úteis."
tip_scrub_shortcut: "Ctrl+[ e Ctrl+] Rebobinar e Avançar."
tip_guide_exists: "Clique no guia no topo da página para ter informações úteis."
tip_open_source: "CodeCombat é 100% código aberto!"
tip_tell_friends: "Está gostando de CodeCombate? Dibulgue para os seus amigos!"
tip_tell_friends: "Está gostando do CodeCombat? Divulgue para os seus amigos!"
tip_beta_launch: "CodeCombat lançou sua versão beta em outubro de 2013."
tip_think_solution: "Pense na solução, não no problema."
tip_theory_practice: "Na teoria, não existe diferença entre teoria e prática. Mas, na prática, há. - Yogi Berra"
@ -304,7 +304,7 @@ module.exports = nativeDescription: "Português do Brasil", englishDescription:
tip_debugging_program: "Se depurar é o processo de remover erros, então programar deve ser o processo de adicioná-los. - Edsger W. Dijkstra"
tip_forums: "Vá aos fóruns e diga-nos o que você pensa!"
tip_baby_coders: "No futuro, até bebês serão Arquimagos."
tip_morale_improves: "O carregamento continuará até que a ânimo melhore."
tip_morale_improves: "O carregamento continuará até que a ânimo melhore." # {change}
tip_all_species: "Nós acreditamos em oportunidades iguais para todas as espécies aprenderem a programar."
tip_reticulating: "Reticulando espinhas."
tip_harry: "Você é um Feiticeiro, "
@ -315,32 +315,32 @@ module.exports = nativeDescription: "Português do Brasil", englishDescription:
tip_no_try: "Faça. Ou não faça. Não existe tentar. - Yoda"
tip_patience: "Paciência você deve ter, jovem Padawan. - Yoda"
tip_documented_bug: "Um bug documentado não é um bug; é uma funcionalidade."
tip_impossible: "Sempre parece impossível, até ser feito. - Nelson Mandela"
tip_impossible: "Tudo parece impossível, até que seja feito. - Nelson Mandela"
tip_talk_is_cheap: "Falar é fácil. Mostre-me o código. - Linus Torvalds"
tip_first_language: "A coisa mais desastrosa que você pode aprender é a sua primeira linguagem de programação. - Alan Kay"
tip_hardware_problem: "P: Quantos programadores são necessários para se trocar uma lâmpada? R: Nenhum, é um problema de hardware."
tip_hofstadters_law: "Lei de Hofstadter: Sempre demora mais do que você espera, mesmo quando você leva em consideração a Lei de Hofstadter."
tip_premature_optimization: "Uma otimização permatura é a raíz de todos os males. - Donald Knuth"
tip_hardware_problem: "P: Quantos programadores são necessários para se trocar uma lâmpada? R: Nenhum! Isso é um problema de hardware."
tip_hofstadters_law: "Lei de Hofstadter: Tudo demora mais do que você espera, mesmo quando você leva em consideração a Lei de Hofstadter."
tip_premature_optimization: "Uma otimização prematura é a raíz de todos os males. - Donald Knuth"
tip_brute_force: "Na dúvida, utilize força bruta. - Ken Thompson"
tip_extrapolation: "Existem dois tipos de pessoa: aqueles que podem extrapolar apartir de dados incompletos..."
tip_superpower: "Programar é a coisa mais próxima de termos super poderes."
tip_extrapolation: "Existem dois tipos de pessoa: Aqueles que podem extrapolar apartir de dados incompletos..."
tip_superpower: "Programar é a coisa mais próxima de ter super poderes."
tip_control_destiny: "No verdadeiro código aberto, você tem o direito de controlar seu próprio destino. - Linus Torvalds"
tip_no_code: "Nenhum código é mais rápido que código nenhum. - Kevlin Henney"
tip_code_never_lies: "Código nunca mente, comentários as vezes. — Ron Jeffries"
tip_reusable_software: "Antes do software ser reutilizável, ele primeiro tem que ser utilizável."
tip_code_never_lies: "O código nunca mente, os comentários as vezes. — Ron Jeffries"
tip_reusable_software: "Antes do software ser reutilizável, ele primeiro precisa ser utilizável."
tip_optimization_operator: "Cada linguagem tem um operador de otimização. Na maioria delas esse operador é //"
tip_lines_of_code: "Medir o progresso de programação em linhas de código é como medir a construção de aeronaves pelo peso. — Bill Gates"
tip_source_code: "Eu gostaria de mudar o Mundo, mas eles não me deram o código fonte."
tip_javascript_java: "Java é para o JavaScript o que um Carro é para um Carpete. - Chris Heilmann"
tip_move_forward: "O que quer que você faça, continue indo em frente. - Martin Luther King Jr."
tip_move_forward: "O que quer que você faça, continue em frente de qualquer jeito. - Martin Luther King Jr."
tip_google: "Tem um problema que você não pode solucionar? Google!"
tip_adding_evil: "Adicionando uma pitada de maldade."
tip_hate_computers: "As pessoas realmente pensam porque odeiam computadores. O que eles realmente odeiam são programadores ruins. - Larry Niven"
tip_hate_computers: "As pessoas realmente pensam que odeiam computadores. O que elas realmente odeiam são programadores ruins. - Larry Niven"
tip_open_source_contribute: "Você pode ajudar CodeCombat a melhorar!"
tip_recurse: "Para iterar é humano, para recursão, é divino. - L. Peter Deutsch"
tip_free_your_mind: "Você tem que deixar isso tudo passar, Neo. O medo, a dúvida e a descrença. Liberte sua mente - Morpheus"
tip_strong_opponents: "Mesmo o mais forte dos adversários tem sua fraqueza. - Itachi Uchiha"
tip_paper_and_pen: "Antes de começar a programar, você sempre pode planejar com papel e caneta."
tip_paper_and_pen: "Antes de começar a programar, você sempre deve planejar com papel e caneta."
game_menu:
inventory_tab: "Inventário"
@ -352,15 +352,15 @@ module.exports = nativeDescription: "Português do Brasil", englishDescription:
multiplayer_tab: "Multijogador"
auth_tab: "Registrar"
inventory_caption: "Equipar seu herói"
choose_hero_caption: "Escolha seu herói, linguagem"
choose_hero_caption: "Escolha seu herói, e linguagem"
save_load_caption: "... e visualizar o histórico"
options_caption: "Configurar preferências"
guide_caption: "Documentos e dicas"
guide_caption: "Documentos e Dicas"
multiplayer_caption: "Jogue com seus amigos!"
auth_caption: "Salve seu progresso."
leaderboard:
leaderboard: "Líderança"
leaderboard: "Líderança" # {rankings?}
view_other_solutions: "Ver Outras Soluções" # {change}
scores: "Pontuação"
top_players: "Top Jogadores por"
@ -379,10 +379,10 @@ module.exports = nativeDescription: "Português do Brasil", englishDescription:
required_purchase_title: "Obrigatório"
available_item: "Disponível"
restricted_title: "Restrito"
should_equip: "(dois cliques para equipar)"
equipped: "(equipado)"
locked: "(trancado)"
restricted: "(restrito nesse nível)"
should_equip: "(Dois cliques para equipar)"
equipped: "(Equipado)"
locked: "(Trancado)"
restricted: "(Restrito nesse nível)"
equip: "Equipar"
unequip: "Desequipar"
@ -393,10 +393,10 @@ module.exports = nativeDescription: "Português do Brasil", englishDescription:
purchasing: "Comprando..."
declined: "Seu cartão foi rejeitado, desculpe."
retrying: "Erro de servidor, tentando novamente."
prompt_title: "Gemas insulficientes"
prompt_body: "Você quer conseguir mais gemas?"
prompt_title: "Gemas insuficientes"
prompt_body: "Você quer adquirir mais gemas?"
prompt_button: "Entrar na loja"
recovered: "Gemas de compras anteriores Recuperadas. Por favor atualize a pagina."
recovered: "Gemas das compras anteriores recuperadas. Por favor atualize a pagina."
price: "x3500 / mês"
subscribe:
@ -582,15 +582,15 @@ module.exports = nativeDescription: "Português do Brasil", englishDescription:
press_paragraph_1_link: "Midia Kit"
press_paragraph_1_suffix: ". Todas as logomarcas e imagens podem ser usadas sem nos contactar previamente."
team: "Time"
george_title: "CEO" # {change}
george_title: "Cofundador"
george_blurb: "Administrador"
scott_title: "Programador" # {change}
scott_title: "Cofundador"
scott_blurb: "O Sensato"
nick_title: "Programador" # {change}
nick_title: "Cofundador"
nick_blurb: "Guru Motivacional"
michael_title: "Programador"
michael_blurb: "Administrador de Sistemas"
matt_title: "Programador" # {change}
matt_title: "Cofundador"
matt_blurb: "O Ciclista"
cat_title: "Chefe Artesão"
cat_blurb: "Corta-vento"
@ -1354,7 +1354,7 @@ module.exports = nativeDescription: "Português do Brasil", englishDescription:
next_name: "Nome?"
next_short_description: "escreva uma breve descrição."
next_long_description: "descreva o tipo de vaga ou cargo desejados."
next_skills: "relacione pelo menos cinco habilidades."
next_skills: "liste pelo menos cinco habilidades."
next_work: "descreva seu histórico de trabalho."
next_education: "descreva seu percurso acadêmico."
next_projects: "mostre até três projetos nos quais você trabalhou."
@ -1411,7 +1411,7 @@ module.exports = nativeDescription: "Português do Brasil", englishDescription:
work_duration: "Duração"
work_duration_help: "Por quanto tempo?"
work_description: "Descrição"
work_description_help: "O que você fez lá? (140 carac.; opcional)"
work_description_help: "O que você fez lá? (140 carac; opcional)"
education: "Educação"
education_header: "Descreva seu percurso acadêmico"
education_blurb: "Liste seu percurso acadêmico."

View file

@ -406,10 +406,11 @@ module.exports = nativeDescription: "Português (Portugal)", englishDescription:
feature3: "70+ níveis de bónus"
feature4: "<strong>3500 gemas de bónus</strong> por mês!"
feature5: "Tutoriais em vídeo"
feature6: "Apoio por e-mail superior"
feature6: "Apoio por e-mail prioritário"
feature7: "<strong>Clãs</strong> Privados"
free: "Grátis"
month: "mês"
must_be_logged: "Primeiro tens de ter sessão iniciada. Por favor, cria uma conta ou inicia sessão a partir do menu acima."
subscribe_title: "Subscrever"
unsubscribe: "Cancelar Subscrição"
confirm_unsubscribe: "Confirmar Cancelamento da Subscrição"
@ -420,7 +421,7 @@ module.exports = nativeDescription: "Português (Portugal)", englishDescription:
sorry_to_see_you_go: "Lamentamos ver-te partir! Por favor, diz-nos o que podíamos ter feito melhor."
unsubscribe_feedback_placeholder: "Oh, o que fomos fazer?"
parent_button: "Pergunta ao teu educador"
parent_email_description: "Vamos mandar-lhe um e-mail para que ele possa comprar-te uma subscrição do CodeCombat."
parent_email_description: "Vamos enviar-lhe um e-mail para que possa comprar-te uma subscrição do CodeCombat."
parent_email_input_invalid: "Endereço de e-mail inválido."
parent_email_input_label: "Endereço de e-mail do educador"
parent_email_input_placeholder: "Introduz o e-mail do educador"
@ -429,12 +430,12 @@ module.exports = nativeDescription: "Português (Portugal)", englishDescription:
parent_email_title: "Qual é o e-mail do teu educador?"
parents: "Para Educadores"
parents_title: "Caro Educador: O seu educando está a aprender a programar. Vai ajudá-lo a continuar?"
parents_blurb1: "O seu educando já jogou __nLevels__ níveis e aprendeu as bases da programação. Ajude a desenvolver o interesse dele, comprando-lhe uma subscrição para que possa continuar a jogar."
parents_blurb1: "O seu educando já jogou __nLevels__ níveis e aprendeu as bases da programação. Ajude a desenvolver o interesse dele, comprando-lhe uma subscrição para que ele possa continuar a jogar."
parents_blurb1a: "A programação de computadores é uma habilidade fundamental que o seu educando vai usar incontestavelmente quando for adulto. Em 2020, habilidades de programação básicas serão requisitadas por 77% dos empregos e, atualmente, há uma grande procura por engenheiros informáticos no mundo. Sabia que os cursos universitários ligados às Ciências da Computação são os mais bem pagos?"
parents_blurb2: "Por $9.99 USD/mês, o seu educando recebe novos desafios todas as semanas e suporte pessoal, via e-mail, de programadores profissionais."
parents_blurb3: "Sem Risco: 100% de garantia de devolução do dinheiro, com anulação fácil de 1 clique."
payment_methods: "Formas de Pagamento"
payment_methods_title: "Formas de Pagamento Aceites"
payment_methods: "Métodos de Pagamento"
payment_methods_title: "Métodos de Pagamento Aceites"
payment_methods_blurb1: "Atualmente aceitamos cartões de crédito e Alipay."
payment_methods_blurb2: "Se precisares de uma outra forma de pagamento, por favor contacta"
sale_already_subscribed: "Já estás subscrito!"
@ -475,7 +476,7 @@ module.exports = nativeDescription: "Português (Portugal)", englishDescription:
group_discounts_20: "20% de desconto"
group_discounts_12th: "12ª+ subscrições"
group_discounts_40: "40% de desconto"
subscribing: "A subscrever..."
subscribing: "A Subscrever..."
recipient_emails_placeholder: "Introduz endereços de e-mail para subscrever, um por linha."
subscribe_users: "Subscrever Utilizadores"
users_subscribed: "Utilizadores subscritos:"
@ -519,13 +520,15 @@ module.exports = nativeDescription: "Português (Portugal)", englishDescription:
health_3: "apresentado."
speed_1: "Move a"
speed_2: "metros por segundo."
available_for_purchase: "Disponível para Aquirir" # Shows up when you have unlocked, but not purchased, a hero in the hero store
available_for_purchase: "Disponível para Aquisição" # Shows up when you have unlocked, but not purchased, a hero in the hero store
level_to_unlock: "Nível para desbloquear:" # Label for which level you have to beat to unlock a particular hero (click a locked hero in the store to see)
restricted_to_certain_heroes: "Apenas certos heróis podem jogar este nível."
skill_docs:
writable: "escrevível" # Hover over "attack" in Your Skills while playing a level to see most of this
writable: "editável" # Hover over "attack" in Your Skills while playing a level to see most of this
read_only: "apenas leitura"
action: "Ação-"
spell: "Feitiço-"
action_name: "nome"
action_cooldown: "Demora"
action_specific_cooldown: "Tempo de Recarga"

View file

@ -238,7 +238,7 @@ module.exports = nativeDescription: "繁體中文", englishDescription: "Chinese
reload_confirm: "重設所有程式碼"
victory: "勝利"
victory_title_prefix: ""
victory_title_suffix: " 完成"
victory_title_suffix: "完成"
victory_sign_up: "保存進度"
victory_sign_up_poke: "想保存您的程式碼?建立一個免費帳號吧!"
victory_rate_the_level: "評估關卡: " # Only in old-style levels.
@ -286,15 +286,15 @@ module.exports = nativeDescription: "繁體中文", englishDescription: "Chinese
time_goto: "前往:"
non_user_code_problem_title: "無法加載關卡"
infinite_loop_title: "檢測到無限循環"
infinite_loop_description: "建立世界的初始代碼還沒有運行完畢。這可能是真的很慢或出現無限循環或者存在一個bug。您可以嘗試再次運行這段代碼或重置代碼為默認狀態。如果還是解決不了問題請聯繫我們。."
infinite_loop_description: "建立世界的初始代碼還沒有運行完畢。這可能是真的很慢或出現無限循環或者存在一個bug。您可以嘗試再次運行這段代碼或重置代碼為默認狀態。如果還是解決不了問題請聯繫我們。"
check_dev_console: "您也可以打開開發者界面看一下有什麼可能出錯了。"
check_dev_console_link: "(說明)"
infinite_loop_try_again: "再試一次"
infinite_loop_reset_level: "重置關卡"
infinite_loop_comment_out: "在我的程式碼中加入注解"
tip_toggle_play: "使用 Ctrl+P 切換 播放/暫停."
tip_scrub_shortcut: "Ctrl+[ 快退; Ctrl+] 快進."
tip_guide_exists: "點擊頁面上方的指南,可獲得更多有用的訊息."
tip_toggle_play: "使用 Ctrl+P 切換 播放/暫停"
tip_scrub_shortcut: "Ctrl+[ 快退; Ctrl+] 快進"
tip_guide_exists: "點擊頁面上方的指南,可獲得更多有用的訊息"
tip_open_source: "「CodeCombat」100% 開源!"
tip_tell_friends: "喜歡Codecombat那就把它介紹給朋友!"
tip_beta_launch: "「CodeCombat」在2013年10月進入 BETA 測試。"
@ -318,24 +318,24 @@ module.exports = nativeDescription: "繁體中文", englishDescription: "Chinese
tip_impossible: "事情總是看起來不可能直到它成真那刻. - Nelson Mandela"
tip_talk_is_cheap: "多說無益,放「碼」過來. - Linus Torvalds"
tip_first_language: "您經歷的第一門程式語言是最慘痛的事情. - Alan Kay"
tip_hardware_problem: "Q: 換一顆燈泡需要多少位程序員? A: 一位也不用, 它是個硬體問題."
tip_hofstadters_law: "Hofstadter 定律: 完成一件複雜的事花費的時間總是超乎預期, 甚至您早已知道這個現象( Hofstadter 定律)."
tip_premature_optimization: "過早的優化是萬惡之源. - Donald Knuth"
tip_brute_force: "當您游移不定時, 就是用暴力解. - Ken Thompson"
tip_hardware_problem: "Q: 換一顆燈泡需要多少位程序員? A: 一位也不用,它是個硬體問題。"
tip_hofstadters_law: "Hofstadter 定律: 完成一件複雜的事花費的時間總是超乎預期, 甚至您早已知道這個現象( Hofstadter 定律)"
tip_premature_optimization: "過早的優化是萬惡之源 - Donald Knuth"
tip_brute_force: "當您游移不定時, 就是用暴力解 - Ken Thompson"
tip_extrapolation: "只有 2 種人在這世上: 一種人是能夠根據不完整資訊而推斷..."
tip_superpower: "編程讓我們最接近擁有超能力."
tip_control_destiny: "在真正的開源, 您有權利控制自己的命運. - Linus Torvalds"
tip_superpower: "編程讓我們最接近擁有超能力"
tip_control_destiny: "在真正的開源, 您有權利控制自己的命運 - Linus Torvalds"
tip_no_code: "在速度上,沒有任何代碼可以超過無代碼"
tip_code_never_lies: "代碼從不說謊, 但註釋偶爾會. — Ron Jeffries"
tip_reusable_software: "在軟體被重複使用前,它必須能用."
tip_code_never_lies: "代碼從不說謊, 但註釋偶爾會 — Ron Jeffries"
tip_reusable_software: "在軟體被重複使用前,它必須能用"
tip_optimization_operator: "每種語言都有一個優化的運算符號. 對大部份而言,那符號是‘//"
tip_lines_of_code: "使用代碼行數來管理開發進度就好像使用秤重器來管理建造飛機. — Bill Gates"
tip_lines_of_code: "使用代碼行數來管理開發進度就好像使用秤重器來管理建造飛機 — Bill Gates"
tip_source_code: "我想改變世界但他們不給我源代碼"
tip_javascript_java: "Java 和 JavaScript 的關係就好比馬和馬雲. - Chris Heilmann"
tip_move_forward: "不論您做啥, 持續前進. - Martin Luther King Jr."
tip_google: "擁有一個您不能解決的問題? Google 它!"
tip_adding_evil: "增加一個邪惡掐揑."
tip_hate_computers: "關於自我覺得恨透電腦的那群人. 其實他們真正應該恨的事情是糟糕的程序員. - Larry Niven"
tip_javascript_java: "Java 和 JavaScript 的關係就好比馬和馬雲 - Chris Heilmann"
tip_move_forward: "不論做什麼, 保持前進. - Martin Luther King Jr."
tip_google: "擁有一個您不能解決的問題? Google它!"
tip_adding_evil: "增加一個邪惡掐揑"
tip_hate_computers: "關於自我覺得恨透電腦的那群人. 其實他們真正應該恨的事情是糟糕的程序員 - Larry Niven"
tip_open_source_contribute: "您可以幫助「CodeCombat」提高"
tip_recurse: "迭代者人也,遞歸者神也 - L. Peter Deutsch"
tip_free_your_mind: "放下一切私心雜念,丟棄害怕、疑問和拒信,解放您的思維。 - 莫菲斯《駭客任務》"
@ -392,11 +392,11 @@ module.exports = nativeDescription: "繁體中文", englishDescription: "Chinese
chest_gems: "一箱寶石"
purchasing: "購買中..."
declined: "您的信用卡被拒絕"
retrying: "伺服器錯誤, 正在重試."
retrying: "伺服器錯誤, 正在重試"
prompt_title: "寶石不足"
prompt_body: "想要取得更多?"
prompt_button: "進入商店"
recovered: "先前購買的寶石已回復. 請重新載入頁面."
recovered: "先前購買的寶石已回復,請重新載入頁面。"
price: "x3500 / 月"
subscribe:
@ -431,8 +431,8 @@ module.exports = nativeDescription: "繁體中文", englishDescription: "Chinese
parents_title: "親愛的家長: 您的孩子將要學習編程. 您會支持孩子發展嗎?"
parents_blurb1: "您的孩子已經玩了 __nLevels__ 關,並且學習了編程基礎。請您為了培養他們的興趣而給他們訂閱,他們能繼續玩下去。"
parents_blurb1a: "不要懷疑計算機編程能力將是您的孩子作為一個成年人的基本技能。到2020年77%的工作將會需要編碼能力,並且軟件工程師將在世界各地成為高需求職業。您知道要計算機科學是收入最高的大學學位。"
parents_blurb2: "每月支付 $9.99 美金, 他們每週獲得新挑戰以及使用信件取得專業程式員的幫助."
parents_blurb3: "沒有風險: 保證 100% 退費, 一步取消訂閱."
parents_blurb2: "每月支付 $9.99 美金, 他們每週獲得新挑戰以及使用信件取得專業程式員的幫助"
parents_blurb3: "沒有風險: 保證 100% 退費, 一步取消訂閱"
payment_methods: "付費方法"
payment_methods_title: "可接受的付款方式"
payment_methods_blurb1: "我們現有的付費方式有信用卡和支付寶"
@ -455,8 +455,8 @@ module.exports = nativeDescription: "繁體中文", englishDescription: "Chinese
sale_view_button: "購買年費訂閱:"
stripe_description: "每月訂閱"
stripe_description_year_sale: "年費訂閱 (35% 優惠)"
subscription_required_to_play: "您將需要訂閱來開啟這關."
unlock_help_videos: "訂閱來解開所有鎖住得教學影片."
subscription_required_to_play: "您將需要訂閱來開啟這關"
unlock_help_videos: "訂閱來解開所有鎖住得教學影片"
personal_sub: "個人訂閱" # Accounts Subscription View below
loading_info: "正在加載訂閱內容···"
managed_by: "管理"
@ -780,11 +780,11 @@ module.exports = nativeDescription: "繁體中文", englishDescription: "Chinese
main_title: "CodeCombat社群"
introduction: "查看您可能可以參與的項目以及選擇最吸引您的項目. 我們期待與您一起工作!"
level_editor_prefix: "使用CodeCombat"
level_editor_suffix: "來創造和編輯關卡. 許多人已經創造關卡用在課堂或黑客松,或者給予朋友或兄弟姐妹. 如果您覺得創建一個全新的關卡非常困難,您可以先從現成的開始做起!"
thang_editor_prefix: "我們稱呼遊戲中的單位叫'thangs'. 使用"
thang_editor_suffix: "來修改CodeCombat的原材料. 讓遊戲中的東西可以扔砲彈, 修改遊戲動畫的方向, 調整單位的生命值, 或者上傳自製的素材."
article_editor_prefix: "看到有錯誤在我們的文件中嗎? 想要自己設計指令嗎? 查看我們的"
article_editor_suffix: "以及幫助CodeCombat玩家獲得更多知識在遊戲中."
level_editor_suffix: "來創造和編輯關卡。 許多人已經創造關卡用在課堂或黑客松,或者給予朋友或兄弟姐妹。如果您覺得創建一個全新的關卡非常困難,您可以先從現成的開始做起!"
thang_editor_prefix: "我們稱呼遊戲中的單位叫'thangs' 使用"
thang_editor_suffix: "來修改CodeCombat的原材料。 讓遊戲中的東西可以扔砲彈,修改遊戲動畫的方向,調整單位的生命值,或者上傳自製的素材。"
article_editor_prefix: "看到有錯誤在我們的文件中嗎 想要自己設計指令嗎? 查看我們的"
article_editor_suffix: "以及幫助CodeCombat玩家獲得更多知識在遊戲中"
find_us: "通過這些網站連繫我們"
social_github: "在GitHub上查看我們的代碼"
social_blog: "閱讀CodeCombat在Sett上的部落格"
@ -814,7 +814,7 @@ module.exports = nativeDescription: "繁體中文", englishDescription: "Chinese
edit_clan_description: "編輯部落的描述"
edit_name: "編輯名字"
edit_description: "編輯描述"
private: "私人"
private: "私人"
summary: "綜述"
average_level: "平均等級"
average_achievements: "平均成就"
@ -843,22 +843,22 @@ module.exports = nativeDescription: "繁體中文", englishDescription: "Chinese
classes:
archmage_title: "大法師"
archmage_title_description: "(Coder)"
archmage_summary: "如果您是個在coding教育遊戲有興趣的開發者, 成為大法師來幫助我們建立CodeCombat!"
archmage_summary: "如果您是個在coding教育遊戲有興趣的開發者成為大法師來幫助我們建立CodeCombat"
artisan_title: "工匠"
artisan_title_description: "(Level Builder)"
artisan_summary: "建造遊戲關卡並且分享給您的朋友們. 成為工匠來幫助其他人學習編程."
artisan_summary: "建造遊戲關卡並且分享給您的朋友們。 成為工匠來幫助其他人學習編程。"
adventurer_title: "冒險家"
adventurer_title_description: "(Level Playtester)"
adventurer_summary: "提前一周免費取得我們新的關卡(甚至是訂閱的內容)並且提前在釋出前幫助我們找出錯誤."
adventurer_summary: "提前一周免費取得我們新的關卡(甚至是訂閱的內容)並且提前在釋出前幫助我們找出錯誤"
scribe_title: "文書"
scribe_title_description: "(Article Editor)"
scribe_summary: "好的程式需要好的文件. 來自全世界數百萬的玩家一起編寫, 編輯和提升文件的可讀性."
scribe_summary: "好的程式需要好的文件。 來自全世界數百萬的玩家一起編寫, 編輯和提升文件的可讀性。"
diplomat_title: "外交官"
diplomat_title_description: "(Translator)"
diplomat_summary: "借由我們的外交官CodeCombat已翻譯到45種以上的語言. 幫助我們並且貢獻翻譯."
diplomat_summary: "借由我們的外交官CodeCombat已翻譯到45種以上的語言。 幫助我們並且貢獻翻譯。"
ambassador_title: "使節"
ambassador_title_description: "(Support)"
ambassador_summary: "安撫我們論壇的用戶並且提供發問者適當的方向. 我們的使節代表CodeCombat面對全世界."
ambassador_summary: "安撫我們論壇的用戶並且提供發問者適當的方向。 我們的使節代表CodeCombat面對全世界。"
editor:
main_title: "CodeCombat編輯器"
@ -960,62 +960,62 @@ module.exports = nativeDescription: "繁體中文", englishDescription: "Chinese
intro_blurb: "CodeCombat 是 100% 開源! 上百位專注的玩家已經幫助我們建造到今天的程度. 加入我們並完成下一章 CodeCombat 的冒險給全世界參與!"
alert_account_message_intro: "您好!"
alert_account_message: "為了訂閱課程信件, 您將必須先登入."
archmage_introduction: "在建造遊戲中,其中一個最美好的事情是需要整合許多不同東西. 圖像, 聲音, 及時網路, 社群網路。以及許多不同層面的編程, 從底層數據庫管理, 到用戶界面的設計和實現. 這裡有許多事情需要完成, 如果您是個有經驗的程序員並且熱衷于深入處理 CodeCombat 的本質, 那麼這職業就是為您打造的. 我們將很高興擁有您的幫助來打造有史以來最優質的編程遊戲."
archmage_introduction: "在建造遊戲中,其中一個最美好的事情是需要整合許多不同東西:圖像、 聲音、及時網路和社群網路。以及許多不同層面的編程,從底層數據庫管理,到用戶界面的設計和實現。 這裡有許多事情需要完成, 如果您是個有經驗的程序員並且熱衷于深入處理 CodeCombat 的本質,那麼這職業就是為您打造的。 我們將很高興擁有您的幫助來打造有史以來最優質的編程遊戲。"
class_attributes: "職業說明"
archmage_attribute_1_pref: "熟悉于"
archmage_attribute_1_suf: ", 或者渴望去學習. 我們大部份的程式以這個語言寫成. 如果您是個 Ruby 或 Python 粉絲, 您將感覺到歸屬感. 它是個JavaScript, 但是擁有更佳的文法."
archmage_attribute_2: "一些程式經驗和個人的衝勁. 我們將幫助您找到方向, 但是我們不會花費太多時間訓練您."
archmage_attribute_1_suf: ", 或者渴望去學習。 我們大部份的程式以這個語言寫成。 如果您是個 Ruby 或 Python 的粉絲, 您將感覺到歸屬感。 它是個JavaScript 但是擁有更佳的文法。"
archmage_attribute_2: "一些程式經驗和個人的衝勁。 我們將幫助您找到方向, 但是我們不會花費太多時間訓練您。"
how_to_join: "如何加入"
join_desc_1: "任何人都可加入我們! 只需確認我們的"
join_desc_2: "來開始, 並且勾選底下的條件來宣告您成為勇敢的大法師和借由郵件獲得我們最新的消息. 想要討論可做的事或者更加深入地參與? "
join_desc_3: ", 或者找到我們在"
join_desc_2: "來開始 並且勾選底下的條件來宣告您成為勇敢的大法師和借由郵件獲得我們最新的消息 想要討論可做的事或者更加深入地參與? "
join_desc_3: " 或者找到我們在"
join_desc_4: "讓我們從這開始!"
join_url_email: "發信給我們"
join_url_hipchat: "公共的HipChat房間"
archmage_subscribe_desc: "取得郵件關於新的編程機會和公告."
artisan_introduction_pref: "我們必須建造更多的關卡! 大家為了更多的內容在高聲吶喊, 但只靠我們只能建造這麼多. 現在您的工作場所就是一關; 我們的關卡編輯器是勉強可用的, 所以請小心. 只要您有新的靈感,不論從簡單的 for-loops 到"
artisan_introduction_suf: ", 那個這職業會適合您."
artisan_attribute_1: "任何的創建內容經驗都是加分的, 例如使用過Blizzard的關卡編輯器. 但不是必須的!"
artisan_attribute_2: "渴望去完成許多測試和迭代. 為了製作好關卡, 您需要把它交給別人去玩並且觀察他們如何玩, 之後準備找到一堆東西去修改."
artisan_attribute_3: "暫且擁有探險者般的忍耐力. 我們的關卡編輯器非常的陽春,有些地方非常不易使用. 我們已經提前告知囉!"
archmage_subscribe_desc: "取得郵件關於新的編程機會和公告"
artisan_introduction_pref: "我們必須建造更多的關卡! 大家為了更多的內容在高聲吶喊 但只靠我們只能建造這麼多。 現在您的工作場所就是一關; 我們的關卡編輯器是勉強可用的, 所以請小心. 只要您有新的靈感,不論從簡單的 for-loops 到"
artisan_introduction_suf: " 那個這職業會適合您。"
artisan_attribute_1: "任何的創建內容經驗都是加分的 例如使用過Blizzard的關卡編輯器。 但不是必須的!"
artisan_attribute_2: "渴望去完成許多測試和迭代。 為了製作好關卡, 您需要把它交給別人去玩並且觀察他們如何玩, 之後準備找到一堆東西去修改。"
artisan_attribute_3: "暫且擁有探險者般的忍耐力。 我們的關卡編輯器非常的陽春,有些地方非常不易使用。 我們已經提前告知囉!"
artisan_join_desc: "按照以下步驟使用關卡編輯器:"
artisan_join_step1: "閱讀文擋."
artisan_join_step2: "創建新的關卡並且探索已存在的關卡."
artisan_join_step3: "在公共的HipChat房間裡找到我們尋求幫助."
artisan_join_step4: "公佈您的關卡到論壇中尋求回饋."
artisan_subscribe_desc: "取得郵件關於關卡編輯器更新和公告."
adventurer_introduction: "讓我們清楚的定義您的角色: 您是部坦克. 您將遭受許多傷害. 我們需要玩家來嘗試我們全新的關卡並且幫助我們找出如何讓事情變得更好. 那痛苦將是巨大的; 製作優秀的遊戲是個長遠的過程並且沒有人可以第一次就把事情做對. 如果您可以忍受並且抵抗力高, 那麼這職業也許適合您."
adventurer_attribute_1: "渴望學習. 您想要學習如何編程並且我們想要教導您如何編程. 儘管您將可能在這情況中獨自完成大部分教學."
adventurer_attribute_2: "魅力十足的. 直率但如紳士般的指出需要改進的地方, 並且提供如何改進的建議."
adventurer_join_pref: "無論是與其餘工匠們一起共事, 或者勾選底下的條件來借由郵件獲得我們最新需要測試的關卡. 我們也將公佈需要評估的關卡在我們的網站上,例如:"
artisan_join_step1: "閱讀文擋"
artisan_join_step2: "創建新的關卡並且探索已存在的關卡"
artisan_join_step3: "在公共的HipChat房間裡找到我們尋求幫助"
artisan_join_step4: "公佈您的關卡到論壇中尋求回饋"
artisan_subscribe_desc: "取得郵件關於關卡編輯器更新和公告"
adventurer_introduction: "讓我們清楚的定義您的角色: 您是部坦克。 您將遭受許多傷害。 我們需要玩家來嘗試我們全新的關卡並且幫助我們找出如何讓事情變得更好 那痛苦將是巨大的; 製作優秀的遊戲是個長遠的過程並且沒有人可以第一次就把事情做對。 如果您可以忍受並且抵抗力高, 那麼這職業也許適合您。"
adventurer_attribute_1: "渴望學習。 您想要學習如何編程並且我們想要教導您如何編程。 儘管您將可能在這情況中獨自完成大部分教學。"
adventurer_attribute_2: "魅力十足的。 直率但如紳士般的指出需要改進的地方, 並且提供如何改進的建議。"
adventurer_join_pref: "無論是與其餘工匠們一起共事 或者勾選底下的條件來借由郵件獲得我們最新需要測試的關卡。 我們也將公佈需要評估的關卡在我們的網站上,例如:"
adventurer_forum_url: "我們的論壇"
adventurer_join_suf: "所以如果您更加喜歡借由這方式被通知, 在那些網站上登錄吧!"
adventurer_subscribe_desc: "當有新關卡需要測試時取得郵件."
scribe_introduction_pref: "CodeCombat不只是將擁有一堆關卡. 它將也包含知識資源, 一種充滿編程概念的wiki並且每道關卡都將蘊含著這樣的概念. 在這概念下, 不只每位工匠必須描述針對每個細節提出講解, 他們製作的關卡還可以簡單地和wiki中的編程概念產生連結. 某些東西已經在"
adventurer_join_suf: "所以如果您更加喜歡借由這方式被通知 在那些網站上登錄吧!"
adventurer_subscribe_desc: "當有新關卡需要測試時取得郵件"
scribe_introduction_pref: "CodeCombat不只是將擁有一堆關卡。 它將也包含知識資源, 一種充滿編程概念的wiki並且每道關卡都將蘊含著這樣的概念。 在這概念下, 不只每位工匠必須描述針對每個細節提出講解, 他們製作的關卡還可以簡單地和wiki中的編程概念產生連結。 某些東西已經在"
scribe_introduction_url_mozilla: "Mozilla 開發者社群"
scribe_introduction_suf: "完成. 如果您的有趣意見是可以在 Markdown 形式下闡述編程概念, 那麼這職業也許適合您."
scribe_attribute_1: "文字的技巧幾乎是您全部所需要的. 不只是文法和拼字, 但還需傳達複雜概念給閱讀的人."
scribe_introduction_suf: "完成。 如果您的有趣意見是可以在 Markdown 形式下闡述編程概念, 那麼這職業也許適合您。"
scribe_attribute_1: "文字的技巧幾乎是您全部所需要的。 不只是文法和拼字, 但還需傳達複雜概念給閱讀的人。"
contact_us_url: "聯繫我們"
scribe_join_description: "告訴我們更多關於您的資訊, 您的編程經驗和一些您喜歡寫下的東西. 我們將從這些地方開始!"
scribe_subscribe_desc: "取得公告關於寫作文章的郵件."
diplomat_introduction_pref: "所以, 如果說我們從"
scribe_join_description: "告訴我們更多關於您的資訊 您的編程經驗和一些您喜歡寫下的東西。 我們將從這些地方開始!"
scribe_subscribe_desc: "取得公告關於寫作文章的郵件"
diplomat_introduction_pref: "所以 如果說我們從"
diplomat_launch_url: " 十月的那次上線 "
diplomat_introduction_suf: "中得到了怎樣的啟發: 那就是在許多國家有許多人對CodeCombat產生興趣! 我們正在建立一群翻譯者急於將一組組的英文翻譯成各國語言讓CodeCombat可以讓全世界更多人都可以接觸. 如果您喜歡搶先閱讀新內容並且讓您的國人都可以儘速的擁有, 那麼這職業也許適合您."
diplomat_attribute_1: "擁有流利的英文並且喜歡翻譯某種語言. 當傳遞複雜想法時, 您必須這兩種語言都是熟悉的!"
diplomat_introduction_suf: "中得到了怎樣的啟發: 那就是在許多國家有許多人對CodeCombat產生興趣! 我們正在建立一群翻譯者急於將一組組的英文翻譯成各國語言讓CodeCombat可以讓全世界更多人都可以接觸。 如果您喜歡搶先閱讀新內容並且讓您的國人都可以儘速的擁有, 那麼這職業也許適合您。"
diplomat_attribute_1: "擁有流利的英文並且喜歡翻譯某種語言。 當傳遞複雜想法時, 您必須這兩種語言都是熟悉的!"
diplomat_i18n_page_prefix: "您可以開始從我們的"
diplomat_i18n_page: " 翻譯頁面 "
diplomat_i18n_page_suffix: "翻譯我們的關卡, 或者從我們在 GitHub 上的頁面."
diplomat_i18n_page_suffix: "翻譯我們的關卡 或者從我們在 GitHub 上的頁面。"
diplomat_join_pref_github: ""
diplomat_github_url: " GitHub "
diplomat_join_suf_github: "找到您的語言文件 (繁體中文的是: codecombat/app/locale/zh-HANT.coffee), 在線編輯它, 並且上傳一個 pull 請求. 另外, 勾選底下的條件來借由郵件獲得及時的國際化開發!"
diplomat_subscribe_desc: "取得國際化開發和待翻譯關卡的郵件."
ambassador_introduction: "這是個我們正在建立的社群, 您將是我們與世界的連接點. 我們在論壇, 郵件, 社群網路上和許多人交談並且幫助彼此熟悉遊戲以及互相學習. 如果您想要幫助其它人參與並且從中獲得許多樂趣, 以及樂於感受CodeCombat的脈搏和我們將前往的地方, 那麼這職業也許適合您."
ambassador_attribute_1: "溝通技巧. 可以找到玩家正面臨的問題並且幫助他們解決. 另外, 保持與我們聯繫玩家們討論的, 喜愛的, 厭惡的以及想要的!"
ambassador_join_desc: "告訴我們更多關於您的資訊, 您已完成的事情和您喜歡做的事情. 我們將從這些地方開始!"
diplomat_join_suf_github: "找到您的語言文件 (繁體中文的是: codecombat/app/locale/zh-HANT.coffee), 在線編輯它, 並且上傳一個 pull 請求。 另外, 勾選底下的條件來借由郵件獲得及時的國際化開發!"
diplomat_subscribe_desc: "取得國際化開發和待翻譯關卡的郵件"
ambassador_introduction: "這是個我們正在建立的社群 您將是我們與世界的連接點。 我們在論壇, 郵件, 社群網路上和許多人交談並且幫助彼此熟悉遊戲以及互相學習。 如果您想要幫助其它人參與並且從中獲得許多樂趣, 以及樂於感受CodeCombat的脈搏和我們將前往的地方 那麼這職業也許適合您。"
ambassador_attribute_1: "溝通技巧。 可以找到玩家正面臨的問題並且幫助他們解決。 另外, 保持與我們聯繫玩家們討論的, 喜愛的, 厭惡的以及想要的!"
ambassador_join_desc: "告訴我們更多關於您的資訊 您已完成的事情和您喜歡做的事情。 我們將從這些地方開始!"
ambassador_join_note_strong: "注意"
ambassador_join_note_desc: "其中一件我們優先要做的事情是建立多人連線, 玩家將面臨獨自難以解決的關卡而且可以招喚更高等級的法師來幫助. 這將對於使節是一個很棒的方式來完成自己的責任. 我們會及時地向大家公佈!"
ambassador_subscribe_desc: "取得更新和多人連線開發的郵件."
changes_auto_save: "當您勾選後, 改變將自動儲存."
ambassador_join_note_desc: "其中一件我們優先要做的事情是建立多人連線 玩家將面臨獨自難以解決的關卡而且可以招喚更高等級的法師來幫助。 這將對於使節是一個很棒的方式來完成自己的責任。 我們會及時地向大家公佈!"
ambassador_subscribe_desc: "取得更新和多人連線開發的郵件"
changes_auto_save: "當您勾選後 改變將自動儲存。"
diligent_scribes: "我們勤奮的文書:"
powerful_archmages: "我們強勁的大法師:"
creative_artisans: "我們創意的工匠:"
@ -1156,16 +1156,16 @@ module.exports = nativeDescription: "繁體中文", englishDescription: "Chinese
loading_error:
could_not_load: "從伺服器載入失敗"
connection_failure: "連線失敗."
unauthorized: "您需要先登錄. 您把cookies禁用了嗎?"
forbidden: "您沒有權限."
not_found: "沒找到."
not_allowed: "方法不被允許."
timeout: "伺服器超時."
conflict: "資源衝突."
bad_input: "錯誤輸入."
server_error: "伺服器錯誤."
unknown: "未知錯誤."
connection_failure: "連線失敗"
unauthorized: "您需要先登錄。 您把cookies禁用了嗎"
forbidden: "您沒有權限"
not_found: "沒找到"
not_allowed: "方法不被允許"
timeout: "伺服器超時"
conflict: "資源衝突"
bad_input: "錯誤輸入"
server_error: "伺服器錯誤"
unknown: "未知錯誤"
resources:
sessions: "會話"
@ -1264,37 +1264,37 @@ module.exports = nativeDescription: "繁體中文", englishDescription: "Chinese
multiplayer_hint_label: "提示:"
multiplayer_hint: " 點擊全選,然後按 ⌘-C 或 Ctrl-C 複製連結。"
multiplayer_coming_soon: "請期待更多的多人關卡!"
multiplayer_sign_in_leaderboard: "註冊並且登入帳號,就可以將您的成就放在排行榜上."
multiplayer_sign_in_leaderboard: "註冊並且登入帳號,就可以將您的成就放在排行榜上"
legal:
page_title: "條文"
opensource_intro: "CodeCombat是完全的開源."
opensource_intro: "CodeCombat是完全的開源"
opensource_description_prefix: "查看 "
github_url: "我們的 GitHub"
opensource_description_center: "並且如果有興趣也歡迎您的幫助! CodeCombat是建立在許多的開源專案上, 並且我們深愛它們. 查看 "
opensource_description_center: "並且如果有興趣也歡迎您的幫助 CodeCombat是建立在許多的開源專案上, 並且我們深愛它們。 查看 "
archmage_wiki_url: "我們的大法師wiki"
opensource_description_suffix: " 尋求創造這款遊戲的相關軟體列表."
opensource_description_suffix: " 尋求創造這款遊戲的相關軟體列表"
practices_title: "值得尊敬的最佳實踐"
practices_description: "這些是我們給您, 給玩家的承諾, 儘管這在法律上略顯不足."
practices_description: "這些是我們給您, 給玩家的承諾, 儘管這在法律上略顯不足"
privacy_title: "隱私"
privacy_description: "我們將不會賣出任何關於您個人的資訊."
privacy_description: "我們將不會賣出任何關於您個人的資訊"
security_title: "安全"
security_description: "我們渴望保持您的個人資訊是安全的. 身為一個開源的專案, 我們的網站是開放給任何人來檢視並且提升我們的安全系統."
security_description: "我們渴望保持您的個人資訊是安全的. 身為一個開源的專案, 我們的網站是開放給任何人來檢視並且提升我們的安全系統"
email_title: "郵件"
email_description_prefix: "我們將不會使您的信箱氾濫的收到垃圾信. 不論"
email_description_prefix: "我們將不會使您的信箱氾濫的收到垃圾信 不論"
email_settings_url: " 在您的郵件設定 "
email_description_suffix: "或在我們送出的信件上都有留著我們的聯結, 您可以更改您的喜好並且輕易的隨時取消訂閱."
email_description_suffix: "或在我們送出的信件上都有留著我們的聯結, 您可以更改您的喜好並且輕易的隨時取消訂閱"
cost_title: "花費"
cost_description: "CodeCombat在核心的關卡是全部免費, 但只要花費一個月$9.99美金來訂閱, 您將在每個月取得額外的關卡和3500顆寶石. 您可以輕易地取消訂閱並且保證取得100%的退費."
cost_description: "CodeCombat在核心的關卡是全部免費, 但只要花費一個月$9.99美金來訂閱, 您將在每個月取得額外的關卡和3500顆寶石。 您可以輕易地取消訂閱並且保證取得100%的退費。"
copyrights_title: "版權和許可"
contributor_title: "貢獻者許可協議"
contributor_description_prefix: "所有在本網站或是 GitHub 代碼庫上的貢獻都依照我們的"
cla_url: "貢獻者許可協議"
contributor_description_suffix: "而這在您貢獻之前就應該已经同意."
contributor_description_suffix: "而這在您貢獻之前就應該已经同意"
code_title: "Code - MIT"
code_description_prefix: "所有由 CodeCombat 擁有或是托管在 codecombat.com 的代码,在 GitHub 代碼庫或者 codecombat.com 數據庫,以上許可協議都依照"
mit_license_url: "MIT license"
code_description_suffix: "這包括所有 CodeCombat 公開製作關卡用的系统和組件代碼."
code_description_suffix: "這包括所有 CodeCombat 公開製作關卡用的系统和組件代碼"
art_title: "藝術/音樂 - Creative Commons "
art_description_prefix: "所有共通的内容都在"
cc_license_url: "Creative Commons Attribution 4.0 International License"
@ -1303,23 +1303,23 @@ module.exports = nativeDescription: "繁體中文", englishDescription: "Chinese
art_sound: "聲音"
art_artwork: "藝術作品"
art_sprites: "貼圖"
art_other: "所有製作關卡時公開的,不是代碼的創造性產品."
art_access: "目前還没有簡便通用的下载素材方式. 一般来說從網站上使用的URL下载或者聯繫我们尋求幫助. 當然您也可以幫助我们拓展網站,使這些資源更容易下載."
art_other: "所有製作關卡時公開的,不是代碼的創造性產品"
art_access: "目前還没有簡便通用的下载素材方式。 一般来說從網站上使用的URL下载或者聯繫我们尋求幫助。 當然您也可以幫助我们拓展網站,使這些資源更容易下載。"
art_paragraph_1: "為了歸屬, 請在使用處或適當的地方說明, 或者留下一個聯結至codecombat.com. 例如:"
use_list_1: "如果使用在電影或者另一款遊戲中, 請在製作人員表中加入codecombat.com."
use_list_1: "如果使用在電影或者另一款遊戲中, 請在製作人員表中加入codecombat.com"
use_list_2: "如果使用在網站上, 請在使用處留下codecombat.com, 例如在圖片下面或一個您專門放置Creative Commons和開源專案的地方. 如果您的内容明確提到關於 CodeCombat, 那您就不需要額外署名."
art_paragraph_2: "如果您使用的內容非由CodeCombat製作但由一位codecombat.com中的使用者, 那您應該署名他. 並且如果相對應的頁面上有標記署名指示, 那您應該遵照其指示."
art_paragraph_2: "如果您使用的內容非由CodeCombat製作但由一位codecombat.com中的使用者, 那您應該署名他。 並且如果相對應的頁面上有標記署名指示, 那您應該遵照其指示。"
rights_title: "保留權利"
rights_desc: "所有版權由關卡本身擁有, 這包含:"
rights_scripts: "腳本"
rights_unit: "單元配置"
rights_description: "描述"
rights_writings: "寫作"
rights_media: "聲音、音樂以及其他專門為某道關卡製作, 而不對其他關卡開放的創造性内容."
rights_media: "聲音、音樂以及其他專門為某道關卡製作, 而不對其他關卡開放的創造性内容"
rights_clarification: "澄清一下, 所有在關卡编辑器裡公開用於制作關卡的資源都是在CC協議下發佈的, 然而使用關卡编辑器製作,或者在關卡製作過程中上傳的内容则不是."
nutshell_title: "簡而言之"
nutshell_description: "我们在關卡编辑器里公開的任何資源, 您都可以在製作關卡時隨意使用, 但我们保留在 codecombat.com 之上創建的關卡本身傳播的權利, 因为我们往後可能決定以它們收費."
canonical: "我們宣告這篇說明的英文版本是權威版本. 如果各個翻譯版本之間有任何衝突, 以英文版為準."
canonical: "我們宣告這篇說明的英文版本是權威版本。 如果各個翻譯版本之間有任何衝突, 以英文版為準。"
ladder_prizes:
title: "錦標賽獎項" # This section was for an old tournament and doesn't need new translations now.

View file

@ -7,6 +7,7 @@ _.extend CourseSchema.properties,
campaignID: c.objectId()
concepts: c.array {title: 'Programming Concepts', uniqueItems: true}, c.concept
description: {type: 'string'}
duration: {trype: 'number', description: 'Approximate hours of content'}
pricePerSeat: {type: 'number', description: 'Price per seat in USD cents.'}
screenshot: c.url {title: 'URL', description: 'Link to course screenshot.'}

View file

@ -29,8 +29,8 @@ defaultTasks = [
'Release to adventurers via MailChimp.'
'Write the description.'
'Translate the sample code comments.'
'Add Io/Clojure/Lua/CoffeeScript.'
'Add i18n field for the sample code comments.'
'Add Clojure/Lua/CoffeeScript.'
'Write the guide.'
'Write a loading tip, if needed.'
'Click the Populate i18n button.'
@ -40,7 +40,6 @@ defaultTasks = [
'Release to everyone via MailChimp.'
'Check completion/engagement/problem analytics.'
'Do any custom scripting, if needed.'
'Do thorough set decoration.'
'Add a walkthrough video.'
]

View file

@ -1,4 +1,8 @@
#subscription-view
.logged-out-blurb
font-size: 18px
.start-subscription-button, .end-subscription-button
margin-bottom: 20px
float: left

View file

@ -0,0 +1,68 @@
#courses-view
.center
text-align: center
.code-input
width: 100%
.course-image
width: 100%
.course-panel
margin: 20px
.faq-blurb
font-size: 14px
.continue-dialog .modal-dialog
background-color: white
max-width: 400px
.instruction-label
font-size: 14pt
.or
margin-bottom: 20px
font-size: 14pt
.btn-enroll
margin-top: 20px
.center
text-align: center
.concepts-container
width: 200px
.contact-container
margin-top: 20px
text-align: center
.info-container
margin: 0% 10%
font-size: 18px
.monitoring-img-container
margin-top: 10px
.praise-caption
font-size: 14px
.praise-quote
font-size: 20px
font-style: italic
.progress-container
font-size: 20px
.img-quote
height: 160px
.popover
z-index: 1050
min-width: 400px
h3
background: transparent
border: 0
font-size: 30px

View file

@ -1,4 +1,4 @@
#course-details-view
#course-details-mock-view
.section-selector
margin-bottom: 0px

View file

@ -1,4 +1,4 @@
#course-enroll-view
#course-enroll-mock-view
.btn-buy
margin: 20px 0px

View file

@ -1,4 +1,4 @@
#courses-view
#courses-mock-view
.center
text-align: center

View file

@ -1,9 +1,7 @@
#ladder-tab-view
.name-col-cell
max-width: 100px
white-space: nowrap
overflow: hidden
text-overflow: ellipsis
.ladder-table
.name-col-cell
max-width: 170px
.histogram-display
height: 130px

View file

@ -12,6 +12,9 @@
.input-heard-about
width: 100%
.logged-out-blurb
font-size: 18px
.thanks-submit
display: none

View file

@ -11,7 +11,7 @@ block content
li.active(data-i18n="account.subscription")
if me.get('anonymous')
p(data-i18n="account_settings.not_logged_in")
p.logged-out-blurb(data-i18n="subscribe.must_be_logged")
else
//- Personal Subscriptions

View file

@ -8,19 +8,136 @@ block content
span *UNDER CONSTRUCTION, please send feedback to
a.spl(href='mailto:team@codecombat.com') team@codecombat.com
h1(style='text-align: center;') Courses
br
if studentMode
+student-main
else
+teacher-main
.container-fluid
.row(style='font-size: 20px;')
.col-md-3
.col-md-3 Name
.col-md-3 Description
.col-md-3 Concepts
each course in courses
.row(style='border-top: 1px solid gray; padding: 10px;')
.col-md-3
img(src="#{course.get('screenshot')}", style="width: 100%;")
.col-md-3
p= course.get('name')
a(href="/editor/campaign/#{course.get('campaignID')}") Campaign (levels)
.col-md-3= course.get('description')
.col-md-3= course.get('concepts').join(' ')
- var i = 0
while i < courses.length
.row
+course-block(courses[i], instances)
- i++
if i < courses.length
+course-block(courses[i], instances)
- i++
mixin student-main
button.btn.btn-warning.btn-teacher Teachers Click Here
h1.center Courses on CodeCombat
mixin teacher-main
button.btn.btn-warning.btn-student Students Click Here
h1.center Courses on CodeCombat
.info-container
p Courses are designed to introduce computer science concepts using CodeCombat's fun and engaging environment. CodeCombat levels are organized around key topics to encourage progressive learning, over the course of 5 hours.
.container-fluid
.row
.col-md-6
ul
li Learn more in less time
li No coding experience necesssary
li Easily monitor student progress
p Purchase a course for your entire class. It's easy to sign up your students!
p.faq-blurb
span.spr See the courses
a.spr.courses-faq FAQ
span for more information.
.col-md-6
img.img-quote(src="/images/pages/courses/coco_complab.png")
p
.well.well-sm
div.praise-quote "#{praise.quote}"
div.praise-caption - #{praise.source}
h2.center Choose Your Course:
mixin student-dialog(course)
.modal.continue-dialog(id="continueModal#{course.id}")
.modal-dialog
.modal-header
button.close(data-dismiss='modal')
span &times;
h3.modal-title= course.get('name')
.modal-body
.container-fluid
.row.button-row
.col-md-12
.well.well-sm
p
div.instruction-label Enter an unlock code
.container-fluid
.row
.col-md-8
input.code-input(type='text', placeholder="Enter unlock code")
.col-md-4
button.btn.btn-success.btn-enroll Enroll
mixin teacher-dialog(course)
.modal.continue-dialog(id="continueModal#{course.id}")
.modal-dialog
.modal-header
button.close(data-dismiss='modal')
span &times;
h3.modal-title= course.get('name')
.modal-body
.container-fluid
if enrolledCourses[course.id]
.row.button-row.row-pick-class
.col-md-12
.well.well-sm
p
div.instruction-label Pick from your current classes
.container-fluid
.row
.col-md-8
select.form-control.select-session
each inst in instances
if inst.get('name')
option(value="#{inst.id}")= inst.get('name')
else
option(value="#{inst.id}") *unnamed*
.col-md-4
button.btn.btn-success.btn-enter(data-course-id="#{course.id}") Enter
.row.button-row.center.row-pick-class
.col-md-12
div.or Or
.row.button-row.center
.col-md-12
button.btn.btn-success.btn-lg.btn-buy(data-course-id="#{course.id}") Buy this course
mixin course-block(course)
if studentMode
+student-dialog(course)
else
+teacher-dialog(course)
.col-md-6
.well.panel.course-panel(class=enrolledCourses[course.id] ? 'panel-success' : 'panel-info')
.panel-heading
.panel-title
span.spr #{course.get('name')}
strong #{enrolledCourses[course.id] ? '[ enrolled ]' : ''}
.panel-body
.container-fluid
.row
.col-md-12
p
img.course-image(src="#{course.get('screenshot')}")
.row.button-row
.col-md-6
strong Topics
ul
each concept in course.get('concepts')
li(data-i18n="concepts." + concept)
strong Hours of content: #{course.get('duration')}
.col-md-6.center(style='margin-top: 40px;')
if studentMode
if enrolledCourses[course.id]
a.btn.btn-lg.btn-success.btn-continue(href="/courses/#{course.id}?student=true") Continue
else
button.btn.btn-lg.btn-success.btn-continue(data-toggle='modal', data-target="#continueModal#{course.id}") Enter
else if enrolledCourses[course.id]
button.btn.btn-lg.btn-success.btn-continue(data-toggle='modal', data-target="#continueModal#{course.id}") Continue
else
button.btn.btn-lg.btn-success.btn-buy(data-course-id="#{course.id}") #{course.get('pricePerSeat') === 0 ? 'Get FREE course' : 'Buy course'}

View file

@ -1,8 +1,8 @@
div#columns.row
.row
for team, teamIndex in teams
div.column.col-md-4
div.column.col-md-6
div(id="histogram-display-#{team.name}", class="histogram-display", data-team-name=team.name)
table.table.table-bordered.table-condensed.table-hover(data-team=team.id)
table.table.table-bordered.table-condensed.table-hover.ladder-table(data-team=team.id)
thead
tr
th(colspan=level.get('type', true) == 'hero-ladder' ? 3 : 2)
@ -13,6 +13,7 @@ div#columns.row
th(colspan=level.get('type', true) == 'hero-ladder' ? 3 : 2)
th(data-i18n="general.score") Score
th(data-i18n="general.name").name-col-cell Name
th(data-i18n="general.when") When
th
th.iconic-cell
.glyphicon.glyphicon-eye-open
@ -31,6 +32,7 @@ div#columns.row
td.rank-cell= rank + 1
td.score-cell= Math.round(sessionStats.totalScore * 100)
td.name-col-cell= session.get('creatorName') || "Anonymous"
td.age-cell= moment(session.get('submitDate')).fromNow().replace('a few ', '')
td.fight-cell
a(href="/play/level/#{level.get('slug') || level.id}?team=#{team.otherTeam}&opponent=#{session.id}" + (league ? "&league=" + league.id : ""))
span(data-i18n="ladder.fight") Fight!
@ -50,6 +52,7 @@ div#columns.row
td.rank-cell= session.rank
td.score-cell= Math.round(sessionStats.totalScore * 100)
td.name-col-cell= session.get('creatorName') || "Anonymous"
td.age-cell= moment(session.get('submitDate')).fromNow().replace('a few ', '')
td.fight-cell
a(href="/play/level/#{level.get('slug') || level.id}?team=#{team.otherTeam}&opponent=#{session.id}" + (league ? "&league=" + league.id : ""))
span(data-i18n="ladder.fight") Fight!
@ -58,7 +61,7 @@ div#columns.row
if teamIndex == 1
.btn.btn-sm.load-more-ladder-entries(data-i18n="editor.more") More
div.column.col-md-4
div.column.col-md-4.secret
h4.friends-header(data-i18n="ladder.friends_playing") Friends Playing
if me.get('anonymous')
div.alert.alert-info

View file

@ -1,7 +1,7 @@
div#columns.row
.row
for team in teams
div.matches-column.col-md-6
table.table.table-bordered.table-condensed
table.table.table-bordered.table-condensed.my-matches-table
tr
th(colspan=5, style="color: #{team.primaryColor}")

View file

@ -5,7 +5,7 @@ block content
h2(data-i18n="teachers_survey.title")
if me.isAnonymous()
p(data-i18n="teachers_survey.must_be_logged")
p.logged-out-blurb(data-i18n="teachers_survey.must_be_logged")
else if fetchingData
h4(data-i18n="teachers_survey.retrieving")
else if existingRequests.length > 0

View file

@ -18,6 +18,7 @@ block content
p(data-i18n="teachers.free_2")
h3.teachers-title(data-i18n="teachers.teacher_subs_title")
p(data-i18n="teachers.teacher_subs_0")
p
span.spr(data-i18n="teachers.teacher_subs_1")
a(href='/teachers/freetrial', data-i18n="teachers.teacher_subs_2")

View file

@ -20,7 +20,7 @@ module.exports = class CourseEnrollView extends RootView
subscriptions:
'stripe:received-token': 'onStripeReceivedToken'
constructor: (options, @courseID=0) ->
constructor: (options, @courseID) ->
super options
@courseID ?= options.courseID
@seats = 20
@ -99,7 +99,7 @@ module.exports = class CourseEnrollView extends RootView
createClass: (token) ->
data =
name: $('.class-name').val()
name: @className
seats: @seats
token: token
data.courseID = @selectedCourse.id if @selectedCourse

View file

@ -1,18 +1,95 @@
RootView = require 'views/core/RootView'
template = require 'templates/courses/courses'
app = require 'core/application'
CocoCollection = require 'collections/CocoCollection'
Course = require 'models/Course'
CourseInstance = require 'models/CourseInstance'
RootView = require 'views/core/RootView'
template = require 'templates/courses/courses'
utils = require 'core/utils'
module.exports = class CoursesView extends RootView
id: 'courses-view'
template: template
events:
'click .btn-buy': 'onClickBuy'
'click .btn-enroll': 'onClickEnroll'
'click .btn-enter': 'onClickEnter'
'click .btn-student': 'onClickStudent'
'click .btn-teacher': 'onClickTeacher'
constructor: (options) ->
super options
super(options)
@praise = utils.getCoursePraise()
@studentMode = utils.getQueryVariable('student', false) or options.studentMode
@courses = new CocoCollection([], { url: "/db/course", model: Course})
@supermodel.loadCollection(@courses, 'courses')
@courseInstances = new CocoCollection([], { url: "/db/user/#{me.id}/course_instances", model: CourseInstance})
@listenToOnce @courseInstances, 'sync', @onCourseInstancesLoaded
@supermodel.loadCollection(@courseInstances, 'course_instances')
getRenderData: ->
context = super()
context.courses = @courses.models ? []
context.enrolledCourses = @enrolledCourses ? {}
context.instances = @courseInstances.models ? []
context.praise = @praise
context.studentMode = @studentMode
context
afterRender: ->
super()
@setupCoursesFAQPopover()
onCourseInstancesLoaded: ->
@enrolledCourses = {}
@enrolledCourses[courseInstance.get('courseID')] = true for courseInstance in @courseInstances.models
setupCoursesFAQPopover: ->
popoverTitle = "<h3>Courses FAQ<button type='button' class='close' onclick='$(&#39;.courses-faq&#39;).popover(&#39;hide&#39;);'>&times;</button></h3>"
popoverContent = "<p><strong>Q:</strong> What's the difference between these courses and the single player game?</p>"
popoverContent += "<p><strong>A:</strong> The single player game is designed for individuals, while the courses are designed for classes.</p>"
popoverContent += "<p>The single player game has items, gems, hero selection, leveling up, and in-app purchases. Courses have classroom management features and streamlined student-focused level pacing.</p>"
@$el.find('.courses-faq').popover(
animation: true
html: true
placement: 'top'
trigger: 'click'
title: popoverTitle
content: popoverContent
container: @$el
).on 'shown.bs.popover', =>
application.tracker?.trackEvent 'Subscription payment methods hover'
onClickBuy: (e) ->
courseID = $(e.target).data('course-id')
route = "/courses/enroll/#{courseID}"
viewClass = require 'views/courses/CourseEnrollView'
viewArgs = [{}, courseID]
navigationEvent = route: route, viewClass: viewClass, viewArgs: viewArgs
Backbone.Mediator.publish 'router:navigate', navigationEvent
onClickEnroll: (e) ->
alert('TODO: redeem course prepaid and navigate to correct course instance')
onClickEnter: (e) ->
$('.continue-dialog').modal('hide')
courseID = $(e.target).data('course-id')
courseInstanceID = $('.select-session').val()
viewClass = require 'views/courses/CourseDetailsView'
viewArgs = [{courseInstanceID:courseInstanceID}, courseID]
navigationEvent = route: "/courses/#{courseID}", viewClass: viewClass, viewArgs: viewArgs
Backbone.Mediator.publish 'router:navigate', navigationEvent
onClickStudent: (e) ->
route = "/courses?student=true"
viewClass = require 'views/courses/CoursesView'
viewArgs = [studentMode: true]
navigationEvent = route: route, viewClass: viewClass, viewArgs: viewArgs
Backbone.Mediator.publish 'router:navigate', navigationEvent
onClickTeacher: (e) ->
route = "/courses?student=false"
viewClass = require 'views/courses/CoursesView'
viewArgs = [studentMode: false]
navigationEvent = route: route, viewClass: viewClass, viewArgs: viewArgs
Backbone.Mediator.publish 'router:navigate', navigationEvent

View file

@ -6,7 +6,7 @@ CocoCollection = require 'collections/CocoCollection'
Campaign = require 'models/Campaign'
module.exports = class CourseDetailsView extends RootView
id: 'course-details-view'
id: 'course-details-mock-view'
template: template
events:

View file

@ -3,7 +3,7 @@ RootView = require 'views/core/RootView'
template = require 'templates/courses/mock1/course-enroll'
module.exports = class CourseEnrollView extends RootView
id: 'course-enroll-view'
id: 'course-enroll-mock-view'
template: template
events:

View file

@ -4,7 +4,7 @@ RootView = require 'views/core/RootView'
template = require 'templates/courses/mock1/courses'
module.exports = class CoursesView extends RootView
id: 'courses-view'
id: 'courses-mock-view'
template: template
events:

View file

@ -101,7 +101,7 @@ module.exports = class LadderPlayModal extends ModalView
{id: 'coffeescript', name: 'CoffeeScript (Experimental)'}
{id: 'clojure', name: 'Clojure (Experimental)'}
{id: 'lua', name: 'Lua'}
{id: 'io', name: 'Io (Experimental)'}
#{id: 'io', name: 'Io (Experimental)'}
]
ctx.league = @options.league
teamsList = teamDataFromLevel @level

View file

@ -33,8 +33,9 @@ module.exports = class LadderTabView extends CocoView
@teams = teamDataFromLevel @level
@leaderboards = {}
@refreshLadder()
@socialNetworkRes = @supermodel.addSomethingResource('social_network_apis', 0)
@checkFriends()
# Trying not loading the FP/G+ stuff for now to see if anyone complains they were using it so we can have just two columns.
#@socialNetworkRes = @supermodel.addSomethingResource('social_network_apis', 0)
#@checkFriends()
checkFriends: ->
return if @checked or (not window.FB) or (not window.gapi)
@ -185,6 +186,7 @@ module.exports = class LadderTabView extends CocoView
ctx.capitalize = _.string.capitalize
ctx.league = @options.league
ctx._ = _
ctx.moment = moment
ctx
generateHistogram: (histogramElement, histogramData, teamName) ->
@ -196,9 +198,9 @@ module.exports = class LadderTabView extends CocoView
top: 20
right: 20
bottom: 30
left: 0
left: 15
width = 300 - margin.left - margin.right
width = 470 - margin.left - margin.right
height = 125 - margin.top - margin.bottom
formatCount = d3.format(',.0')

View file

@ -1,6 +1,7 @@
CocoView = require 'views/core/CocoView'
template = require 'templates/play/common/ladder_submission'
{createAetherOptions} = require 'lib/aether_utils'
LevelSession = require 'models/LevelSession'
module.exports = class LadderSubmissionView extends CocoView
className: 'ladder-submission-view'
@ -74,18 +75,24 @@ module.exports = class LadderSubmissionView extends CocoView
data: ajaxData
success: success
error: failure
if @mirrorSession
if @mirrorSession and @mirrorSession.get('submittedCode')
# Also submit the mirrorSession after the main session submits successfully.
mirrorAjaxData = _.clone ajaxData
mirrorAjaxData.session = @mirrorSession.id
mirrorCode = @mirrorSession.get('code')
if @session.get('team') is 'humans'
mirrorAjaxData.transpiledCode = 'hero-placeholder-1': transpiledCode['hero-placeholder']
mirrorCode['hero-placeholder-1'] = @session.get('code')['hero-placeholder']
else
mirrorAjaxData.transpiledCode = 'hero-placeholder': transpiledCode['hero-placeholder-1']
mirrorCode['hero-placeholder'] = @session.get('code')['hero-placeholder-1']
mirrorAjaxOptions = _.clone ajaxOptions
mirrorAjaxOptions.data = mirrorAjaxData
ajaxOptions.success = ->
$.ajax '/queue/scoring', mirrorAjaxOptions
ajaxOptions.success = =>
patch = code: mirrorCode, codeLanguage: @session.get('codeLanguage'), submittedCodeLanguage: @session.get('submittedCodeLanguage')
tempSession = new LevelSession _id: @mirrorSession.id
tempSession.save patch, patch: true, type: 'PUT', success: ->
$.ajax '/queue/scoring', mirrorAjaxOptions
$.ajax '/queue/scoring', ajaxOptions

View file

@ -101,7 +101,9 @@ module.exports = class CastButtonView extends CocoView
@casting = false
if @hasCastOnce # Don't play this sound the first time
@playSound 'cast-end', 0.5
_.delay (=> @ladderSubmissionView?.rankSession()), 1000 if @ladderSubmissionView
myHeroID = if me.team is 'ogres' then 'Hero Placeholder 1' else 'Hero Placeholder'
if @ladderSubmissionView and not e.world.thangMap[myHeroID]?.errorsOut
_.delay (=> @ladderSubmissionView?.rankSession()), 1000 if @ladderSubmissionView
@hasCastOnce = true
@updateCastButton()
@world = e.world

View file

@ -190,7 +190,9 @@ module.exports = class DocFormatter
return null unless action
cooldowns = cooldown: action.cooldown, specificCooldown: action.specificCooldown, name: actionName, type: type
for prop in ['range', 'radius', 'duration', 'damage']
cooldowns[prop] = v = owner[_.string.camelize actionName + _.string.capitalize(prop)]
v = owner[_.string.camelize actionName + _.string.capitalize(prop)]
continue if prop is 'range' and v <= 5 # Don't confuse players by showing melee ranges, they will inappropriately use distanceTo(enemy) < 3.
cooldowns[prop] = v
if _.isNumber(v) and v isnt Math.round v
cooldowns[prop] = v.toFixed 2
cooldowns

View file

@ -36,7 +36,7 @@ module.exports = class Spell
else
@setLanguage 'javascript'
@useTranspiledCode = @shouldUseTranspiledCode()
console.log 'Spell', @spellKey, 'is using transpiled code (should only happen if it\'s an enemy/spectate writable method).' if @useTranspiledCode
#console.log 'Spell', @spellKey, 'is using transpiled code (should only happen if it\'s an enemy/spectate writable method).' if @useTranspiledCode
@source = @originalSource
@parameters = p.parameters

View file

@ -113,7 +113,7 @@ module.exports = class PlayHeroesModal extends ModalView
{id: 'coffeescript', name: "CoffeeScript (#{$.i18n.t('choose_hero.experimental')})"}
{id: 'clojure', name: "Clojure (#{$.i18n.t('choose_hero.experimental')})"}
{id: 'lua', name: 'Lua'}
{id: 'io', name: "Io (#{$.i18n.t('choose_hero.experimental')})"}
#{id: 'io', name: "Io (#{$.i18n.t('choose_hero.experimental')})"}
]
onHeroChanged: (e) ->

View file

@ -92,7 +92,7 @@
"karma": "~0.12",
"karma-chrome-launcher": "~0.1.2",
"karma-coffee-preprocessor": "~0.1.2",
"karma-coverage": "~0.1.4",
"karma-coverage": "~0.5.1",
"karma-firefox-launcher": "~0.1.3",
"karma-html2js-preprocessor": "~0.1.0",
"karma-jasmine": "~0.2.0",

View file

@ -0,0 +1,221 @@
// Copy sales leads from HelpScout to Close.io based on HelpScout tags
// TODO: handle leads with multiple email addresses
// TODO: some feedback email threads get broken up in Close.io
var CloseIo = function (apiKey, mailboxEmail) {
this.apiKey = apiKey;
this.mailboxEmail = mailboxEmail;
}
CloseIo.prototype.createLead = function (conversation, done) {
console.log('Close.Io - Creating lead for', conversation.customer.email);
var data = {
contacts: [{
emails: [{
email: conversation.customer.email,
type: 'office'
}],
name: conversation.customer.firstName + ' ' + conversation.customer.lastName
}]
};
var options = {
uri: 'https://' + this.apiKey+ ':X@app.close.io/api/v1/lead/',
body: JSON.stringify(data)
};
request.post(options, function (error, response, body) {
if (error) {
return done(error);
}
return done(null, JSON.parse(body));
});
}
CloseIo.prototype.getActivities = function (leadID, done) {
// console.log('Close.Io - Retrieving activities for lead', leadID);
request.get('https://' + this.apiKey + ':X@app.close.io/api/v1/activity/email/?lead_id=' + leadID, function(error, response, body) {
if (error) {
return done(error);
}
return done(null, JSON.parse(body));
});
}
CloseIo.prototype.getLead = function (conversation, done) {
// console.log('Close.Io - Retrieving contact', conversation.customer.email);
var uri = 'https://' + this.apiKey + ':X@app.close.io/api/v1/lead/?query=email_address:' + conversation.customer.email;
request.get(uri, (function(error, response, body) {
if (error) return done(error);
var leads = JSON.parse(body);
if (leads.data.length === 1) {
return done(null, leads.data[0]);
}
else if (leads.data.length > 1) {
return done('ERROR: too many leads returned for ' + conversation.customer.email + ' ' + leads.data.length);
}
this.createLead(conversation, (function(error, lead) {
if (error) return done(error);
return done(null, lead);
}).bind(this));
}).bind(this));
}
CloseIo.prototype.updateActivity = function (activities, lead, conversation, conversationThread, done) {
// console.log('Close.Io - Updating email thread', conversation.subject);
var data = {
body_html: conversationThread.body,
contact_id: lead.contacts[0].id,
date_created: conversationThread.createdAt,
lead_id: lead.id,
sender: conversationThread.createdBy.email,
_type: 'Email'
}
if (conversation.subject) {
data.subject = conversation.subject;
if (data.subject.substring(0, 4) === 'Re: ') {
data.subject = data.subject.substring(4);
}
}
if (conversationThread.createdBy.email === this.mailboxEmail) {
data.status = 'sent';
data.to = [conversationThread.customer.email];
}
else {
data.status = 'inbox';
data.to = [this.mailboxEmail];
}
for (var i = 0; i < activities.data.length; i++) {
if (activities.data[i].body_html === data.body_html
&& new Date(activities.data[i].date_created).getTime() == new Date(data.date_created).getTime()) {
// console.log('Close.Io - Found existing email', data.subject, data.date_created);
return done();
}
}
var options = {
uri: 'https://' + this.apiKey + ':X@app.close.io/api/v1/activity/email/',
body: JSON.stringify(data)
};
request.post(options, function (error, response, body) {
if (error) {
return done(error);
}
return done();
});
}
CloseIo.prototype.updateLead = function (conversation, done) {
console.log('Close.Io - Updating lead', conversation.customer.email);
this.getLead(conversation, (function(error, lead) {
if (error) return done(error);
this.updateLeadEmails(lead, conversation, (function(error) {
if (error) {
console.log(error);
return;
}
}).bind(this));
}).bind(this));
}
CloseIo.prototype.updateLeadEmails = function (lead, conversation, done) {
console.log('Close.Io - Updating lead emails', lead.display_name, conversation.subject);
if (conversation.type !== 'email') return done();
this.getActivities(lead.id, (function(error, activities) {
if (error) return done(error);
for (var i = 0; i < conversation.threads.length; i++) {
if (conversation.threads[i].type !== 'message') continue;
if (conversation.threads[i].state !== 'published') continue;
if (!conversation.threads[i].body || conversation.threads[i].body.length === 0) continue;
this.updateActivity(activities, lead, conversation, conversation.threads[i], done);
}
}).bind(this));
}
var HelpScout = function (apiKey, mailboxEmails, searchTag) {
this.apiKey = apiKey;
this.mailboxEmails = mailboxEmails;
this.searchTag = searchTag;
}
HelpScout.prototype.getConversation = function (conversationId, done) {
// console.log('HelpScout - Retrieving conversation', conversationId);
request.get('https://' + this.apiKey + ':X@api.helpscout.net/v1/conversations/' + conversationId + '.json', function (error, response, body) {
if (error) return done(error);
var conversation = JSON.parse(body);
return done(null, conversation.item);
});
}
HelpScout.prototype.getConversations = function (mailboxId, done) {
// console.log('HelpScout - Retrieving conversations for mailbox', mailboxId);
var results = [];
var fetchPage = (function (page) {
// console.error("HelpScout - Fetching conversations page", page);
var uri = 'https://' + this.apiKey + ':X@api.helpscout.net/v1/mailboxes/' + mailboxId + '/conversations.json'
uri += '?page=' + page + '&tag=' + this.searchTag;
request.get(uri, function (error, response, body) {
if (error) return done(error);
var conversations = JSON.parse(body);
results = results.concat(conversations.items);
if (conversations.page < conversations.pages) {
return fetchPage(page + 1);
}
return done(null, results);
});
}).bind(this);
fetchPage(1);
}
HelpScout.prototype.getMailboxes = function (done) {
// console.log('HelpScout - Retrieving mailboxes');
var results = [];
request.get('https://' + this.apiKey + ':X@api.helpscout.net/v1/mailboxes.json', (function (error, response, body) {
if (error) return done(error);
var mailboxes = JSON.parse(body);
for (var i = 0 ; i < mailboxes.items.length; i++) {
if (this.mailboxEmails.indexOf(mailboxes.items[i].email) >= 0) {
results.push(mailboxes.items[i]);
}
}
return done(null, results);
}).bind(this));
}
// Main program
if (process.argv.length !== 4) {
log("Usage: node <script> <HelpScout API key> <Close.io API key>");
process.exit();
}
var request = require('request');
var helpScout = new HelpScout(process.argv[2], ['support@codecombat.com', 'team@codecombat.com'], 'make the sale');
var closeIo = new CloseIo(process.argv[3], 'matt@codecombat.com');
helpScout.getMailboxes(function (error, mailboxes) {
if (error) {
console.log(error);
return;
}
for (var i = 0; i < mailboxes.length; i++) {
var mailbox = mailboxes[i];
helpScout.getConversations(mailbox.id, function(error, conversations) {
if (error) {
console.log(error);
return;
}
console.log(mailbox.email, 'mailbox has', conversations.length, 'conversations');
for (var i = 0; i < conversations.length; i++) {
if (conversations[i].type !== 'email') continue;
if (i > 8) {
console.log('TODO: process all the conversations');
break;
}
helpScout.getConversation(conversations[i].id, function(error, conversation) {
if (error) {
console.log(error);
return;
}
closeIo.updateLead(conversation, function(error, lead) {
if (error) {
console.log(error);
return;
}
});
});
}
});
}
});

View file

@ -4,10 +4,9 @@
// mongo <address>:<port>/<database> <script file> -u <username> -p <password>
// NOTE: uses name as unique identifier, so changing the name will insert a new course
// NOTE: concepts should match actual campaign levels
// NOTE: pricePerSeat in USD cents
var documents =
var courses =
[
{
name: "Introduction to Computer Science",
@ -15,6 +14,7 @@ var documents =
campaignID: ObjectId("55b29efd1cd6abe8ce07db0d"),
concepts: ['basic_syntax', 'arguments', 'while_loops', 'strings', 'variables'],
description: "Learn basic syntax, while loops, and the CodeCombat environment.",
duration: NumberInt(1),
pricePerSeat: NumberInt(0),
screenshot: "/images/pages/courses/101_info.png"
},
@ -24,6 +24,7 @@ var documents =
campaignID: ObjectId("55b29efd1cd6abe8ce07db0d"),
concepts: ['basic_syntax', 'arguments', 'while_loops', 'strings', 'variables', 'if_statements'],
description: "Introduce Arguments, Variables, If Statements, and Arithmetic.",
duration: NumberInt(5),
pricePerSeat: NumberInt(400),
screenshot: "/images/pages/courses/102_info.png"
},
@ -33,16 +34,30 @@ var documents =
campaignID: ObjectId("55b29efd1cd6abe8ce07db0d"),
concepts: ['if_statements', 'arithmetic'],
description: "Learn how to handle input.",
duration: NumberInt(5),
pricePerSeat: NumberInt(400),
screenshot: "/images/pages/courses/103_info.png"
}
];
for (var i = 0; i < documents.length; i++) {
var doc = documents[i];
db.courses.update({name: doc.name}, doc, {upsert: true});
print("Finding course concepts..");
for (var i = 0; i < courses.length; i++) {
var concepts = {};
var cursor = db.campaigns.find({_id: courses[i].campaignID}, {'levels': 1});
if (cursor.hasNext()) {
var doc = cursor.next();
for (var levelID in doc.levels) {
for (var j = 0; j < doc.levels[levelID].concepts.length; j++) {
concepts[doc.levels[levelID].concepts[j]] = true;
}
}
}
courses[i].concepts = Object.keys(concepts);
}
function log(str) {
print(new Date().toISOString() + " " + str);
print("Updating courses..");
for (var i = 0; i < courses.length; i++) {
db.courses.update({name: courses[i].name}, courses[i], {upsert: true});
}
print("Done.");

View file

@ -205,7 +205,7 @@ LevelHandler = class LevelHandler extends Handler
sortParameters =
'totalScore': req.query.order
selectProperties = ['totalScore', 'creatorName', 'creator', 'submittedCodeLanguage', 'heroConfig', 'leagues.leagueID', 'leagues.stats.totalScore']
selectProperties = ['totalScore', 'creatorName', 'creator', 'submittedCodeLanguage', 'heroConfig', 'leagues.leagueID', 'leagues.stats.totalScore', 'submitDate']
query = Session
.find(sessionsQueryParameters)

View file

@ -21,21 +21,23 @@ module.exports = createNewTask = (req, res) ->
fetchInitialSessionsToRankAgainst.bind(yetiGuru, requestLevelMajorVersion, originalLevelID)
generateAndSendTaskPairsToTheQueue
], (err, successMessageObject) ->
if err? then return errors.serverError res, "There was an error submitting the game to the queue:#{err}"
if err? then return errors.serverError res, "There was an error submitting the game to the queue: #{err}"
scoringUtils.sendResponseObject res, successMessageObject
validatePermissions = (req, sessionID, callback) ->
return callback 'You are unauthorized to submit that game to the simulator' unless req.user?.get('email')
return callback 'You are unauthorized to submit that game to the simulator.' unless req.user?.get('email')
return callback null if req.user?.isAdmin()
findParameters = _id: sessionID
selectString = 'creator submittedCode code'
LevelSession.findOne(findParameters).select(selectString).lean().exec (err, retrievedSession) ->
LevelSession.findOne(findParameters).select(selectString).lean().exec (err, retrievedSession) =>
if err? then return callback err
userHasPermissionToSubmitCode = retrievedSession.creator is req.user?.id and
not _.isEqual(retrievedSession.code, retrievedSession.submittedCode)
unless userHasPermissionToSubmitCode then return callback 'You are unauthorized to submit that game to the simulator'
userHasPermissionToSubmitCode = retrievedSession.creator is req.user?.id
unless userHasPermissionToSubmitCode then return callback 'You are unauthorized to submit that game to the simulator.'
# Disabling this for now, since mirror matches submit different transpiled code for the same source code.
#alreadySubmitted = _.isEqual(retrievedSession.code, retrievedSession.submittedCode)
#unless alreadySubmitted then return callback 'You have already submitted that exact code for simulation.'
callback null

View file

@ -17,7 +17,7 @@ sessionSelectionString = 'team totalScore transpiledCode submittedCodeLanguage t
sendSessionsResponse = (res) ->
(err, sessions) ->
if err then return errors.serverError res, "Couldn't get two games to simulate: #{err}"
unless sessions.length is 2
unless _.filter(sessions).length is 2
console.log 'No games to score.', sessions.length
res.send 204, 'No games to score.'
return res.end()
@ -66,7 +66,7 @@ getRandomSessions = (user, callback) ->
# Sampling by level: we pick a level, then find a human and ogre session for that level, one at random, one biased towards recent submissions.
#ladderLevelIDs = ['greed', 'criss-cross', 'brawlwood', 'dungeon-arena', 'gold-rush', 'sky-span'] # Let's not give any extra simulations to old ladders.
ladderLevelIDs = ['dueling-grounds', 'cavern-survival', 'multiplayer-treasure-grove', 'harrowland', 'zero-sum', 'ace-of-coders']
ladderLevelIDs = ['dueling-grounds', 'cavern-survival', 'multiplayer-treasure-grove', 'harrowland', 'zero-sum', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders', 'ace-of-coders']
sampleByLevel = (callback) ->
levelID = _.sample ladderLevelIDs
favorRecentHumans = Math.random() < 0.5 # We pick one session favoring recent submissions, then find another one uniformly to play against
@ -76,6 +76,7 @@ findRandomSession = (queryParams, callback) ->
# In MongoDB 3.2, we will be able to easily get a random document with aggregate $sample: https://jira.mongodb.org/browse/SERVER-533
queryParams.submitted = true
favorRecent = queryParams.favorRecent
favorRecent = false # temp, for Ace of Coders tournament
delete queryParams.favorRecent
if favorRecent
return findRecentRandomSession queryParams, callback
@ -110,5 +111,3 @@ findEarliestSubmission = (queryParams, callback) ->
return callback err if err
result = earliestSubmissionCache[cacheKey] = earliest?.submitDate
callback null, result

4
singlecore.coffee Normal file
View file

@ -0,0 +1,4 @@
require('coffee-script')
require('coffee-script/register')
server = require('./server')
server.startServer()

View file

@ -94,6 +94,7 @@ describe 'LevelLoader', ->
describe 'loadDependenciesForSession', ->
it 'loads hero and item thang types from heroConfig in the given session', ->
levelLoader = new LevelLoader({supermodel:new SuperModel(), sessionID: 'id', levelID: 'id'})
levelLoader.sessionDependenciesRegistered = {}
session = new LevelSession(sessionWithAnyaWithGloves)
levelLoader.loadDependenciesForSession(session)
requests = jasmine.Ajax.requests.all()
@ -103,6 +104,7 @@ describe 'LevelLoader', ->
it 'loads components for the hero in the heroConfig in the given session', ->
levelLoader = new LevelLoader({supermodel:new SuperModel(), sessionID: 'id', levelID: 'id'})
levelLoader.sessionDependenciesRegistered = {}
session = new LevelSession(sessionWithAnyaWithGloves)
levelLoader.loadDependenciesForSession(session)
responses = {

File diff suppressed because it is too large Load diff