@leaflink/stash 53.4.7 → 53.4.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/AppSidebar.js +43 -41
- package/dist/AppSidebar.js.map +1 -1
- package/dist/Modal.js +37 -35
- package/dist/Modal.js.map +1 -1
- package/dist/Modals.js +30 -26
- package/dist/Modals.js.map +1 -1
- package/dist/SearchBar.js +27 -25
- package/dist/SearchBar.js.map +1 -1
- package/dist/Select.js +22 -20
- package/dist/Select.js.map +1 -1
- package/dist/ThumbnailGroup.js +24 -22
- package/dist/ThumbnailGroup.js.map +1 -1
- package/dist/Timeline.js +15 -13
- package/dist/Timeline.js.map +1 -1
- package/dist/components.css +1 -1
- package/dist/useValidation.d.ts +11 -1
- package/dist/useValidation.js +240 -198
- package/dist/useValidation.js.map +1 -1
- package/package.json +1 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useValidation.js","sources":["../../../node_modules/.pnpm/flat@6.0.1/node_modules/flat/index.js","../src/composables/useValidation/parseJsonApiFieldErrors.ts","../src/composables/useValidation/ruleFactories/email.ts","../src/composables/useValidation/ruleFactories/maxLength.ts","../src/composables/useValidation/ruleFactories/maxValue.ts","../src/composables/useValidation/ruleFactories/minLength.ts","../src/composables/useValidation/ruleFactories/minValue.ts","../src/composables/useValidation/ruleFactories/pattern.ts","../src/composables/useValidation/ruleFactories/positiveNumber.ts","../src/composables/useValidation/ruleFactories/price.ts","../src/composables/useValidation/ruleFactories/required.ts","../src/composables/useValidation/ruleFactories/wholeNumber.ts","../src/composables/useValidation/useValidation.ts"],"sourcesContent":["function isBuffer (obj) {\n return obj &&\n obj.constructor &&\n (typeof obj.constructor.isBuffer === 'function') &&\n obj.constructor.isBuffer(obj)\n}\n\nfunction keyIdentity (key) {\n return key\n}\n\nexport function flatten (target, opts) {\n opts = opts || {}\n\n const delimiter = opts.delimiter || '.'\n const maxDepth = opts.maxDepth\n const transformKey = opts.transformKey || keyIdentity\n const output = {}\n\n function step (object, prev, currentDepth) {\n currentDepth = currentDepth || 1\n Object.keys(object).forEach(function (key) {\n const value = object[key]\n const isarray = opts.safe && Array.isArray(value)\n const type = Object.prototype.toString.call(value)\n const isbuffer = isBuffer(value)\n const isobject = (\n type === '[object Object]' ||\n type === '[object Array]'\n )\n\n const newKey = prev\n ? prev + delimiter + transformKey(key)\n : transformKey(key)\n\n if (!isarray && !isbuffer && isobject && Object.keys(value).length &&\n (!opts.maxDepth || currentDepth < maxDepth)) {\n return step(value, newKey, currentDepth + 1)\n }\n\n output[newKey] = value\n })\n }\n\n step(target)\n\n return output\n}\n\nexport function unflatten (target, opts) {\n opts = opts || {}\n\n const delimiter = opts.delimiter || '.'\n const overwrite = opts.overwrite || false\n const transformKey = opts.transformKey || keyIdentity\n const result = {}\n\n const isbuffer = isBuffer(target)\n if (isbuffer || Object.prototype.toString.call(target) !== '[object Object]') {\n return target\n }\n\n // safely ensure that the key is\n // an integer.\n function getkey (key) {\n const parsedKey = Number(key)\n\n return (\n isNaN(parsedKey) ||\n key.indexOf('.') !== -1 ||\n opts.object\n )\n ? key\n : parsedKey\n }\n\n function addKeys (keyPrefix, recipient, target) {\n return Object.keys(target).reduce(function (result, key) {\n result[keyPrefix + delimiter + key] = target[key]\n\n return result\n }, recipient)\n }\n\n function isEmpty (val) {\n const type = Object.prototype.toString.call(val)\n const isArray = type === '[object Array]'\n const isObject = type === '[object Object]'\n\n if (!val) {\n return true\n } else if (isArray) {\n return !val.length\n } else if (isObject) {\n return !Object.keys(val).length\n }\n }\n\n target = Object.keys(target).reduce(function (result, key) {\n const type = Object.prototype.toString.call(target[key])\n const isObject = (type === '[object Object]' || type === '[object Array]')\n if (!isObject || isEmpty(target[key])) {\n result[key] = target[key]\n return result\n } else {\n return addKeys(\n key,\n result,\n flatten(target[key], opts)\n )\n }\n }, {})\n\n Object.keys(target).forEach(function (key) {\n const split = key.split(delimiter).map(transformKey)\n let key1 = getkey(split.shift())\n let key2 = getkey(split[0])\n let recipient = result\n\n while (key2 !== undefined) {\n if (key1 === '__proto__') {\n return\n }\n\n const type = Object.prototype.toString.call(recipient[key1])\n const isobject = (\n type === '[object Object]' ||\n type === '[object Array]'\n )\n\n // do not write over falsey, non-undefined values if overwrite is false\n if (!overwrite && !isobject && typeof recipient[key1] !== 'undefined') {\n return\n }\n\n if ((overwrite && !isobject) || (!overwrite && recipient[key1] == null)) {\n recipient[key1] = (\n typeof key2 === 'number' &&\n !opts.object\n ? []\n : {}\n )\n }\n\n recipient = recipient[key1]\n if (split.length > 0) {\n key1 = getkey(split.shift())\n key2 = getkey(split[0])\n }\n }\n\n // unflatten again for 'messy objects'\n recipient[key1] = unflatten(target[key], opts)\n })\n\n return result\n}\n","import type { JsonApiValidationError } from './useValidation.types';\n\n/**\n * Converts a JSON:API pointer (e.g. `/data/attributes/email` or `/data/attributes/product_name`) to a flat field name\n * for useValidation. Segment names are left unchanged (e.g. snake_case from the backend stays snake_case). Nested\n * paths (e.g. `/data/attributes/price/min_value`) become dotted names (e.g. `price.min_value`).\n */\nfunction pointerToFieldName(pointer: string): string {\n const normalized = pointer.replace(/^\\//, '');\n const prefix = 'data/attributes/';\n\n if (normalized.startsWith(prefix)) {\n const pathWithinAttributes = normalized.slice(prefix.length);\n const segments = pathWithinAttributes.split('/').filter(Boolean);\n return segments.join('.');\n }\n\n const segments = normalized.split('/').filter(Boolean);\n return segments[segments.length - 1] || pointer;\n}\n\n/**\n * Parses an array of JSON:API error objects into a map of field names to error messages.\n * Uses `source.pointer` to determine the field (e.g. `/data/attributes/email` → `email`) and `detail` (or `title`) as the message.\n * If multiple errors reference the same field, the last one wins.\n */\nexport function parseJsonApiFieldErrors(errors: JsonApiValidationError[]): Record<string, string> {\n const map: Record<string, string> = {};\n for (const err of errors) {\n const pointer = err.source?.pointer;\n if (!pointer) {\n continue;\n }\n const message = err.detail || err.title || '';\n if (!message) {\n continue;\n }\n const fieldName = pointerToFieldName(pointer);\n map[fieldName] = message;\n }\n return map;\n}\n","import { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n message?: ValidationMessage;\n}\n\nexport default function email(config: Config = {}): ValidationRule {\n return {\n name: 'email',\n validator(value) {\n return !isDefined(value) || (typeof value === 'string' && /^\\S+@\\S+\\.\\S+$/.test(value));\n },\n message: config.message || t('ll.validation.email'),\n };\n}\n","import { MaybeRefOrGetter, toValue } from 'vue';\n\nimport { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n max: MaybeRefOrGetter<number>;\n message?: ValidationMessage;\n trim?: boolean;\n}\n\nexport default function maxLength(config: Config): ValidationRule {\n return {\n name: 'maxLength',\n validator(_value) {\n const max = toValue(config.max);\n const value = toValue(_value);\n\n if (!isDefined(value)) {\n return true;\n }\n\n let valueString = String(value);\n\n if (config.trim) {\n valueString = valueString.trim();\n }\n\n return valueString.length <= max;\n },\n message: config.message || (() => t('ll.validation.maxLength', { max: String(toValue(config.max)) })),\n };\n}\n","import { MaybeRefOrGetter, toValue } from 'vue';\n\nimport { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n max: MaybeRefOrGetter<number>;\n message?: ValidationMessage;\n}\n\nexport default function maxValue(config: Config): ValidationRule {\n return {\n name: 'maxValue',\n validator(value) {\n const max = toValue(config.max);\n\n return !isDefined(value) || Number(value) <= max;\n },\n message: config.message || (() => t('ll.validation.maxValue', { max: String(toValue(config.max)) })),\n };\n}\n","import { MaybeRefOrGetter, toValue } from 'vue';\n\nimport { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n min: MaybeRefOrGetter<number>;\n message?: ValidationMessage;\n trim?: boolean;\n}\n\nexport default function minLength(config: Config): ValidationRule {\n return {\n name: 'minLength',\n validator(_value) {\n const min = toValue(config.min);\n const value = toValue(_value);\n\n if (!isDefined(value)) {\n return true;\n }\n\n let valueString = String(value);\n\n if (config.trim) {\n valueString = valueString.trim();\n }\n\n return valueString.length >= min;\n },\n message: config.message || (() => t('ll.validation.minLength', { min: String(toValue(config.min)) })),\n };\n}\n","import { MaybeRefOrGetter, toValue } from 'vue';\n\nimport { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n min: MaybeRefOrGetter<number>;\n message?: ValidationMessage;\n}\n\nexport default function minValue(config: Config): ValidationRule {\n return {\n name: 'minValue',\n validator(value) {\n const min = toValue(config.min);\n\n return !isDefined(value) || Number(value) >= min;\n },\n message: config.message || (() => t('ll.validation.minValue', { min: String(toValue(config.min)) })),\n };\n}\n","import { toValue } from 'vue';\n\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n regex: RegExp;\n /** A custom message is required in order to inform the user of the required pattern. */\n message: ValidationMessage;\n}\n\nexport default function pattern(config: Config): ValidationRule {\n return {\n name: 'pattern',\n validator(_value) {\n const value = toValue(_value);\n\n return !isDefined(value) || config.regex.test(String(value));\n },\n message: () => {\n if (typeof config.message !== 'string' || !config.message.trim()) {\n throw new Error(\n 'The \"pattern\" ruleFactory requires a custom message informing the user of the required pattern.',\n );\n }\n\n return config.message;\n },\n };\n}\n","import { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n message?: ValidationMessage;\n}\n\nexport default function positiveNumber(config: Config = {}): ValidationRule {\n return {\n name: 'positiveNumber',\n validator(value) {\n return !isDefined(value) || Number(value) > 0;\n },\n message: config.message || t('ll.validation.positiveNumber'),\n };\n}\n","import round from 'lodash-es/round';\n\nimport { DECIMAL_PRECISION } from '../../../constants';\nimport { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n message?: ValidationMessage;\n}\n\nexport default function price(config: Config = {}): ValidationRule {\n return {\n name: 'price',\n validator(value) {\n const price = Number(value);\n\n return (\n !isDefined(value) || (price !== Infinity && price >= 0 && price === round(price, DECIMAL_PRECISION.CURRENCY))\n );\n },\n message: config.message || t('ll.validation.price'),\n };\n}\n","import { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n message?: ValidationMessage;\n}\n\nexport default function required(config: Config = {}): ValidationRule {\n return {\n name: 'required',\n validator(value) {\n return isDefined(typeof value === 'string' ? value.trim() : value);\n },\n message: config.message || t('ll.validation.required'),\n };\n}\n","import { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n message?: ValidationMessage;\n}\n\nexport default function wholeNumber(config: Config = {}): ValidationRule {\n return {\n name: 'wholeNumber',\n validator(value) {\n return !isDefined(value) || (Number.isInteger(Number(value)) && Number(value) >= 0);\n },\n message: config.message || t('ll.validation.wholeNumber'),\n };\n}\n","import { flatten } from 'flat';\nimport debounce from 'lodash-es/debounce';\nimport get from 'lodash-es/get';\nimport { computed, nextTick, reactive, readonly, Ref, ref, toValue, UnwrapRef, watch } from 'vue';\n\nimport { DEBOUNCE } from '../../constants';\nimport { parseJsonApiFieldErrors } from './parseJsonApiFieldErrors';\nimport {\n type JsonApiValidationError,\n UseValidationArgs,\n ValidationError,\n ValidationField,\n ValidationGroup,\n ValidationRule,\n} from './useValidation.types';\n\nconst API_ERROR_RULE_NAME = 'api';\n\nexport default function useValidation<Values extends object>({\n rules,\n values,\n}: UseValidationArgs<Values>): ValidationGroup<Values> {\n const fieldNames = computed(() => Object.keys(flatten(rules, { safe: true })));\n const apiErrors = ref<Record<string, string>>({});\n\n const fields = fieldNames.value.reduce(\n (map, fieldName) => {\n const fieldValue = ref(get(toValue(values), fieldName));\n\n // Having this function here allows us to update the fieldValue when the value of the field changes.\n // Also, passing `fieldValue` outside the `.reduce()` loop will cause a racing condition on `fieldValue` updates\n const updateFieldValue = (fieldName: string) => {\n fieldValue.value = get(toValue(values), fieldName);\n };\n\n const debouncedSetFieldValue = debounce(() => {\n updateFieldValue(fieldName);\n }, DEBOUNCE.FAST);\n\n watch(\n () => get(toValue(values), fieldName),\n () => {\n debouncedSetFieldValue();\n },\n );\n\n map[fieldName] = buildField<UnwrapRef<typeof fieldValue>>({\n fieldName,\n fieldValue,\n flush: () => {\n debouncedSetFieldValue.cancel();\n updateFieldValue(fieldName);\n },\n getApiError: () => apiErrors.value[fieldName] || '',\n rules: get(rules, fieldName),\n });\n\n return map;\n },\n {} as Record<string, ValidationField>,\n );\n\n const fieldList = computed(() => Object.values(fields));\n\n const hasErrors = computed(() => fieldList.value.some((field) => field.errors.length > 0));\n\n const someTouched = computed(() => fieldList.value.some((field) => field.isTouched));\n\n const dirtyFields = computed(() => fieldList.value.filter((field) => field.isDirty));\n\n const validate: ValidationGroup<Values>['validate'] = async function ({ preventScroll } = {}) {\n fieldList.value.forEach((field) => {\n // Doing setTouched(true) on a field that already has isTouched as `true` will not trigger reactivity for that field. Therefore, setting isTouched to `false` for all fields ensures that setTouched(true) will trigger reactivity for every field, which will cause all validations to run and display any error messages.\n field.setTouched(false);\n field.setTouched(true);\n });\n await nextTick();\n\n if (hasErrors.value && !preventScroll) {\n const firstFieldWithError = Object.entries(fields).find(([, field]) => field.errorMessage);\n const fieldName = firstFieldWithError?.[0] || '';\n const firstErrorElement = document?.querySelector(`[name=${fieldName}]`);\n\n if (firstErrorElement) {\n firstErrorElement.scrollIntoView({ behavior: 'smooth' });\n }\n }\n\n return !hasErrors.value;\n };\n\n const getError: ValidationGroup<Values>['getError'] = function (fieldName: string) {\n return fields[fieldName]?.errorMessage || '';\n };\n\n const touch: ValidationGroup<Values>['touch'] = function (fieldName: string) {\n if (!fields[fieldName]) {\n throw new Error(`In touch: fieldName \"${fieldName}\" does not exist in the validation fields.`);\n }\n\n fields[fieldName].setTouched();\n };\n\n const setAllUntouched: ValidationGroup<Values>['setAllUntouched'] = async function () {\n await nextTick(); // wait for field values to be reset\n fieldList.value.forEach((field) => {\n field.setTouched(false);\n });\n };\n\n const setInitialValues: ValidationGroup<Values>['setInitialValues'] = function (intialValues: Values) {\n fieldList.value.forEach((field) => {\n field.setInitialValue(intialValues[field.name]);\n });\n };\n\n function setApiErrors(errors: JsonApiValidationError[]) {\n const parsed = parseJsonApiFieldErrors(errors);\n const known = fieldNames.value;\n const next: Record<string, string> = {};\n for (const name of known) {\n if (parsed[name]) {\n next[name] = parsed[name];\n }\n }\n apiErrors.value = next;\n }\n\n function clearApiErrors(fieldName?: string) {\n if (fieldName) {\n const next = { ...apiErrors.value };\n delete next[fieldName];\n apiErrors.value = next;\n } else {\n apiErrors.value = {};\n }\n }\n\n return reactive({\n validate,\n getError,\n touch,\n setAllUntouched,\n setInitialValues,\n setApiErrors,\n clearApiErrors,\n fields,\n dirtyFields,\n hasErrors,\n someTouched,\n });\n}\n\ninterface BuildFieldArgs<Value = unknown> {\n fieldName: string;\n fieldValue: Ref<Value> | Ref<Value>;\n rules: ValidationRule[];\n flush: () => void;\n getApiError: () => string;\n}\n\nfunction buildField<Value = unknown>({\n fieldName,\n fieldValue,\n rules,\n flush,\n getApiError,\n}: BuildFieldArgs<Value>): ValidationField<Value> {\n /**\n * In order for `initialValue` to work properly, the `buildField` function must not be reactive; `buildField` should be called only once for each field when `useValidation` is called.\n */\n const initialValue = ref(fieldValue.value) as Ref<Value>;\n const isTouched = ref(false);\n const isDirty = computed(() => (fieldValue.value ?? '') !== (initialValue.value ?? ''));\n\n const results = computed(() => {\n // Adding a check for `isTouched` to avoid running the validation rules on the initial load, when the field is not touched.\n // if receives a fieldValue with some value as default or not, rule validation should also be triggered only via `touch()` or `validate()` methods.\n if (!isTouched.value) {\n return [];\n }\n\n return rules.map((rule) => ({\n fieldName,\n ruleName: rule.name,\n isValid: rule.validator(fieldValue.value),\n message: typeof rule.message === 'function' ? rule.message(fieldValue.value) : rule.message,\n }));\n });\n\n const errors = computed<ValidationError[]>(() => {\n const apiMessage = getApiError();\n const apiErrorList: ValidationError[] =\n apiMessage !== '' ? [{ ruleName: API_ERROR_RULE_NAME, message: apiMessage }] : [];\n const ruleErrors = results.value\n .filter((result) => !result.isValid)\n .map((result) => ({\n ruleName: result.ruleName,\n message: result.message,\n }));\n return [...apiErrorList, ...ruleErrors];\n });\n\n function setTouched(value = true) {\n // Flushing the debounced value to be updated right away.\n // So that, we can have reactivity for `rules` validation, `isTouched`, `isDirty`, among other values\n flush();\n\n isTouched.value = value;\n }\n\n function setInitialValue(value: Value) {\n initialValue.value = value;\n }\n\n return reactive({\n name: fieldName,\n currentValue: readonly(fieldValue),\n initialValue: readonly(initialValue),\n isTouched: readonly(isTouched),\n isDirty: readonly(isDirty),\n errorMessage: computed(() => errors.value?.[0]?.message || ''),\n errors,\n setInitialValue,\n setTouched,\n });\n}\n\n// The ruleFactories are excluded from the main entrypoint in vite.config.ts, so they are exported here instead. This allows one import statement to be used for useValidation, its types, and all of the ruleFactories.\nexport { default as email } from './ruleFactories/email';\nexport { default as maxLength } from './ruleFactories/maxLength';\nexport { default as maxValue } from './ruleFactories/maxValue';\nexport { default as minLength } from './ruleFactories/minLength';\nexport { default as minValue } from './ruleFactories/minValue';\nexport { default as pattern } from './ruleFactories/pattern';\nexport { default as positiveNumber } from './ruleFactories/positiveNumber';\nexport { default as price } from './ruleFactories/price';\nexport { default as required } from './ruleFactories/required';\nexport { default as wholeNumber } from './ruleFactories/wholeNumber';\nexport * from './useValidation.types';\nexport { default as isDefined } from './utils/isDefined';\n"],"names":["isBuffer","obj","keyIdentity","key","flatten","target","opts","delimiter","maxDepth","transformKey","output","step","object","prev","currentDepth","value","isarray","type","isbuffer","isobject","newKey","pointerToFieldName","pointer","normalized","prefix","segments","parseJsonApiFieldErrors","errors","map","err","_a","message","fieldName","email","config","isDefined","t","maxLength","_value","max","toValue","valueString","maxValue","minLength","min","minValue","pattern","positiveNumber","price","round","DECIMAL_PRECISION","required","wholeNumber","API_ERROR_RULE_NAME","useValidation","rules","values","fieldNames","computed","apiErrors","ref","fields","fieldValue","get","updateFieldValue","debouncedSetFieldValue","debounce","DEBOUNCE","watch","buildField","fieldList","hasErrors","field","someTouched","dirtyFields","validate","preventScroll","nextTick","firstFieldWithError","firstErrorElement","getError","touch","setAllUntouched","setInitialValues","intialValues","setApiErrors","parsed","known","next","name","clearApiErrors","reactive","flush","getApiError","initialValue","isTouched","isDirty","results","rule","apiMessage","apiErrorList","ruleErrors","result","setTouched","setInitialValue","readonly","_b"],"mappings":"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","x_google_ignoreList":[0]}
|
|
1
|
+
{"version":3,"file":"useValidation.js","sources":["../src/composables/useValidation/parseJsonApiFieldErrors.ts","../src/composables/useValidation/ruleFactories/email.ts","../src/composables/useValidation/ruleFactories/maxLength.ts","../src/composables/useValidation/ruleFactories/maxValue.ts","../src/composables/useValidation/ruleFactories/minLength.ts","../src/composables/useValidation/ruleFactories/minValue.ts","../src/composables/useValidation/ruleFactories/pattern.ts","../src/composables/useValidation/ruleFactories/positiveNumber.ts","../src/composables/useValidation/ruleFactories/price.ts","../src/composables/useValidation/ruleFactories/required.ts","../src/composables/useValidation/ruleFactories/wholeNumber.ts","../src/composables/useValidation/useValidation.ts"],"sourcesContent":["import type { JsonApiValidationError } from './useValidation.types';\n\n/**\n * Converts a JSON:API pointer to a dotted field name for useValidation.\n *\n * - Standard attributes: `/data/attributes/...` → strip that prefix, then join segments with `.` (e.g. `email`,\n * `price.min_value`, `terpenes.0.name`). Segment names are left unchanged (e.g. snake_case stays snake_case).\n * - Shorthand paths (no `data/attributes/`): join all segments with `.` (e.g. `/terpenes/0/percentage` →\n * `terpenes.0.percentage`). Single-segment pointers (e.g. `/email`) still map to `email`.\n */\nfunction pointerToFieldName(pointer: string): string {\n const normalized = pointer.replace(/^\\//, '');\n const prefix = 'data/attributes/';\n\n if (normalized.startsWith(prefix)) {\n const pathWithinAttributes = normalized.slice(prefix.length);\n const segments = pathWithinAttributes.split('/').filter(Boolean);\n return segments.join('.');\n }\n\n const segments = normalized.split('/').filter(Boolean);\n return segments.length ? segments.join('.') : pointer;\n}\n\n/**\n * Parses an array of JSON:API error objects into a map of field names to error messages.\n * Uses `source.pointer` to determine the field (e.g. `/data/attributes/email` → `email`) and `detail` (or `title`) as the message.\n * If multiple errors reference the same field, the last one wins.\n */\nexport function parseJsonApiFieldErrors(errors: JsonApiValidationError[]): Record<string, string> {\n const map: Record<string, string> = {};\n for (const err of errors) {\n const pointer = err.source?.pointer;\n if (!pointer) {\n continue;\n }\n const message = err.detail || err.title || '';\n if (!message) {\n continue;\n }\n const fieldName = pointerToFieldName(pointer);\n map[fieldName] = message;\n }\n return map;\n}\n","import { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n message?: ValidationMessage;\n}\n\nexport default function email(config: Config = {}): ValidationRule {\n return {\n name: 'email',\n validator(value) {\n return !isDefined(value) || (typeof value === 'string' && /^\\S+@\\S+\\.\\S+$/.test(value));\n },\n message: config.message || t('ll.validation.email'),\n };\n}\n","import { MaybeRefOrGetter, toValue } from 'vue';\n\nimport { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n max: MaybeRefOrGetter<number>;\n message?: ValidationMessage;\n trim?: boolean;\n}\n\nexport default function maxLength(config: Config): ValidationRule {\n return {\n name: 'maxLength',\n validator(_value) {\n const max = toValue(config.max);\n const value = toValue(_value);\n\n if (!isDefined(value)) {\n return true;\n }\n\n let valueString = String(value);\n\n if (config.trim) {\n valueString = valueString.trim();\n }\n\n return valueString.length <= max;\n },\n message: config.message || (() => t('ll.validation.maxLength', { max: String(toValue(config.max)) })),\n };\n}\n","import { MaybeRefOrGetter, toValue } from 'vue';\n\nimport { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n max: MaybeRefOrGetter<number>;\n message?: ValidationMessage;\n}\n\nexport default function maxValue(config: Config): ValidationRule {\n return {\n name: 'maxValue',\n validator(value) {\n const max = toValue(config.max);\n\n return !isDefined(value) || Number(value) <= max;\n },\n message: config.message || (() => t('ll.validation.maxValue', { max: String(toValue(config.max)) })),\n };\n}\n","import { MaybeRefOrGetter, toValue } from 'vue';\n\nimport { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n min: MaybeRefOrGetter<number>;\n message?: ValidationMessage;\n trim?: boolean;\n}\n\nexport default function minLength(config: Config): ValidationRule {\n return {\n name: 'minLength',\n validator(_value) {\n const min = toValue(config.min);\n const value = toValue(_value);\n\n if (!isDefined(value)) {\n return true;\n }\n\n let valueString = String(value);\n\n if (config.trim) {\n valueString = valueString.trim();\n }\n\n return valueString.length >= min;\n },\n message: config.message || (() => t('ll.validation.minLength', { min: String(toValue(config.min)) })),\n };\n}\n","import { MaybeRefOrGetter, toValue } from 'vue';\n\nimport { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n min: MaybeRefOrGetter<number>;\n message?: ValidationMessage;\n}\n\nexport default function minValue(config: Config): ValidationRule {\n return {\n name: 'minValue',\n validator(value) {\n const min = toValue(config.min);\n\n return !isDefined(value) || Number(value) >= min;\n },\n message: config.message || (() => t('ll.validation.minValue', { min: String(toValue(config.min)) })),\n };\n}\n","import { toValue } from 'vue';\n\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n regex: RegExp;\n /** A custom message is required in order to inform the user of the required pattern. */\n message: ValidationMessage;\n}\n\nexport default function pattern(config: Config): ValidationRule {\n return {\n name: 'pattern',\n validator(_value) {\n const value = toValue(_value);\n\n return !isDefined(value) || config.regex.test(String(value));\n },\n message: () => {\n if (typeof config.message !== 'string' || !config.message.trim()) {\n throw new Error(\n 'The \"pattern\" ruleFactory requires a custom message informing the user of the required pattern.',\n );\n }\n\n return config.message;\n },\n };\n}\n","import { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n message?: ValidationMessage;\n}\n\nexport default function positiveNumber(config: Config = {}): ValidationRule {\n return {\n name: 'positiveNumber',\n validator(value) {\n return !isDefined(value) || Number(value) > 0;\n },\n message: config.message || t('ll.validation.positiveNumber'),\n };\n}\n","import round from 'lodash-es/round';\n\nimport { DECIMAL_PRECISION } from '../../../constants';\nimport { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n message?: ValidationMessage;\n}\n\nexport default function price(config: Config = {}): ValidationRule {\n return {\n name: 'price',\n validator(value) {\n const price = Number(value);\n\n return (\n !isDefined(value) || (price !== Infinity && price >= 0 && price === round(price, DECIMAL_PRECISION.CURRENCY))\n );\n },\n message: config.message || t('ll.validation.price'),\n };\n}\n","import { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n message?: ValidationMessage;\n}\n\nexport default function required(config: Config = {}): ValidationRule {\n return {\n name: 'required',\n validator(value) {\n return isDefined(typeof value === 'string' ? value.trim() : value);\n },\n message: config.message || t('ll.validation.required'),\n };\n}\n","import { t } from '../../../locale';\nimport { ValidationMessage, ValidationRule } from '../useValidation.types';\nimport isDefined from '../utils/isDefined';\n\ninterface Config {\n message?: ValidationMessage;\n}\n\nexport default function wholeNumber(config: Config = {}): ValidationRule {\n return {\n name: 'wholeNumber',\n validator(value) {\n return !isDefined(value) || (Number.isInteger(Number(value)) && Number(value) >= 0);\n },\n message: config.message || t('ll.validation.wholeNumber'),\n };\n}\n","import debounce from 'lodash-es/debounce';\nimport get from 'lodash-es/get';\nimport {\n computed,\n effectScope,\n nextTick,\n reactive,\n readonly,\n type Ref,\n ref,\n toValue,\n type UnwrapRef,\n watch,\n} from 'vue';\n\nimport { DEBOUNCE } from '../../constants';\nimport { parseJsonApiFieldErrors } from './parseJsonApiFieldErrors';\nimport type {\n JsonApiValidationError,\n UseValidationArgs,\n ValidationError,\n ValidationField,\n ValidationGroup,\n ValidationRule,\n} from './useValidation.types';\n\nconst API_ERROR_RULE_NAME = 'api';\n\nfunction isValidationRule(x: unknown): x is ValidationRule {\n if (typeof x !== 'object' || x === null) {\n return false;\n }\n if (!('validator' in x)) {\n return false;\n }\n return typeof Reflect.get(x, 'validator') === 'function';\n}\n\nfunction isValidationRuleArray(value: unknown): value is ValidationRule[] {\n return Array.isArray(value) && value.every(isValidationRule);\n}\n\n/**\n * Lists dotted field paths for useValidation. Unlike `flatten(..., { safe: true })`, this descends into\n * arrays whose elements are per-row rule objects (e.g. `terpenes: [{ name: [...], amount: [...] }]`).\n * Arrays whose first element looks like a `ValidationRule` are treated as a single field's rule list.\n * An empty rule array at a path (e.g. `optionalField: []`) still registers that field so `touch`, API\n * errors, and dirty state work.\n */\nfunction collectValidationFieldPaths(value: unknown, prefix = ''): string[] {\n if (value === null || typeof value !== 'object') {\n return [];\n }\n\n if (Array.isArray(value)) {\n if (value.length === 0) {\n return prefix ? [prefix] : [];\n }\n const first = value[0];\n if (isValidationRule(first)) {\n return prefix ? [prefix] : [];\n }\n const paths: string[] = [];\n for (let i = 0; i < value.length; i++) {\n const p = prefix === '' ? String(i) : `${prefix}.${i}`;\n paths.push(...collectValidationFieldPaths(value[i], p));\n }\n return paths;\n }\n\n const paths: string[] = [];\n for (const key of Object.keys(value)) {\n const child = (value as Record<string, unknown>)[key];\n const p = prefix === '' ? key : `${prefix}.${key}`;\n paths.push(...collectValidationFieldPaths(child, p));\n }\n return paths;\n}\n\n/** Per-field teardown: value watcher, debounce, and `buildField` effectScope (stops its computeds). */\ninterface FieldCleanup {\n stop: () => void;\n cancelDebounced: () => void;\n stopFieldScope: () => void;\n}\n\nexport default function useValidation<Values extends object>({\n rules,\n values,\n}: UseValidationArgs<Values>): ValidationGroup<Values> {\n const apiErrors = ref<Record<string, string>>({});\n\n const fields = reactive<Record<string, ValidationField>>({});\n const fieldCleanups = new Map<string, FieldCleanup>();\n\n // Sort so traversal order is stable; the computed caches one sorted list per rules invalidation.\n const sortedRuleFieldNames = computed(() => collectValidationFieldPaths(toValue(rules)).sort());\n\n function removeField(fieldName: string) {\n const cleanup = fieldCleanups.get(fieldName);\n if (cleanup) {\n cleanup.cancelDebounced();\n cleanup.stop();\n cleanup.stopFieldScope();\n fieldCleanups.delete(fieldName);\n }\n if (fields[fieldName]) {\n delete fields[fieldName];\n }\n if (apiErrors.value[fieldName]) {\n const next = { ...apiErrors.value };\n delete next[fieldName];\n apiErrors.value = next;\n }\n }\n\n function addField(fieldName: string) {\n if (fields[fieldName]) {\n return;\n }\n\n const fieldValue = ref(get(toValue(values), fieldName));\n\n const updateFieldValue = () => {\n fieldValue.value = get(toValue(values), fieldName);\n };\n\n const debouncedSetFieldValue = debounce(() => {\n updateFieldValue();\n }, DEBOUNCE.FAST);\n\n const stop = watch(\n () => get(toValue(values), fieldName),\n () => {\n debouncedSetFieldValue();\n },\n );\n\n // Computeds inside `buildField` subscribe to rules/apiErrors; scope.stop() drops those subscriptions when the row is removed.\n const fieldScope = effectScope();\n const builtField = fieldScope.run(() =>\n buildField<UnwrapRef<typeof fieldValue>>({\n fieldName,\n fieldValue,\n flush: () => {\n debouncedSetFieldValue.cancel();\n updateFieldValue();\n },\n getApiError: () => apiErrors.value[fieldName] || '',\n getRules: () => {\n const raw = get(toValue(rules), fieldName);\n return isValidationRuleArray(raw) ? raw : [];\n },\n }),\n );\n\n if (!builtField) {\n stop();\n debouncedSetFieldValue.cancel();\n fieldScope.stop();\n return;\n }\n\n fieldCleanups.set(fieldName, {\n stop,\n cancelDebounced: () => debouncedSetFieldValue.cancel(),\n stopFieldScope: () => fieldScope.stop(),\n });\n\n fields[fieldName] = builtField;\n }\n\n watch(\n sortedRuleFieldNames,\n (newNames, oldNames) => {\n const prev = oldNames ?? [];\n const newSet = new Set(newNames);\n const oldSet = new Set(prev);\n\n for (const name of prev) {\n if (!newSet.has(name)) {\n removeField(name);\n }\n }\n for (const name of newNames) {\n if (!oldSet.has(name)) {\n addField(name);\n }\n }\n },\n { immediate: true },\n );\n\n const fieldList = computed(() => Object.values(fields));\n\n const hasErrors = computed(() => fieldList.value.some((field) => field.errors.length > 0));\n\n const someTouched = computed(() => fieldList.value.some((field) => field.isTouched));\n\n const dirtyFields = computed(() => fieldList.value.filter((field) => field.isDirty));\n\n const validate: ValidationGroup<Values>['validate'] = async function ({ preventScroll } = {}) {\n fieldList.value.forEach((field) => {\n // Doing setTouched(true) on a field that already has isTouched as `true` will not trigger reactivity for that field. Therefore, setting isTouched to `false` for all fields ensures that setTouched(true) will trigger reactivity for every field, which will cause all validations to run and display any error messages.\n field.setTouched(false);\n field.setTouched(true);\n });\n await nextTick();\n\n if (hasErrors.value && !preventScroll) {\n const firstFieldWithError = Object.entries(fields).find(([, field]) => field.errorMessage);\n const fieldName = firstFieldWithError?.[0] || '';\n const firstErrorElement = document?.querySelector(`[name=\"${fieldName}\"]`);\n\n if (firstErrorElement) {\n firstErrorElement.scrollIntoView({ behavior: 'smooth' });\n }\n }\n\n return !hasErrors.value;\n };\n\n const getError: ValidationGroup<Values>['getError'] = function (fieldName: string) {\n return fields[fieldName]?.errorMessage || '';\n };\n\n const touch: ValidationGroup<Values>['touch'] = function (fieldName: string) {\n if (!fields[fieldName]) {\n throw new Error(`In touch: fieldName \"${fieldName}\" does not exist in the validation fields.`);\n }\n\n fields[fieldName].setTouched();\n };\n\n const setAllUntouched: ValidationGroup<Values>['setAllUntouched'] = async function () {\n await nextTick(); // wait for field values to be reset\n fieldList.value.forEach((field) => {\n field.setTouched(false);\n });\n };\n\n const setInitialValues: ValidationGroup<Values>['setInitialValues'] = function (initialValues: Values) {\n fieldList.value.forEach((field) => {\n field.setInitialValue(get(initialValues, field.name));\n });\n };\n\n function setApiErrors(errors: JsonApiValidationError[]) {\n const parsed = parseJsonApiFieldErrors(errors);\n const known = sortedRuleFieldNames.value;\n const next: Record<string, string> = {};\n for (const name of known) {\n if (parsed[name]) {\n next[name] = parsed[name];\n }\n }\n apiErrors.value = next;\n }\n\n function clearApiErrors(fieldName?: string) {\n if (fieldName) {\n const next = { ...apiErrors.value };\n delete next[fieldName];\n apiErrors.value = next;\n } else {\n apiErrors.value = {};\n }\n }\n\n return reactive({\n validate,\n getError,\n touch,\n setAllUntouched,\n setInitialValues,\n setApiErrors,\n clearApiErrors,\n fields,\n dirtyFields,\n hasErrors,\n someTouched,\n });\n}\n\ninterface BuildFieldArgs<Value = unknown> {\n fieldName: string;\n fieldValue: Ref<Value>;\n getRules: () => ValidationRule[];\n flush: () => void;\n getApiError: () => string;\n}\n\nfunction buildField<Value = unknown>({\n fieldName,\n fieldValue,\n getRules,\n flush,\n getApiError,\n}: BuildFieldArgs<Value>): ValidationField<Value> {\n /**\n * In order for `initialValue` to work properly, `initialValue` is captured when the field is registered; `setInitialValue` updates it thereafter.\n */\n const initialValue = ref(fieldValue.value) as Ref<Value>;\n const isTouched = ref(false);\n const isDirty = computed(() => (fieldValue.value ?? '') !== (initialValue.value ?? ''));\n\n const results = computed(() => {\n // Adding a check for `isTouched` to avoid running the validation rules on the initial load, when the field is not touched.\n // if receives a fieldValue with some value as default or not, rule validation should also be triggered only via `touch()` or `validate()` methods.\n if (!isTouched.value) {\n return [];\n }\n\n const rulesList = getRules();\n return rulesList.map((rule) => ({\n fieldName,\n ruleName: rule.name,\n isValid: rule.validator(fieldValue.value),\n message: typeof rule.message === 'function' ? rule.message(fieldValue.value) : rule.message,\n }));\n });\n\n const errors = computed<ValidationError[]>(() => {\n const apiMessage = getApiError();\n const apiErrorList: ValidationError[] =\n apiMessage !== '' ? [{ ruleName: API_ERROR_RULE_NAME, message: apiMessage }] : [];\n const ruleErrors = results.value\n .filter((result) => !result.isValid)\n .map((result) => ({\n ruleName: result.ruleName,\n message: result.message,\n }));\n return [...apiErrorList, ...ruleErrors];\n });\n\n function setTouched(value = true) {\n // Flushing the debounced value to be updated right away.\n // So that, we can have reactivity for `rules` validation, `isTouched`, `isDirty`, among other values\n flush();\n\n isTouched.value = value;\n }\n\n function setInitialValue(value: Value) {\n initialValue.value = value;\n }\n\n return reactive({\n name: fieldName,\n currentValue: readonly(fieldValue),\n initialValue: readonly(initialValue),\n isTouched: readonly(isTouched),\n isDirty: readonly(isDirty),\n errorMessage: computed(() => errors.value?.[0]?.message || ''),\n errors,\n setInitialValue,\n setTouched,\n });\n}\n\n// The ruleFactories are excluded from the main entrypoint in vite.config.ts, so they are exported here instead. This allows one import statement to be used for useValidation, its types, and all of the ruleFactories.\nexport { default as email } from './ruleFactories/email';\nexport { default as maxLength } from './ruleFactories/maxLength';\nexport { default as maxValue } from './ruleFactories/maxValue';\nexport { default as minLength } from './ruleFactories/minLength';\nexport { default as minValue } from './ruleFactories/minValue';\nexport { default as pattern } from './ruleFactories/pattern';\nexport { default as positiveNumber } from './ruleFactories/positiveNumber';\nexport { default as price } from './ruleFactories/price';\nexport { default as required } from './ruleFactories/required';\nexport { default as wholeNumber } from './ruleFactories/wholeNumber';\nexport * from './useValidation.types';\nexport { default as isDefined } from './utils/isDefined';\n"],"names":["pointerToFieldName","pointer","normalized","prefix","segments","parseJsonApiFieldErrors","errors","map","err","_a","message","fieldName","email","config","value","isDefined","t","maxLength","_value","max","toValue","valueString","maxValue","minLength","min","minValue","pattern","positiveNumber","price","round","DECIMAL_PRECISION","required","wholeNumber","API_ERROR_RULE_NAME","isValidationRule","x","isValidationRuleArray","collectValidationFieldPaths","first","paths","i","p","key","child","useValidation","rules","values","apiErrors","ref","fields","reactive","fieldCleanups","sortedRuleFieldNames","computed","removeField","cleanup","next","addField","fieldValue","get","updateFieldValue","debouncedSetFieldValue","debounce","DEBOUNCE","stop","watch","fieldScope","effectScope","builtField","buildField","raw","newNames","oldNames","prev","newSet","oldSet","name","fieldList","hasErrors","field","someTouched","dirtyFields","validate","preventScroll","nextTick","firstFieldWithError","firstErrorElement","getError","touch","setAllUntouched","setInitialValues","initialValues","setApiErrors","parsed","known","clearApiErrors","getRules","flush","getApiError","initialValue","isTouched","isDirty","results","rule","apiMessage","apiErrorList","ruleErrors","result","setTouched","setInitialValue","readonly","_b"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@leaflink/stash",
|
|
3
|
-
"version": "53.4.
|
|
3
|
+
"version": "53.4.9",
|
|
4
4
|
"description": "LeafLink's design system.",
|
|
5
5
|
"homepage": "https://stash.leaflink.com",
|
|
6
6
|
"main": "./dist/index.ts",
|
|
@@ -86,7 +86,6 @@
|
|
|
86
86
|
"date-fns": "3.6.0",
|
|
87
87
|
"date-fns-tz": "3.1.3",
|
|
88
88
|
"dompurify": "3.2.4",
|
|
89
|
-
"flat": "6.0.1",
|
|
90
89
|
"fuzzysort": "3.0.2",
|
|
91
90
|
"sanitize-html": "2.13.0",
|
|
92
91
|
"v-calendar": "3.1.2",
|