Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@tolgee/core

Package Overview
Dependencies
Maintainers
2
Versions
357
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@tolgee/core - npm Package Compare versions

Comparing version 4.10.0-rc.2b55a5c.0 to 4.10.0-rc.43623be.0

dist/tolgee.esm.js

258

dist/tolgee.cjs.js

@@ -480,5 +480,6 @@ 'use strict';

const PluginService = (getLanguage, getInitialOptions, getAvailableLanguages, getTranslationNs, getTranslation, changeTranslation) => {
const PluginService = (getLanguage, getInitialOptions, getObserverOptions, getAvailableLanguages, getTranslationNs, getTranslation, changeTranslation) => {
const plugins = {
ui: undefined,
observer: undefined,
};

@@ -508,13 +509,20 @@ const instances = {

};
const run = () => {
var _a;
instances.ui =
plugins.ui &&
new plugins.ui({
apiKey: getInitialOptions().apiKey,
apiUrl: getInitialOptions().apiUrl,
highlight,
changeTranslation,
});
(_a = instances.observer) === null || _a === void 0 ? void 0 : _a.run({ mouseHighlight: Boolean(instances.ui) });
const run = (isDev) => {
var _a, _b;
if (!instances.ui && plugins.ui) {
instances.ui = new plugins.ui({
apiKey: getInitialOptions().apiKey,
apiUrl: getInitialOptions().apiUrl,
highlight,
changeTranslation,
});
}
if (!instances.observer) {
instances.observer = (_a = plugins.observer) === null || _a === void 0 ? void 0 : _a.call(plugins, {
translate,
onClick,
options: getObserverOptions(),
});
}
(_b = instances.observer) === null || _b === void 0 ? void 0 : _b.run({ mouseHighlight: isDev });
};

@@ -535,6 +543,6 @@ const stop = () => {

const setObserver = (observer) => {
instances.observer = observer === null || observer === void 0 ? void 0 : observer({ translate, onClick });
plugins.observer = observer;
};
const getObserver = () => {
return instances.observer;
const hasObserver = () => {
return Boolean(plugins.observer);
};

@@ -552,4 +560,4 @@ const addFormatter = (formatter) => {

};
const getUi = () => {
return plugins.ui;
const hasUi = () => {
return Boolean(plugins.ui);
};

@@ -688,5 +696,5 @@ const setLanguageStorage = (storage) => {

setObserver,
getObserver,
hasObserver,
setUi,
getUi,
hasUi,
addBackend,

@@ -730,6 +738,23 @@ setDevBackend,

const defaultValues$1 = {
tagAttributes: {
textarea: ['placeholder'],
input: ['value', 'placeholder'],
img: ['alt'],
'*': ['aria-label', 'title'],
},
restrictedElements: ['script', 'style'],
highlightKeys: ['Alt'],
highlightColor: 'rgb(255, 0, 0)',
highlightWidth: 5,
inputPrefix: '%-%tolgee:',
inputSuffix: '%-%',
passToParent: ['option', 'optgroup'],
};
const initObserverOptions = (options) => {
return Object.assign(Object.assign({}, defaultValues$1), options);
};
const defaultValues = {
enableLanguageStore: true,
defaultNs: '',
filesUrlPrefix: 'i18n/',
};

@@ -753,2 +778,4 @@ const initState = (options, previousState) => {

let state = initState();
let observerOptions = initObserverOptions();
let devCredentials = undefined;
function init(options) {

@@ -791,3 +818,3 @@ state = initState(options, state);

function getInitialOptions() {
return state.initialOptions;
return Object.assign(Object.assign({}, state.initialOptions), devCredentials);
}

@@ -857,2 +884,11 @@ function addActiveNs(ns) {

}
function overrideCredentials(credentials) {
devCredentials = credentials;
}
function setObserverOptions(options) {
observerOptions = initObserverOptions(options);
}
function getObserverOptions() {
return observerOptions;
}
return Object.freeze({

@@ -876,2 +912,5 @@ init,

withDefaultNs,
overrideCredentials,
setObserverOptions,
getObserverOptions,
});

@@ -944,3 +983,3 @@ };

const state = State(events.onLanguageChange, events.onPendingLanguageChange, events.onRunningChange);
const pluginService = PluginService(state.getLanguage, state.getInitialOptions, state.getAvailableLanguages, getTranslationNs, getTranslation, changeTranslation);
const pluginService = PluginService(state.getLanguage, state.getInitialOptions, state.getObserverOptions, state.getAvailableLanguages, getTranslationNs, getTranslation, changeTranslation);
const cache = Cache(events.onCacheChange, pluginService.getBackendRecord, pluginService.getBackendDevRecord, state.withDefaultNs, state.isInitialLoading, fetchingObserver, loadingObserver);

@@ -976,3 +1015,5 @@ if (options) {

function isDev() {
return Boolean(state.getInitialOptions().apiKey && pluginService.getDevBackend());
return Boolean(state.getInitialOptions().apiKey &&
state.getInitialOptions().apiUrl &&
pluginService.getDevBackend());
}

@@ -1115,3 +1156,3 @@ async function addActiveNs(ns, forget) {

state.setRunning(true);
pluginService.run();
pluginService.run(isDev());
result = loadInitial();

@@ -1157,5 +1198,5 @@ }

setObserver: controller.setObserver,
getObserver: controller.getObserver,
hasObserver: controller.hasObserver,
setUi: controller.setUi,
getUi: controller.getUi,
hasUi: controller.hasUi,
setDevBackend: controller.setDevBackend,

@@ -1165,2 +1206,3 @@ addBackend: controller.addBackend,

setLanguageStorage: controller.setLanguageStorage,
overrideCredentials: controller.overrideCredentials,
});

@@ -1203,2 +1245,6 @@ const withRestart = (callback) => {

// plugins
setObserverOptions: (options) => {
controller.setObserverOptions(options);
return tolgee;
},
use: (plugin) => {

@@ -1222,6 +1268,158 @@ if (plugin) {

const TOLGEE_WRAPPED_ONLY_DATA_ATTRIBUTE = 'data-tolgee-key-only';
// needs to be same as in @tolgee/ui package
const DEVTOOLS_ID = '__tolgee_dev_tools';
exports.DEVTOOLS_ID = DEVTOOLS_ID;
const ERROR_PARAM_EMPTY = 0, ERROR_UNEXPECTED_CHAR = 1, ERROR_UNEXPECTED_END = 2;
class FormatError extends Error {
constructor(code, index, text) {
let error;
if (code === ERROR_PARAM_EMPTY) {
error = 'Empty parameter';
}
else if (code === ERROR_UNEXPECTED_CHAR) {
error = 'Unexpected character';
}
else {
error = 'Unexpected end';
}
super(`Tolgee parser: ${error} at ${index} in "${text}"`);
this.code = code;
this.index = index;
}
}
function isWhitespace(ch) {
return /\s/.test(ch);
}
const STATE_TEXT = 0, STATE_ESCAPE_MAYBE = 1, STATE_ESCAPE = 2, STATE_PARAM = 3, STATE_PARAM_AFTER = 4;
const END_STATES = new Set([
STATE_ESCAPE,
STATE_ESCAPE_MAYBE,
STATE_TEXT,
]);
const CHAR_ESCAPE = "'";
const ESCAPABLE = new Set(['{', '}', CHAR_ESCAPE]);
const isAllowedInParam = (char) => {
return /[0-9a-zA-Z_]/.test(char);
};
function formatParser(translation) {
let state = STATE_TEXT;
let text = '';
let param = '';
let ch = '';
const texts = [];
const params = [];
let i = 0;
function parsingError(code) {
throw new FormatError(code, i, translation);
}
const addText = () => {
texts.push(text);
text = '';
};
const addParamChar = () => {
if (!isAllowedInParam(ch)) {
parsingError(ERROR_UNEXPECTED_CHAR);
}
param += ch;
};
const addParam = () => {
if (param === '') {
parsingError(ERROR_PARAM_EMPTY);
}
params.push(param);
param = '';
};
for (i = 0; i < translation.length; i++) {
ch = translation[i];
switch (state) {
case STATE_TEXT:
if (ch === CHAR_ESCAPE) {
text += ch;
state = STATE_ESCAPE_MAYBE;
}
else if (ch === '{') {
addText();
state = STATE_PARAM;
}
else {
text += ch;
state = STATE_TEXT;
}
break;
case STATE_ESCAPE_MAYBE:
if (ESCAPABLE.has(ch)) {
text = text.slice(0, -1) + ch;
state = STATE_ESCAPE;
}
else {
text += ch;
state = STATE_TEXT;
}
break;
case STATE_ESCAPE:
if (ch === CHAR_ESCAPE) {
state = STATE_TEXT;
}
else {
text += ch;
state = STATE_ESCAPE;
}
break;
case STATE_PARAM:
if (ch === '}') {
addParam();
state = STATE_TEXT;
}
else if (!isWhitespace(ch)) {
addParamChar();
state = STATE_PARAM;
}
else if (param !== '') {
addParam();
state = STATE_PARAM_AFTER;
}
break;
case STATE_PARAM_AFTER:
if (ch == '}') {
state = STATE_TEXT;
}
else if (isWhitespace(ch)) {
state = STATE_PARAM_AFTER;
}
else {
parsingError(ERROR_UNEXPECTED_CHAR);
}
}
}
if (!END_STATES.has(state)) {
parsingError(ERROR_UNEXPECTED_END);
}
addText();
return [texts, params];
}
function formatter(translation, params) {
const [texts, pars] = formatParser(translation);
const result = [texts[0]];
for (let i = 1; i < texts.length; i++) {
const parameter = params === null || params === void 0 ? void 0 : params[pars[i - 1]];
if (parameter === undefined) {
throw new Error(`Missing parameter "${pars[i - 1]}" in "${translation}"`);
}
result.push(String(parameter));
result.push(texts[i]);
}
return result.join('');
}
function FormatSimpleCreator() {
return {
format: ({ translation, params }) => formatter(translation, params),
};
}
const FormatSimple = () => (tolgee, tools) => {
tools.setFinalFormatter(FormatSimpleCreator());
return tolgee;
};
exports.FormatSimple = FormatSimple;
exports.RESTRICTED_ASCENDANT_ATTRIBUTE = RESTRICTED_ASCENDANT_ATTRIBUTE;

@@ -1228,0 +1426,0 @@ exports.TOLGEE_ATTRIBUTE_NAME = TOLGEE_ATTRIBUTE_NAME;

2

dist/tolgee.cjs.min.js

@@ -1,2 +0,2 @@

"use strict";Object.defineProperty(exports,"__esModule",{value:!0});const e=()=>{let e=[];return Object.freeze({listen:n=>{const a=e=>{n(e)};return e.push(a),{unsubscribe:()=>{e=e.filter((e=>a!==e))}}},emit:n=>{e.forEach((e=>e({value:n})))}})};function n(e){return"string"==typeof e?[e]:Array.isArray(e)?e:void 0}function a(e){return n(e)||[]}function t(e,n){return"object"!=typeof(t=n)||Array.isArray(t)||null===t?a(n):a(null==n?void 0:n[e]);var t}function i(e){return Array.from(new Set(e))}function o(e,n){const a=e.get(n)||0;e.set(n,a+1)}function r(e,n){let a=e.get(n)||1;a-=1,a<=0?e.delete(n):e.set(n,a)}const s=e=>{const n=new Set,t=new Set,i=n=>{if(n.has(void 0)){const a=new Set(n.keys());return a.delete(void 0),e().forEach((e=>a.add(e))),a}return n};let s=[];const g=()=>{if(0===s.length)return;n.forEach((e=>{e({value:void 0})}));const e=new Set;let a=new Set;s.forEach((n=>{void 0===(null==n?void 0:n.ns)?e.add(void 0):n.ns.forEach((n=>e.add(n))),void 0===(null==n?void 0:n.key)?a=void 0:void 0!==a&&a.add(n.key)}));const o=Array.from(i(e).keys());(a||[void 0]).forEach((e=>{((e,n)=>{t.forEach((a=>{const t=i(a.namespaces),o=void 0===n||-1!==(null==n?void 0:n.findIndex((e=>t.has(e)))),r=void 0===e||a.keys.has(e)||0===a.keys.size;o&&r&&a.fn({value:void 0})}))})(e,o)})),s=[]};return Object.freeze({listenSome:e=>{const n={fn:n=>{e(n)},keys:new Map,namespaces:new Map};t.add(n);const i={unsubscribe:()=>{t.delete(n)},subscribeNs:e=>(a(e).forEach((e=>o(n.namespaces,e))),i),unsubscribeNs:e=>(a(e).forEach((e=>r(n.namespaces,e))),i),subscribeKey:e=>{const{key:t,ns:r}=e;return o(n.keys,t),a(r).forEach((e=>o(n.namespaces,e))),void 0===r&&o(n.namespaces,void 0),i},unsubscribeKey:e=>{const{key:t,ns:o}=e;return r(n.keys,t),a(o).forEach((e=>r(n.namespaces,e))),void 0===o&&r(n.namespaces,void 0),i}};return i},listen:e=>{n.add(e);return{unsubscribe:()=>{n.delete(e)}}},emit:(e,n)=>{s.push(e),n?Promise.resolve().then((()=>{g()})):g()}})},g=e=>{const n=new Map;return Object.entries(e).forEach((([e,a])=>{null!=a&&("object"!=typeof a?n.set(e,a):g(a).forEach(((a,t)=>{n.set(e+"."+t,a)})))})),n},c=e=>{const[n,a]=e.split(":");return{language:n,namespace:a||""}},u=({language:e,namespace:n})=>n?`${e}:${n}`:e,l=(e,n,t,i,o,r,s)=>{const l=new Map,d=new Map;let f={},p=0;function v(n,a,t){const i=u(n);d.set(i,{data:g(a),version:t}),e.emit(n)}function m(e,n){v(e,n,p)}function b(e,n=!1){const a=d.get(u(e));return a&&n?a.version===p:Boolean(a)}function h(e){var n;return null===(n=d.get(u(i(e))))||void 0===n?void 0:n.data}function y(e){let a;if(!a){const n=f[u(e)];"function"==typeof n&&(a=n())}return a||(a=n(e)),a||(a=Promise.resolve({})),a}return Object.freeze({addStaticData:function(e){e&&(f=Object.assign(Object.assign({},f),e),Object.entries(e).forEach((([e,n])=>{if("function"!=typeof n){const a=c(e),t=d.get(e);t&&0!==t.version||v(a,n,0)}})))},invalidate:function(){l.clear(),p+=1},addRecord:m,exists:b,getRecord:h,getTranslation:function(e,n){var a;return null===(a=d.get(u(e)))||void 0===a?void 0:a.data.get(n)},getTranslationNs:function(e,n,a){var t;for(const i of e)for(const e of n){const n=null===(t=d.get(u({language:e,namespace:i})))||void 0===t?void 0:t.data.get(a);if(null!=n)return i}return Array.from(new Set(e))},getTranslationFallback:function(e,n,a){var t;for(const i of e)for(const e of n){const n=null===(t=d.get(u({language:e,namespace:i})))||void 0===t?void 0:t.data.get(a);if(null!=n)return n}},changeTranslation:function(n,a,t){var i;const o=null===(i=d.get(u(n)))||void 0===i?void 0:i.data;null==o||o.set(a,t),e.emit(Object.assign(Object.assign({},n),{key:a}))},isFetching:function(e){if(o())return!0;if(void 0===e)return l.size>0;const n=a(e);return Boolean(Array.from(l.keys()).find((e=>n.includes(c(e).namespace))))},isLoading:function(e,n){const t=a(n);return Boolean(o()||Array.from(l.keys()).find((n=>{const a=c(n);return(!t.length||t.includes(a.namespace))&&!b({namespace:a.namespace,language:e})})))},loadRecords:async function(e,n){const a=e.map((e=>{const a=i(e),o=u(a),r=l.get(o);if(r)return{new:!1,promise:r,keyObject:a,cacheKey:o};const s=function(e,n){var a;let i;return n&&(i=null===(a=t(e))||void 0===a?void 0:a.catch((()=>(console.warn("Tolgee: Failed to fetch data from dev backend"),y(e))))),i||(i=y(e)),i}(a,n);return l.set(o,s),{new:!0,promise:s,keyObject:a,cacheKey:o}}));r.notify(),s.notify();const o=await Promise.all(a.map((e=>e.promise)));return a.forEach(((e,n)=>{const a=l.get(e.cacheKey)!==e.promise;if(e.new&&!a){l.delete(e.cacheKey);const a=o[n];a&&m(e.keyObject,a)}})),r.notify(),s.notify(),a.map((e=>h(e.keyObject)))},getAllRecords:function(){return Array.from(d.entries()).map((([e,n])=>Object.assign(Object.assign({},c(e)),{data:n.data})))}})};function d(e){return Boolean(e&&"function"==typeof e.then)}const f=(e,n)=>d(e)?Promise.resolve(e).then(n):n(e),p=e=>`Tolgee: You need to specify '${e}' option`,v=(e,n,t,i,o,r)=>{const s={ui:void 0},g={formatters:[],finalFormatter:void 0,observer:void 0,devBackend:void 0,backends:[],ui:void 0,languageDetector:void 0,languageStorage:void 0},c=async(e,{keysAndDefaults:n})=>{var t;const r=n.map((({key:e,ns:n,defaultValue:t})=>({key:e,defaultValue:t,ns:a(i({key:e,ns:n,defaultValue:t})),translation:o({key:e,ns:n})})));null===(t=g.ui)||void 0===t||t.handleElementClick(e,r)},u=(e,n)=>{var a,t;return(null===(t=null===(a=g.observer)||void 0===a?void 0:a.highlight)||void 0===t?void 0:t.call(a,e,n))||{unhighlight(){}}},l=e=>{const n=o(e);return p(Object.assign(Object.assign({},e),{translation:n,formatEnabled:!0}))},p=({key:n,translation:a,defaultValue:t,noWrap:i,params:o,orEmpty:r,ns:s,formatEnabled:c})=>{var u;const l=a||t;let d=l||(r?"":n);g.observer&&!i&&(d=g.observer.wrap({key:n,translation:d,defaultValue:t,params:o,ns:s}));const f=e(),p=c||!(null===(u=g.observer)||void 0===u?void 0:u.outputNotFormattable);if(l&&f&&p)for(const e of g.formatters)d=e.format({translation:d,language:f,params:o});return g.finalFormatter&&l&&f&&p&&(d=g.finalFormatter.format({translation:d,language:f,params:o})),d};return Object.freeze({setFinalFormatter:e=>{g.finalFormatter=e},addFormatter:e=>{e&&g.formatters.push(e)},formatTranslation:p,setObserver:e=>{g.observer=null==e?void 0:e({translate:l,onClick:c})},getObserver:()=>g.observer,setUi:e=>{s.ui=(null==e?void 0:e.UI)||e},getUi:()=>s.ui,addBackend:e=>{e&&g.backends.push(e)},setDevBackend:e=>{g.devBackend=e},getDevBackend:()=>g.devBackend,getBackendRecord:({language:e,namespace:n})=>{for(const a of g.backends){const t=a.getRecord({language:e,namespace:n});if(d(t))return null==t?void 0:t.catch((e=>(console.error(e),{})));if(void 0!==t)return t}},getBackendDevRecord:({language:e,namespace:a})=>{var t;return null===(t=g.devBackend)||void 0===t?void 0:t.getRecord({apiKey:n().apiKey,apiUrl:n().apiUrl,language:e,namespace:a})},setLanguageDetector:e=>{g.languageDetector=e},getLanguageDetector:()=>g.languageDetector,setLanguageStorage:e=>{g.languageStorage=e},getLanguageStorage:()=>g.languageStorage,getInitialLanguage:()=>{var e;const n=t(),a=null===(e=g.languageStorage)||void 0===e?void 0:e.getLanguage();return f(a,(e=>n&&!n.includes(e)||!e?(()=>{if(!g.languageDetector)return;const e=t();return g.languageDetector.getLanguage({availableLanguages:e})})():e))},setStoredLanguage:e=>{var n;null===(n=g.languageStorage)||void 0===n||n.setLanguage(e)},run:()=>{var e;g.ui=s.ui&&new s.ui({apiKey:n().apiKey,apiUrl:n().apiUrl,highlight:u,changeTranslation:r}),null===(e=g.observer)||void 0===e||e.run({mouseHighlight:Boolean(g.ui)})},stop:()=>{var e;g.ui=void 0,null===(e=g.observer)||void 0===e||e.stop()},retranslate:()=>{var e;null===(e=g.observer)||void 0===e||e.retranslate()},highlight:u,wrap:e=>{var n;return g.observer?null===(n=g.observer)||void 0===n?void 0:n.wrap(e):e.translation},unwrap:e=>{var n;return g.observer?null===(n=g.observer)||void 0===n?void 0:n.unwrap(e):{text:e,keys:[]}}})},m=(e,n,a)=>{let t=e;return Object.freeze({init:function(e){t=e},notify:function(){const e=n();t!==e&&a(e),t=e}})},b={enableLanguageStore:!0,defaultNs:"",filesUrlPrefix:"i18n/"},h=(e,n)=>{const a=Object.assign(Object.assign(Object.assign({},b),null==n?void 0:n.initialOptions),e),t=a.apiUrl;return a.apiUrl=t?t.replace(/\/+$/,""):t,{initialOptions:a,activeNamespaces:(null==n?void 0:n.activeNamespaces)||new Map,language:null==n?void 0:n.language,pendingLanguage:null==n?void 0:n.language,isInitialLoading:!1,isRunning:!1}};function y(e){var{ns:n,noWrap:a,orEmpty:t,params:i}=e,o=function(e,n){var a={};for(var t in e)Object.prototype.hasOwnProperty.call(e,t)&&n.indexOf(t)<0&&(a[t]=e[t]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols){var i=0;for(t=Object.getOwnPropertySymbols(e);i<t.length;i++)n.indexOf(t[i])<0&&Object.prototype.propertyIsEnumerable.call(e,t[i])&&(a[t[i]]=e[t[i]])}return a}(e,["ns","noWrap","orEmpty","params"]);return{ns:n,noWrap:a,orEmpty:t,params:Object.assign(Object.assign({},o),i)}}const L=(e,...n)=>{let a,t={};return"object"==typeof e?t=e:(t.key=e,"string"==typeof n[0]?(t.defaultValue=n[0],a=n[1]):"object"==typeof n[0]&&(a=n[0])),a&&(t=Object.assign(Object.assign({},y(a)),t)),t},O=({options:n})=>{const o=(n=>{const a=e(),t=e(),i=e(),o=e(),r=e(),g=e(),c=s(n),u=e(),l=e();return g.listen((()=>c.emit())),t.listen((()=>c.emit())),u.listen((({value:e})=>{c.emit({ns:[e.namespace],key:e.key},!0)})),Object.freeze({onPendingLanguageChange:a,onLanguageChange:t,onKeyChange:i,onKeyUpdate:c,onLoadingChange:o,onFetchingChange:r,onInitialLoaded:g,onRunningChange:l,onCacheChange:u,on:(e,n)=>{switch(e){case"pendingLanguage":return a.listen(n);case"language":return t.listen(n);case"loading":return o.listen(n);case"fetching":return r.listen(n);case"initialLoad":return g.listen(n);case"running":return l.listen(n);case"cache":return u.listen(n);case"keyUpdate":return c.listen(n)}}})})((function(){return u.getFallbackNamespaces()})),r=m(!1,(()=>y.isFetching()),o.onFetchingChange.emit),g=m(!1,(()=>R()),o.onLoadingChange.emit),u=((e,n,o)=>{let r=h();function s(){return r.language||r.initialOptions.language}function g(){return r.initialOptions}return Object.freeze({init:function(e){r=h(e,r)},isRunning:function(){return r.isRunning},setRunning:function(e){r.isRunning!==e&&(r.isRunning=e,o.emit(e))},isInitialLoading:function(){return r.isInitialLoading},setInitialLoading:function(e){r.isInitialLoading=e},getLanguage:s,setLanguage:function(n){r.language!==n&&(r.language=n,e.emit(n))},getPendingLanguage:function(){return r.pendingLanguage||s()},setPendingLanguage:function(e){r.pendingLanguage!==e&&(r.pendingLanguage=e,n.emit(e))},getInitialOptions:g,addActiveNs:function(e){a(e).forEach((e=>{const n=r.activeNamespaces.get(e);void 0!==n?r.activeNamespaces.set(e,n+1):r.activeNamespaces.set(e,1)}))},removeActiveNs:function(e){a(e).forEach((e=>{const n=r.activeNamespaces.get(e);void 0!==n&&n>1?r.activeNamespaces.set(e,n-1):r.activeNamespaces.delete(e)}))},getRequiredNamespaces:function(){return i([...r.initialOptions.ns||[r.initialOptions.defaultNs],...r.activeNamespaces.keys()])},getFallbackLangs:function(e){const n=e||s();return n?i([n,...t(n,r.initialOptions.fallbackLanguage)]):[]},getFallbackNamespaces:function(){const e=r.initialOptions.defaultNs;return i([..."string"==typeof e?[e]:[],...a(r.initialOptions.fallbackNs)])},getAvailableLanguages:function(){if(r.initialOptions.availableLanguages)return r.initialOptions.availableLanguages;if(r.initialOptions.staticData){const e=Object.keys(r.initialOptions.staticData).map((e=>c(e).language));return Array.from(new Set(e))}},withDefaultNs:function(e){return{namespace:void 0===e.namespace?g().defaultNs:e.namespace,language:e.language}}})})(o.onLanguageChange,o.onPendingLanguageChange,o.onRunningChange),b=v(u.getLanguage,u.getInitialOptions,u.getAvailableLanguages,(function({key:e,ns:n}){const t=void 0!==n?a(n):u.getFallbackNamespaces(),i=u.getFallbackLangs();return y.getTranslationNs(t,i,e)}),w,O),y=l(o.onCacheChange,b.getBackendRecord,b.getBackendDevRecord,u.withDefaultNs,u.isInitialLoading,r,g);function O(e,n,a){const t=u.withDefaultNs(e),i=y.getTranslation(t,n);return y.changeTranslation(t,n,a),{revert:()=>{y.changeTranslation(t,n,i)}}}function k(e){u.init(e),y.addStaticData(u.getInitialOptions().staticData)}function R(e){return y.isLoading(u.getLanguage(),e)}function E(){return Boolean(u.getInitialOptions().apiKey&&b.getDevBackend())}function j(e,n){const t=function(e,n){const t=u.getFallbackLangs(e),i=void 0!==n?a(n):u.getRequiredNamespaces(),o=[];return t.forEach((e=>{i.forEach((n=>{y.exists({language:e,namespace:n},!0)||o.push({language:e,namespace:n})}))})),o}(e,n);if(t.length)return f(T(t),(()=>{}))}function w({key:e,ns:n}){const t=void 0!==n?a(n):u.getFallbackNamespaces(),i=u.getFallbackLangs();return y.getTranslationFallback(t,i,e)}function N(){const e=f(function(){if(u.getLanguage())return;if(!u.getInitialOptions().defaultLanguage)throw new Error(p("defaultLanguage"));const e=b.getInitialLanguage();return f(e,(e=>{const n=e||u.getInitialOptions().defaultLanguage;n&&u.setLanguage(n)}))}(),(()=>j()));if(d(e))return u.setInitialLoading(!0),r.notify(),g.notify(),Promise.resolve(e).then((()=>{u.setInitialLoading(!1),r.notify(),g.notify(),o.onInitialLoaded.emit()}));o.onInitialLoaded.emit()}function T(e){return y.loadRecords(e,E())}n&&k(n),o.onKeyUpdate.listen((()=>{u.isRunning()&&b.retranslate()}));return Object.freeze(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({},o),u),b),y),{init:k,changeLanguage:async function(e){u.getPendingLanguage()===e&&u.getLanguage()===e||(u.setPendingLanguage(e),u.isRunning()&&await j(e),e===u.getPendingLanguage()&&(u.setLanguage(e),b.setStoredLanguage(e)))},getTranslation:w,changeTranslation:O,addActiveNs:async function(e,n){n||u.addActiveNs(e),u.isRunning()&&await j(void 0,e)},loadRequiredRecords:j,loadRecords:T,loadRecord:async function(e){return(await T([e]))[0]},isLoading:R,isLoaded:function(e){const n=u.getLanguage();if(!n)return!1;const t=u.getFallbackLangs(n),i=void 0!==e?a(e):u.getRequiredNamespaces(),o=[];return t.forEach((e=>{i.forEach((n=>{y.exists({language:e,namespace:n})||o.push({language:e,namespace:n})}))})),0===o.length},t:(...e)=>{const n=L(...e),a=w(n);return b.formatTranslation(Object.assign(Object.assign({},n),{translation:a}))},isDev:E,run:function(){let e;return(()=>{const e=b.getLanguageDetector();if(e&&!u.getAvailableLanguages())throw new Error(p("availableLanguages"));if(!u.getLanguage()&&!u.getInitialOptions().defaultLanguage)throw e?new Error(p("defaultLanguage")):new Error(p("language"))})(),u.isRunning()||(E()&&y.invalidate(),u.setRunning(!0),b.run(),e=N()),Promise.resolve(e)},stop:function(){u.isRunning()&&(b.stop(),u.setRunning(!1))}}))};exports.DEVTOOLS_ID="__tolgee_dev_tools",exports.RESTRICTED_ASCENDANT_ATTRIBUTE="data-tolgee-restricted",exports.TOLGEE_ATTRIBUTE_NAME="_tolgee",exports.TOLGEE_HIGHLIGHTER_CLASS="_tolgee-highlighter",exports.TOLGEE_WRAPPED_ONLY_DATA_ATTRIBUTE="data-tolgee-key-only",exports.Tolgee=e=>{const n=O({options:e}),a=Object.freeze({setFinalFormatter:n.setFinalFormatter,addFormatter:n.addFormatter,setObserver:n.setObserver,getObserver:n.getObserver,setUi:n.setUi,getUi:n.getUi,setDevBackend:n.setDevBackend,addBackend:n.addBackend,setLanguageDetector:n.setLanguageDetector,setLanguageStorage:n.setLanguageStorage}),t=e=>{const a=n.isRunning();a&&n.stop(),e(),a&&n.run()},i=Object.freeze({on:n.on,onKeyUpdate:n.onKeyUpdate.listenSome,getLanguage:n.getLanguage,getPendingLanguage:n.getPendingLanguage,changeLanguage:n.changeLanguage,changeTranslation:n.changeTranslation,addActiveNs:n.addActiveNs,removeActiveNs:n.removeActiveNs,loadRecords:n.loadRecords,loadRecord:n.loadRecord,addStaticData:n.addStaticData,getRecord:n.getRecord,getAllRecords:n.getAllRecords,isLoaded:n.isLoaded,isInitialLoading:n.isInitialLoading,isLoading:n.isLoading,isFetching:n.isFetching,isRunning:n.isRunning,run:n.run,stop:n.stop,t:n.t,highlight:n.highlight,getInitialOptions:n.getInitialOptions,isDev:n.isDev,wrap:n.wrap,unwrap:n.unwrap,use:e=>(e&&t((()=>e(i,a))),i),init:e=>(t((()=>n.init(e))),i)});return i},exports.getFallback=n,exports.getFallbackArray=a,exports.getTranslateParams=L;
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});const e=()=>{let e=[];return Object.freeze({listen:n=>{const t=e=>{n(e)};return e.push(t),{unsubscribe:()=>{e=e.filter((e=>t!==e))}}},emit:n=>{e.forEach((e=>e({value:n})))}})};function n(e){return"string"==typeof e?[e]:Array.isArray(e)?e:void 0}function t(e){return n(e)||[]}function a(e,n){return"object"!=typeof(a=n)||Array.isArray(a)||null===a?t(n):t(null==n?void 0:n[e]);var a}function i(e){return Array.from(new Set(e))}function r(e,n){const t=e.get(n)||0;e.set(n,t+1)}function o(e,n){let t=e.get(n)||1;t-=1,t<=0?e.delete(n):e.set(n,t)}const s=e=>{const n=new Set,a=new Set,i=n=>{if(n.has(void 0)){const t=new Set(n.keys());return t.delete(void 0),e().forEach((e=>t.add(e))),t}return n};let s=[];const g=()=>{if(0===s.length)return;n.forEach((e=>{e({value:void 0})}));const e=new Set;let t=new Set;s.forEach((n=>{void 0===(null==n?void 0:n.ns)?e.add(void 0):n.ns.forEach((n=>e.add(n))),void 0===(null==n?void 0:n.key)?t=void 0:void 0!==t&&t.add(n.key)}));const r=Array.from(i(e).keys());(t||[void 0]).forEach((e=>{((e,n)=>{a.forEach((t=>{const a=i(t.namespaces),r=void 0===n||-1!==(null==n?void 0:n.findIndex((e=>a.has(e)))),o=void 0===e||t.keys.has(e)||0===t.keys.size;r&&o&&t.fn({value:void 0})}))})(e,r)})),s=[]};return Object.freeze({listenSome:e=>{const n={fn:n=>{e(n)},keys:new Map,namespaces:new Map};a.add(n);const i={unsubscribe:()=>{a.delete(n)},subscribeNs:e=>(t(e).forEach((e=>r(n.namespaces,e))),i),unsubscribeNs:e=>(t(e).forEach((e=>o(n.namespaces,e))),i),subscribeKey:e=>{const{key:a,ns:o}=e;return r(n.keys,a),t(o).forEach((e=>r(n.namespaces,e))),void 0===o&&r(n.namespaces,void 0),i},unsubscribeKey:e=>{const{key:a,ns:r}=e;return o(n.keys,a),t(r).forEach((e=>o(n.namespaces,e))),void 0===r&&o(n.namespaces,void 0),i}};return i},listen:e=>{n.add(e);return{unsubscribe:()=>{n.delete(e)}}},emit:(e,n)=>{s.push(e),n?Promise.resolve().then((()=>{g()})):g()}})},g=e=>{const n=new Map;return Object.entries(e).forEach((([e,t])=>{null!=t&&("object"!=typeof t?n.set(e,t):g(t).forEach(((t,a)=>{n.set(e+"."+a,t)})))})),n},c=e=>{const[n,t]=e.split(":");return{language:n,namespace:t||""}},u=({language:e,namespace:n})=>n?`${e}:${n}`:e,l=(e,n,a,i,r,o,s)=>{const l=new Map,d=new Map;let f={},p=0;function v(n,t,a){const i=u(n);d.set(i,{data:g(t),version:a}),e.emit(n)}function h(e,n){v(e,n,p)}function b(e,n=!1){const t=d.get(u(e));return t&&n?t.version===p:Boolean(t)}function m(e){var n;return null===(n=d.get(u(i(e))))||void 0===n?void 0:n.data}function y(e){let t;if(!t){const n=f[u(e)];"function"==typeof n&&(t=n())}return t||(t=n(e)),t||(t=Promise.resolve({})),t}return Object.freeze({addStaticData:function(e){e&&(f=Object.assign(Object.assign({},f),e),Object.entries(e).forEach((([e,n])=>{if("function"!=typeof n){const t=c(e),a=d.get(e);a&&0!==a.version||v(t,n,0)}})))},invalidate:function(){l.clear(),p+=1},addRecord:h,exists:b,getRecord:m,getTranslation:function(e,n){var t;return null===(t=d.get(u(e)))||void 0===t?void 0:t.data.get(n)},getTranslationNs:function(e,n,t){var a;for(const i of e)for(const e of n){const n=null===(a=d.get(u({language:e,namespace:i})))||void 0===a?void 0:a.data.get(t);if(null!=n)return i}return Array.from(new Set(e))},getTranslationFallback:function(e,n,t){var a;for(const i of e)for(const e of n){const n=null===(a=d.get(u({language:e,namespace:i})))||void 0===a?void 0:a.data.get(t);if(null!=n)return n}},changeTranslation:function(n,t,a){var i;const r=null===(i=d.get(u(n)))||void 0===i?void 0:i.data;null==r||r.set(t,a),e.emit(Object.assign(Object.assign({},n),{key:t}))},isFetching:function(e){if(r())return!0;if(void 0===e)return l.size>0;const n=t(e);return Boolean(Array.from(l.keys()).find((e=>n.includes(c(e).namespace))))},isLoading:function(e,n){const a=t(n);return Boolean(r()||Array.from(l.keys()).find((n=>{const t=c(n);return(!a.length||a.includes(t.namespace))&&!b({namespace:t.namespace,language:e})})))},loadRecords:async function(e,n){const t=e.map((e=>{const t=i(e),r=u(t),o=l.get(r);if(o)return{new:!1,promise:o,keyObject:t,cacheKey:r};const s=function(e,n){var t;let i;return n&&(i=null===(t=a(e))||void 0===t?void 0:t.catch((()=>(console.warn("Tolgee: Failed to fetch data from dev backend"),y(e))))),i||(i=y(e)),i}(t,n);return l.set(r,s),{new:!0,promise:s,keyObject:t,cacheKey:r}}));o.notify(),s.notify();const r=await Promise.all(t.map((e=>e.promise)));return t.forEach(((e,n)=>{const t=l.get(e.cacheKey)!==e.promise;if(e.new&&!t){l.delete(e.cacheKey);const t=r[n];t&&h(e.keyObject,t)}})),o.notify(),s.notify(),t.map((e=>m(e.keyObject)))},getAllRecords:function(){return Array.from(d.entries()).map((([e,n])=>Object.assign(Object.assign({},c(e)),{data:n.data})))}})};function d(e){return Boolean(e&&"function"==typeof e.then)}const f=(e,n)=>d(e)?Promise.resolve(e).then(n):n(e),p=e=>`Tolgee: You need to specify '${e}' option`,v=(e,n,a,i,r,o,s)=>{const g={ui:void 0,observer:void 0},c={formatters:[],finalFormatter:void 0,observer:void 0,devBackend:void 0,backends:[],ui:void 0,languageDetector:void 0,languageStorage:void 0},u=async(e,{keysAndDefaults:n})=>{var a;const i=n.map((({key:e,ns:n,defaultValue:a})=>({key:e,defaultValue:a,ns:t(r({key:e,ns:n,defaultValue:a})),translation:o({key:e,ns:n})})));null===(a=c.ui)||void 0===a||a.handleElementClick(e,i)},l=(e,n)=>{var t,a;return(null===(a=null===(t=c.observer)||void 0===t?void 0:t.highlight)||void 0===a?void 0:a.call(t,e,n))||{unhighlight(){}}},p=e=>{const n=o(e);return v(Object.assign(Object.assign({},e),{translation:n,formatEnabled:!0}))},v=({key:n,translation:t,defaultValue:a,noWrap:i,params:r,orEmpty:o,ns:s,formatEnabled:g})=>{var u;const l=t||a;let d=l||(o?"":n);c.observer&&!i&&(d=c.observer.wrap({key:n,translation:d,defaultValue:a,params:r,ns:s}));const f=e(),p=g||!(null===(u=c.observer)||void 0===u?void 0:u.outputNotFormattable);if(l&&f&&p)for(const e of c.formatters)d=e.format({translation:d,language:f,params:r});return c.finalFormatter&&l&&f&&p&&(d=c.finalFormatter.format({translation:d,language:f,params:r})),d};return Object.freeze({setFinalFormatter:e=>{c.finalFormatter=e},addFormatter:e=>{e&&c.formatters.push(e)},formatTranslation:v,setObserver:e=>{g.observer=e},hasObserver:()=>Boolean(g.observer),setUi:e=>{g.ui=(null==e?void 0:e.UI)||e},hasUi:()=>Boolean(g.ui),addBackend:e=>{e&&c.backends.push(e)},setDevBackend:e=>{c.devBackend=e},getDevBackend:()=>c.devBackend,getBackendRecord:({language:e,namespace:n})=>{for(const t of c.backends){const a=t.getRecord({language:e,namespace:n});if(d(a))return null==a?void 0:a.catch((e=>(console.error(e),{})));if(void 0!==a)return a}},getBackendDevRecord:({language:e,namespace:t})=>{var a;return null===(a=c.devBackend)||void 0===a?void 0:a.getRecord({apiKey:n().apiKey,apiUrl:n().apiUrl,language:e,namespace:t})},setLanguageDetector:e=>{c.languageDetector=e},getLanguageDetector:()=>c.languageDetector,setLanguageStorage:e=>{c.languageStorage=e},getLanguageStorage:()=>c.languageStorage,getInitialLanguage:()=>{var e;const n=i(),t=null===(e=c.languageStorage)||void 0===e?void 0:e.getLanguage();return f(t,(e=>n&&!n.includes(e)||!e?(()=>{if(!c.languageDetector)return;const e=i();return c.languageDetector.getLanguage({availableLanguages:e})})():e))},setStoredLanguage:e=>{var n;null===(n=c.languageStorage)||void 0===n||n.setLanguage(e)},run:e=>{var t,i;!c.ui&&g.ui&&(c.ui=new g.ui({apiKey:n().apiKey,apiUrl:n().apiUrl,highlight:l,changeTranslation:s})),c.observer||(c.observer=null===(t=g.observer)||void 0===t?void 0:t.call(g,{translate:p,onClick:u,options:a()})),null===(i=c.observer)||void 0===i||i.run({mouseHighlight:e})},stop:()=>{var e;c.ui=void 0,null===(e=c.observer)||void 0===e||e.stop()},retranslate:()=>{var e;null===(e=c.observer)||void 0===e||e.retranslate()},highlight:l,wrap:e=>{var n;return c.observer?null===(n=c.observer)||void 0===n?void 0:n.wrap(e):e.translation},unwrap:e=>{var n;return c.observer?null===(n=c.observer)||void 0===n?void 0:n.unwrap(e):{text:e,keys:[]}}})},h=(e,n,t)=>{let a=e;return Object.freeze({init:function(e){a=e},notify:function(){const e=n();a!==e&&t(e),a=e}})},b={tagAttributes:{textarea:["placeholder"],input:["value","placeholder"],img:["alt"],"*":["aria-label","title"]},restrictedElements:["script","style"],highlightKeys:["Alt"],highlightColor:"rgb(255, 0, 0)",highlightWidth:5,inputPrefix:"%-%tolgee:",inputSuffix:"%-%",passToParent:["option","optgroup"]},m=e=>Object.assign(Object.assign({},b),e),y={defaultNs:""},O=(e,n)=>{const t=Object.assign(Object.assign(Object.assign({},y),null==n?void 0:n.initialOptions),e),a=t.apiUrl;return t.apiUrl=a?a.replace(/\/+$/,""):a,{initialOptions:t,activeNamespaces:(null==n?void 0:n.activeNamespaces)||new Map,language:null==n?void 0:n.language,pendingLanguage:null==n?void 0:n.language,isInitialLoading:!1,isRunning:!1}};function L(e){var{ns:n,noWrap:t,orEmpty:a,params:i}=e,r=function(e,n){var t={};for(var a in e)Object.prototype.hasOwnProperty.call(e,a)&&n.indexOf(a)<0&&(t[a]=e[a]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols){var i=0;for(a=Object.getOwnPropertySymbols(e);i<a.length;i++)n.indexOf(a[i])<0&&Object.prototype.propertyIsEnumerable.call(e,a[i])&&(t[a[i]]=e[a[i]])}return t}(e,["ns","noWrap","orEmpty","params"]);return{ns:n,noWrap:t,orEmpty:a,params:Object.assign(Object.assign({},r),i)}}const k=(e,...n)=>{let t,a={};return"object"==typeof e?a=e:(a.key=e,"string"==typeof n[0]?(a.defaultValue=n[0],t=n[1]):"object"==typeof n[0]&&(t=n[0])),t&&(a=Object.assign(Object.assign({},L(t)),a)),a},j=({options:n})=>{const r=(n=>{const t=e(),a=e(),i=e(),r=e(),o=e(),g=e(),c=s(n),u=e(),l=e();return g.listen((()=>c.emit())),a.listen((()=>c.emit())),u.listen((({value:e})=>{c.emit({ns:[e.namespace],key:e.key},!0)})),Object.freeze({onPendingLanguageChange:t,onLanguageChange:a,onKeyChange:i,onKeyUpdate:c,onLoadingChange:r,onFetchingChange:o,onInitialLoaded:g,onRunningChange:l,onCacheChange:u,on:(e,n)=>{switch(e){case"pendingLanguage":return t.listen(n);case"language":return a.listen(n);case"loading":return r.listen(n);case"fetching":return o.listen(n);case"initialLoad":return g.listen(n);case"running":return l.listen(n);case"cache":return u.listen(n);case"keyUpdate":return c.listen(n)}}})})((function(){return u.getFallbackNamespaces()})),o=h(!1,(()=>y.isFetching()),r.onFetchingChange.emit),g=h(!1,(()=>w()),r.onLoadingChange.emit),u=((e,n,r)=>{let o,s=O(),g=m();function u(){return s.language||s.initialOptions.language}function l(){return Object.assign(Object.assign({},s.initialOptions),o)}return Object.freeze({init:function(e){s=O(e,s)},isRunning:function(){return s.isRunning},setRunning:function(e){s.isRunning!==e&&(s.isRunning=e,r.emit(e))},isInitialLoading:function(){return s.isInitialLoading},setInitialLoading:function(e){s.isInitialLoading=e},getLanguage:u,setLanguage:function(n){s.language!==n&&(s.language=n,e.emit(n))},getPendingLanguage:function(){return s.pendingLanguage||u()},setPendingLanguage:function(e){s.pendingLanguage!==e&&(s.pendingLanguage=e,n.emit(e))},getInitialOptions:l,addActiveNs:function(e){t(e).forEach((e=>{const n=s.activeNamespaces.get(e);void 0!==n?s.activeNamespaces.set(e,n+1):s.activeNamespaces.set(e,1)}))},removeActiveNs:function(e){t(e).forEach((e=>{const n=s.activeNamespaces.get(e);void 0!==n&&n>1?s.activeNamespaces.set(e,n-1):s.activeNamespaces.delete(e)}))},getRequiredNamespaces:function(){return i([...s.initialOptions.ns||[s.initialOptions.defaultNs],...s.activeNamespaces.keys()])},getFallbackLangs:function(e){const n=e||u();return n?i([n,...a(n,s.initialOptions.fallbackLanguage)]):[]},getFallbackNamespaces:function(){const e=s.initialOptions.defaultNs;return i([..."string"==typeof e?[e]:[],...t(s.initialOptions.fallbackNs)])},getAvailableLanguages:function(){if(s.initialOptions.availableLanguages)return s.initialOptions.availableLanguages;if(s.initialOptions.staticData){const e=Object.keys(s.initialOptions.staticData).map((e=>c(e).language));return Array.from(new Set(e))}},withDefaultNs:function(e){return{namespace:void 0===e.namespace?l().defaultNs:e.namespace,language:e.language}},overrideCredentials:function(e){o=e},setObserverOptions:function(e){g=m(e)},getObserverOptions:function(){return g}})})(r.onLanguageChange,r.onPendingLanguageChange,r.onRunningChange),b=v(u.getLanguage,u.getInitialOptions,u.getObserverOptions,u.getAvailableLanguages,(function({key:e,ns:n}){const a=void 0!==n?t(n):u.getFallbackNamespaces(),i=u.getFallbackLangs();return y.getTranslationNs(a,i,e)}),N,L),y=l(r.onCacheChange,b.getBackendRecord,b.getBackendDevRecord,u.withDefaultNs,u.isInitialLoading,o,g);function L(e,n,t){const a=u.withDefaultNs(e),i=y.getTranslation(a,n);return y.changeTranslation(a,n,t),{revert:()=>{y.changeTranslation(a,n,i)}}}function j(e){u.init(e),y.addStaticData(u.getInitialOptions().staticData)}function w(e){return y.isLoading(u.getLanguage(),e)}function E(){return Boolean(u.getInitialOptions().apiKey&&u.getInitialOptions().apiUrl&&b.getDevBackend())}function R(e,n){const a=function(e,n){const a=u.getFallbackLangs(e),i=void 0!==n?t(n):u.getRequiredNamespaces(),r=[];return a.forEach((e=>{i.forEach((n=>{y.exists({language:e,namespace:n},!0)||r.push({language:e,namespace:n})}))})),r}(e,n);if(a.length)return f(T(a),(()=>{}))}function N({key:e,ns:n}){const a=void 0!==n?t(n):u.getFallbackNamespaces(),i=u.getFallbackLangs();return y.getTranslationFallback(a,i,e)}function A(){const e=f(function(){if(u.getLanguage())return;if(!u.getInitialOptions().defaultLanguage)throw new Error(p("defaultLanguage"));const e=b.getInitialLanguage();return f(e,(e=>{const n=e||u.getInitialOptions().defaultLanguage;n&&u.setLanguage(n)}))}(),(()=>R()));if(d(e))return u.setInitialLoading(!0),o.notify(),g.notify(),Promise.resolve(e).then((()=>{u.setInitialLoading(!1),o.notify(),g.notify(),r.onInitialLoaded.emit()}));r.onInitialLoaded.emit()}function T(e){return y.loadRecords(e,E())}n&&j(n),r.onKeyUpdate.listen((()=>{u.isRunning()&&b.retranslate()}));return Object.freeze(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({},r),u),b),y),{init:j,changeLanguage:async function(e){u.getPendingLanguage()===e&&u.getLanguage()===e||(u.setPendingLanguage(e),u.isRunning()&&await R(e),e===u.getPendingLanguage()&&(u.setLanguage(e),b.setStoredLanguage(e)))},getTranslation:N,changeTranslation:L,addActiveNs:async function(e,n){n||u.addActiveNs(e),u.isRunning()&&await R(void 0,e)},loadRequiredRecords:R,loadRecords:T,loadRecord:async function(e){return(await T([e]))[0]},isLoading:w,isLoaded:function(e){const n=u.getLanguage();if(!n)return!1;const a=u.getFallbackLangs(n),i=void 0!==e?t(e):u.getRequiredNamespaces(),r=[];return a.forEach((e=>{i.forEach((n=>{y.exists({language:e,namespace:n})||r.push({language:e,namespace:n})}))})),0===r.length},t:(...e)=>{const n=k(...e),t=N(n);return b.formatTranslation(Object.assign(Object.assign({},n),{translation:t}))},isDev:E,run:function(){let e;return(()=>{const e=b.getLanguageDetector();if(e&&!u.getAvailableLanguages())throw new Error(p("availableLanguages"));if(!u.getLanguage()&&!u.getInitialOptions().defaultLanguage)throw e?new Error(p("defaultLanguage")):new Error(p("language"))})(),u.isRunning()||(E()&&y.invalidate(),u.setRunning(!0),b.run(E()),e=A()),Promise.resolve(e)},stop:function(){u.isRunning()&&(b.stop(),u.setRunning(!1))}}))};class w extends Error{constructor(e,n,t){let a;a=0===e?"Empty parameter":1===e?"Unexpected character":"Unexpected end",super(`Tolgee parser: ${a} at ${n} in "${t}"`),this.code=e,this.index=n}}function E(e){return/\s/.test(e)}const R=new Set([2,1,0]),N=new Set(["{","}","'"]);function A(e,n){const[t,a]=function(e){let n=0,t="",a="",i="";const r=[],o=[];let s=0;function g(n){throw new w(n,s,e)}const c=()=>{r.push(t),t=""},u=()=>{""===a&&g(0),o.push(a),a=""};for(s=0;s<e.length;s++)switch(i=e[s],n){case 0:"'"===i?(t+=i,n=1):"{"===i?(c(),n=3):(t+=i,n=0);break;case 1:N.has(i)?(t=t.slice(0,-1)+i,n=2):(t+=i,n=0);break;case 2:"'"===i?n=0:(t+=i,n=2);break;case 3:"}"===i?(u(),n=0):E(i)?""!==a&&(u(),n=4):(/[0-9a-zA-Z_]/.test(i)||g(1),a+=i,n=3);break;case 4:"}"==i?n=0:E(i)?n=4:g(1)}return R.has(n)||g(2),c(),[r,o]}(e),i=[t[0]];for(let r=1;r<t.length;r++){const o=null==n?void 0:n[a[r-1]];if(void 0===o)throw new Error(`Missing parameter "${a[r-1]}" in "${e}"`);i.push(String(o)),i.push(t[r])}return i.join("")}exports.FormatSimple=()=>(e,n)=>(n.setFinalFormatter({format:({translation:e,params:n})=>A(e,n)}),e),exports.RESTRICTED_ASCENDANT_ATTRIBUTE="data-tolgee-restricted",exports.TOLGEE_ATTRIBUTE_NAME="_tolgee",exports.TOLGEE_HIGHLIGHTER_CLASS="_tolgee-highlighter",exports.TOLGEE_WRAPPED_ONLY_DATA_ATTRIBUTE="data-tolgee-key-only",exports.Tolgee=e=>{const n=j({options:e}),t=Object.freeze({setFinalFormatter:n.setFinalFormatter,addFormatter:n.addFormatter,setObserver:n.setObserver,hasObserver:n.hasObserver,setUi:n.setUi,hasUi:n.hasUi,setDevBackend:n.setDevBackend,addBackend:n.addBackend,setLanguageDetector:n.setLanguageDetector,setLanguageStorage:n.setLanguageStorage,overrideCredentials:n.overrideCredentials}),a=e=>{const t=n.isRunning();t&&n.stop(),e(),t&&n.run()},i=Object.freeze({on:n.on,onKeyUpdate:n.onKeyUpdate.listenSome,getLanguage:n.getLanguage,getPendingLanguage:n.getPendingLanguage,changeLanguage:n.changeLanguage,changeTranslation:n.changeTranslation,addActiveNs:n.addActiveNs,removeActiveNs:n.removeActiveNs,loadRecords:n.loadRecords,loadRecord:n.loadRecord,addStaticData:n.addStaticData,getRecord:n.getRecord,getAllRecords:n.getAllRecords,isLoaded:n.isLoaded,isInitialLoading:n.isInitialLoading,isLoading:n.isLoading,isFetching:n.isFetching,isRunning:n.isRunning,run:n.run,stop:n.stop,t:n.t,highlight:n.highlight,getInitialOptions:n.getInitialOptions,isDev:n.isDev,wrap:n.wrap,unwrap:n.unwrap,setObserverOptions:e=>(n.setObserverOptions(e),i),use:e=>(e&&a((()=>e(i,t))),i),init:e=>(a((()=>n.init(e))),i)});return i},exports.getFallback=n,exports.getFallbackArray=t,exports.getTranslateParams=k;
//# sourceMappingURL=tolgee.cjs.min.js.map

