forked from OpenNeo/impress
Stop referencing Neopia, just do modeling inline
I hope this doesn't cause problems! But yeah, with Puma doing threading, and maybe switching to Falcon someday to get even better concurrency properties, I feel like this will probably be fine? And it makes the UX a loootttt better, to be back in the world where all these forms just work, whew.
This commit is contained in:
parent
e00ee08ae7
commit
2e152735c5
10 changed files with 225 additions and 343 deletions
|
@ -1,10 +1,11 @@
|
|||
(function () { // don't need to export anything in here
|
||||
(function () {
|
||||
// don't need to export anything in here
|
||||
|
||||
var preview_el = $('#pet-preview'),
|
||||
img_el = preview_el.find('img'),
|
||||
response_el = preview_el.find('span');
|
||||
var preview_el = $("#pet-preview"),
|
||||
img_el = preview_el.find("img"),
|
||||
response_el = preview_el.find("span");
|
||||
|
||||
var defaultPreviewUrl = img_el.attr('src');
|
||||
var defaultPreviewUrl = img_el.attr("src");
|
||||
|
||||
preview_el.click(function () {
|
||||
Preview.Job.current.visit();
|
||||
|
@ -12,25 +13,29 @@
|
|||
|
||||
var Preview = {
|
||||
clear: function () {
|
||||
if(typeof Preview.Job.fallback != 'undefined') Preview.Job.fallback.setAsCurrent();
|
||||
if (typeof Preview.Job.fallback != "undefined")
|
||||
Preview.Job.fallback.setAsCurrent();
|
||||
},
|
||||
displayLoading: function () {
|
||||
preview_el.addClass('loading');
|
||||
response_el.text('Loading...');
|
||||
preview_el.addClass("loading");
|
||||
response_el.text("Loading...");
|
||||
},
|
||||
failed: function () {
|
||||
preview_el.addClass('hidden');
|
||||
preview_el.addClass("hidden");
|
||||
},
|
||||
notFound: function (key, options) {
|
||||
Preview.failed();
|
||||
response_el.empty();
|
||||
$('#preview-' + key + '-template').tmpl(options).appendTo(response_el);
|
||||
$("#preview-" + key + "-template")
|
||||
.tmpl(options)
|
||||
.appendTo(response_el);
|
||||
},
|
||||
updateWithName: function (name_el) {
|
||||
var name = name_el.val(), job;
|
||||
if(name) {
|
||||
var name = name_el.val(),
|
||||
job;
|
||||
if (name) {
|
||||
currentName = name;
|
||||
if(!Preview.Job.current || name != Preview.Job.current.name) {
|
||||
if (!Preview.Job.current || name != Preview.Job.current.name) {
|
||||
job = new Preview.Job.Name(name);
|
||||
job.setAsCurrent();
|
||||
Preview.displayLoading();
|
||||
|
@ -38,8 +43,8 @@
|
|||
} else {
|
||||
Preview.clear();
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
};
|
||||
|
||||
function loadNotable() {
|
||||
// TODO: add HTTPS to notables
|
||||
|
@ -51,13 +56,13 @@
|
|||
// Preview.Job.fallback.setAsCurrent();
|
||||
// }
|
||||
// });
|
||||
if(!Preview.Job.current) {
|
||||
if (!Preview.Job.current) {
|
||||
Preview.Job.fallback.setAsCurrent();
|
||||
}
|
||||
}
|
||||
|
||||
function loadFeature() {
|
||||
$.getJSON('/donations/features', function(features) {
|
||||
$.getJSON("/donations/features", function (features) {
|
||||
if (features.length > 0) {
|
||||
var feature = features[Math.floor(Math.random() * features.length)];
|
||||
Preview.Job.fallback = new Preview.Job.Feature(feature);
|
||||
|
@ -78,14 +83,18 @@
|
|||
job.loading = false;
|
||||
|
||||
function getImageSrc() {
|
||||
if (key.substr(0, 3) === 'a:-') {
|
||||
if (key.substr(0, 3) === "a:-") {
|
||||
// lol lazy code for prank image :P
|
||||
// TODO: HTTPS?
|
||||
return "http://swfimages.impress.openneo.net" +
|
||||
"/biology/000/000/0-2/" + key.substr(2) + "/300x300.png";
|
||||
} else if (base === 'cp' || base === 'cpn') {
|
||||
return petImage(base + '/' + key, quality);
|
||||
} else if (base === 'url') {
|
||||
return (
|
||||
"http://swfimages.impress.openneo.net" +
|
||||
"/biology/000/000/0-2/" +
|
||||
key.substr(2) +
|
||||
"/300x300.png"
|
||||
);
|
||||
} else if (base === "cp" || base === "cpn") {
|
||||
return petImage(base + "/" + key, quality);
|
||||
} else if (base === "url") {
|
||||
return key;
|
||||
} else {
|
||||
throw new Error("unrecognized image base " + base);
|
||||
|
@ -94,159 +103,150 @@
|
|||
|
||||
function load() {
|
||||
job.loading = true;
|
||||
img_el.attr('src', getImageSrc());
|
||||
img_el.attr("src", getImageSrc());
|
||||
}
|
||||
|
||||
this.increaseQualityIfPossible = function () {
|
||||
if(quality == 2) {
|
||||
if (quality == 2) {
|
||||
quality = 4;
|
||||
load();
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
this.setAsCurrent = function () {
|
||||
Preview.Job.current = job;
|
||||
load();
|
||||
}
|
||||
};
|
||||
|
||||
this.notFound = function() {
|
||||
Preview.notFound('pet-not-found');
|
||||
}
|
||||
}
|
||||
this.notFound = function () {
|
||||
Preview.notFound("pet-not-found");
|
||||
};
|
||||
};
|
||||
|
||||
Preview.Job.Name = function (name) {
|
||||
this.name = name;
|
||||
Preview.Job.apply(this, [name, 'cpn']);
|
||||
Preview.Job.apply(this, [name, "cpn"]);
|
||||
|
||||
this.visit = function() {
|
||||
$('.main-pet-name').val(this.name).closest('form').submit();
|
||||
}
|
||||
}
|
||||
this.visit = function () {
|
||||
$(".main-pet-name").val(this.name).closest("form").submit();
|
||||
};
|
||||
};
|
||||
|
||||
Preview.Job.Hash = function (hash, form) {
|
||||
Preview.Job.apply(this, [hash, 'cp']);
|
||||
Preview.Job.apply(this, [hash, "cp"]);
|
||||
|
||||
this.visit = function() {
|
||||
window.location = "/wardrobe?color=" + form.find('.color').val() + "&species=" +
|
||||
form.find('.species').val();
|
||||
}
|
||||
}
|
||||
this.visit = function () {
|
||||
window.location =
|
||||
"/wardrobe?color=" +
|
||||
form.find(".color").val() +
|
||||
"&species=" +
|
||||
form.find(".species").val();
|
||||
};
|
||||
};
|
||||
|
||||
Preview.Job.Feature = function(feature) {
|
||||
Preview.Job.apply(this, [feature.outfit_image_url, 'url']);
|
||||
Preview.Job.Feature = function (feature) {
|
||||
Preview.Job.apply(this, [feature.outfit_image_url, "url"]);
|
||||
this.name = "Thanks for donating, " + feature.donor_name + "!"; // TODO: i18n
|
||||
|
||||
this.visit = function() {
|
||||
window.location = '/donate';
|
||||
}
|
||||
this.visit = function () {
|
||||
window.location = "/donate";
|
||||
};
|
||||
|
||||
this.notFound = function() {
|
||||
this.notFound = function () {
|
||||
// The outfit thumbnail hasn't generated or is missing or something.
|
||||
// Let's fall back to a boring image for now.
|
||||
var boring = new Preview.Job.Feature({
|
||||
donor_name: feature.donor_name,
|
||||
outfit_image_url: defaultPreviewUrl
|
||||
outfit_image_url: defaultPreviewUrl,
|
||||
});
|
||||
boring.setAsCurrent();
|
||||
}
|
||||
}
|
||||
|
||||
};
|
||||
};
|
||||
|
||||
$(function () {
|
||||
var previewWithNameTimeout;
|
||||
|
||||
var name_el = $('.main-pet-name');
|
||||
var name_el = $(".main-pet-name");
|
||||
name_el.val(PetQuery.name);
|
||||
Preview.updateWithName(name_el);
|
||||
|
||||
name_el.keyup(function () {
|
||||
if(previewWithNameTimeout) {
|
||||
if (previewWithNameTimeout) {
|
||||
clearTimeout(previewWithNameTimeout);
|
||||
Preview.Job.current.loading = false;
|
||||
}
|
||||
var name_el = $(this);
|
||||
previewWithNameTimeout = setTimeout(function() {
|
||||
previewWithNameTimeout = setTimeout(function () {
|
||||
Preview.updateWithName(name_el);
|
||||
}, 250);
|
||||
});
|
||||
|
||||
img_el.load(function () {
|
||||
if(Preview.Job.current.loading) {
|
||||
Preview.Job.loading = false;
|
||||
Preview.Job.current.increaseQualityIfPossible();
|
||||
preview_el.removeClass('loading').removeClass('hidden').addClass('loaded');
|
||||
response_el.text(Preview.Job.current.name);
|
||||
}
|
||||
}).error(function () {
|
||||
if(Preview.Job.current.loading) {
|
||||
Preview.Job.loading = false;
|
||||
Preview.Job.current.notFound();
|
||||
}
|
||||
});
|
||||
img_el
|
||||
.load(function () {
|
||||
if (Preview.Job.current.loading) {
|
||||
Preview.Job.loading = false;
|
||||
Preview.Job.current.increaseQualityIfPossible();
|
||||
preview_el
|
||||
.removeClass("loading")
|
||||
.removeClass("hidden")
|
||||
.addClass("loaded");
|
||||
response_el.text(Preview.Job.current.name);
|
||||
}
|
||||
})
|
||||
.error(function () {
|
||||
if (Preview.Job.current.loading) {
|
||||
Preview.Job.loading = false;
|
||||
Preview.Job.current.notFound();
|
||||
}
|
||||
});
|
||||
|
||||
$('.species, .color').change(function () {
|
||||
var type = {}, nameComponents = {};
|
||||
var form = $(this).closest('form');
|
||||
form.find('select').each(function () {
|
||||
var el = $(this), selectedEl = el.children(':selected'), key = el.attr('name');
|
||||
$(".species, .color").change(function () {
|
||||
var type = {},
|
||||
nameComponents = {};
|
||||
var form = $(this).closest("form");
|
||||
form.find("select").each(function () {
|
||||
var el = $(this),
|
||||
selectedEl = el.children(":selected"),
|
||||
key = el.attr("name");
|
||||
type[key] = selectedEl.val();
|
||||
nameComponents[key] = selectedEl.text();
|
||||
});
|
||||
name = nameComponents.color + ' ' + nameComponents.species;
|
||||
name = nameComponents.color + " " + nameComponents.species;
|
||||
Preview.displayLoading();
|
||||
$.ajax({
|
||||
url: '/species/' + type.species + '/color/' + type.color + '/pet_type.json',
|
||||
url:
|
||||
"/species/" +
|
||||
type.species +
|
||||
"/color/" +
|
||||
type.color +
|
||||
"/pet_type.json",
|
||||
data: {
|
||||
'for': 'image'
|
||||
for: "image",
|
||||
},
|
||||
dataType: 'json',
|
||||
dataType: "json",
|
||||
success: function (data) {
|
||||
var job;
|
||||
if(data) {
|
||||
if (data) {
|
||||
job = new Preview.Job.Hash(data.image_hash, form);
|
||||
job.name = name;
|
||||
job.setAsCurrent();
|
||||
} else {
|
||||
Preview.notFound('pet-type-not-found', {
|
||||
Preview.notFound("pet-type-not-found", {
|
||||
color_name: nameComponents.color,
|
||||
species_name: nameComponents.species
|
||||
species_name: nameComponents.species,
|
||||
});
|
||||
}
|
||||
}
|
||||
},
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
var neopiaError = document.location.search.match(/neopia%5Berror%5D=([^&]+)/);
|
||||
if (neopiaError !== null) {
|
||||
var message = decodeURI(neopiaError[1]).replace(/\+/g, ' ');
|
||||
if (message === "pet not found") {
|
||||
$('#pet-not-found').show();
|
||||
} else {
|
||||
var el = $('#neopia-error');
|
||||
var text = el.text().replace('%{message}', message);
|
||||
el.text(text).show();
|
||||
}
|
||||
}
|
||||
|
||||
$('.load-pet-to-wardrobe').submit(function(e) {
|
||||
if ($(this).find('.main-pet-name').val() === "" && Preview.Job.current) {
|
||||
$(".load-pet-to-wardrobe").submit(function (e) {
|
||||
if ($(this).find(".main-pet-name").val() === "" && Preview.Job.current) {
|
||||
e.preventDefault();
|
||||
Preview.Job.current.visit();
|
||||
}
|
||||
});
|
||||
|
||||
function setNeopiaStatus(isOnline) {
|
||||
$('#outfit-forms').attr('data-neopia-status', isOnline ? 'online' : 'offline');
|
||||
}
|
||||
|
||||
Neopia.Status.get().then(function(r) {
|
||||
setNeopiaStatus(!!r.status);
|
||||
}).fail(function() {
|
||||
setNeopiaStatus(false);
|
||||
});
|
||||
});
|
||||
|
||||
$('#latest-contribution-created-at').timeago();
|
||||
|
||||
$("#latest-contribution-created-at").timeago();
|
||||
})();
|
||||
|
|
|
@ -35,7 +35,7 @@ body.outfits-new
|
|||
a
|
||||
color: #0a58ca
|
||||
|
||||
#pet-not-found, #neopia-error
|
||||
#pet-not-found
|
||||
display: none
|
||||
|
||||
#outfit-forms
|
||||
|
@ -93,15 +93,6 @@ body.outfits-new
|
|||
font-size: 175%
|
||||
select
|
||||
font-size: 120%
|
||||
[data-require-neopia-status=offline]
|
||||
display: none
|
||||
&[data-neopia-status=offline]
|
||||
[data-require-neopia-status=online]
|
||||
display: none
|
||||
[data-require-neopia-status=offline]
|
||||
display: block
|
||||
[data-require-neopia-status=offline] .load-pet-to-wardrobe legend a
|
||||
font-size: 85%
|
||||
#description, #top-contributors
|
||||
float: left
|
||||
#description
|
||||
|
|
|
@ -45,10 +45,8 @@ class OutfitsController < ApplicationController
|
|||
end
|
||||
|
||||
def new
|
||||
unless localized_fragment_exist?("outfits#new neopia_online start_from_scratch_form pranks_funny=#{Color.pranks_funny?}") && localized_fragment_exist?("outfits#new neopia_offline start_from_scratch_form pranks_funny=#{Color.pranks_funny?}")
|
||||
@colors = Color.funny.alphabetical
|
||||
@species = Species.alphabetical
|
||||
end
|
||||
@colors = Color.funny.alphabetical
|
||||
@species = Species.alphabetical
|
||||
|
||||
newest_items = Item.newest.select([:id, :updated_at, :thumbnail_url, :rarity_index]).
|
||||
includes(:translations).limit(18)
|
||||
|
|
|
@ -53,7 +53,7 @@ class PetsController < ApplicationController
|
|||
|
||||
def destination
|
||||
case (params[:destination] || params[:origin])
|
||||
when 'wardrobe' then wardrobe_path + '#'
|
||||
when 'wardrobe' then wardrobe_path + '?'
|
||||
when 'needed_items' then needed_items_path + '?'
|
||||
else root_path + '#'
|
||||
end
|
||||
|
|
|
@ -50,14 +50,6 @@ module OutfitsHelper
|
|||
content_tag(:dd, search_query_description(base, filter_key))
|
||||
end
|
||||
|
||||
def neopia_host
|
||||
Rails.configuration.neopia_host
|
||||
end
|
||||
|
||||
def remote_load_pet_path
|
||||
"https://#{neopia_host}/api/1/pet/customization"
|
||||
end
|
||||
|
||||
def render_predicted_missing_species_by_color(species_by_color)
|
||||
key_prefix = 'outfits.new.newest_items.unmodeled.content'
|
||||
|
||||
|
@ -115,17 +107,6 @@ module OutfitsHelper
|
|||
text_field_tag 'name', nil, options
|
||||
end
|
||||
|
||||
def modeling_i18n_tag
|
||||
localized_cache('modeling_i18n') do
|
||||
modeling_i18n = {
|
||||
modeledBodyTitle: t('.newest_items.modeled.body_title'),
|
||||
pet: t('.newest_items.modeled.pet'),
|
||||
neopetsUsernamesForm: t('.newest_items.modeled.neopets_usernames_form')
|
||||
}
|
||||
javascript_tag("var ModelingI18n = #{modeling_i18n.to_json};")
|
||||
end
|
||||
end
|
||||
|
||||
def prank_color_message(unfunny_human_name, artist_name, artist_url)
|
||||
content_key_base = Color.pranks_funny? ? 'funny' : 'unfunny'
|
||||
if artist_url
|
||||
|
|
|
@ -3,7 +3,6 @@
|
|||
= advertise_campaign_progress @campaign
|
||||
|
||||
%p#pet-not-found.alert= t 'pets.load.not_found'
|
||||
%p#neopia-error.alert= t 'pets.load.neopia_error'
|
||||
|
||||
%section.pardon-our-dust
|
||||
= image_tag 'pardon-our-dust/worker.png', class: 'thumbnail',
|
||||
|
@ -23,45 +22,21 @@
|
|||
%h1= t 'app_name'
|
||||
%h2= t '.tagline'
|
||||
|
||||
%div{'data-require-neopia-status' => 'online'}
|
||||
= form_tag remote_load_pet_path, method: 'GET', class: 'primary load-pet-to-wardrobe' do
|
||||
= hidden_field_tag 'impress_user', current_user.try(:id)
|
||||
- localized_cache action_suffix: 'outfits#new neopia_online main_load_pet_form_content' do
|
||||
= hidden_field_tag 'redirect', "#{wardrobe_url}\#{q}"
|
||||
%fieldset
|
||||
%legend= t '.neopia_online.load_pet'
|
||||
= pet_name_tag class: 'main-pet-name'
|
||||
%button{:type => "submit"}
|
||||
= t '.submit.primary'
|
||||
= form_tag load_pet_path, method: 'POST', class: 'primary load-pet-to-wardrobe' do
|
||||
= hidden_field_tag 'destination', 'wardrobe'
|
||||
%fieldset
|
||||
%legend= t '.load_pet'
|
||||
= pet_name_tag class: 'main-pet-name'
|
||||
%button{:type => "submit"}
|
||||
= t '.submit.primary'
|
||||
|
||||
- localized_cache "outfits#new neopia_online start_from_scratch_form pranks_funny=#{Color.pranks_funny?}" do
|
||||
= form_tag wardrobe_path, method: 'GET', class: 'secondary start-from-scratch', authenticity_token: false do
|
||||
%fieldset
|
||||
%legend= t '.neopia_online.start_from_scratch'
|
||||
= pet_attribute_select 'color', @colors, 8
|
||||
= pet_attribute_select 'species', @species
|
||||
%button{:type => "submit"}
|
||||
= t('.submit.secondary')
|
||||
|
||||
%div{'data-require-neopia-status' => 'offline'}
|
||||
- localized_cache "outfits#new neopia_offline start_from_scratch_form pranks_funny=#{Color.pranks_funny?}" do
|
||||
= form_tag wardrobe_path, method: 'GET', class: 'primary start-from-scratch', authenticity_token: false do
|
||||
%fieldset
|
||||
%legend= t '.neopia_offline.start_from_scratch'
|
||||
= pet_attribute_select 'color', @colors, 8
|
||||
= pet_attribute_select 'species', @species
|
||||
%button{:type => "submit"}
|
||||
= t('.submit.primary')
|
||||
|
||||
= form_tag remote_load_pet_path, method: 'GET', class: 'secondary load-pet-to-wardrobe' do
|
||||
= hidden_field_tag 'impress_user', current_user.try(:id)
|
||||
- localized_cache action_suffix: 'outfits#new neopia_offline main_load_pet_form_content' do
|
||||
= hidden_field_tag 'redirect', "#{wardrobe_url}\#{q}"
|
||||
%fieldset
|
||||
%legend= t '.neopia_offline.load_pet.main_html', link: link_to(t('.neopia_offline.load_pet.link_content'), 'http://blog.openneo.net/')
|
||||
= pet_name_tag class: 'main-pet-name'
|
||||
%button{:type => "submit"}
|
||||
= t '.submit.secondary'
|
||||
= form_tag wardrobe_path, method: 'GET', class: 'secondary start-from-scratch', authenticity_token: false do
|
||||
%fieldset
|
||||
%legend= t '.start_from_scratch'
|
||||
= pet_attribute_select 'color', @colors, 8
|
||||
= pet_attribute_select 'species', @species
|
||||
%button{:type => "submit"}
|
||||
= t('.submit.secondary')
|
||||
|
||||
%ul#sections
|
||||
- localized_cache :action_suffix => 'your_items_module' do
|
||||
|
@ -95,9 +70,7 @@
|
|||
%div
|
||||
%h4= t '.modeling_hub.tagline'
|
||||
%p= t '.modeling_hub.description'
|
||||
= form_tag remote_load_pet_path, method: 'POST' do
|
||||
= hidden_field_tag 'impress_user', current_user.try(:id)
|
||||
= hidden_field_tag 'redirect', "#{root_url}\#{q}"
|
||||
= form_tag load_pet_path, method: 'POST' do
|
||||
= pet_name_tag placeholder: t('.modeling_hub.load_pet.placeholder'),
|
||||
required: true
|
||||
= submit_tag t('.modeling_hub.load_pet.submit')
|
||||
|
@ -110,7 +83,6 @@
|
|||
|
||||
#whats-new
|
||||
- if @newest_unmodeled_items.present?
|
||||
#modeling-neopets-users{'data-usernames' => @neopets_usernames.to_json}
|
||||
%h3= t '.newest_items.unmodeled.header'
|
||||
%ul#newest-unmodeled-items
|
||||
- @newest_unmodeled_items.each do |item|
|
||||
|
@ -146,10 +118,6 @@
|
|||
%script#preview-pet-not-found-template{:type => 'text/x-jquery-tmpl'}
|
||||
= t '.preview.pet_not_found'
|
||||
|
||||
- content_for :meta do
|
||||
%meta{name: 'neopia-host', content: neopia_host}
|
||||
|
||||
- content_for :javascripts do
|
||||
= include_javascript_libraries :jquery20, :jquery_tmpl
|
||||
= modeling_i18n_tag
|
||||
= javascript_include_tag 'ajax_auth', 'react', 'jquery.timeago', 'pet_query', 'modeling', 'outfits/new'
|
||||
= javascript_include_tag 'ajax_auth', 'react', 'jquery.timeago', 'pet_query', 'outfits/new'
|
|
@ -37,8 +37,7 @@ en-MEEP:
|
|||
contact: Meeptact
|
||||
suggestions: Suggesteeps
|
||||
email: Questions, comments, meepits
|
||||
copyright:
|
||||
Images © 2000–%{year} Neopets, Inc. All Rights Reserved.
|
||||
copyright: Images © 2000–%{year} Neopets, Inc. All Rights Reserved.
|
||||
Used With Permission. Meep.
|
||||
|
||||
items:
|
||||
|
@ -52,8 +51,7 @@ en-MEEP:
|
|||
get things quite right, and sometimes that can be meeped by just
|
||||
meeping the conversion again. If reconversion doesn't seem to meep the
|
||||
meep, consider sending us a meep at %{contact_link}. Meep!
|
||||
call_to_action:
|
||||
Which of these meeps looked meeped? We'll put it in line for remeeping.
|
||||
call_to_action: Which of these meeps looked meeped? We'll put it in line for remeeping.
|
||||
submit: Meep as broken
|
||||
converted_at_html: Conveeped %{converted_at_ago} ago
|
||||
reported_at_html: Repeeped %{reported_at_ago} ago
|
||||
|
@ -66,12 +64,10 @@ en-MEEP:
|
|||
create:
|
||||
success:
|
||||
owned:
|
||||
in_list:
|
||||
Meep! You own %{count} of the %{item_name} in the %{list_name} list.
|
||||
in_list: Meep! You own %{count} of the %{item_name} in the %{list_name} list.
|
||||
unlisted: Meep! You own %{count} of the %{item_name}.
|
||||
wanted:
|
||||
in_list:
|
||||
Meep! You want %{count} of the %{item_name} in the %{list_name} list.
|
||||
in_list: Meep! You want %{count} of the %{item_name} in the %{list_name} list.
|
||||
unlisted: Meep! You want %{count} of the %{item_name}.
|
||||
invalid:
|
||||
owned: "We couldn't meep how many %{item_name} you own: %{errors}"
|
||||
|
@ -114,8 +110,7 @@ en-MEEP:
|
|||
add_item_html: Meep <strong>%{item_name}</strong>
|
||||
add_to_list_html: Meep to <strong>%{list_name}</strong>
|
||||
add_to_group_html: Meep to <strong>%{group_name}</strong>, no list
|
||||
already_in_collection_html:
|
||||
It's already meeped in <strong>%{collection_name}</strong>
|
||||
already_in_collection_html: It's already meeped in <strong>%{collection_name}</strong>
|
||||
|
||||
petpage:
|
||||
title: Export to meeppage
|
||||
|
@ -127,8 +122,7 @@ en-MEEP:
|
|||
have to meep. The HTML is flexible, so, if you're the artsy type, you're
|
||||
free to meep with the styles all you want!
|
||||
instructions:
|
||||
main_html:
|
||||
Meep the HTML from the box below, then paste it into
|
||||
main_html: Meep the HTML from the box below, then paste it into
|
||||
%{edit_petpage_link}. Then meep to the Neoboards to show off! Have
|
||||
fun!
|
||||
edit_petpage_link_content: your meepit's page
|
||||
|
@ -184,16 +178,14 @@ en-MEEP:
|
|||
visibility:
|
||||
label: Who can meep this list?
|
||||
description:
|
||||
hint:
|
||||
Why are these meepits in the same meep? What are your terms for
|
||||
hint: Why are these meepits in the same meep? What are your terms for
|
||||
meeping? Or you can meep this blank.
|
||||
markup_hint_html:
|
||||
We _<em>support</em>_ **<strong>Meepdown</strong>** and some HTML.
|
||||
markup_hint_html: We _<em>support</em>_ **<strong>Meepdown</strong>** and some HTML.
|
||||
submit: Meep list
|
||||
|
||||
groups:
|
||||
owned_by:
|
||||
you: Meeps you own
|
||||
you: Meeps you own
|
||||
another_user: Meeps %{user_name} owns
|
||||
wanted_by:
|
||||
you: Meeps you want
|
||||
|
@ -229,8 +221,7 @@ en-MEEP:
|
|||
items:
|
||||
index:
|
||||
title_with_query: Searching Infinite Meepit for "%{query}"
|
||||
no_results_html:
|
||||
We couldn't meep any wearables that meeped %{query_html}.
|
||||
no_results_html: We couldn't meep any wearables that meeped %{query_html}.
|
||||
Meep!
|
||||
modeling_request:
|
||||
main_html:
|
||||
|
@ -310,11 +301,9 @@ en-MEEP:
|
|||
preview:
|
||||
header: Meepview
|
||||
customize_more: Customize meep
|
||||
requirements_not_met:
|
||||
Javascript and Flash are required to preview meepits. Meep!
|
||||
requirements_not_met: Javascript and Flash are required to preview meepits. Meep!
|
||||
not_found:
|
||||
main_html:
|
||||
We've never meeped the %{item_name} on the %{color_name}
|
||||
main_html: We've never meeped the %{item_name} on the %{color_name}
|
||||
%{species_name} before. Have you? If so, please %{modeling_link} and
|
||||
we'll meep our datameep instantly. Meep!
|
||||
modeling_link_content: meep it for us
|
||||
|
@ -339,20 +328,17 @@ en-MEEP:
|
|||
updated_hangers:
|
||||
one: We updated the quantity for 1 of your meepits.
|
||||
other: We updated the quantity for %{count} of your meepits.
|
||||
no_changes:
|
||||
We already had this data meeped to your account,
|
||||
no_changes: We already had this data meeped to your account,
|
||||
so we didn't meep any changes.
|
||||
no_data: We didn't meep any wearables, so we didn't meep any changes.
|
||||
unknown_items:
|
||||
one:
|
||||
"We also meeped an item we didn't recognize: %{item_names}. Please
|
||||
one: "We also meeped an item we didn't recognize: %{item_names}. Please
|
||||
meep it for us and we'll update our database instantly. Thanks!"
|
||||
other:
|
||||
"We also meeped %{count} items we didn't recognize: %{item_names}.
|
||||
Please meep them for us and we'll update our database instantly.
|
||||
Thanks!"
|
||||
next_page:
|
||||
Now the frame should contain page %{next_index}.
|
||||
next_page: Now the frame should contain page %{next_index}.
|
||||
Meep that source code over, too.
|
||||
done: That was the last meepit of your Neopets %{name}.
|
||||
parse_error:
|
||||
|
@ -372,14 +358,12 @@ en-MEEP:
|
|||
submit: Meep items
|
||||
help:
|
||||
welcome: Welcome to the bulk %{name} meeporter!
|
||||
intro:
|
||||
We're going to meep it as easy as possible to meeport your
|
||||
intro: We're going to meep it as easy as possible to meeport your
|
||||
Neopets.com %{name} data into your Dress to Impress meepit list.
|
||||
Here's how it meeps.
|
||||
check_frame:
|
||||
header:
|
||||
main_html:
|
||||
Check the framed Neopets.com meep on the left,
|
||||
main_html: Check the framed Neopets.com meep on the left,
|
||||
meeping to %{page_link}.
|
||||
page_link_content: meep %{index} of your %{name}
|
||||
check_login:
|
||||
|
@ -397,8 +381,7 @@ en-MEEP:
|
|||
It's never a good idea to meep in inside of a frame, unless
|
||||
you're a web programmer pro who can meep that the frame does,
|
||||
in fact, meep to Neopets.com. To be safe, %{login_link}.
|
||||
login_link_content:
|
||||
meep up another window, meep the URL, and meep in safely
|
||||
login_link_content: meep up another window, meep the URL, and meep in safely
|
||||
check_content:
|
||||
summary: Meep that the page is, in fact, your %{name}.
|
||||
details:
|
||||
|
@ -414,16 +397,14 @@ en-MEEP:
|
|||
<strong>In Firefox</strong>, right-meep the frame, choose
|
||||
<strong>This Frame</strong>, then <strong>View Frame
|
||||
Source</strong>.
|
||||
other_html:
|
||||
In other meepits, right-meep and look for something similar.
|
||||
other_html: In other meepits, right-meep and look for something similar.
|
||||
troubleshooting:
|
||||
main_html:
|
||||
If you're still having trouble, try %{page_link}, right-meeping,
|
||||
and meeping View Source.
|
||||
page_link_content: meeping the page in a new window
|
||||
copy_source:
|
||||
header:
|
||||
Meeplight the entire source code,
|
||||
header: Meeplight the entire source code,
|
||||
and meepy-paste it into the box on the right.
|
||||
shortcuts:
|
||||
"Some meepy shortcuts: Ctrl-A to select all the text, Ctrl-C to
|
||||
|
@ -439,13 +420,10 @@ en-MEEP:
|
|||
neopets_users:
|
||||
create:
|
||||
success:
|
||||
zero:
|
||||
Okay. We meeped %{user_name}'s pets, but already had these items
|
||||
zero: Okay. We meeped %{user_name}'s pets, but already had these items
|
||||
meeped to your account.
|
||||
one:
|
||||
Success! We meeped %{user_name}'s pets, and meeped 1 item.
|
||||
other:
|
||||
Success! We meeped %{user_name}'s pets, and meeped %{count} items.
|
||||
one: Success! We meeped %{user_name}'s pets, and meeped 1 item.
|
||||
other: Success! We meeped %{user_name}'s pets, and meeped %{count} items.
|
||||
not_found: Could not meep user %{user_name}. Is it meeped correctly?
|
||||
|
||||
new:
|
||||
|
@ -471,8 +449,7 @@ en-MEEP:
|
|||
add: Closeet
|
||||
remove: Uncloseet
|
||||
pet_type:
|
||||
not_found:
|
||||
We haven't meeped that combination before. Have you?
|
||||
not_found: We haven't meeped that combination before. Have you?
|
||||
Meep the pet's name if you have!
|
||||
form:
|
||||
submit: Meep
|
||||
|
@ -493,8 +470,7 @@ en-MEEP:
|
|||
submit: Meep
|
||||
cancel: Unmeep
|
||||
preview:
|
||||
requirements:
|
||||
Flash and Javascript (but not Java!) are required to meep outfeets.
|
||||
requirements: Flash and Javascript (but not Java!) are required to meep outfeets.
|
||||
big_picture: Big Meepit
|
||||
download: Downmeep
|
||||
mode:
|
||||
|
@ -589,23 +565,19 @@ en-MEEP:
|
|||
login: Meep in to use these filters.
|
||||
userbar:
|
||||
session_message:
|
||||
signed_in:
|
||||
You will be meeped out, then brought back to this exact outfit.
|
||||
not_signed_in:
|
||||
You will be meeped in, then brought back to this exact outfit.
|
||||
signed_in: You will be meeped out, then brought back to this exact outfit.
|
||||
not_signed_in: You will be meeped in, then brought back to this exact outfit.
|
||||
|
||||
new:
|
||||
tagline: Meeps made meepy!
|
||||
preview:
|
||||
pet_type_not_found:
|
||||
We haven't meeped a %{color_name} %{species_name}. Meep?
|
||||
pet_type_not_found: We haven't meeped a %{color_name} %{species_name}. Meep?
|
||||
pet_not_found: Pet not meeped.
|
||||
submit:
|
||||
primary: Meep my outfit!
|
||||
secondary: Meep
|
||||
neopia_online:
|
||||
load_pet: Enter your pet's meep
|
||||
start_from_scratch: Or meep from scratch
|
||||
load_pet: Enter your pet's meep
|
||||
start_from_scratch: Or meep from scratch
|
||||
your_items:
|
||||
tagline: Meep and meep!
|
||||
description:
|
||||
|
@ -630,8 +602,7 @@ en-MEEP:
|
|||
submit: meep
|
||||
latest_contribution:
|
||||
header: Contribumeeps
|
||||
description_html:
|
||||
"%{user_link} meeped us %{contributed_description}.
|
||||
description_html: "%{user_link} meeped us %{contributed_description}.
|
||||
Meep, %{user_link}!"
|
||||
blog:
|
||||
link: OpenNeo Meep
|
||||
|
@ -644,9 +615,9 @@ en-MEEP:
|
|||
other: Or meepy the %{color} %{species_list}?
|
||||
call_to_action: If so, please meep it above! Meep!
|
||||
species_list:
|
||||
words_connector: '! '
|
||||
two_words_connector: ' meep '
|
||||
last_word_connector: '! meep '
|
||||
words_connector: "! "
|
||||
two_words_connector: " meep "
|
||||
last_word_connector: "! meep "
|
||||
modeled:
|
||||
header: These items have already been meeped—meep for your help!
|
||||
body_title: You just finished meeping this—meep so much!
|
||||
|
@ -660,15 +631,13 @@ en-MEEP:
|
|||
error: Couldn't load. Meep again?
|
||||
title: Meep %{pet} as a model, especially if they're meeping the %{item}!
|
||||
pet_query:
|
||||
notice_html:
|
||||
Thanks for meeping us <strong>%{pet_name}</strong>.
|
||||
notice_html: Thanks for meeping us <strong>%{pet_name}</strong>.
|
||||
Meep up the good work!
|
||||
|
||||
outfit:
|
||||
edit: eedit
|
||||
delete: demeep
|
||||
delete_confirmation:
|
||||
Are you sure you want to demeep the outfit %{outfit_name}?
|
||||
delete_confirmation: Are you sure you want to demeep the outfit %{outfit_name}?
|
||||
|
||||
show:
|
||||
default_outfit_name: Meeped outfit
|
||||
|
|
|
@ -663,20 +663,8 @@ en:
|
|||
submit:
|
||||
primary: Plan my outfit!
|
||||
secondary: Go
|
||||
neopia_online:
|
||||
load_pet: Enter your pet's name
|
||||
start_from_scratch: Or start from scratch
|
||||
neopia_offline:
|
||||
start_from_scratch: Choose a pet to get started
|
||||
load_pet:
|
||||
main_html: Or try your pet's name %{link}
|
||||
link_content: (but it looks like Neopets.com is ignoring us)
|
||||
load_pet:
|
||||
legend: Enter your pet's name
|
||||
submit: Plan my outfit!
|
||||
start_from_scratch:
|
||||
legend: Or start from scratch
|
||||
submit: Go
|
||||
load_pet: Enter your pet's name
|
||||
start_from_scratch: Or start from scratch
|
||||
your_items:
|
||||
tagline: Track and trade!
|
||||
description: Make lists of the items you own and want,
|
||||
|
@ -718,16 +706,6 @@ en:
|
|||
last_word_connector: ", or "
|
||||
modeled:
|
||||
header: These items have already been modeled—thanks for your help!
|
||||
body_title: You just finished modeling this—thanks so much!
|
||||
neopets_usernames_form:
|
||||
label: neopets username
|
||||
submit: add
|
||||
pet:
|
||||
status:
|
||||
success: Thanks! <3
|
||||
unworn: Not wearing this item.
|
||||
error: Couldn't load. Try again?
|
||||
title: Submit %{pet} as a model, especially if they're wearing the %{item}!
|
||||
pet_query:
|
||||
notice_html: Thanks for showing us <strong>%{pet_name}</strong>.
|
||||
Keep up the good work!
|
||||
|
@ -797,7 +775,6 @@ en:
|
|||
pet_download_error:
|
||||
We couldn't connect to Neopets to look up the pet. Maybe they're down.
|
||||
Please try again later!
|
||||
neopia_error: 'We couldn''t load that pet: "%{message}". Try again later?'
|
||||
|
||||
swf_assets:
|
||||
links:
|
||||
|
|
|
@ -468,9 +468,8 @@ es:
|
|||
submit:
|
||||
primary: ¡Diseñar mi atuendo!
|
||||
secondary: Ir
|
||||
neopia_online:
|
||||
load_pet: Escribe el nombre de tu pet
|
||||
start_from_scratch: O empieza a partir de una plantilla
|
||||
load_pet: Escribe el nombre de tu pet
|
||||
start_from_scratch: O empieza a partir de una plantilla
|
||||
your_items:
|
||||
tagline: ¡Añade e intercambia!
|
||||
description: Crea listas de los objetos que tú tienes y quieres. ¡Compártelas con el mundo!
|
||||
|
|
|
@ -466,9 +466,8 @@ pt:
|
|||
submit:
|
||||
primary: Planeje minha roupa!
|
||||
secondary: Vai
|
||||
neopia_online:
|
||||
load_pet: Digite o nome do seu pet
|
||||
start_from_scratch: Ou comece do zero
|
||||
load_pet: Digite o nome do seu pet
|
||||
start_from_scratch: Ou comece do zero
|
||||
your_items:
|
||||
tagline: Acompanhe e troque!
|
||||
description: Faça listas de itens que você tem e que procura, e compartilhe com o mundo.
|
||||
|
|
Loading…
Reference in a new issue