// Holds the various pages and implementations for codex books, so they can be used in more than just books. /datum/codex_tree var/atom/movable/holder = null var/root_type = null var/datum/lore/codex/home = null // Top-most page. var/list/current_page = list() // Current page or category to display to the user. // converted to list to track multiple players. var/list/indexed_pages = list() // Assoc list with search terms pointing to a ref of the page. It's created on New(). var/list/history = list() // List of pages we previously visited. // now a 2D list /datum/codex_tree/New(var/new_holder, var/new_root_type) holder = new_holder root_type = new_root_type generate_pages() ..() /datum/codex_tree/proc/generate_pages() home = new root_type(src) // This will also generate the others. //current_page = home indexed_pages = home.index_page() // changed from current_page to home. // Changes current_page to its parent, assuming one exists. /datum/codex_tree/proc/go_to_parent(var/mob/user) var/datum/lore/codex/D = current_page["[user]"] if(istype(D) && D.parent) current_page["[user]"] = D.parent // Changes current_page to a specific page or category. /datum/codex_tree/proc/go_to_page(var/datum/lore/codex/new_page, var/dont_record_history = FALSE, var/mob/user) var/datum/lore/codex/D = current_page["[user]"] if(new_page && istype(D)) // Make sure we're not going to a null page for whatever reason. current_page["[user]"] = new_page if(!dont_record_history) var/list/H = history["[user]"] if(!H) H = list() H.Add(new_page) history["[user]"] = H /datum/codex_tree/proc/quick_link(var/search_word, var/mob/user) for(var/word in indexed_pages) if(lowertext(search_word) == lowertext(word)) // Exact matches unfortunately limit our ability to perform SEOs. go_to_page(indexed_pages[word], FALSE, user) return /datum/codex_tree/proc/get_page_from_type(var/desired_type) for(var/word in indexed_pages) var/datum/lore/codex/C = indexed_pages[word] if(C.type == desired_type) return C return null // Returns to the last visited page, based on the history list. /datum/codex_tree/proc/go_back(var/mob/user) var/list/H = history["[user]"] var/datum/lore/codex/D = current_page["[user]"] if(!LAZYLEN(H) || !istype(D)) return if((H.len) > 1) if(H[H.len] == D) H.len-- // This gets rid of the current page in the history. history["[user]"] = H if(H.len == 1) go_to_page(H[H.len], TRUE, user) return go_to_page(pop(history["[user]"]), TRUE, user) // Where as this will get us the previous page that we want to go to. else go_to_page(H[H.len], TRUE, user) /datum/codex_tree/proc/get_tree_position(var/mob/user) var/datum/lore/codex/checked = current_page["[user]"] if(istype(checked)) var/output = "" output = span_bold("[checked.name]") while(checked.parent) output = "[checked.parent.name] \> [output]" checked = checked.parent return output /datum/codex_tree/proc/make_search_bar() var/html = {"
"} return html /datum/codex_tree/proc/display(mob/user) // icon_state = "[initial(icon_state)]-open" if(!home) generate_pages() if(!user) return var/datum/lore/codex/D = current_page["[user]"] if(!istype(D)) // Initialize current_page and history current_page["[user]"] = home D = current_page["[user]"] if(!istype(D)) log_runtime("Codex_tree failed to failed to load for [user].") return var/list/H_init = list() H_init.Add(home) history["[user]"] = H_init //if(!current_page) //generate_pages() user << browse_rsc('html/browser/codex.css', "codex.css") var/dat dat = "" dat += "[holder.name] ([D.name])" dat += "" dat += "" dat += "" dat += "[get_tree_position(user)]
" dat += "[make_search_bar()]
" dat += "
" dat += "

[D.name]

" dat += "
" if(D.data) dat += "[D.data]
" dat += "
" if(istype(D, /datum/lore/codex/category)) dat += "
" var/datum/lore/codex/category/C = D for(var/datum/lore/codex/child in C.children) dat += "[child.name]" dat += "
" dat += "
" var/list/H = history["[user]"] if(LAZYLEN(H)) dat += "
\[Go Back\]" if(D.parent) dat += "
\[Go Up\]" if(D != home) dat += "
\[Go To Home\]" dat += "
" user << browse("[dat]", "window=the_empress_protects;size=600x550") onclose(user, "the_empress_protects", src) /datum/codex_tree/Topic(href, href_list) . = ..() if(.) return if(href_list["target"]) // Direct link, using a ref var/datum/lore/codex/new_page = locate(href_list["target"]) go_to_page(new_page, FALSE, usr) else if(href_list["search_query"]) quick_link(href_list["search_query"], usr) else if(href_list["go_to_parent"]) go_to_parent(usr) else if(href_list["go_back"]) go_back(usr) else if(href_list["go_to_home"]) go_to_page(home, FALSE, usr) else if(href_list["quick_link"]) // Indirect link, using a (hopefully) indexed word. quick_link(href_list["quick_link"], usr) else if(href_list["close"]) // Close the book, if our holder is actually a book. //if(istype(holder, /obj/item/book/codex)) //holder.icon_state = initial(holder.icon_state) usr << browse(null, "window=the_empress_protects") return display(usr)