feat: integrate cron editor in vm schedule edit page (#635)

Signed-off-by: Andy Lee <andy.lee@suse.com>
This commit is contained in:
Andy Lee 2025-12-10 08:02:58 +08:00 committed by GitHub
parent b4019a2c86
commit 5b668a176c
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 48 additions and 13 deletions

View File

@ -75,7 +75,7 @@ export default {
<div class="row"> <div class="row">
<div class="col span-6 mb-20"> <div class="col span-6 mb-20">
<LabelValue <LabelValue
:name="t('harvester.schedule.cron')" :name="t('harvester.schedule.cron.label')"
:value="cronExpression" :value="cronExpression"
/> />
</div> </div>

View File

@ -1,4 +1,5 @@
<script> <script>
import { mapGetters } from 'vuex';
import { RadioGroup } from '@components/Form/Radio'; import { RadioGroup } from '@components/Form/Radio';
import { Banner } from '@components/Banner'; import { Banner } from '@components/Banner';
import { LabeledInput } from '@components/Form/LabeledInput'; import { LabeledInput } from '@components/Form/LabeledInput';
@ -16,6 +17,7 @@ import { sortBy } from '@shell/utils/sort';
import { BACKUP_TYPE } from '../config/types'; import { BACKUP_TYPE } from '../config/types';
import { _EDIT, _CREATE } from '@shell/config/query-params'; import { _EDIT, _CREATE } from '@shell/config/query-params';
import { isBackupTargetSettingEmpty, isBackupTargetSettingUnavailable } from '../utils/setting'; import { isBackupTargetSettingEmpty, isBackupTargetSettingUnavailable } from '../utils/setting';
import CronExpressionEditorModal from '@shell/components/Cron/CronExpressionEditorModal.vue';
export default { export default {
name: 'CreateVMSchedule', name: 'CreateVMSchedule',
@ -28,6 +30,7 @@ export default {
LabeledSelect, LabeledSelect,
MessageLink, MessageLink,
Banner, Banner,
CronExpressionEditorModal
}, },
mixins: [CreateEditView], mixins: [CreateEditView],
@ -86,10 +89,12 @@ export default {
} }
} }
return { settings: [] }; return { settings: [], showModel: false };
}, },
computed: { computed: {
...mapGetters({ t: 'i18n/t' }),
backupTargetResource() { backupTargetResource() {
return this.settings.find( (O) => O.id === 'backup-target'); return this.settings.find( (O) => O.id === 'backup-target');
}, },
@ -172,6 +177,9 @@ export default {
this.value.spec['maxFailure'] = this.value.spec.retain; this.value.spec['maxFailure'] = this.value.spec.retain;
} }
}, },
openModal() {
this.showModel = true;
},
}, },
}; };
</script> </script>
@ -256,16 +264,28 @@ export default {
:weight="99" :weight="99"
class="bordered-table" class="bordered-table"
> >
<LabeledInput <div class="cronEditor">
v-model:value="value.spec.cron" <LabeledInput
class="mb-30" v-model:value="value.spec.cron"
type="cron" class="mb-30"
required type="cron"
:mode="mode" required
:label="t('harvester.schedule.cron')" :mode="mode"
placeholder="0 * * * *" :label="t('harvester.schedule.cron.label')"
:disabled="isBackupTargetUnAvailable || isView" placeholder="0 * * * *"
/> :disabled="isBackupTargetUnAvailable || isView"
/>
<button
class="editCronBtn btn role-primary"
@click="openModal"
>
{{ t('harvester.schedule.cron.editButton') }}
</button>
<CronExpressionEditorModal
v-model:show="showModel"
v-model:cron-expression="value.spec.cron"
/>
</div>
<LabeledInput <LabeledInput
v-model:value.number="value.spec.retain" v-model:value.number="value.spec.retain"
class="mb-30" class="mb-30"
@ -292,3 +312,16 @@ export default {
</Tabbed> </Tabbed>
</CruResource> </CruResource>
</template> </template>
<style lang="scss" scoped>
.cronEditor {
align-items: center;
display: flex;
}
.editCronBtn {
margin-bottom: 30px;
margin-left: 10px;
height: 60px;
}
</style>

View File

@ -983,7 +983,9 @@ harvester:
createTitle: Create Schedule createTitle: Create Schedule
createButtonText: Create Schedule createButtonText: Create Schedule
scheduleType: Virtual Machine Schedule Type scheduleType: Virtual Machine Schedule Type
cron: Cron Schedule cron:
label: Cron Schedule
editButton: Edit
detail: detail:
namespace: Namespace namespace: Namespace
sourceVM: Source Virtual Machine sourceVM: Source Virtual Machine