routie dev init since i didn't adhere to any proper guidance up until now

This commit is contained in:
2026-04-29 22:27:29 -06:00
commit e1dabb71e2
15301 changed files with 3562618 additions and 0 deletions
+8
View File
@@ -0,0 +1,8 @@
import type { I18n, useI18n } from 'vue-i18n';
import type { LocaleInstance } from '../../composables/locale.js';
type VueI18nAdapterParams = {
i18n: I18n<any, {}, {}, string, false>;
useI18n: typeof useI18n;
};
export declare function createVueI18nAdapter({ i18n, useI18n }: VueI18nAdapterParams): LocaleInstance;
+76
View File
@@ -0,0 +1,76 @@
// Composables
import { useProxiedModel } from "../../composables/proxiedModel.js"; // Utilities
import { toRef, watch } from 'vue';
// Types
function useProvided(props, prop, provided) {
const internal = useProxiedModel(props, prop);
internal.value = props[prop] ?? provided.value;
watch(provided, v => {
if (props[prop] == null) {
internal.value = v;
}
});
return internal;
}
function inferDecimalSeparator(format) {
return format(0.1).includes(',') ? ',' : '.';
}
function createProvideFunction(data) {
return props => {
const current = useProvided(props, 'locale', data.current);
const fallback = useProvided(props, 'fallback', data.fallback);
const messages = useProvided(props, 'messages', data.messages);
const i18n = data.useI18n({
locale: current.value,
fallbackLocale: fallback.value,
messages: messages.value,
useScope: 'local',
legacy: false,
inheritLocale: false
});
watch(current, v => {
i18n.locale.value = v;
});
return {
name: 'vue-i18n',
current,
fallback,
messages,
decimalSeparator: toRef(() => props.decimalSeparator ?? inferDecimalSeparator(i18n.n)),
t: (key, ...params) => i18n.t(key, params),
n: i18n.n,
provide: createProvideFunction({
current,
fallback,
messages,
useI18n: data.useI18n
})
};
};
}
export function createVueI18nAdapter({
i18n,
useI18n
}) {
const current = i18n.global.locale;
const fallback = i18n.global.fallbackLocale;
const messages = i18n.global.messages;
return {
name: 'vue-i18n',
current,
fallback,
messages,
decimalSeparator: toRef(() => inferDecimalSeparator(i18n.global.n)),
t: (key, ...params) => i18n.global.t(key, params),
n: i18n.global.n,
provide: createProvideFunction({
current,
fallback,
messages,
useI18n
})
};
}
//# sourceMappingURL=vue-i18n.js.map
File diff suppressed because one or more lines are too long
+2
View File
@@ -0,0 +1,2 @@
import type { LocaleInstance, LocaleOptions } from '../../composables/locale.js';
export declare function createVuetifyAdapter(options?: LocaleOptions): LocaleInstance;
+101
View File
@@ -0,0 +1,101 @@
// Composables
import { useProxiedModel } from "../../composables/proxiedModel.js"; // Utilities
import { ref, shallowRef, toRef, watch } from 'vue';
import { consoleError, consoleWarn, getObjectValueByPath } from "../../util/index.js"; // Locales
import en from "../en.js"; // Types
const LANG_PREFIX = '$vuetify.';
const replace = (str, params) => {
return str.replace(/\{(\d+)\}/g, (match, index) => {
return String(params[Number(index)]);
});
};
const createTranslateFunction = (current, fallback, messages) => {
return (key, ...params) => {
if (!key.startsWith(LANG_PREFIX)) {
return replace(key, params);
}
const shortKey = key.replace(LANG_PREFIX, '');
const currentLocale = current.value && messages.value[current.value];
const fallbackLocale = fallback.value && messages.value[fallback.value];
let str = getObjectValueByPath(currentLocale, shortKey, null);
if (!str) {
consoleWarn(`Translation key "${key}" not found in "${current.value}", trying fallback locale`);
str = getObjectValueByPath(fallbackLocale, shortKey, null);
}
if (!str) {
consoleError(`Translation key "${key}" not found in fallback`);
str = key;
}
if (typeof str !== 'string') {
consoleError(`Translation key "${key}" has a non-string value`);
str = key;
}
return replace(str, params);
};
};
function createNumberFunction(current, fallback) {
return (value, options) => {
const numberFormat = new Intl.NumberFormat([current.value, fallback.value], options);
return numberFormat.format(value);
};
}
function inferDecimalSeparator(current, fallback) {
const format = createNumberFunction(current, fallback);
return format(0.1).includes(',') ? ',' : '.';
}
function useProvided(props, prop, provided) {
const internal = useProxiedModel(props, prop, props[prop] ?? provided.value);
// TODO: Remove when defaultValue works
internal.value = props[prop] ?? provided.value;
watch(provided, v => {
if (props[prop] == null) {
internal.value = provided.value;
}
});
return internal;
}
function createProvideFunction(state) {
return props => {
const current = useProvided(props, 'locale', state.current);
const fallback = useProvided(props, 'fallback', state.fallback);
const messages = useProvided(props, 'messages', state.messages);
return {
name: 'vuetify',
current,
fallback,
messages,
decimalSeparator: toRef(() => inferDecimalSeparator(current, fallback)),
t: createTranslateFunction(current, fallback, messages),
n: createNumberFunction(current, fallback),
provide: createProvideFunction({
current,
fallback,
messages
})
};
};
}
export function createVuetifyAdapter(options) {
const current = shallowRef(options?.locale ?? 'en');
const fallback = shallowRef(options?.fallback ?? 'en');
const messages = ref({
en,
...options?.messages
});
return {
name: 'vuetify',
current,
fallback,
messages,
decimalSeparator: toRef(() => options?.decimalSeparator ?? inferDecimalSeparator(current, fallback)),
t: createTranslateFunction(current, fallback, messages),
n: createNumberFunction(current, fallback),
provide: createProvideFunction({
current,
fallback,
messages
})
};
}
//# sourceMappingURL=vuetify.js.map
File diff suppressed because one or more lines are too long