X-Git-Url: https://git.localhorst.tv/?a=blobdiff_plain;f=resources%2Fjs%2Fhelpers%2FTechnique.js;h=f3daae7d1dfd53453dd1166edaa639f27dcf167d;hb=442732627373739adf18518b6bbfbc305356f53f;hp=410f01595657de34f339d8c0f88b529bbdab316c;hpb=0586e04204885088f31ac9861446eb0759cc8d2f;p=alttp.git diff --git a/resources/js/helpers/Technique.js b/resources/js/helpers/Technique.js index 410f015..f3daae7 100644 --- a/resources/js/helpers/Technique.js +++ b/resources/js/helpers/Technique.js @@ -1,5 +1,21 @@ import i18n from '../i18n'; +export const getLink = tech => { + if (tech.type === 'dungeon') { + return `/dungeons/${tech.name}`; + } + if (tech.type === 'location') { + return `/locations/${tech.name}`; + } + if (tech.type === 'mode') { + return `/modes/${tech.name}`; + } + if (tech.type === 'ruleset') { + return `/rulesets/${tech.name}`; + } + return `/tech/${tech.name}`; +}; + export const getRelations = (tech, type) => { const rs = (tech && tech.relations) || []; return type ? rs.filter(r => r && r.pivot && r.pivot.type === type) : rs; @@ -7,6 +23,20 @@ export const getRelations = (tech, type) => { export const hasRelations = (tech, type) => getRelations(tech, type).length > 0; +export const getLanguages = tech => ['en', ...tech.translations.map(t => t.locale)]; + +export const getMatchedLocale = (tech, lang) => { + const direct = tech.translations.find(t => t.locale === lang); + if (direct) { + return direct.locale; + } + const sameLang = tech.translations.find(t => t.locale.substr(0, 2) === lang.substr(0, 2)); + if (sameLang) { + return sameLang.locale; + } + return 'en'; +}; + export const getTranslation = (tech, prop, lang) => { const direct = tech.translations.find(t => t.locale === lang); if (direct) { @@ -26,6 +56,7 @@ export const sorted = (techs) => [...techs].sort(compareTranslation('title', i18 export default { compareTranslation, + getLanguages, getRelations, getTranslation, hasRelations,