Files
leadchat/app/javascript/v3/components/Form/WithLabel.vue
Shivam Mishra b533980880 feat: Add support for minutes in auto resolve feature (#11269)
### Summary

- Converts conversation auto-resolution duration from days to minutes
for more
granular control
- Updates validation to allow values from 10 minutes (minimum) to 999
days (maximum)
- Implements smart messaging to show appropriate time units in activity
messages

###  Changes

- Created migration to convert existing durations from days to minutes
(x1440)
- Updated conversation resolver to use minutes instead of days
- Added dynamic translation key selection based on duration value
- Updated related specs and documentation
- Added support for displaying durations in days, hours, or minutes
based on value

###  Test plan

- Verify account validation accepts new minute-based ranges
- Confirm existing account settings are correctly migrated
- Test auto-resolution works properly with minute values
- Ensure proper time unit display in activity messages

---------

Co-authored-by: Sivin Varghese <64252451+iamsivin@users.noreply.github.com>
2025-05-07 00:36:15 -07:00

52 lines
1.3 KiB
Vue

<script setup>
defineProps({
label: { type: String, default: '' },
name: { type: String, required: true },
icon: { type: String, default: '' },
hasError: { type: Boolean, default: false },
helpMessage: { type: String, default: '' },
errorMessage: { type: String, default: '' },
});
</script>
<template>
<div class="space-y-1">
<label
v-if="label"
:for="name"
class="flex justify-between text-sm font-medium leading-6 text-n-slate-12"
:class="{ 'text-n-ruby-12': hasError }"
>
<slot name="label">
{{ label }}
</slot>
<slot name="rightOfLabel" />
</label>
<div class="w-full">
<div class="flex items-center relative w-full">
<fluent-icon
v-if="icon"
size="16"
:icon="icon"
class="absolute left-2 transform text-n-slate-9 w-5 h-5"
/>
<slot />
</div>
<div
v-if="errorMessage && hasError"
class="text-xs mt-2 ml-px text-n-ruby-9 leading-tight"
>
{{ errorMessage }}
</div>
<div
v-else-if="helpMessage || $slots.help"
class="text-xs mt-2 ml-px text-n-slate-10 leading-tight"
>
<slot name="help">
{{ helpMessage }}
</slot>
</div>
</div>
</div>
</template>