mirror of
https://github.com/CorentinTh/it-tools.git
synced 2025-04-23 00:06:15 -04:00

* feat(new tool): Regex Tester Fix https://github.com/CorentinTh/it-tools/issues/1007, https://github.com/CorentinTh/it-tools/issues/991, https://github.com/CorentinTh/it-tools/issues/936, https://github.com/CorentinTh/it-tools/issues/761, https://github.com/CorentinTh/it-tools/issues/649 https://github.com/CorentinTh/it-tools/issues/644, https://github.com/CorentinTh/it-tools/issues/554 https://github.com/CorentinTh/it-tools/issues/308 * fix: refactor to service + add regex diagram + ui enhancements * fix: update queryParams * fix: deps * fix: svg style bug in @regexper/render @regexper/render use a stylesheet in svg that cause bugs in whole site. So add regexper in a shadow root * feat(new tool): added Regex Cheatsheet * Update src/tools/regex-memo/index.ts * Update src/tools/regex-tester/index.ts --------- Co-authored-by: Corentin THOMASSET <corentin.thomasset74@gmail.com>
94 lines
2.1 KiB
TypeScript
94 lines
2.1 KiB
TypeScript
import { type MaybeRef, get } from '@vueuse/core';
|
|
import _ from 'lodash';
|
|
import { type Ref, reactive, watch } from 'vue';
|
|
|
|
type ValidatorReturnType = unknown;
|
|
type GetErrorMessageReturnType = string;
|
|
|
|
export interface UseValidationRule<T> {
|
|
validator: (value: T) => ValidatorReturnType
|
|
getErrorMessage?: (value: T) => GetErrorMessageReturnType
|
|
message: string
|
|
}
|
|
|
|
export function isFalsyOrHasThrown(cb: () => ValidatorReturnType): boolean {
|
|
try {
|
|
const returnValue = cb();
|
|
|
|
if (_.isNil(returnValue)) {
|
|
return true;
|
|
}
|
|
|
|
return returnValue === false;
|
|
}
|
|
catch (_) {
|
|
return true;
|
|
}
|
|
}
|
|
|
|
export function getErrorMessageOrThrown(cb: () => GetErrorMessageReturnType): string {
|
|
try {
|
|
return cb() || '';
|
|
}
|
|
catch (e: any) {
|
|
return e.toString();
|
|
}
|
|
}
|
|
|
|
export interface ValidationAttrs {
|
|
feedback: string
|
|
validationStatus: string | undefined
|
|
}
|
|
|
|
export function useValidation<T>({
|
|
source,
|
|
rules,
|
|
watch: watchRefs = [],
|
|
}: {
|
|
source: Ref<T>
|
|
rules: MaybeRef<UseValidationRule<T>[]>
|
|
watch?: Ref<unknown>[]
|
|
}) {
|
|
const state = reactive<{
|
|
message: string
|
|
status: undefined | 'error'
|
|
isValid: boolean
|
|
attrs: ValidationAttrs
|
|
}>({
|
|
message: '',
|
|
status: undefined,
|
|
isValid: false,
|
|
attrs: {
|
|
validationStatus: undefined,
|
|
feedback: '',
|
|
},
|
|
});
|
|
|
|
watch(
|
|
[source, ...watchRefs],
|
|
() => {
|
|
state.message = '';
|
|
state.status = undefined;
|
|
|
|
for (const rule of get(rules)) {
|
|
if (isFalsyOrHasThrown(() => rule.validator(source.value))) {
|
|
if (rule.getErrorMessage) {
|
|
const getErrorMessage = rule.getErrorMessage;
|
|
state.message = rule.message.replace('{0}', getErrorMessageOrThrown(() => getErrorMessage(source.value)));
|
|
}
|
|
else {
|
|
state.message = rule.message;
|
|
}
|
|
state.status = 'error';
|
|
}
|
|
}
|
|
|
|
state.isValid = state.status !== 'error';
|
|
state.attrs.feedback = state.message;
|
|
state.attrs.validationStatus = state.status;
|
|
},
|
|
{ immediate: true },
|
|
);
|
|
|
|
return state;
|
|
}
|