X-Git-Url: https://jasonwoof.com/gitweb/?p=hexbog.git;a=blobdiff_plain;f=main.coffee;h=015ce7c2fa221d9b772d863a05d56b0d74aa01ed;hp=04670557f2d7211008a21202d1ba4204e240f6bd;hb=5f118636bd356acfabd1e6a3a9da0b6bc433c95b;hpb=0b70e4b47604d7a6ee1f851c31bb5ce2f6410044 diff --git a/main.coffee b/main.coffee index 0467055..015ce7c 100644 --- a/main.coffee +++ b/main.coffee @@ -237,12 +237,32 @@ init_board = -> # (neighbors, above, down) init_board_layout() -$selection_display = null # initialized by init_html_board +$big_tip = null # initialized by init_html_board +$little_tip = null # initialized by init_html_board $score_display = null # initialized by init_html_board $definition_body = null # initialized by init_html_board update_selection_display = -> word = selected_word() - $selection_display.html word + $big_tip.removeClass('good') + if word.length > 0 + if word.length < 3 + $big_tip.html word + $little_tip.html "Click more tiles (3 minimum)" + else + if is_word word + if word.indexOf(word.substr(word.length - 1)) < word.length - 1 + last = 'last ' + else + last = '' + $little_tip.html "Click the #{last}\"#{word.substr(word.length - 1)}\" for #{score_for word} points" + $big_tip.html "#{word}" + $big_tip.addClass('good') + else + $big_tip.html word + $little_tip.html "\"#{word}\" is not in the word list." + else + $big_tip.html "← Click a word" + $little_tip.html "(tiles must be touching)" # color the selected tiles according to whether they're a word or not if word.length @@ -338,6 +358,8 @@ blip_selection = -> sliders[i] = false save_game() +score_for = (word) -> Math.round(Math.pow(1.7, word.length)) + activate_selection = -> word = selected_word() if word.length < 3 @@ -348,7 +370,7 @@ activate_selection = -> # FIXME make this automatically part of the selection display log "Not on word list: \"#{word}\"" return - word_score = Math.round(Math.pow(1.7, word.length)) + word_score = score_for word score += word_score $score_display.html score # FIXME make some kind of animation showing score gain @@ -416,7 +438,8 @@ $board = null html_tiles = [] init_html_board = -> $('#loading').remove() - $selection_display = $('#selection') + $big_tip = $('#big_tip') + $little_tip = $('#little_tip') $score_display = $('#score') $score_display.html score $definition_body = $('#definition_body') @@ -505,8 +528,8 @@ extract_wiktionary_definiton = (html) -> if part and el.tagName is 'OL' $(el).children().each (i, el) -> new_def = $(el).text() - if new_def.substr(0, 9) is '(obsolete' or new_def.substr(0, 8) is "(archaic" - key = 'obsolete' + if new_def.substr(0, 9) is '(obsolete' or new_def.substr(0, 8) is "(archaic" or new_def.substr(0, 20) is "Alternative form of " or new_def.substr(0, 24) is "Alternative spelling of " + key = 'lame' else if part is 'verb' key = 'verb' @@ -520,7 +543,7 @@ extract_wiktionary_definiton = (html) -> if found.verb return false # break - part_defs = (finds[i] for i in ['verb', 'nonverb', 'obsolete'] when finds[i]) + part_defs = (finds[i] for i in ['verb', 'nonverb', 'lame'] when finds[i]) unless part_defs.length return false @@ -528,7 +551,7 @@ extract_wiktionary_definiton = (html) -> look_up_definition = (word) -> - $definition_body.html "Looking up definition for \"#{word}\"." + $definition_body.html "Looking up definition for \"#{word}\"..." $.ajax({ url: "http://en.wiktionary.org/w/api.php?action=parse&format=json&page=#{word}" jsonpCallback: "lud_#{word}" # always use the same callback for the same word so it's cacheable @@ -608,5 +631,6 @@ init_game = -> init_board() init_html_board() init_start_over_link() + update_selection_display() $(init_game)