@@ -482,5 +482,6 @@ (function (global, factory) {

const PluginService = (getLanguage, getInitialOptions, getAvailableLanguages, getTranslationNs, getTranslation, changeTranslation) => {
const PluginService = (getLanguage, getInitialOptions, getObserverOptions, getAvailableLanguages, getTranslationNs, getTranslation, changeTranslation) => {
const plugins = {
ui: undefined,
observer: undefined,
};

@@ -510,13 +511,20 @@ const instances = {

};
const run = () => {
var _a;
instances.ui =
plugins.ui &&
new plugins.ui({
apiKey: getInitialOptions().apiKey,
apiUrl: getInitialOptions().apiUrl,
highlight,
changeTranslation,
});
(_a = instances.observer) === null || _a === void 0 ? void 0 : _a.run({ mouseHighlight: Boolean(instances.ui) });
const run = (isDev) => {
var _a, _b;
if (!instances.ui && plugins.ui) {
instances.ui = new plugins.ui({
apiKey: getInitialOptions().apiKey,
apiUrl: getInitialOptions().apiUrl,
highlight,
changeTranslation,
});
}
if (!instances.observer) {
instances.observer = (_a = plugins.observer) === null || _a === void 0 ? void 0 : _a.call(plugins, {
translate,
onClick,
options: getObserverOptions(),
});
}
(_b = instances.observer) === null || _b === void 0 ? void 0 : _b.run({ mouseHighlight: isDev });
};

@@ -537,6 +545,6 @@ const stop = () => {

const setObserver = (observer) => {
instances.observer = observer === null || observer === void 0 ? void 0 : observer({ translate, onClick });
plugins.observer = observer;
};
const getObserver = () => {
return instances.observer;
const hasObserver = () => {
return Boolean(plugins.observer);
};

@@ -554,4 +562,4 @@ const addFormatter = (formatter) => {

};
const getUi = () => {
return plugins.ui;
const hasUi = () => {
return Boolean(plugins.ui);
};

@@ -690,5 +698,5 @@ const setLanguageStorage = (storage) => {

setObserver,
getObserver,
hasObserver,
setUi,
getUi,
hasUi,
addBackend,

@@ -732,6 +740,23 @@ setDevBackend,

const defaultValues$1 = {
tagAttributes: {
textarea: ['placeholder'],
input: ['value', 'placeholder'],
img: ['alt'],
'*': ['aria-label', 'title'],
},
restrictedElements: ['script', 'style'],
highlightKeys: ['Alt'],
highlightColor: 'rgb(255, 0, 0)',
highlightWidth: 5,
inputPrefix: '%-%tolgee:',
inputSuffix: '%-%',
passToParent: ['option', 'optgroup'],
};
const initObserverOptions = (options) => {
return Object.assign(Object.assign({}, defaultValues$1), options);
};
const defaultValues = {
enableLanguageStore: true,
defaultNs: '',
filesUrlPrefix: 'i18n/',
};

@@ -755,2 +780,4 @@ const initState = (options, previousState) => {

let state = initState();
let observerOptions = initObserverOptions();
let devCredentials = undefined;
function init(options) {

@@ -793,3 +820,3 @@ state = initState(options, state);

function getInitialOptions() {
return state.initialOptions;
return Object.assign(Object.assign({}, state.initialOptions), devCredentials);
}

@@ -859,2 +886,11 @@ function addActiveNs(ns) {

}
function overrideCredentials(credentials) {
devCredentials = credentials;
}
function setObserverOptions(options) {
observerOptions = initObserverOptions(options);
}
function getObserverOptions() {
return observerOptions;
}
return Object.freeze({

@@ -878,2 +914,5 @@ init,

withDefaultNs,
overrideCredentials,
setObserverOptions,
getObserverOptions,
});

@@ -946,3 +985,3 @@ };

const state = State(events.onLanguageChange, events.onPendingLanguageChange, events.onRunningChange);
const pluginService = PluginService(state.getLanguage, state.getInitialOptions, state.getAvailableLanguages, getTranslationNs, getTranslation, changeTranslation);
const pluginService = PluginService(state.getLanguage, state.getInitialOptions, state.getObserverOptions, state.getAvailableLanguages, getTranslationNs, getTranslation, changeTranslation);
const cache = Cache(events.onCacheChange, pluginService.getBackendRecord, pluginService.getBackendDevRecord, state.withDefaultNs, state.isInitialLoading, fetchingObserver, loadingObserver);

@@ -978,3 +1017,5 @@ if (options) {

function isDev() {
return Boolean(state.getInitialOptions().apiKey && pluginService.getDevBackend());
return Boolean(state.getInitialOptions().apiKey &&
state.getInitialOptions().apiUrl &&
pluginService.getDevBackend());
}

@@ -1117,3 +1158,3 @@ async function addActiveNs(ns, forget) {

state.setRunning(true);
pluginService.run();
pluginService.run(isDev());
result = loadInitial();

@@ -1159,5 +1200,5 @@ }

setObserver: controller.setObserver,
getObserver: controller.getObserver,
hasObserver: controller.hasObserver,
setUi: controller.setUi,
getUi: controller.getUi,
hasUi: controller.hasUi,
setDevBackend: controller.setDevBackend,

@@ -1167,2 +1208,3 @@ addBackend: controller.addBackend,

setLanguageStorage: controller.setLanguageStorage,
overrideCredentials: controller.overrideCredentials,
});

@@ -1205,2 +1247,6 @@ const withRestart = (callback) => {

// plugins
setObserverOptions: (options) => {
controller.setObserverOptions(options);
return tolgee;
},
use: (plugin) => {

@@ -1224,6 +1270,158 @@ if (plugin) {

const TOLGEE_WRAPPED_ONLY_DATA_ATTRIBUTE = 'data-tolgee-key-only';
// needs to be same as in @tolgee/ui package
const DEVTOOLS_ID = '__tolgee_dev_tools';
exports.DEVTOOLS_ID = DEVTOOLS_ID;
const ERROR_PARAM_EMPTY = 0, ERROR_UNEXPECTED_CHAR = 1, ERROR_UNEXPECTED_END = 2;
class FormatError extends Error {
constructor(code, index, text) {
let error;
if (code === ERROR_PARAM_EMPTY) {
error = 'Empty parameter';
}
else if (code === ERROR_UNEXPECTED_CHAR) {
error = 'Unexpected character';
}
else {
error = 'Unexpected end';
}
super(`Tolgee parser: ${error} at ${index} in "${text}"`);
this.code = code;
this.index = index;
}
}
function isWhitespace(ch) {
return /\s/.test(ch);
}
const STATE_TEXT = 0, STATE_ESCAPE_MAYBE = 1, STATE_ESCAPE = 2, STATE_PARAM = 3, STATE_PARAM_AFTER = 4;
const END_STATES = new Set([
STATE_ESCAPE,
STATE_ESCAPE_MAYBE,
STATE_TEXT,
]);
const CHAR_ESCAPE = "'";
const ESCAPABLE = new Set(['{', '}', CHAR_ESCAPE]);
const isAllowedInParam = (char) => {
return /[0-9a-zA-Z_]/.test(char);
};
function formatParser(translation) {
let state = STATE_TEXT;
let text = '';
let param = '';
let ch = '';
const texts = [];
const params = [];
let i = 0;
function parsingError(code) {
throw new FormatError(code, i, translation);
}
const addText = () => {
texts.push(text);
text = '';
};
const addParamChar = () => {
if (!isAllowedInParam(ch)) {
parsingError(ERROR_UNEXPECTED_CHAR);
}
param += ch;
};
const addParam = () => {
if (param === '') {
parsingError(ERROR_PARAM_EMPTY);
}
params.push(param);
param = '';
};
for (i = 0; i < translation.length; i++) {
ch = translation[i];
switch (state) {
case STATE_TEXT:
if (ch === CHAR_ESCAPE) {
text += ch;
state = STATE_ESCAPE_MAYBE;
}
else if (ch === '{') {
addText();
state = STATE_PARAM;
}
else {
text += ch;
state = STATE_TEXT;
}
break;
case STATE_ESCAPE_MAYBE:
if (ESCAPABLE.has(ch)) {
text = text.slice(0, -1) + ch;
state = STATE_ESCAPE;
}
else {
text += ch;
state = STATE_TEXT;
}
break;
case STATE_ESCAPE:
if (ch === CHAR_ESCAPE) {
state = STATE_TEXT;
}
else {
text += ch;
state = STATE_ESCAPE;
}
break;
case STATE_PARAM:
if (ch === '}') {
addParam();
state = STATE_TEXT;
}
else if (!isWhitespace(ch)) {
addParamChar();
state = STATE_PARAM;
}
else if (param !== '') {
addParam();
state = STATE_PARAM_AFTER;
}
break;
case STATE_PARAM_AFTER:
if (ch == '}') {
state = STATE_TEXT;
}
else if (isWhitespace(ch)) {
state = STATE_PARAM_AFTER;
}
else {
parsingError(ERROR_UNEXPECTED_CHAR);
}
}
}
if (!END_STATES.has(state)) {
parsingError(ERROR_UNEXPECTED_END);
}
addText();
return [texts, params];
}
function formatter(translation, params) {
const [texts, pars] = formatParser(translation);
const result = [texts[0]];
for (let i = 1; i < texts.length; i++) {
const parameter = params === null || params === void 0 ? void 0 : params[pars[i - 1]];
if (parameter === undefined) {
throw new Error(`Missing parameter "${pars[i - 1]}" in "${translation}"`);
}
result.push(String(parameter));
result.push(texts[i]);
}
return result.join('');
}
function FormatSimpleCreator() {
return {
format: ({ translation, params }) => formatter(translation, params),
};
}
const FormatSimple = () => (tolgee, tools) => {
tools.setFinalFormatter(FormatSimpleCreator());
return tolgee;
};
exports.FormatSimple = FormatSimple;
exports.RESTRICTED_ASCENDANT_ATTRIBUTE = RESTRICTED_ASCENDANT_ATTRIBUTE;

@@ -1230,0 +1428,0 @@ exports.TOLGEE_ATTRIBUTE_NAME = TOLGEE_ATTRIBUTE_NAME;

@@ -1,2 +0,2 @@

!function(e,n){"object"==typeof exports&&"undefined"!=typeof module?n(exports):"function"==typeof define&&define.amd?define(["exports"],n):n((e="undefined"!=typeof globalThis?globalThis:e||self)["@tolgee/core"]={})}(this,(function(e){"use strict";const n=()=>{let e=[];return Object.freeze({listen:n=>{const a=e=>{n(e)};return e.push(a),{unsubscribe:()=>{e=e.filter((e=>a!==e))}}},emit:n=>{e.forEach((e=>e({value:n})))}})};function a(e){return"string"==typeof e?[e]:Array.isArray(e)?e:void 0}function t(e){return a(e)||[]}function i(e,n){return"object"!=typeof(a=n)||Array.isArray(a)||null===a?t(n):t(null==n?void 0:n[e]);var a}function o(e){return Array.from(new Set(e))}function r(e,n){const a=e.get(n)||0;e.set(n,a+1)}function s(e,n){let a=e.get(n)||1;a-=1,a<=0?e.delete(n):e.set(n,a)}const g=e=>{const n=new Set,a=new Set,i=n=>{if(n.has(void 0)){const a=new Set(n.keys());return a.delete(void 0),e().forEach((e=>a.add(e))),a}return n};let o=[];const g=()=>{if(0===o.length)return;n.forEach((e=>{e({value:void 0})}));const e=new Set;let t=new Set;o.forEach((n=>{void 0===(null==n?void 0:n.ns)?e.add(void 0):n.ns.forEach((n=>e.add(n))),void 0===(null==n?void 0:n.key)?t=void 0:void 0!==t&&t.add(n.key)}));const r=Array.from(i(e).keys());(t||[void 0]).forEach((e=>{((e,n)=>{a.forEach((a=>{const t=i(a.namespaces),o=void 0===n||-1!==(null==n?void 0:n.findIndex((e=>t.has(e)))),r=void 0===e||a.keys.has(e)||0===a.keys.size;o&&r&&a.fn({value:void 0})}))})(e,r)})),o=[]};return Object.freeze({listenSome:e=>{const n={fn:n=>{e(n)},keys:new Map,namespaces:new Map};a.add(n);const i={unsubscribe:()=>{a.delete(n)},subscribeNs:e=>(t(e).forEach((e=>r(n.namespaces,e))),i),unsubscribeNs:e=>(t(e).forEach((e=>s(n.namespaces,e))),i),subscribeKey:e=>{const{key:a,ns:o}=e;return r(n.keys,a),t(o).forEach((e=>r(n.namespaces,e))),void 0===o&&r(n.namespaces,void 0),i},unsubscribeKey:e=>{const{key:a,ns:o}=e;return s(n.keys,a),t(o).forEach((e=>s(n.namespaces,e))),void 0===o&&s(n.namespaces,void 0),i}};return i},listen:e=>{n.add(e);return{unsubscribe:()=>{n.delete(e)}}},emit:(e,n)=>{o.push(e),n?Promise.resolve().then((()=>{g()})):g()}})},c=e=>{const n=new Map;return Object.entries(e).forEach((([e,a])=>{null!=a&&("object"!=typeof a?n.set(e,a):c(a).forEach(((a,t)=>{n.set(e+"."+t,a)})))})),n},u=e=>{const[n,a]=e.split(":");return{language:n,namespace:a||""}},l=({language:e,namespace:n})=>n?`${e}:${n}`:e,d=(e,n,a,i,o,r,s)=>{const g=new Map,d=new Map;let f={},v=0;function p(n,a,t){const i=l(n);d.set(i,{data:c(a),version:t}),e.emit(n)}function m(e,n){p(e,n,v)}function b(e,n=!1){const a=d.get(l(e));return a&&n?a.version===v:Boolean(a)}function h(e){var n;return null===(n=d.get(l(i(e))))||void 0===n?void 0:n.data}function y(e){let a;if(!a){const n=f[l(e)];"function"==typeof n&&(a=n())}return a||(a=n(e)),a||(a=Promise.resolve({})),a}return Object.freeze({addStaticData:function(e){e&&(f=Object.assign(Object.assign({},f),e),Object.entries(e).forEach((([e,n])=>{if("function"!=typeof n){const a=u(e),t=d.get(e);t&&0!==t.version||p(a,n,0)}})))},invalidate:function(){g.clear(),v+=1},addRecord:m,exists:b,getRecord:h,getTranslation:function(e,n){var a;return null===(a=d.get(l(e)))||void 0===a?void 0:a.data.get(n)},getTranslationNs:function(e,n,a){var t;for(const i of e)for(const e of n){const n=null===(t=d.get(l({language:e,namespace:i})))||void 0===t?void 0:t.data.get(a);if(null!=n)return i}return Array.from(new Set(e))},getTranslationFallback:function(e,n,a){var t;for(const i of e)for(const e of n){const n=null===(t=d.get(l({language:e,namespace:i})))||void 0===t?void 0:t.data.get(a);if(null!=n)return n}},changeTranslation:function(n,a,t){var i;const o=null===(i=d.get(l(n)))||void 0===i?void 0:i.data;null==o||o.set(a,t),e.emit(Object.assign(Object.assign({},n),{key:a}))},isFetching:function(e){if(o())return!0;if(void 0===e)return g.size>0;const n=t(e);return Boolean(Array.from(g.keys()).find((e=>n.includes(u(e).namespace))))},isLoading:function(e,n){const a=t(n);return Boolean(o()||Array.from(g.keys()).find((n=>{const t=u(n);return(!a.length||a.includes(t.namespace))&&!b({namespace:t.namespace,language:e})})))},loadRecords:async function(e,n){const t=e.map((e=>{const t=i(e),o=l(t),r=g.get(o);if(r)return{new:!1,promise:r,keyObject:t,cacheKey:o};const s=function(e,n){var t;let i;return n&&(i=null===(t=a(e))||void 0===t?void 0:t.catch((()=>(console.warn("Tolgee: Failed to fetch data from dev backend"),y(e))))),i||(i=y(e)),i}(t,n);return g.set(o,s),{new:!0,promise:s,keyObject:t,cacheKey:o}}));r.notify(),s.notify();const o=await Promise.all(t.map((e=>e.promise)));return t.forEach(((e,n)=>{const a=g.get(e.cacheKey)!==e.promise;if(e.new&&!a){g.delete(e.cacheKey);const a=o[n];a&&m(e.keyObject,a)}})),r.notify(),s.notify(),t.map((e=>h(e.keyObject)))},getAllRecords:function(){return Array.from(d.entries()).map((([e,n])=>Object.assign(Object.assign({},u(e)),{data:n.data})))}})};function f(e){return Boolean(e&&"function"==typeof e.then)}const v=(e,n)=>f(e)?Promise.resolve(e).then(n):n(e),p=e=>`Tolgee: You need to specify '${e}' option`,m=(e,n,a,i,o,r)=>{const s={ui:void 0},g={formatters:[],finalFormatter:void 0,observer:void 0,devBackend:void 0,backends:[],ui:void 0,languageDetector:void 0,languageStorage:void 0},c=async(e,{keysAndDefaults:n})=>{var a;const r=n.map((({key:e,ns:n,defaultValue:a})=>({key:e,defaultValue:a,ns:t(i({key:e,ns:n,defaultValue:a})),translation:o({key:e,ns:n})})));null===(a=g.ui)||void 0===a||a.handleElementClick(e,r)},u=(e,n)=>{var a,t;return(null===(t=null===(a=g.observer)||void 0===a?void 0:a.highlight)||void 0===t?void 0:t.call(a,e,n))||{unhighlight(){}}},l=e=>{const n=o(e);return d(Object.assign(Object.assign({},e),{translation:n,formatEnabled:!0}))},d=({key:n,translation:a,defaultValue:t,noWrap:i,params:o,orEmpty:r,ns:s,formatEnabled:c})=>{var u;const l=a||t;let d=l||(r?"":n);g.observer&&!i&&(d=g.observer.wrap({key:n,translation:d,defaultValue:t,params:o,ns:s}));const f=e(),v=c||!(null===(u=g.observer)||void 0===u?void 0:u.outputNotFormattable);if(l&&f&&v)for(const e of g.formatters)d=e.format({translation:d,language:f,params:o});return g.finalFormatter&&l&&f&&v&&(d=g.finalFormatter.format({translation:d,language:f,params:o})),d};return Object.freeze({setFinalFormatter:e=>{g.finalFormatter=e},addFormatter:e=>{e&&g.formatters.push(e)},formatTranslation:d,setObserver:e=>{g.observer=null==e?void 0:e({translate:l,onClick:c})},getObserver:()=>g.observer,setUi:e=>{s.ui=(null==e?void 0:e.UI)||e},getUi:()=>s.ui,addBackend:e=>{e&&g.backends.push(e)},setDevBackend:e=>{g.devBackend=e},getDevBackend:()=>g.devBackend,getBackendRecord:({language:e,namespace:n})=>{for(const a of g.backends){const t=a.getRecord({language:e,namespace:n});if(f(t))return null==t?void 0:t.catch((e=>(console.error(e),{})));if(void 0!==t)return t}},getBackendDevRecord:({language:e,namespace:a})=>{var t;return null===(t=g.devBackend)||void 0===t?void 0:t.getRecord({apiKey:n().apiKey,apiUrl:n().apiUrl,language:e,namespace:a})},setLanguageDetector:e=>{g.languageDetector=e},getLanguageDetector:()=>g.languageDetector,setLanguageStorage:e=>{g.languageStorage=e},getLanguageStorage:()=>g.languageStorage,getInitialLanguage:()=>{var e;const n=a(),t=null===(e=g.languageStorage)||void 0===e?void 0:e.getLanguage();return v(t,(e=>n&&!n.includes(e)||!e?(()=>{if(!g.languageDetector)return;const e=a();return g.languageDetector.getLanguage({availableLanguages:e})})():e))},setStoredLanguage:e=>{var n;null===(n=g.languageStorage)||void 0===n||n.setLanguage(e)},run:()=>{var e;g.ui=s.ui&&new s.ui({apiKey:n().apiKey,apiUrl:n().apiUrl,highlight:u,changeTranslation:r}),null===(e=g.observer)||void 0===e||e.run({mouseHighlight:Boolean(g.ui)})},stop:()=>{var e;g.ui=void 0,null===(e=g.observer)||void 0===e||e.stop()},retranslate:()=>{var e;null===(e=g.observer)||void 0===e||e.retranslate()},highlight:u,wrap:e=>{var n;return g.observer?null===(n=g.observer)||void 0===n?void 0:n.wrap(e):e.translation},unwrap:e=>{var n;return g.observer?null===(n=g.observer)||void 0===n?void 0:n.unwrap(e):{text:e,keys:[]}}})},b=(e,n,a)=>{let t=e;return Object.freeze({init:function(e){t=e},notify:function(){const e=n();t!==e&&a(e),t=e}})},h={enableLanguageStore:!0,defaultNs:"",filesUrlPrefix:"i18n/"},y=(e,n)=>{const a=Object.assign(Object.assign(Object.assign({},h),null==n?void 0:n.initialOptions),e),t=a.apiUrl;return a.apiUrl=t?t.replace(/\/+$/,""):t,{initialOptions:a,activeNamespaces:(null==n?void 0:n.activeNamespaces)||new Map,language:null==n?void 0:n.language,pendingLanguage:null==n?void 0:n.language,isInitialLoading:!1,isRunning:!1}};function L(e){var{ns:n,noWrap:a,orEmpty:t,params:i}=e,o=function(e,n){var a={};for(var t in e)Object.prototype.hasOwnProperty.call(e,t)&&n.indexOf(t)<0&&(a[t]=e[t]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols){var i=0;for(t=Object.getOwnPropertySymbols(e);i<t.length;i++)n.indexOf(t[i])<0&&Object.prototype.propertyIsEnumerable.call(e,t[i])&&(a[t[i]]=e[t[i]])}return a}(e,["ns","noWrap","orEmpty","params"]);return{ns:n,noWrap:a,orEmpty:t,params:Object.assign(Object.assign({},o),i)}}const O=(e,...n)=>{let a,t={};return"object"==typeof e?t=e:(t.key=e,"string"==typeof n[0]?(t.defaultValue=n[0],a=n[1]):"object"==typeof n[0]&&(a=n[0])),a&&(t=Object.assign(Object.assign({},L(a)),t)),t},k=({options:e})=>{const a=(e=>{const a=n(),t=n(),i=n(),o=n(),r=n(),s=n(),c=g(e),u=n(),l=n();return s.listen((()=>c.emit())),t.listen((()=>c.emit())),u.listen((({value:e})=>{c.emit({ns:[e.namespace],key:e.key},!0)})),Object.freeze({onPendingLanguageChange:a,onLanguageChange:t,onKeyChange:i,onKeyUpdate:c,onLoadingChange:o,onFetchingChange:r,onInitialLoaded:s,onRunningChange:l,onCacheChange:u,on:(e,n)=>{switch(e){case"pendingLanguage":return a.listen(n);case"language":return t.listen(n);case"loading":return o.listen(n);case"fetching":return r.listen(n);case"initialLoad":return s.listen(n);case"running":return l.listen(n);case"cache":return u.listen(n);case"keyUpdate":return c.listen(n)}}})})((function(){return c.getFallbackNamespaces()})),r=b(!1,(()=>h.isFetching()),a.onFetchingChange.emit),s=b(!1,(()=>R()),a.onLoadingChange.emit),c=((e,n,a)=>{let r=y();function s(){return r.language||r.initialOptions.language}function g(){return r.initialOptions}return Object.freeze({init:function(e){r=y(e,r)},isRunning:function(){return r.isRunning},setRunning:function(e){r.isRunning!==e&&(r.isRunning=e,a.emit(e))},isInitialLoading:function(){return r.isInitialLoading},setInitialLoading:function(e){r.isInitialLoading=e},getLanguage:s,setLanguage:function(n){r.language!==n&&(r.language=n,e.emit(n))},getPendingLanguage:function(){return r.pendingLanguage||s()},setPendingLanguage:function(e){r.pendingLanguage!==e&&(r.pendingLanguage=e,n.emit(e))},getInitialOptions:g,addActiveNs:function(e){t(e).forEach((e=>{const n=r.activeNamespaces.get(e);void 0!==n?r.activeNamespaces.set(e,n+1):r.activeNamespaces.set(e,1)}))},removeActiveNs:function(e){t(e).forEach((e=>{const n=r.activeNamespaces.get(e);void 0!==n&&n>1?r.activeNamespaces.set(e,n-1):r.activeNamespaces.delete(e)}))},getRequiredNamespaces:function(){return o([...r.initialOptions.ns||[r.initialOptions.defaultNs],...r.activeNamespaces.keys()])},getFallbackLangs:function(e){const n=e||s();return n?o([n,...i(n,r.initialOptions.fallbackLanguage)]):[]},getFallbackNamespaces:function(){const e=r.initialOptions.defaultNs;return o([..."string"==typeof e?[e]:[],...t(r.initialOptions.fallbackNs)])},getAvailableLanguages:function(){if(r.initialOptions.availableLanguages)return r.initialOptions.availableLanguages;if(r.initialOptions.staticData){const e=Object.keys(r.initialOptions.staticData).map((e=>u(e).language));return Array.from(new Set(e))}},withDefaultNs:function(e){return{namespace:void 0===e.namespace?g().defaultNs:e.namespace,language:e.language}}})})(a.onLanguageChange,a.onPendingLanguageChange,a.onRunningChange),l=m(c.getLanguage,c.getInitialOptions,c.getAvailableLanguages,(function({key:e,ns:n}){const a=void 0!==n?t(n):c.getFallbackNamespaces(),i=c.getFallbackLangs();return h.getTranslationNs(a,i,e)}),w,L),h=d(a.onCacheChange,l.getBackendRecord,l.getBackendDevRecord,c.withDefaultNs,c.isInitialLoading,r,s);function L(e,n,a){const t=c.withDefaultNs(e),i=h.getTranslation(t,n);return h.changeTranslation(t,n,a),{revert:()=>{h.changeTranslation(t,n,i)}}}function k(e){c.init(e),h.addStaticData(c.getInitialOptions().staticData)}function R(e){return h.isLoading(c.getLanguage(),e)}function j(){return Boolean(c.getInitialOptions().apiKey&&l.getDevBackend())}function E(e,n){const a=function(e,n){const a=c.getFallbackLangs(e),i=void 0!==n?t(n):c.getRequiredNamespaces(),o=[];return a.forEach((e=>{i.forEach((n=>{h.exists({language:e,namespace:n},!0)||o.push({language:e,namespace:n})}))})),o}(e,n);if(a.length)return v(T(a),(()=>{}))}function w({key:e,ns:n}){const a=void 0!==n?t(n):c.getFallbackNamespaces(),i=c.getFallbackLangs();return h.getTranslationFallback(a,i,e)}function N(){const e=v(function(){if(c.getLanguage())return;if(!c.getInitialOptions().defaultLanguage)throw new Error(p("defaultLanguage"));const e=l.getInitialLanguage();return v(e,(e=>{const n=e||c.getInitialOptions().defaultLanguage;n&&c.setLanguage(n)}))}(),(()=>E()));if(f(e))return c.setInitialLoading(!0),r.notify(),s.notify(),Promise.resolve(e).then((()=>{c.setInitialLoading(!1),r.notify(),s.notify(),a.onInitialLoaded.emit()}));a.onInitialLoaded.emit()}function T(e){return h.loadRecords(e,j())}e&&k(e),a.onKeyUpdate.listen((()=>{c.isRunning()&&l.retranslate()}));return Object.freeze(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({},a),c),l),h),{init:k,changeLanguage:async function(e){c.getPendingLanguage()===e&&c.getLanguage()===e||(c.setPendingLanguage(e),c.isRunning()&&await E(e),e===c.getPendingLanguage()&&(c.setLanguage(e),l.setStoredLanguage(e)))},getTranslation:w,changeTranslation:L,addActiveNs:async function(e,n){n||c.addActiveNs(e),c.isRunning()&&await E(void 0,e)},loadRequiredRecords:E,loadRecords:T,loadRecord:async function(e){return(await T([e]))[0]},isLoading:R,isLoaded:function(e){const n=c.getLanguage();if(!n)return!1;const a=c.getFallbackLangs(n),i=void 0!==e?t(e):c.getRequiredNamespaces(),o=[];return a.forEach((e=>{i.forEach((n=>{h.exists({language:e,namespace:n})||o.push({language:e,namespace:n})}))})),0===o.length},t:(...e)=>{const n=O(...e),a=w(n);return l.formatTranslation(Object.assign(Object.assign({},n),{translation:a}))},isDev:j,run:function(){let e;return(()=>{const e=l.getLanguageDetector();if(e&&!c.getAvailableLanguages())throw new Error(p("availableLanguages"));if(!c.getLanguage()&&!c.getInitialOptions().defaultLanguage)throw e?new Error(p("defaultLanguage")):new Error(p("language"))})(),c.isRunning()||(j()&&h.invalidate(),c.setRunning(!0),l.run(),e=N()),Promise.resolve(e)},stop:function(){c.isRunning()&&(l.stop(),c.setRunning(!1))}}))};e.DEVTOOLS_ID="__tolgee_dev_tools",e.RESTRICTED_ASCENDANT_ATTRIBUTE="data-tolgee-restricted",e.TOLGEE_ATTRIBUTE_NAME="_tolgee",e.TOLGEE_HIGHLIGHTER_CLASS="_tolgee-highlighter",e.TOLGEE_WRAPPED_ONLY_DATA_ATTRIBUTE="data-tolgee-key-only",e.Tolgee=e=>{const n=k({options:e}),a=Object.freeze({setFinalFormatter:n.setFinalFormatter,addFormatter:n.addFormatter,setObserver:n.setObserver,getObserver:n.getObserver,setUi:n.setUi,getUi:n.getUi,setDevBackend:n.setDevBackend,addBackend:n.addBackend,setLanguageDetector:n.setLanguageDetector,setLanguageStorage:n.setLanguageStorage}),t=e=>{const a=n.isRunning();a&&n.stop(),e(),a&&n.run()},i=Object.freeze({on:n.on,onKeyUpdate:n.onKeyUpdate.listenSome,getLanguage:n.getLanguage,getPendingLanguage:n.getPendingLanguage,changeLanguage:n.changeLanguage,changeTranslation:n.changeTranslation,addActiveNs:n.addActiveNs,removeActiveNs:n.removeActiveNs,loadRecords:n.loadRecords,loadRecord:n.loadRecord,addStaticData:n.addStaticData,getRecord:n.getRecord,getAllRecords:n.getAllRecords,isLoaded:n.isLoaded,isInitialLoading:n.isInitialLoading,isLoading:n.isLoading,isFetching:n.isFetching,isRunning:n.isRunning,run:n.run,stop:n.stop,t:n.t,highlight:n.highlight,getInitialOptions:n.getInitialOptions,isDev:n.isDev,wrap:n.wrap,unwrap:n.unwrap,use:e=>(e&&t((()=>e(i,a))),i),init:e=>(t((()=>n.init(e))),i)});return i},e.getFallback=a,e.getFallbackArray=t,e.getTranslateParams=O,Object.defineProperty(e,"__esModule",{value:!0})}));
!function(e,n){"object"==typeof exports&&"undefined"!=typeof module?n(exports):"function"==typeof define&&define.amd?define(["exports"],n):n((e="undefined"!=typeof globalThis?globalThis:e||self)["@tolgee/core"]={})}(this,(function(e){"use strict";const n=()=>{let e=[];return Object.freeze({listen:n=>{const t=e=>{n(e)};return e.push(t),{unsubscribe:()=>{e=e.filter((e=>t!==e))}}},emit:n=>{e.forEach((e=>e({value:n})))}})};function t(e){return"string"==typeof e?[e]:Array.isArray(e)?e:void 0}function a(e){return t(e)||[]}function i(e,n){return"object"!=typeof(t=n)||Array.isArray(t)||null===t?a(n):a(null==n?void 0:n[e]);var t}function o(e){return Array.from(new Set(e))}function r(e,n){const t=e.get(n)||0;e.set(n,t+1)}function s(e,n){let t=e.get(n)||1;t-=1,t<=0?e.delete(n):e.set(n,t)}const g=e=>{const n=new Set,t=new Set,i=n=>{if(n.has(void 0)){const t=new Set(n.keys());return t.delete(void 0),e().forEach((e=>t.add(e))),t}return n};let o=[];const g=()=>{if(0===o.length)return;n.forEach((e=>{e({value:void 0})}));const e=new Set;let a=new Set;o.forEach((n=>{void 0===(null==n?void 0:n.ns)?e.add(void 0):n.ns.forEach((n=>e.add(n))),void 0===(null==n?void 0:n.key)?a=void 0:void 0!==a&&a.add(n.key)}));const r=Array.from(i(e).keys());(a||[void 0]).forEach((e=>{((e,n)=>{t.forEach((t=>{const a=i(t.namespaces),o=void 0===n||-1!==(null==n?void 0:n.findIndex((e=>a.has(e)))),r=void 0===e||t.keys.has(e)||0===t.keys.size;o&&r&&t.fn({value:void 0})}))})(e,r)})),o=[]};return Object.freeze({listenSome:e=>{const n={fn:n=>{e(n)},keys:new Map,namespaces:new Map};t.add(n);const i={unsubscribe:()=>{t.delete(n)},subscribeNs:e=>(a(e).forEach((e=>r(n.namespaces,e))),i),unsubscribeNs:e=>(a(e).forEach((e=>s(n.namespaces,e))),i),subscribeKey:e=>{const{key:t,ns:o}=e;return r(n.keys,t),a(o).forEach((e=>r(n.namespaces,e))),void 0===o&&r(n.namespaces,void 0),i},unsubscribeKey:e=>{const{key:t,ns:o}=e;return s(n.keys,t),a(o).forEach((e=>s(n.namespaces,e))),void 0===o&&s(n.namespaces,void 0),i}};return i},listen:e=>{n.add(e);return{unsubscribe:()=>{n.delete(e)}}},emit:(e,n)=>{o.push(e),n?Promise.resolve().then((()=>{g()})):g()}})},c=e=>{const n=new Map;return Object.entries(e).forEach((([e,t])=>{null!=t&&("object"!=typeof t?n.set(e,t):c(t).forEach(((t,a)=>{n.set(e+"."+a,t)})))})),n},u=e=>{const[n,t]=e.split(":");return{language:n,namespace:t||""}},l=({language:e,namespace:n})=>n?`${e}:${n}`:e,d=(e,n,t,i,o,r,s)=>{const g=new Map,d=new Map;let f={},p=0;function v(n,t,a){const i=l(n);d.set(i,{data:c(t),version:a}),e.emit(n)}function h(e,n){v(e,n,p)}function b(e,n=!1){const t=d.get(l(e));return t&&n?t.version===p:Boolean(t)}function m(e){var n;return null===(n=d.get(l(i(e))))||void 0===n?void 0:n.data}function y(e){let t;if(!t){const n=f[l(e)];"function"==typeof n&&(t=n())}return t||(t=n(e)),t||(t=Promise.resolve({})),t}return Object.freeze({addStaticData:function(e){e&&(f=Object.assign(Object.assign({},f),e),Object.entries(e).forEach((([e,n])=>{if("function"!=typeof n){const t=u(e),a=d.get(e);a&&0!==a.version||v(t,n,0)}})))},invalidate:function(){g.clear(),p+=1},addRecord:h,exists:b,getRecord:m,getTranslation:function(e,n){var t;return null===(t=d.get(l(e)))||void 0===t?void 0:t.data.get(n)},getTranslationNs:function(e,n,t){var a;for(const i of e)for(const e of n){const n=null===(a=d.get(l({language:e,namespace:i})))||void 0===a?void 0:a.data.get(t);if(null!=n)return i}return Array.from(new Set(e))},getTranslationFallback:function(e,n,t){var a;for(const i of e)for(const e of n){const n=null===(a=d.get(l({language:e,namespace:i})))||void 0===a?void 0:a.data.get(t);if(null!=n)return n}},changeTranslation:function(n,t,a){var i;const o=null===(i=d.get(l(n)))||void 0===i?void 0:i.data;null==o||o.set(t,a),e.emit(Object.assign(Object.assign({},n),{key:t}))},isFetching:function(e){if(o())return!0;if(void 0===e)return g.size>0;const n=a(e);return Boolean(Array.from(g.keys()).find((e=>n.includes(u(e).namespace))))},isLoading:function(e,n){const t=a(n);return Boolean(o()||Array.from(g.keys()).find((n=>{const a=u(n);return(!t.length||t.includes(a.namespace))&&!b({namespace:a.namespace,language:e})})))},loadRecords:async function(e,n){const a=e.map((e=>{const a=i(e),o=l(a),r=g.get(o);if(r)return{new:!1,promise:r,keyObject:a,cacheKey:o};const s=function(e,n){var a;let i;return n&&(i=null===(a=t(e))||void 0===a?void 0:a.catch((()=>(console.warn("Tolgee: Failed to fetch data from dev backend"),y(e))))),i||(i=y(e)),i}(a,n);return g.set(o,s),{new:!0,promise:s,keyObject:a,cacheKey:o}}));r.notify(),s.notify();const o=await Promise.all(a.map((e=>e.promise)));return a.forEach(((e,n)=>{const t=g.get(e.cacheKey)!==e.promise;if(e.new&&!t){g.delete(e.cacheKey);const t=o[n];t&&h(e.keyObject,t)}})),r.notify(),s.notify(),a.map((e=>m(e.keyObject)))},getAllRecords:function(){return Array.from(d.entries()).map((([e,n])=>Object.assign(Object.assign({},u(e)),{data:n.data})))}})};function f(e){return Boolean(e&&"function"==typeof e.then)}const p=(e,n)=>f(e)?Promise.resolve(e).then(n):n(e),v=e=>`Tolgee: You need to specify '${e}' option`,h=(e,n,t,i,o,r,s)=>{const g={ui:void 0,observer:void 0},c={formatters:[],finalFormatter:void 0,observer:void 0,devBackend:void 0,backends:[],ui:void 0,languageDetector:void 0,languageStorage:void 0},u=async(e,{keysAndDefaults:n})=>{var t;const i=n.map((({key:e,ns:n,defaultValue:t})=>({key:e,defaultValue:t,ns:a(o({key:e,ns:n,defaultValue:t})),translation:r({key:e,ns:n})})));null===(t=c.ui)||void 0===t||t.handleElementClick(e,i)},l=(e,n)=>{var t,a;return(null===(a=null===(t=c.observer)||void 0===t?void 0:t.highlight)||void 0===a?void 0:a.call(t,e,n))||{unhighlight(){}}},d=e=>{const n=r(e);return v(Object.assign(Object.assign({},e),{translation:n,formatEnabled:!0}))},v=({key:n,translation:t,defaultValue:a,noWrap:i,params:o,orEmpty:r,ns:s,formatEnabled:g})=>{var u;const l=t||a;let d=l||(r?"":n);c.observer&&!i&&(d=c.observer.wrap({key:n,translation:d,defaultValue:a,params:o,ns:s}));const f=e(),p=g||!(null===(u=c.observer)||void 0===u?void 0:u.outputNotFormattable);if(l&&f&&p)for(const e of c.formatters)d=e.format({translation:d,language:f,params:o});return c.finalFormatter&&l&&f&&p&&(d=c.finalFormatter.format({translation:d,language:f,params:o})),d};return Object.freeze({setFinalFormatter:e=>{c.finalFormatter=e},addFormatter:e=>{e&&c.formatters.push(e)},formatTranslation:v,setObserver:e=>{g.observer=e},hasObserver:()=>Boolean(g.observer),setUi:e=>{g.ui=(null==e?void 0:e.UI)||e},hasUi:()=>Boolean(g.ui),addBackend:e=>{e&&c.backends.push(e)},setDevBackend:e=>{c.devBackend=e},getDevBackend:()=>c.devBackend,getBackendRecord:({language:e,namespace:n})=>{for(const t of c.backends){const a=t.getRecord({language:e,namespace:n});if(f(a))return null==a?void 0:a.catch((e=>(console.error(e),{})));if(void 0!==a)return a}},getBackendDevRecord:({language:e,namespace:t})=>{var a;return null===(a=c.devBackend)||void 0===a?void 0:a.getRecord({apiKey:n().apiKey,apiUrl:n().apiUrl,language:e,namespace:t})},setLanguageDetector:e=>{c.languageDetector=e},getLanguageDetector:()=>c.languageDetector,setLanguageStorage:e=>{c.languageStorage=e},getLanguageStorage:()=>c.languageStorage,getInitialLanguage:()=>{var e;const n=i(),t=null===(e=c.languageStorage)||void 0===e?void 0:e.getLanguage();return p(t,(e=>n&&!n.includes(e)||!e?(()=>{if(!c.languageDetector)return;const e=i();return c.languageDetector.getLanguage({availableLanguages:e})})():e))},setStoredLanguage:e=>{var n;null===(n=c.languageStorage)||void 0===n||n.setLanguage(e)},run:e=>{var a,i;!c.ui&&g.ui&&(c.ui=new g.ui({apiKey:n().apiKey,apiUrl:n().apiUrl,highlight:l,changeTranslation:s})),c.observer||(c.observer=null===(a=g.observer)||void 0===a?void 0:a.call(g,{translate:d,onClick:u,options:t()})),null===(i=c.observer)||void 0===i||i.run({mouseHighlight:e})},stop:()=>{var e;c.ui=void 0,null===(e=c.observer)||void 0===e||e.stop()},retranslate:()=>{var e;null===(e=c.observer)||void 0===e||e.retranslate()},highlight:l,wrap:e=>{var n;return c.observer?null===(n=c.observer)||void 0===n?void 0:n.wrap(e):e.translation},unwrap:e=>{var n;return c.observer?null===(n=c.observer)||void 0===n?void 0:n.unwrap(e):{text:e,keys:[]}}})},b=(e,n,t)=>{let a=e;return Object.freeze({init:function(e){a=e},notify:function(){const e=n();a!==e&&t(e),a=e}})},m={tagAttributes:{textarea:["placeholder"],input:["value","placeholder"],img:["alt"],"*":["aria-label","title"]},restrictedElements:["script","style"],highlightKeys:["Alt"],highlightColor:"rgb(255, 0, 0)",highlightWidth:5,inputPrefix:"%-%tolgee:",inputSuffix:"%-%",passToParent:["option","optgroup"]},y=e=>Object.assign(Object.assign({},m),e),O={defaultNs:""},L=(e,n)=>{const t=Object.assign(Object.assign(Object.assign({},O),null==n?void 0:n.initialOptions),e),a=t.apiUrl;return t.apiUrl=a?a.replace(/\/+$/,""):a,{initialOptions:t,activeNamespaces:(null==n?void 0:n.activeNamespaces)||new Map,language:null==n?void 0:n.language,pendingLanguage:null==n?void 0:n.language,isInitialLoading:!1,isRunning:!1}};function k(e){var{ns:n,noWrap:t,orEmpty:a,params:i}=e,o=function(e,n){var t={};for(var a in e)Object.prototype.hasOwnProperty.call(e,a)&&n.indexOf(a)<0&&(t[a]=e[a]);if(null!=e&&"function"==typeof Object.getOwnPropertySymbols){var i=0;for(a=Object.getOwnPropertySymbols(e);i<a.length;i++)n.indexOf(a[i])<0&&Object.prototype.propertyIsEnumerable.call(e,a[i])&&(t[a[i]]=e[a[i]])}return t}(e,["ns","noWrap","orEmpty","params"]);return{ns:n,noWrap:t,orEmpty:a,params:Object.assign(Object.assign({},o),i)}}const j=(e,...n)=>{let t,a={};return"object"==typeof e?a=e:(a.key=e,"string"==typeof n[0]?(a.defaultValue=n[0],t=n[1]):"object"==typeof n[0]&&(t=n[0])),t&&(a=Object.assign(Object.assign({},k(t)),a)),a},w=({options:e})=>{const t=(e=>{const t=n(),a=n(),i=n(),o=n(),r=n(),s=n(),c=g(e),u=n(),l=n();return s.listen((()=>c.emit())),a.listen((()=>c.emit())),u.listen((({value:e})=>{c.emit({ns:[e.namespace],key:e.key},!0)})),Object.freeze({onPendingLanguageChange:t,onLanguageChange:a,onKeyChange:i,onKeyUpdate:c,onLoadingChange:o,onFetchingChange:r,onInitialLoaded:s,onRunningChange:l,onCacheChange:u,on:(e,n)=>{switch(e){case"pendingLanguage":return t.listen(n);case"language":return a.listen(n);case"loading":return o.listen(n);case"fetching":return r.listen(n);case"initialLoad":return s.listen(n);case"running":return l.listen(n);case"cache":return u.listen(n);case"keyUpdate":return c.listen(n)}}})})((function(){return c.getFallbackNamespaces()})),r=b(!1,(()=>m.isFetching()),t.onFetchingChange.emit),s=b(!1,(()=>w()),t.onLoadingChange.emit),c=((e,n,t)=>{let r,s=L(),g=y();function c(){return s.language||s.initialOptions.language}function l(){return Object.assign(Object.assign({},s.initialOptions),r)}return Object.freeze({init:function(e){s=L(e,s)},isRunning:function(){return s.isRunning},setRunning:function(e){s.isRunning!==e&&(s.isRunning=e,t.emit(e))},isInitialLoading:function(){return s.isInitialLoading},setInitialLoading:function(e){s.isInitialLoading=e},getLanguage:c,setLanguage:function(n){s.language!==n&&(s.language=n,e.emit(n))},getPendingLanguage:function(){return s.pendingLanguage||c()},setPendingLanguage:function(e){s.pendingLanguage!==e&&(s.pendingLanguage=e,n.emit(e))},getInitialOptions:l,addActiveNs:function(e){a(e).forEach((e=>{const n=s.activeNamespaces.get(e);void 0!==n?s.activeNamespaces.set(e,n+1):s.activeNamespaces.set(e,1)}))},removeActiveNs:function(e){a(e).forEach((e=>{const n=s.activeNamespaces.get(e);void 0!==n&&n>1?s.activeNamespaces.set(e,n-1):s.activeNamespaces.delete(e)}))},getRequiredNamespaces:function(){return o([...s.initialOptions.ns||[s.initialOptions.defaultNs],...s.activeNamespaces.keys()])},getFallbackLangs:function(e){const n=e||c();return n?o([n,...i(n,s.initialOptions.fallbackLanguage)]):[]},getFallbackNamespaces:function(){const e=s.initialOptions.defaultNs;return o([..."string"==typeof e?[e]:[],...a(s.initialOptions.fallbackNs)])},getAvailableLanguages:function(){if(s.initialOptions.availableLanguages)return s.initialOptions.availableLanguages;if(s.initialOptions.staticData){const e=Object.keys(s.initialOptions.staticData).map((e=>u(e).language));return Array.from(new Set(e))}},withDefaultNs:function(e){return{namespace:void 0===e.namespace?l().defaultNs:e.namespace,language:e.language}},overrideCredentials:function(e){r=e},setObserverOptions:function(e){g=y(e)},getObserverOptions:function(){return g}})})(t.onLanguageChange,t.onPendingLanguageChange,t.onRunningChange),l=h(c.getLanguage,c.getInitialOptions,c.getObserverOptions,c.getAvailableLanguages,(function({key:e,ns:n}){const t=void 0!==n?a(n):c.getFallbackNamespaces(),i=c.getFallbackLangs();return m.getTranslationNs(t,i,e)}),N,O),m=d(t.onCacheChange,l.getBackendRecord,l.getBackendDevRecord,c.withDefaultNs,c.isInitialLoading,r,s);function O(e,n,t){const a=c.withDefaultNs(e),i=m.getTranslation(a,n);return m.changeTranslation(a,n,t),{revert:()=>{m.changeTranslation(a,n,i)}}}function k(e){c.init(e),m.addStaticData(c.getInitialOptions().staticData)}function w(e){return m.isLoading(c.getLanguage(),e)}function E(){return Boolean(c.getInitialOptions().apiKey&&c.getInitialOptions().apiUrl&&l.getDevBackend())}function R(e,n){const t=function(e,n){const t=c.getFallbackLangs(e),i=void 0!==n?a(n):c.getRequiredNamespaces(),o=[];return t.forEach((e=>{i.forEach((n=>{m.exists({language:e,namespace:n},!0)||o.push({language:e,namespace:n})}))})),o}(e,n);if(t.length)return p(A(t),(()=>{}))}function N({key:e,ns:n}){const t=void 0!==n?a(n):c.getFallbackNamespaces(),i=c.getFallbackLangs();return m.getTranslationFallback(t,i,e)}function T(){const e=p(function(){if(c.getLanguage())return;if(!c.getInitialOptions().defaultLanguage)throw new Error(v("defaultLanguage"));const e=l.getInitialLanguage();return p(e,(e=>{const n=e||c.getInitialOptions().defaultLanguage;n&&c.setLanguage(n)}))}(),(()=>R()));if(f(e))return c.setInitialLoading(!0),r.notify(),s.notify(),Promise.resolve(e).then((()=>{c.setInitialLoading(!1),r.notify(),s.notify(),t.onInitialLoaded.emit()}));t.onInitialLoaded.emit()}function A(e){return m.loadRecords(e,E())}e&&k(e),t.onKeyUpdate.listen((()=>{c.isRunning()&&l.retranslate()}));return Object.freeze(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({},t),c),l),m),{init:k,changeLanguage:async function(e){c.getPendingLanguage()===e&&c.getLanguage()===e||(c.setPendingLanguage(e),c.isRunning()&&await R(e),e===c.getPendingLanguage()&&(c.setLanguage(e),l.setStoredLanguage(e)))},getTranslation:N,changeTranslation:O,addActiveNs:async function(e,n){n||c.addActiveNs(e),c.isRunning()&&await R(void 0,e)},loadRequiredRecords:R,loadRecords:A,loadRecord:async function(e){return(await A([e]))[0]},isLoading:w,isLoaded:function(e){const n=c.getLanguage();if(!n)return!1;const t=c.getFallbackLangs(n),i=void 0!==e?a(e):c.getRequiredNamespaces(),o=[];return t.forEach((e=>{i.forEach((n=>{m.exists({language:e,namespace:n})||o.push({language:e,namespace:n})}))})),0===o.length},t:(...e)=>{const n=j(...e),t=N(n);return l.formatTranslation(Object.assign(Object.assign({},n),{translation:t}))},isDev:E,run:function(){let e;return(()=>{const e=l.getLanguageDetector();if(e&&!c.getAvailableLanguages())throw new Error(v("availableLanguages"));if(!c.getLanguage()&&!c.getInitialOptions().defaultLanguage)throw e?new Error(v("defaultLanguage")):new Error(v("language"))})(),c.isRunning()||(E()&&m.invalidate(),c.setRunning(!0),l.run(E()),e=T()),Promise.resolve(e)},stop:function(){c.isRunning()&&(l.stop(),c.setRunning(!1))}}))};class E extends Error{constructor(e,n,t){let a;a=0===e?"Empty parameter":1===e?"Unexpected character":"Unexpected end",super(`Tolgee parser: ${a} at ${n} in "${t}"`),this.code=e,this.index=n}}function R(e){return/\s/.test(e)}const N=new Set([2,1,0]),T=new Set(["{","}","'"]);function A(e,n){const[t,a]=function(e){let n=0,t="",a="",i="";const o=[],r=[];let s=0;function g(n){throw new E(n,s,e)}const c=()=>{o.push(t),t=""},u=()=>{""===a&&g(0),r.push(a),a=""};for(s=0;s<e.length;s++)switch(i=e[s],n){case 0:"'"===i?(t+=i,n=1):"{"===i?(c(),n=3):(t+=i,n=0);break;case 1:T.has(i)?(t=t.slice(0,-1)+i,n=2):(t+=i,n=0);break;case 2:"'"===i?n=0:(t+=i,n=2);break;case 3:"}"===i?(u(),n=0):R(i)?""!==a&&(u(),n=4):(/[0-9a-zA-Z_]/.test(i)||g(1),a+=i,n=3);break;case 4:"}"==i?n=0:R(i)?n=4:g(1)}return N.has(n)||g(2),c(),[o,r]}(e),i=[t[0]];for(let o=1;o<t.length;o++){const r=null==n?void 0:n[a[o-1]];if(void 0===r)throw new Error(`Missing parameter "${a[o-1]}" in "${e}"`);i.push(String(r)),i.push(t[o])}return i.join("")}e.FormatSimple=()=>(e,n)=>(n.setFinalFormatter({format:({translation:e,params:n})=>A(e,n)}),e),e.RESTRICTED_ASCENDANT_ATTRIBUTE="data-tolgee-restricted",e.TOLGEE_ATTRIBUTE_NAME="_tolgee",e.TOLGEE_HIGHLIGHTER_CLASS="_tolgee-highlighter",e.TOLGEE_WRAPPED_ONLY_DATA_ATTRIBUTE="data-tolgee-key-only",e.Tolgee=e=>{const n=w({options:e}),t=Object.freeze({setFinalFormatter:n.setFinalFormatter,addFormatter:n.addFormatter,setObserver:n.setObserver,hasObserver:n.hasObserver,setUi:n.setUi,hasUi:n.hasUi,setDevBackend:n.setDevBackend,addBackend:n.addBackend,setLanguageDetector:n.setLanguageDetector,setLanguageStorage:n.setLanguageStorage,overrideCredentials:n.overrideCredentials}),a=e=>{const t=n.isRunning();t&&n.stop(),e(),t&&n.run()},i=Object.freeze({on:n.on,onKeyUpdate:n.onKeyUpdate.listenSome,getLanguage:n.getLanguage,getPendingLanguage:n.getPendingLanguage,changeLanguage:n.changeLanguage,changeTranslation:n.changeTranslation,addActiveNs:n.addActiveNs,removeActiveNs:n.removeActiveNs,loadRecords:n.loadRecords,loadRecord:n.loadRecord,addStaticData:n.addStaticData,getRecord:n.getRecord,getAllRecords:n.getAllRecords,isLoaded:n.isLoaded,isInitialLoading:n.isInitialLoading,isLoading:n.isLoading,isFetching:n.isFetching,isRunning:n.isRunning,run:n.run,stop:n.stop,t:n.t,highlight:n.highlight,getInitialOptions:n.getInitialOptions,isDev:n.isDev,wrap:n.wrap,unwrap:n.unwrap,setObserverOptions:e=>(n.setObserverOptions(e),i),use:e=>(e&&a((()=>e(i,t))),i),init:e=>(a((()=>n.init(e))),i)});return i},e.getFallback=t,e.getFallbackArray=a,e.getTranslateParams=j,Object.defineProperty(e,"__esModule",{value:!0})}));
//# sourceMappingURL=tolgee.umd.min.js.map

@@ -5,2 +5,1 @@ export declare const RESTRICTED_ASCENDANT_ATTRIBUTE = "data-tolgee-restricted";

export declare const TOLGEE_WRAPPED_ONLY_DATA_ATTRIBUTE = "data-tolgee-key-only";
export declare const DEVTOOLS_ID = "__tolgee_dev_tools";

@@ -1,4 +0,4 @@

import { CacheDescriptor, CacheDescriptorInternal, CacheDescriptorWithKey, EventEmitterType, FallbackNSTranslation, Options, TranslationsFlat, TranslationValue, TreeTranslationsData, BackendGetRecord, BackendGetDevRecord } from '../../types';
import { CacheDescriptor, CacheDescriptorInternal, CacheDescriptorWithKey, EventEmitterInstance, FallbackNSTranslation, Options, TranslationsFlat, TranslationValue, TreeTranslationsData, BackendGetRecord, BackendGetDevRecord } from '../../types';
import { ValueObserverInstance } from '../ValueObserver';
export declare const Cache: (onCacheChange: EventEmitterType<CacheDescriptorWithKey>, backendGetRecord: BackendGetRecord, backendGetDevRecord: BackendGetDevRecord, withDefaultNs: (descriptor: CacheDescriptor) => CacheDescriptorInternal, isInitialLoading: () => boolean, fetchingObserver: ValueObserverInstance<boolean>, loadingObserver: ValueObserverInstance<boolean>) => Readonly<{
export declare const Cache: (onCacheChange: EventEmitterInstance<CacheDescriptorWithKey>, backendGetRecord: BackendGetRecord, backendGetDevRecord: BackendGetDevRecord, withDefaultNs: (descriptor: CacheDescriptor) => CacheDescriptorInternal, isInitialLoading: () => boolean, fetchingObserver: ValueObserverInstance<boolean>, loadingObserver: ValueObserverInstance<boolean>) => Readonly<{
addStaticData: (data: Options['staticData']) => void;

@@ -5,0 +5,0 @@ invalidate: () => void;

@@ -48,13 +48,5 @@ import { CacheDescriptor, FallbackNSTranslation, Options, TFnType, TranslatePropsInternal } from '../types';

setObserver: (observer: import("../types").ObserverInterface | undefined) => void;
getObserver: () => {
unwrap: (text: string) => import("../types").Unwrapped;
wrap: import("../types").WrapperWrapFunction;
retranslate: () => void;
stop: () => void;
run: (props: import("../types").ObserverRunProps) => void;
highlight: import("../types").HighlightInterface;
outputNotFormattable: boolean;
} | undefined;
hasObserver: () => boolean;
setUi: (ui: import("../types").UiType | undefined) => void;
getUi: () => import("../types").UiConstructor | undefined;
hasUi: () => boolean;
addBackend: (backend: import("../types").BackendInterface | undefined) => void;

@@ -83,3 +75,17 @@ setDevBackend: (backend: import("../types").BackendDevInterface | undefined) => void;

setPendingLanguage: (language: string) => void;
getInitialOptions: () => Options;
getInitialOptions: () => {
apiUrl?: string | undefined;
apiKey?: string | undefined;
language?: string | undefined;
projectId?: number | undefined;
defaultLanguage?: string | undefined;
availableLanguages?: string[] | undefined;
fallbackLanguage?: import("../types").FallbackLanguageOption;
ns?: string[] | undefined;
fallbackNs?: import("../types").FallbackGeneral;
defaultNs: string;
staticData?: {
[key: string]: import("../types").TreeTranslationsData | (() => Promise<import("../types").TreeTranslationsData>);
} | undefined;
};
removeActiveNs: (ns: FallbackNSTranslation) => void;

@@ -91,47 +97,14 @@ getRequiredNamespaces: () => string[];

withDefaultNs: (descriptor: CacheDescriptor) => import("../types").CacheDescriptorInternal;
onPendingLanguageChange: Readonly<{
listen: (handler: import("../types").ListenerHandler<string>) => import("../types").Listener;
emit: (data: string) => void;
}>;
onLanguageChange: Readonly<{
listen: (handler: import("../types").ListenerHandler<string>) => import("../types").Listener;
emit: (data: string) => void;
}>;
onKeyChange: Readonly<{
listen: (handler: import("../types").ListenerHandler<import("../types").KeyDescriptorInternal>) => import("../types").Listener;
emit: (data: import("../types").KeyDescriptorInternal) => void;
}>;
onKeyUpdate: Readonly<{
listenSome: (handler: import("../types").ListenerHandler<undefined>) => {
unsubscribe: () => void;
subscribeNs: (ns: FallbackNSTranslation) => any;
unsubscribeNs: (ns: FallbackNSTranslation) => any;
subscribeKey: (descriptor: import("../types").KeyDescriptor) => any;
unsubscribeKey: (descriptor: import("../types").KeyDescriptor) => any;
};
listen: (handler: import("../types").ListenerHandler<void>) => {
unsubscribe: () => void;
};
emit: (descriptor?: import("../types").KeyDescriptorInternal | undefined, delayed?: boolean | undefined) => void;
}>;
onLoadingChange: Readonly<{
listen: (handler: import("../types").ListenerHandler<boolean>) => import("../types").Listener;
emit: (data: boolean) => void;
}>;
onFetchingChange: Readonly<{
listen: (handler: import("../types").ListenerHandler<boolean>) => import("../types").Listener;
emit: (data: boolean) => void;
}>;
onInitialLoaded: Readonly<{
listen: (handler: import("../types").ListenerHandler<void>) => import("../types").Listener;
emit: (data: void) => void;
}>;
onRunningChange: Readonly<{
listen: (handler: import("../types").ListenerHandler<boolean>) => import("../types").Listener;
emit: (data: boolean) => void;
}>;
onCacheChange: Readonly<{
listen: (handler: import("../types").ListenerHandler<import("../types").CacheDescriptorWithKey>) => import("../types").Listener;
emit: (data: import("../types").CacheDescriptorWithKey) => void;
}>;
overrideCredentials: (credentials: import("../types").DevCredentials) => void;
setObserverOptions: (options: Partial<import("./State/initObserverOptions").ObserverOptions>) => void;
getObserverOptions: () => import("./State/initObserverOptions").ObserverOptions;
onPendingLanguageChange: import("./Events/EventEmitter").EventEmitterInstance<string>;
onLanguageChange: import("./Events/EventEmitter").EventEmitterInstance<string>;
onKeyChange: import("./Events/EventEmitter").EventEmitterInstance<import("../types").KeyDescriptorInternal>;
onKeyUpdate: import("./Events/EventEmitterSelective").EventEmitterSelectiveInstance;
onLoadingChange: import("./Events/EventEmitter").EventEmitterInstance<boolean>;
onFetchingChange: import("./Events/EventEmitter").EventEmitterInstance<boolean>;
onInitialLoaded: import("./Events/EventEmitter").EventEmitterInstance<void>;
onRunningChange: import("./Events/EventEmitter").EventEmitterInstance<boolean>;
onCacheChange: import("./Events/EventEmitter").EventEmitterInstance<import("../types").CacheDescriptorWithKey>;
on: import("../types").TolgeeOn;

@@ -138,0 +111,0 @@ }>;

import { Listener, ListenerHandler } from '../../types';
export declare const EventEmitter: <T>() => Readonly<{
listen: (handler: ListenerHandler<T>) => Listener;
emit: (data: T) => void;
}>;
export declare type EventEmitterType<T> = ReturnType<typeof EventEmitter<T>>;
export declare const EventEmitter: <T>() => EventEmitterInstance<T>;
export declare type EventEmitterInstance<T> = {
readonly listen: (handler: ListenerHandler<T>) => Listener;
readonly emit: (data: T) => void;
};

@@ -1,15 +0,7 @@

import { FallbackNSTranslation, KeyDescriptor, KeyDescriptorInternal, ListenerHandler } from '../../types';
export declare const EventEmitterSelective: <T>(getFallbackNamespaces: () => string[]) => Readonly<{
listenSome: (handler: ListenerHandler<undefined>) => {
unsubscribe: () => void;
subscribeNs: (ns: FallbackNSTranslation) => any;
unsubscribeNs: (ns: FallbackNSTranslation) => any;
subscribeKey: (descriptor: KeyDescriptor) => any;
unsubscribeKey: (descriptor: KeyDescriptor) => any;
};
listen: (handler: ListenerHandler<T>) => {
unsubscribe: () => void;
};
emit: (descriptor?: KeyDescriptorInternal, delayed?: boolean) => void;
}>;
export declare type EventEmitterSelectiveType<T> = ReturnType<typeof EventEmitterSelective<T>>;
import { KeyDescriptorInternal, Listener, ListenerHandler, ListenerSelective } from '../../types';
export declare const EventEmitterSelective: (getFallbackNamespaces: () => string[]) => EventEmitterSelectiveInstance;
export declare type EventEmitterSelectiveInstance = {
readonly listenSome: (handler: ListenerHandler<undefined>) => ListenerSelective;
readonly listen: (handler: ListenerHandler<undefined>) => Listener;
readonly emit: (descriptor?: KeyDescriptorInternal, delayed?: boolean) => void;
};

@@ -1,50 +0,14 @@

import { CacheDescriptorWithKey, KeyDescriptorInternal, ListenerHandler, TolgeeOn } from '../../types';
import { CacheDescriptorWithKey, KeyDescriptorInternal, TolgeeOn } from '../../types';
export declare const Events: (getFallbackNamespaces: () => string[]) => Readonly<{
onPendingLanguageChange: Readonly<{
listen: (handler: ListenerHandler<string>) => import("../../types").Listener;
emit: (data: string) => void;
}>;
onLanguageChange: Readonly<{
listen: (handler: ListenerHandler<string>) => import("../../types").Listener;
emit: (data: string) => void;
}>;
onKeyChange: Readonly<{
listen: (handler: ListenerHandler<KeyDescriptorInternal>) => import("../../types").Listener;
emit: (data: KeyDescriptorInternal) => void;
}>;
onKeyUpdate: Readonly<{
listenSome: (handler: ListenerHandler<undefined>) => {
unsubscribe: () => void;
subscribeNs: (ns: import("../../types").FallbackNSTranslation) => any;
unsubscribeNs: (ns: import("../../types").FallbackNSTranslation) => any;
subscribeKey: (descriptor: import("../../types").KeyDescriptor) => any;
unsubscribeKey: (descriptor: import("../../types").KeyDescriptor) => any;
};
listen: (handler: ListenerHandler<void>) => {
unsubscribe: () => void;
};
emit: (descriptor?: KeyDescriptorInternal | undefined, delayed?: boolean | undefined) => void;
}>;
onLoadingChange: Readonly<{
listen: (handler: ListenerHandler<boolean>) => import("../../types").Listener;
emit: (data: boolean) => void;
}>;
onFetchingChange: Readonly<{
listen: (handler: ListenerHandler<boolean>) => import("../../types").Listener;
emit: (data: boolean) => void;
}>;
onInitialLoaded: Readonly<{
listen: (handler: ListenerHandler<void>) => import("../../types").Listener;
emit: (data: void) => void;
}>;
onRunningChange: Readonly<{
listen: (handler: ListenerHandler<boolean>) => import("../../types").Listener;
emit: (data: boolean) => void;
}>;
onCacheChange: Readonly<{
listen: (handler: ListenerHandler<CacheDescriptorWithKey>) => import("../../types").Listener;
emit: (data: CacheDescriptorWithKey) => void;
}>;
onPendingLanguageChange: import("./EventEmitter").EventEmitterInstance<string>;
onLanguageChange: import("./EventEmitter").EventEmitterInstance<string>;
onKeyChange: import("./EventEmitter").EventEmitterInstance<KeyDescriptorInternal>;
onKeyUpdate: import("./EventEmitterSelective").EventEmitterSelectiveInstance;
onLoadingChange: import("./EventEmitter").EventEmitterInstance<boolean>;
onFetchingChange: import("./EventEmitter").EventEmitterInstance<boolean>;
onInitialLoaded: import("./EventEmitter").EventEmitterInstance<void>;
onRunningChange: import("./EventEmitter").EventEmitterInstance<boolean>;
onCacheChange: import("./EventEmitter").EventEmitterInstance<CacheDescriptorWithKey>;
on: TolgeeOn;
}>;
export declare type EventServiceType = ReturnType<typeof Events>;

@@ -1,3 +0,4 @@

import { BackendDevInterface, BackendGetRecord, BackendInterface, FormatterInterface, ObserverInterface, TranslatePropsInternal, UiType, FinalFormatterInterface, HighlightInterface, UiConstructor, LanguageDetectorInterface, LanguageStorageInterface, Options, ChangeTranslationInterface, WrapperWrapProps, Unwrapped } from '../../types';
export declare const PluginService: (getLanguage: () => string | undefined, getInitialOptions: () => Options, getAvailableLanguages: () => string[] | undefined, getTranslationNs: (props: TranslatePropsInternal) => string[] | string, getTranslation: (props: TranslatePropsInternal) => string | undefined, changeTranslation: ChangeTranslationInterface) => Readonly<{
import { BackendDevInterface, BackendGetRecord, BackendInterface, FormatterInterface, ObserverInterface, TranslatePropsInternal, UiType, FinalFormatterInterface, HighlightInterface, LanguageDetectorInterface, LanguageStorageInterface, Options, ChangeTranslationInterface, WrapperWrapProps, Unwrapped } from '../../types';
import { ObserverOptions } from '../State/initObserverOptions';
export declare const PluginService: (getLanguage: () => string | undefined, getInitialOptions: () => Options, getObserverOptions: () => ObserverOptions, getAvailableLanguages: () => string[] | undefined, getTranslationNs: (props: TranslatePropsInternal) => string[] | string, getTranslation: (props: TranslatePropsInternal) => string | undefined, changeTranslation: ChangeTranslationInterface) => Readonly<{
setFinalFormatter: (formatter: FinalFormatterInterface | undefined) => void;

@@ -14,13 +15,5 @@ addFormatter: (formatter: FormatterInterface | undefined) => void;

setObserver: (observer: ObserverInterface | undefined) => void;
getObserver: () => {
unwrap: (text: string) => Unwrapped;
wrap: import("../../types").WrapperWrapFunction;
retranslate: () => void;
stop: () => void;
run: (props: import("../../types").ObserverRunProps) => void;
highlight: HighlightInterface;
outputNotFormattable: boolean;
} | undefined;
hasObserver: () => boolean;
setUi: (ui: UiType | undefined) => void;
getUi: () => UiConstructor | undefined;
hasUi: () => boolean;
addBackend: (backend: BackendInterface | undefined) => void;

@@ -37,3 +30,3 @@ setDevBackend: (backend: BackendDevInterface | undefined) => void;

setStoredLanguage: (language: string) => void;
run: () => void;
run: (isDev: boolean) => void;
stop: () => void;

@@ -40,0 +33,0 @@ retranslate: () => void;

@@ -24,6 +24,2 @@ import { FallbackLanguageOption, FallbackNS, TreeTranslationsData } from '../../types';

/**
* Store user language in localStorage (default: true)
*/
enableLanguageStore?: boolean;
/**
* Namespaces which should be always fetched

@@ -40,6 +36,2 @@ */

defaultNs: string;
/**
* Prefix used for fetching languages (default: 'i18n/')
*/
filesUrlPrefix: string;
staticData?: {

@@ -46,0 +38,0 @@ [key: string]: TreeTranslationsData | (() => Promise<TreeTranslationsData>);

@@ -1,4 +0,5 @@

import { CacheDescriptor, CacheDescriptorInternal, EventEmitterType, FallbackNSTranslation } from '../../types';
import { CacheDescriptor, CacheDescriptorInternal, DevCredentials, EventEmitterInstance, FallbackNSTranslation } from '../../types';
import { ObserverOptions } from './initObserverOptions';
import { Options } from './initState';
export declare const State: (onLanguageChange: EventEmitterType<string>, onPendingLanguageChange: EventEmitterType<string>, onRunningChange: EventEmitterType<boolean>) => Readonly<{
export declare const State: (onLanguageChange: EventEmitterInstance<string>, onPendingLanguageChange: EventEmitterInstance<string>, onRunningChange: EventEmitterInstance<boolean>) => Readonly<{
init: (options?: Partial<Options>) => void;

@@ -13,3 +14,17 @@ isRunning: () => boolean;

setPendingLanguage: (language: string) => void;
getInitialOptions: () => Options;
getInitialOptions: () => {
apiUrl?: string | undefined;
apiKey?: string | undefined;
language?: string | undefined;
projectId?: number | undefined;
defaultLanguage?: string | undefined;
availableLanguages?: string[] | undefined;
fallbackLanguage?: import("../../types").FallbackLanguageOption;
ns?: string[] | undefined;
fallbackNs?: import("../../types").FallbackGeneral;
defaultNs: string;
staticData?: {
[key: string]: import("../../types").TreeTranslationsData | (() => Promise<import("../../types").TreeTranslationsData>);
} | undefined;
};
addActiveNs: (ns: FallbackNSTranslation) => void;

@@ -22,2 +37,5 @@ removeActiveNs: (ns: FallbackNSTranslation) => void;

withDefaultNs: (descriptor: CacheDescriptor) => CacheDescriptorInternal;
overrideCredentials: (credentials: DevCredentials) => void;
setObserverOptions: (options: Partial<ObserverOptions>) => void;
getObserverOptions: () => ObserverOptions;
}>;

@@ -1,5 +0,5 @@

export declare const ValueObserver: <T = any>(initialValue: T, valueGetter: () => T, handler: (value: T) => void) => Readonly<{
init: (value: T) => void;
notify: () => void;
}>;
export declare type ValueObserverInstance<T> = ReturnType<typeof ValueObserver<T>>;
export declare const ValueObserver: <T = any>(initialValue: T, valueGetter: () => T, handler: (value: T) => void) => ValueObserverInstance<T>;
export declare type ValueObserverInstance<T> = {
readonly init: (value: T) => void;
readonly notify: () => void;
};
export { Tolgee } from './Tolgee';
export { RESTRICTED_ASCENDANT_ATTRIBUTE, DEVTOOLS_ID, TOLGEE_ATTRIBUTE_NAME, TOLGEE_HIGHLIGHTER_CLASS, TOLGEE_WRAPPED_ONLY_DATA_ATTRIBUTE, } from './constants';
export { RESTRICTED_ASCENDANT_ATTRIBUTE, TOLGEE_ATTRIBUTE_NAME, TOLGEE_HIGHLIGHTER_CLASS, TOLGEE_WRAPPED_ONLY_DATA_ATTRIBUTE, } from './constants';
export * from './types';
export { getTranslateParams } from './TranslateParams';
export { getFallback, getFallbackArray } from './Controller/State/helpers';
export { FormatSimple } from './FormatSimple/FormatSimple';
import type { Options } from './Controller/State/initState';
import type { ObserverOptions } from './Controller/State/initObserverOptions';
export type { State, Options } from './Controller/State/initState';
export type { EventEmitterType } from './Controller/Events/EventEmitter';
export type { EventEmitterSelectiveType } from './Controller/Events/EventEmitterSelective';
export type { ObserverOptions, ModifierKey, } from './Controller/State/initObserverOptions';
export type { EventEmitterInstance } from './Controller/Events/EventEmitter';
export type { EventEmitterSelectiveInstance } from './Controller/Events/EventEmitterSelective';
export declare type FallbackGeneral = undefined | false | string | string[];

@@ -93,2 +95,3 @@ export declare type FallbackNS = FallbackGeneral;

onClick: TranslationOnClick;
options: ObserverOptions;
};

@@ -120,2 +123,6 @@ export declare type HighlightInterface = (key?: string, ns?: FallbackNSTranslation) => {

};
export declare type DevCredentials = undefined | {
apiUrl?: string;
apiKey?: string;
};
export declare type BackendDevProps = {

@@ -179,2 +186,3 @@ apiUrl?: string;

unwrap: (text: string) => Unwrapped;
setObserverOptions: (options: Partial<ObserverOptions>) => TolgeeInstance;
}>;

@@ -185,5 +193,5 @@ export declare type PluginServicePublic = Readonly<{

setObserver: (observer: ObserverInterface | undefined) => void;
getObserver: () => ReturnType<ObserverInterface> | undefined;
hasObserver: () => boolean;
setUi: (ui: UiLibInterface | undefined) => void;
getUi: () => UiConstructor | undefined;
hasUi: () => boolean;
addBackend: (backend: BackendInterface | undefined) => void;

@@ -193,2 +201,3 @@ setDevBackend: (backend: BackendInterface | undefined) => void;

setLanguageStorage: (languageStorage: LanguageStorageInterface | undefined) => void;
overrideCredentials: (credentials: DevCredentials) => void;
}>;

@@ -195,0 +204,0 @@ export declare type NodeMeta = {

{
"name": "@tolgee/core",
"version": "4.10.0-rc.2b55a5c.0",
"version": "4.10.0-rc.43623be.0",
"description": "Library providing ability to translate messages directly in context of developed application.",
"main": "./dist/tolgee.cjs.js",
"module": "./dist/tolgee.esm.mjs",
"module": "./dist/tolgee.esm.js",
"types": "./lib/index.d.ts",

@@ -24,3 +24,3 @@ "repository": {

"require": "./dist/tolgee.cjs.js",
"import": "./dist/tolgee.esm.mjs"
"import": "./dist/tolgee.esm.js"
},

@@ -53,2 +53,3 @@ "directories": {

"concurrently": "7.3.0",
"intl-messageformat": "^9.9.1",
"jest": "^27.2.4",

@@ -66,3 +67,3 @@ "jest-fetch-mock": "^3.0.3",

},
"gitHead": "a4499bdf0eaf58dd49775553b10e0570a14cb3c9"
"gitHead": "c9e14f1c63155188a3c089e77cbc0dd2a2885811"
}

@@ -73,2 +73,14 @@ import { Tolgee } from '../index';

});
it('emits keyUpdate on initialLoad', async () => {
const tolgee = Tolgee({
language: 'en',
staticData: { en: { hello: 'world' } },
});
const onKeyChange = jest.fn();
tolgee.on('keyUpdate', onKeyChange);
expect(onKeyChange).toBeCalledTimes(0);
await tolgee.run();
expect(onKeyChange).toBeCalledTimes(1);
});
});

@@ -9,7 +9,11 @@ import { Tolgee } from '../Tolgee';

WrapperWrapFunction,
ObserverOptions,
} from '../types';
const testObserver =
(outputNotFormattable: boolean): ObserverInterface =>
() => {
(
outputNotFormattable: boolean,
onCreate?: (options: ObserverOptions) => void
): ObserverInterface =>
({ options }) => {
const wrap: WrapperWrapFunction = ({ key, translation }) => {

@@ -28,2 +32,4 @@ return `${key}|${translation}`;

onCreate?.(options);
return Object.freeze({

@@ -59,5 +65,8 @@ wrap,

const observerPlugin =
(outputNotFormattable: boolean): TolgeePlugin =>
(
outputNotFormattable: boolean,
onCreate?: (options: ObserverOptions) => void
): TolgeePlugin =>
(tolgee, tools) => {
tools.setObserver(testObserver(outputNotFormattable));
tools.setObserver(testObserver(outputNotFormattable, onCreate));
return tolgee;

@@ -101,2 +110,31 @@ };

});
it("won't wrap before run", () => {
const tolgee = Tolgee({
language: 'en',
staticData: { en: { hello: 'world' } },
});
tolgee.use(observerPlugin(false));
expect(tolgee.t({ key: 'hello' })).toEqual('world');
tolgee.run();
expect(tolgee.t({ key: 'hello' })).toEqual('hello|world');
});
it('observer recieves options', () => {
const tolgee = Tolgee({
language: 'en',
staticData: { en: { hello: 'world' } },
});
const restrictedElements = ['test'];
tolgee.setObserverOptions({
restrictedElements,
});
const onCreate = jest.fn();
tolgee.use(observerPlugin(false, onCreate));
tolgee.run();
expect(onCreate).toBeCalledTimes(1);
expect(onCreate.mock.calls[0][0].restrictedElements).toEqual(
restrictedElements
);
});
});

@@ -5,4 +5,1 @@ export const RESTRICTED_ASCENDANT_ATTRIBUTE = 'data-tolgee-restricted';

export const TOLGEE_WRAPPED_ONLY_DATA_ATTRIBUTE = 'data-tolgee-key-only';
// needs to be same as in @tolgee/ui package
export const DEVTOOLS_ID = '__tolgee_dev_tools';

@@ -6,3 +6,3 @@ import {

CacheDescriptorWithKey,
EventEmitterType,
EventEmitterInstance,
FallbackNSTranslation,

@@ -29,3 +29,3 @@ Options,

export const Cache = (
onCacheChange: EventEmitterType<CacheDescriptorWithKey>,
onCacheChange: EventEmitterInstance<CacheDescriptorWithKey>,
backendGetRecord: BackendGetRecord,

@@ -32,0 +32,0 @@ backendGetDevRecord: BackendGetDevRecord,

@@ -43,2 +43,3 @@ import { Events } from './Events/Events';

state.getInitialOptions,
state.getObserverOptions,
state.getAvailableLanguages,

@@ -100,3 +101,5 @@ getTranslationNs,

return Boolean(
state.getInitialOptions().apiKey && pluginService.getDevBackend()
state.getInitialOptions().apiKey &&
state.getInitialOptions().apiUrl &&
pluginService.getDevBackend()
);

@@ -267,3 +270,3 @@ }

state.setRunning(true);
pluginService.run();
pluginService.run(isDev());
result = loadInitial();

@@ -270,0 +273,0 @@ }

import { Listener, ListenerHandler } from '../../types';
export const EventEmitter = <T>() => {
export const EventEmitter = <T>(): EventEmitterInstance<T> => {
let handlers: ListenerHandler<T>[] = [];

@@ -27,2 +27,5 @@

export type EventEmitterType<T> = ReturnType<typeof EventEmitter<T>>;
export type EventEmitterInstance<T> = {
readonly listen: (handler: ListenerHandler<T>) => Listener;
readonly emit: (data: T) => void;
};

@@ -5,3 +5,3 @@ import { EventEmitterSelective } from './EventEmitterSelective';

it('handles correctly fallback namespaces', () => {
const emitter = EventEmitterSelective<void>(() => ['a', 'b']);
const emitter = EventEmitterSelective(() => ['a', 'b']);
const handler = jest.fn();

@@ -23,3 +23,3 @@ const listener = emitter.listenSome(handler);

it('subscribes to key', () => {
const emitter = EventEmitterSelective<void>(() => ['']);
const emitter = EventEmitterSelective(() => ['']);
const handler = jest.fn();

@@ -39,3 +39,3 @@ const listener = emitter.listenSome(handler);

it('subscribes to key with namespaces', () => {
const emitter = EventEmitterSelective<void>(() => []);
const emitter = EventEmitterSelective(() => []);
const handler = jest.fn();

@@ -59,3 +59,3 @@ const listener = emitter.listenSome(handler);

it('unsubscribes', () => {
const emitter = EventEmitterSelective<void>(() => []);
const emitter = EventEmitterSelective(() => []);
const handler = jest.fn();

@@ -84,3 +84,3 @@ const listener = emitter.listenSome(handler);

it('groups events correctly', async () => {
const emitter = EventEmitterSelective<void>(() => ['test', 'opqrst']);
const emitter = EventEmitterSelective(() => ['test', 'opqrst']);
const handler = jest.fn();

@@ -113,3 +113,3 @@ const hanlderAll = jest.fn();

it('subscribes to ns only', async () => {
const emitter = EventEmitterSelective<void>(() => ['test', 'youda']);
const emitter = EventEmitterSelective(() => ['test', 'youda']);
const handler = jest.fn();

@@ -116,0 +116,0 @@ const listener = emitter.listenSome(handler);

@@ -6,4 +6,6 @@ import { getFallbackArray } from '../State/helpers';

KeyDescriptorInternal,
Listener,
ListenerHandler,
ListenerHandlerEvent,
ListenerSelective,
} from '../../types';

@@ -32,9 +34,9 @@

export const EventEmitterSelective = <T>(
export const EventEmitterSelective = (
getFallbackNamespaces: () => string[]
) => {
const listeners: Set<ListenerHandler<T>> = new Set();
): EventEmitterSelectiveInstance => {
const listeners: Set<ListenerHandler<undefined>> = new Set();
const partialListeners: Set<HandlerWrapperType> = new Set();
const listen = (handler: ListenerHandler<T>) => {
const listen = (handler: ListenerHandler<undefined>) => {
listeners.add(handler);

@@ -179,4 +181,11 @@ const result = {

export type EventEmitterSelectiveType<T> = ReturnType<
typeof EventEmitterSelective<T>
>;
export type EventEmitterSelectiveInstance = {
readonly listenSome: (
handler: ListenerHandler<undefined>
) => ListenerSelective;
readonly listen: (handler: ListenerHandler<undefined>) => Listener;
readonly emit: (
descriptor?: KeyDescriptorInternal,
delayed?: boolean
) => void;
};

@@ -17,3 +17,3 @@ import { EventEmitter } from './EventEmitter';

const onInitialLoaded = EventEmitter<void>();
const onKeyUpdate = EventEmitterSelective<void>(getFallbackNamespaces);
const onKeyUpdate = EventEmitterSelective(getFallbackNamespaces);
const onCacheChange = EventEmitter<CacheDescriptorWithKey>();

@@ -20,0 +20,0 @@ const onRunningChange = EventEmitter<boolean>();

@@ -25,2 +25,3 @@ import { isPromise, valueOrPromise } from '../../helpers';

import { getFallbackArray } from '../State/helpers';
import { ObserverOptions } from '../State/initObserverOptions';

@@ -30,2 +31,3 @@ export const PluginService = (

getInitialOptions: () => Options,
getObserverOptions: () => ObserverOptions,
getAvailableLanguages: () => string[] | undefined,

@@ -38,2 +40,3 @@ getTranslationNs: (props: TranslatePropsInternal) => string[] | string,

ui: undefined as UiConstructor | undefined,
observer: undefined as ObserverInterface | undefined,
};

@@ -67,6 +70,5 @@

const run = () => {
instances.ui =
plugins.ui &&
new plugins.ui({
const run = (isDev: boolean) => {
if (!instances.ui && plugins.ui) {
instances.ui = new plugins.ui({
apiKey: getInitialOptions().apiKey!,

@@ -77,3 +79,11 @@ apiUrl: getInitialOptions().apiUrl!,

});
instances.observer?.run({ mouseHighlight: Boolean(instances.ui) });
}
if (!instances.observer) {
instances.observer = plugins.observer?.({
translate,
onClick,
options: getObserverOptions(),
});
}
instances.observer?.run({ mouseHighlight: isDev });
};

@@ -96,7 +106,7 @@

const setObserver = (observer: ObserverInterface | undefined) => {
instances.observer = observer?.({ translate, onClick });
plugins.observer = observer;
};
const getObserver = () => {
return instances.observer;
const hasObserver = () => {
return Boolean(plugins.observer);
};

@@ -120,4 +130,4 @@

const getUi = () => {
return plugins.ui;
const hasUi = () => {
return Boolean(plugins.ui);
};

@@ -289,5 +299,5 @@

setObserver,
getObserver,
hasObserver,
setUi,
getUi,
hasUi,
addBackend,

@@ -294,0 +304,0 @@ setDevBackend,

@@ -29,6 +29,2 @@ import {

/**
* Store user language in localStorage (default: true)
*/
enableLanguageStore?: boolean;
/**
* Namespaces which should be always fetched

@@ -45,6 +41,2 @@ */

defaultNs: string;
/**
* Prefix used for fetching languages (default: 'i18n/')
*/
filesUrlPrefix: string;
staticData?: {

@@ -65,5 +57,3 @@ [key: string]: TreeTranslationsData | (() => Promise<TreeTranslationsData>);

const defaultValues: Options = {
enableLanguageStore: true,
defaultNs: '',
filesUrlPrefix: 'i18n/',
};

@@ -80,2 +70,3 @@

};
// remove extra '/' from url end

@@ -82,0 +73,0 @@ const apiUrl = initialOptions.apiUrl;

import {
CacheDescriptor,
CacheDescriptorInternal,
EventEmitterType,
DevCredentials,
EventEmitterInstance,
FallbackNSTranslation,

@@ -9,10 +10,13 @@ } from '../../types';

import { getFallbackArray, getFallbackFromStruct, unique } from './helpers';
import { initObserverOptions, ObserverOptions } from './initObserverOptions';
import { initState, Options } from './initState';
export const State = (
onLanguageChange: EventEmitterType<string>,
onPendingLanguageChange: EventEmitterType<string>,
onRunningChange: EventEmitterType<boolean>
onLanguageChange: EventEmitterInstance<string>,
onPendingLanguageChange: EventEmitterInstance<string>,
onRunningChange: EventEmitterInstance<boolean>
) => {
let state = initState();
let observerOptions = initObserverOptions();
let devCredentials: DevCredentials = undefined;

@@ -65,3 +69,3 @@ function init(options?: Partial<Options>) {

function getInitialOptions() {
return state.initialOptions;
return { ...state.initialOptions, ...devCredentials };
}

@@ -139,2 +143,14 @@

function overrideCredentials(credentials: DevCredentials) {
devCredentials = credentials;
}
function setObserverOptions(options: Partial<ObserverOptions>) {
observerOptions = initObserverOptions(options);
}
function getObserverOptions() {
return observerOptions;
}
return Object.freeze({

@@ -158,3 +174,6 @@ init,

withDefaultNs,
overrideCredentials,
setObserverOptions,
getObserverOptions,
});
};

@@ -5,3 +5,3 @@ export const ValueObserver = <T = any>(

handler: (value: T) => void
) => {
): ValueObserverInstance<T> => {
let previousValue: T = initialValue;

@@ -24,2 +24,5 @@ function init(value: T) {

export type ValueObserverInstance<T> = ReturnType<typeof ValueObserver<T>>;
export type ValueObserverInstance<T> = {
readonly init: (value: T) => void;
readonly notify: () => void;
};
export { Tolgee } from './Tolgee';
export {
RESTRICTED_ASCENDANT_ATTRIBUTE,
DEVTOOLS_ID,
TOLGEE_ATTRIBUTE_NAME,

@@ -12,1 +11,2 @@ TOLGEE_HIGHLIGHTER_CLASS,

export { getFallback, getFallbackArray } from './Controller/State/helpers';
export { FormatSimple } from './FormatSimple/FormatSimple';
import { Controller } from './Controller/Controller';
import { Options, TolgeeInstance, TolgeePlugin } from './types';
import {
Options,
TolgeeInstance,
TolgeePlugin,
ObserverOptions,
} from './types';

@@ -13,5 +18,5 @@ export const Tolgee = (options?: Partial<Options>): TolgeeInstance => {

setObserver: controller.setObserver,
getObserver: controller.getObserver,
hasObserver: controller.hasObserver,
setUi: controller.setUi,
getUi: controller.getUi,
hasUi: controller.hasUi,
setDevBackend: controller.setDevBackend,

@@ -21,2 +26,3 @@ addBackend: controller.addBackend,

setLanguageStorage: controller.setLanguageStorage,
overrideCredentials: controller.overrideCredentials,
});

@@ -63,2 +69,6 @@

// plugins
setObserverOptions: (options: Partial<ObserverOptions>) => {
controller.setObserverOptions(options);
return tolgee;
},
use: (plugin: TolgeePlugin | undefined) => {

@@ -65,0 +75,0 @@ if (plugin) {

import type { Options } from './Controller/State/initState';
import type { ObserverOptions } from './Controller/State/initObserverOptions';
export type { State, Options } from './Controller/State/initState';
export type { EventEmitterType } from './Controller/Events/EventEmitter';
export type { EventEmitterSelectiveType } from './Controller/Events/EventEmitterSelective';
export type {
ObserverOptions,
ModifierKey,
} from './Controller/State/initObserverOptions';
export type { EventEmitterInstance } from './Controller/Events/EventEmitter';
export type { EventEmitterSelectiveInstance } from './Controller/Events/EventEmitterSelective';
export type FallbackGeneral = undefined | false | string | string[];

@@ -129,2 +135,3 @@

onClick: TranslationOnClick;
options: ObserverOptions;
};

@@ -168,2 +175,9 @@

export type DevCredentials =
| undefined
| {
apiUrl?: string;
apiKey?: string;
};
export type BackendDevProps = {

@@ -250,2 +264,3 @@ apiUrl?: string;

unwrap: (text: string) => Unwrapped;
setObserverOptions: (options: Partial<ObserverOptions>) => TolgeeInstance;
}>;

@@ -257,5 +272,5 @@

setObserver: (observer: ObserverInterface | undefined) => void;
getObserver: () => ReturnType<ObserverInterface> | undefined;
hasObserver: () => boolean;
setUi: (ui: UiLibInterface | undefined) => void;
getUi: () => UiConstructor | undefined;
hasUi: () => boolean;
addBackend: (backend: BackendInterface | undefined) => void;

@@ -269,2 +284,3 @@ setDevBackend: (backend: BackendInterface | undefined) => void;

) => void;
overrideCredentials: (credentials: DevCredentials) => void;
}>;

@@ -271,0 +287,0 @@

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc