2015-10-26 22:50:09 +01:00
var currentVersion = 0.1 ;
var currentDictionary = {
name : "New" ,
2015-10-26 05:41:25 +01:00
words : [ ] ,
settings : {
caseSensitive : false ,
2015-10-26 22:50:09 +01:00
preferUpperCase : false ,
isComplete : false
} ,
dictionaryBuilderVersion : currentVersion
}
var defaultDictionaryJSON = JSON . stringify ( currentDictionary ) ; //Saves a stringifyed default dictionary.
//document.write(defaultDictionaryJSON);
var savedScroll = {
x : 0 ,
y : 0
2015-10-26 05:41:25 +01:00
}
window . onload = function ( ) {
2015-10-26 22:50:09 +01:00
//defaultDictionaryJSON = JSON.stringify(currentDictionary); //Saves a stringifyed default dictionary.
2015-10-26 05:41:25 +01:00
LoadDictionary ( ) ;
2015-10-26 22:50:09 +01:00
ClearForm ( ) ;
if ( currentDictionary . settings . isComplete ) {
document . getElementById ( "wordEntryForm" ) . style . display = "none" ;
}
2015-10-26 05:41:25 +01:00
}
var Word = function ( word , simpleDefinition , longDefinition , partOfSpeech ) {
//this.index = currentDictionary.index++;
this . name = word ;
this . simpleDefinition = simpleDefinition ;
this . longDefinition = longDefinition ;
this . partOfSpeech = partOfSpeech ;
}
function AddWord ( ) {
2015-10-26 22:50:09 +01:00
var word = htmlEntities ( document . getElementById ( "word" ) . value ) ;
var simpleDefinition = htmlEntities ( document . getElementById ( "simpleDefinition" ) . value ) ;
var longDefinition = htmlEntities ( document . getElementById ( "longDefinition" ) . value ) ;
var partOfSpeech = htmlEntities ( document . getElementById ( "partOfSpeech" ) . value ) ;
var editIndex = htmlEntities ( document . getElementById ( "editIndex" ) . value ) ;
var errorMessageArea = document . getElementById ( "errorMessage" ) ;
var errorMessage = "" ;
var updateConflictArea = document . getElementById ( "updateConflict" ) ;
var updateConflictMessageArea = document . getElementById ( "updateConflictMessage" ) ;
var updateConfirmButton = document . getElementById ( "updateConfirmButton" ) ;
2015-10-26 05:41:25 +01:00
if ( word != "" && ( simpleDefinition != "" || longDefinition != "" ) ) {
if ( ! currentDictionary . settings . caseSensitive ) {
if ( currentDictionary . settings . preferUpperCase ) {
word = word . toUpperCase ( ) ;
} else {
word = word . toLowerCase ( ) ;
}
}
var wordIndex = WordIndex ( word ) ;
2015-10-26 22:50:09 +01:00
if ( editIndex != "" ) {
if ( currentDictionary . words [ parseInt ( editIndex ) ] . name != word || currentDictionary . words [ parseInt ( editIndex ) ] . simpleDefinition != simpleDefinition || currentDictionary . words [ parseInt ( editIndex ) ] . longDefinition != longDefinition || currentDictionary . words [ parseInt ( editIndex ) ] . partOfSpeech != partOfSpeech ) {
updateConflictArea . style . display = "block" ;
updateConflictArea . innerHTML = "<span id='updateConflictMessage'>Do you really want to change the word \"" + currentDictionary . words [ parseInt ( editIndex ) ] . name + "\" to what you have set above?</span>" ;
updateConflictArea . innerHTML += '<button type="button" id="updateConfirmButton" onclick="UpdateWord(' + editIndex + ', \'' +
htmlEntities ( word ) + '\', \'' +
htmlEntities ( simpleDefinition ) + '\', \'' +
htmlEntities ( longDefinition ) + '\', \'' +
htmlEntities ( partOfSpeech ) + '\'); return false;">Yes, Update it</button>' ;
updateConflictArea . innerHTML += '<button type="button" id="updateCancelButton" onclick="CloseUpdateConflictArea(); return false;">No, Leave it</button>' ;
} else {
errorMessage = "No change has been made to \"" + word + "\"" ;
}
} else if ( wordIndex >= 0 ) {
if ( currentDictionary . words [ parseInt ( wordIndex ) ] . simpleDefinition != simpleDefinition || currentDictionary . words [ parseInt ( wordIndex ) ] . longDefinition != longDefinition || currentDictionary . words [ parseInt ( wordIndex ) ] . partOfSpeech != partOfSpeech ) {
updateConflictArea . style . display = "block" ;
updateConflictArea . innerHTML = "<span id='updateConflictMessage'>\"" + word + "\" is already in the dictionary. Do you want to update it to what you have set above?</span>" ;
updateConflictArea . innerHTML += '<button type="button" id="updateConfirmButton" onclick="UpdateWord(' + wordIndex + ', \'' +
htmlEntities ( word ) + '\', \'' +
htmlEntities ( simpleDefinition ) + '\', \'' +
htmlEntities ( longDefinition ) + '\', \'' +
htmlEntities ( partOfSpeech ) + '\'); return false;">Yes, Update it</button>' ;
updateConflictArea . innerHTML += ' <button type="button" id="updateCancelButton" onclick="CloseUpdateConflictArea(); return false;">No, Leave it</button>' ;
} else {
errorMessage = "\"" + word + "\" is already in the dictionary exactly as it is written above." ;
2015-10-26 05:41:25 +01:00
}
} else {
currentDictionary . words . push ( new Word ( word , simpleDefinition , longDefinition , partOfSpeech ) ) ;
2015-10-26 22:50:09 +01:00
ClearForm ( ) ;
2015-10-26 05:41:25 +01:00
}
currentDictionary . words . sort ( dynamicSort ( "name" ) ) ;
2015-10-26 22:50:09 +01:00
errorMessageArea . innerHTML = "" ;
2015-10-26 05:41:25 +01:00
ShowDictionary ( ) ;
SaveDictionary ( ) ;
} else {
if ( word == "" ) {
2015-10-26 22:50:09 +01:00
errorMessage += "Word cannot be blank" ;
2015-10-26 05:41:25 +01:00
if ( simpleDefinition == "" && longDefinition == "" ) {
2015-10-26 22:50:09 +01:00
errorMessage += " and you need at least one definition." ;
2015-10-26 05:41:25 +01:00
} else {
2015-10-26 22:50:09 +01:00
errorMessage += "." ;
2015-10-26 05:41:25 +01:00
}
} else if ( simpleDefinition == "" && longDefinition == "" ) {
2015-10-26 22:50:09 +01:00
errorMessage += "You need at least one definition."
2015-10-26 05:41:25 +01:00
}
}
2015-10-26 22:50:09 +01:00
errorMessageArea . innerHTML = errorMessage ;
2015-10-26 05:41:25 +01:00
}
2015-10-26 22:50:09 +01:00
function SaveScroll ( ) {
var doc = document . documentElement ;
var left = ( window . pageXOffset || doc . scrollLeft ) - ( doc . clientLeft || 0 ) ;
var top = ( window . pageYOffset || doc . scrollTop ) - ( doc . clientTop || 0 ) ;
savedScroll . x = left ;
savedScroll . y = top ;
}
function EditWord ( index ) {
SaveScroll ( ) ;
window . scroll ( 0 , 0 ) ;
ClearForm ( ) ;
document . getElementById ( "editIndex" ) . value = index . toString ( ) ;
document . getElementById ( "word" ) . value = htmlEntitiesParse ( currentDictionary . words [ index ] . name ) ;
document . getElementById ( "simpleDefinition" ) . value = htmlEntitiesParse ( currentDictionary . words [ index ] . simpleDefinition ) ;
document . getElementById ( "longDefinition" ) . value = htmlEntitiesParse ( currentDictionary . words [ index ] . longDefinition ) ;
document . getElementById ( "partOfSpeech" ) . value = htmlEntitiesParse ( currentDictionary . words [ index ] . partOfSpeech ) ;
document . getElementById ( "newWordButtonArea" ) . style . display = "none" ;
document . getElementById ( "editWordButtonArea" ) . style . display = "block" ;
}
function UpdateWord ( wordIndex , word , simpleDefinition , longDefinition , partOfSpeech ) {
currentDictionary . words [ wordIndex ] . name = word ;
2015-10-26 05:41:25 +01:00
currentDictionary . words [ wordIndex ] . simpleDefinition = simpleDefinition ;
currentDictionary . words [ wordIndex ] . longDefinition = longDefinition ;
currentDictionary . words [ wordIndex ] . partOfSpeech = partOfSpeech ;
2015-10-26 22:50:09 +01:00
ShowDictionary ( ) ;
SaveDictionary ( ) ;
ClearForm ( ) ;
CloseUpdateConflictArea ( ) ;
window . scroll ( savedScroll . x , savedScroll . y ) ;
}
function DeleteWord ( index ) {
if ( document . getElementById ( "editIndex" ) . value != "" )
ClearForm ( ) ;
currentDictionary . words . splice ( index , 1 ) ;
ShowDictionary ( ) ;
SaveDictionary ( ) ;
CloseUpdateConflictArea ( ) ;
}
function CloseUpdateConflictArea ( ) {
document . getElementById ( "updateConflict" ) . style . display = "none" ;
}
function ClearForm ( ) {
document . getElementById ( "word" ) . value = "" ;
document . getElementById ( "simpleDefinition" ) . value = "" ;
document . getElementById ( "longDefinition" ) . value = "" ;
document . getElementById ( "partOfSpeech" ) . value = "" ;
document . getElementById ( "editIndex" ) . value = "" ;
document . getElementById ( "newWordButtonArea" ) . style . display = "block" ;
document . getElementById ( "editWordButtonArea" ) . style . display = "none" ;
document . getElementById ( "errorMessage" ) . innerHTML = "" ;
document . getElementById ( "updateConflict" ) . style . display = "none" ;
2015-10-26 05:41:25 +01:00
}
function ShowDictionary ( ) {
2015-10-26 22:50:09 +01:00
var dictionaryNameArea = document . getElementById ( "dictionaryName" ) ;
dictionaryNameArea . innerHTML = htmlEntitiesParse ( currentDictionary . name ) + " Dictionary" ;
2015-10-26 05:41:25 +01:00
var dictionaryArea = document . getElementById ( "theDictionary" ) ;
var dictionaryText = "" ;
2015-10-26 22:50:09 +01:00
if ( currentDictionary . words . length > 0 ) {
for ( var i = 0 ; i < currentDictionary . words . length ; i ++ ) {
dictionaryText += DictionaryEntry ( i ) ;
}
} else {
dictionaryText = "There are no entries in the dictionary."
}
2015-10-26 05:41:25 +01:00
2015-10-26 22:50:09 +01:00
dictionaryArea . innerHTML = dictionaryText ;
}
2015-10-26 05:41:25 +01:00
2015-10-26 22:50:09 +01:00
function DictionaryEntry ( itemIndex ) {
var entryText = "<entry>" ;
2015-10-26 05:41:25 +01:00
2015-10-26 22:50:09 +01:00
entryText += "<word>" + currentDictionary . words [ itemIndex ] . name + "</word>" ;
2015-10-26 05:41:25 +01:00
2015-10-26 22:50:09 +01:00
if ( currentDictionary . words [ itemIndex ] . partOfSpeech != "" ) {
entryText += " <partofspeech>" + currentDictionary . words [ itemIndex ] . partOfSpeech + "</partofspeech>" ;
}
entryText += "<br>" ;
2015-10-26 05:41:25 +01:00
2015-10-26 22:50:09 +01:00
if ( currentDictionary . words [ itemIndex ] . simpleDefinition != "" ) {
entryText += "<simpledefinition> ==> " + currentDictionary . words [ itemIndex ] . simpleDefinition + "</simpledefinition>" ;
2015-10-26 05:41:25 +01:00
}
2015-10-26 22:50:09 +01:00
if ( currentDictionary . words [ itemIndex ] . longDefinition != "" ) {
entryText += "<longdefinition>" + currentDictionary . words [ itemIndex ] . longDefinition + "</longdefinition>" ;
}
entryText += ManagementArea ( itemIndex ) ;
entryText += "</entry>" ;
return entryText ;
}
function ManagementArea ( itemIndex ) {
var managementHTML = "<div class='management'>" ;
managementHTML += "<span class='editButton' onclick='EditWord(" + itemIndex + ")'>Edit</span>" ;
managementHTML += "<span class='deleteButton' onclick='document.getElementById(\"delete" + itemIndex + "Confirm\").style.display = \"block\";'>Delete</span>" ;
managementHTML += "<div class='deleteConfirm' id='delete" + itemIndex + "Confirm' style='display:none;'>Are you sure you want to delete this entry?<br>" ;
managementHTML += "<span class='deleteCancelButton' onclick='document.getElementById(\"delete" + itemIndex + "Confirm\").style.display = \"none\";'>No</span>" ;
managementHTML += "<span class='deleteConfirmButton' onclick='DeleteWord(" + itemIndex + ")'>Yes</span>" ;
managementHTML += "</div>" ;
managementHTML += "</div>" ;
return managementHTML ;
}
function ShowSettings ( ) {
document . getElementById ( "settingsScreen" ) . style . display = "block" ;
document . getElementById ( "dictionaryNameEdit" ) . value = htmlEntitiesParse ( currentDictionary . name ) ;
document . getElementById ( "dictionaryIsComplete" ) . checked = currentDictionary . settings . isComplete ;
}
function SaveSettings ( ) {
2015-10-26 23:21:13 +01:00
if ( htmlEntities ( document . getElementById ( "dictionaryNameEdit" ) . value ) != "" ) {
currentDictionary . name = htmlEntities ( document . getElementById ( "dictionaryNameEdit" ) . value ) ;
}
2015-10-26 22:50:09 +01:00
currentDictionary . settings . isComplete = document . getElementById ( "dictionaryIsComplete" ) . checked ;
ShowDictionary ( ) ;
SaveDictionary ( ) ;
}
function HideSettings ( ) {
document . getElementById ( "settingsScreen" ) . style . display = "none" ;
document . getElementById ( "wordEntryForm" ) . style . display = ( currentDictionary . settings . isComplete ) ? "none" : "block" ;
2015-10-26 05:41:25 +01:00
}
2015-10-26 22:50:09 +01:00
function EmptyWholeDictionary ( ) {
if ( confirm ( "This will delete the entire current dictionary. If you do not have a backed up export, you will lose it forever!\n\nDo you still want to delete?" ) ) {
currentDictionary = JSON . parse ( defaultDictionaryJSON ) ;
ShowDictionary ( ) ;
SaveDictionary ( ) ;
HideSettings ( ) ;
}
}
2015-10-26 05:41:25 +01:00
function SaveDictionary ( ) {
localStorage . setItem ( 'dictionary' , JSON . stringify ( currentDictionary ) ) ;
}
function LoadDictionary ( ) {
if ( localStorage . getItem ( 'dictionary' ) ) {
2015-10-26 22:50:09 +01:00
var tmpDictionary = JSON . parse ( localStorage . getItem ( 'dictionary' ) ) ;
if ( tmpDictionary . words . length > 0 ) {
currentDictionary = JSON . parse ( localStorage . getItem ( 'dictionary' ) ) ;
}
tmpDictionary = null ;
2015-10-26 05:41:25 +01:00
}
ShowDictionary ( ) ;
}
2015-10-26 22:50:09 +01:00
function ExportDictionary ( ) {
2015-10-26 23:21:13 +01:00
var downloadName = currentDictionary . name . replace ( /\W/g , '' ) ;
if ( downloadName == "" ) {
downloadName = "export" ;
}
download ( downloadName + ".dict" , localStorage . getItem ( 'dictionary' ) ) ;
2015-10-26 22:50:09 +01:00
}
function ImportDictionary ( ) {
if ( ! window . FileReader ) {
alert ( 'Your browser is not supported' ) ;
return false ;
}
var reader = new FileReader ( ) ;
if ( document . getElementById ( "importFile" ) . files . length > 0 ) {
var file = document . getElementById ( "importFile" ) . files [ 0 ] ;
// Read the file
reader . readAsText ( file ) ;
// When it's loaded, process it
reader . onloadend = function ( ) {
if ( reader . result && reader . result . length ) {
if ( reader . result . substr ( reader . result . length - 31 ) == '"dictionaryBuilderVersion":' + currentVersion + '}' ) {
localStorage . setItem ( 'dictionary' , reader . result ) ;
document . getElementById ( "importFile" ) . value = "" ;
LoadDictionary ( ) ;
HideSettings ( ) ;
} else {
alert ( "Uploaded file is not compatible." ) ;
}
} else {
alert ( "Upload Failed" ) ;
}
reader = null ;
}
} else {
alert ( "You must add a file to import." ) ;
}
}
2015-10-26 05:41:25 +01:00
function WordIndex ( word ) {
for ( var i = 0 ; i < currentDictionary . words . length ; i ++ )
{
2015-10-26 22:50:09 +01:00
if ( currentDictionary . words [ i ] . name == word ) {
2015-10-26 05:41:25 +01:00
return i ;
}
}
return - 1 ;
2015-10-26 22:50:09 +01:00
}
function htmlEntities ( string ) {
return String ( string ) . replace ( /&/g , '&' ) . replace ( /</g , '<' ) . replace ( />/g , '>' ) . replace ( /"/g , '"' ) . replace ( /'/g , ''' ) . replace ( /\n/g , '<br>' ) ;
}
function htmlEntitiesParse ( string ) {
return String ( string ) . replace ( /&/g , '&' ) . replace ( /</g , '<' ) . replace ( />/g , '>' ) . replace ( /"/g , '"' ) . replace ( /'/g , "'" ) . replace ( /<br>/g , '\n' ) ;
}
2015-10-26 23:21:13 +01:00
function dynamicSort ( property ) {
/* Retrieved from http:/ / stackoverflow . com / a / 4760279
Usage : theArray . sort ( dynamicSort ( "objectProperty" ) ) ; * /
var sortOrder = 1 ;
if ( property [ 0 ] === "-" ) {
sortOrder = - 1 ;
property = property . substr ( 1 ) ;
}
return function ( a , b ) {
var result = ( a [ property ] < b [ property ] ) ? - 1 : ( a [ property ] > b [ property ] ) ? 1 : 0 ;
return result * sortOrder ;
}
}
2015-10-26 22:50:09 +01:00
function download ( filename , text ) {
/* Retrieved from http:/ / stackoverflow . com / a / 18197341 / 3508346
Usage : download ( 'test.txt' , 'Hello world!' ) ; * /
var element = document . createElement ( 'a' ) ;
element . setAttribute ( 'href' , 'data:text/plain;charset=utf-8,' + encodeURIComponent ( text ) ) ;
element . setAttribute ( 'download' , filename ) ;
element . style . display = 'none' ;
document . body . appendChild ( element ) ;
element . click ( ) ;
document . body . removeChild ( element ) ;
2015-10-26 05:41:25 +01:00
}