feat : story et page playground de MalioDateWeek (#MUI-33)
This commit is contained in:
68
.playground/pages/composant/date/dateWeek.vue
Normal file
68
.playground/pages/composant/date/dateWeek.vue
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
<template>
|
||||||
|
<div class="space-y-6 p-4">
|
||||||
|
<h1 class="text-2xl font-bold">MalioDateWeek</h1>
|
||||||
|
|
||||||
|
<div class="flex flex-wrap items-start gap-10">
|
||||||
|
<div class="w-[480px] space-y-3">
|
||||||
|
<h2 class="font-semibold">Large (480px)</h2>
|
||||||
|
<MalioDateWeek
|
||||||
|
v-model="value"
|
||||||
|
label="Semaine"
|
||||||
|
hint="Clique un jour ou un n° de semaine"
|
||||||
|
/>
|
||||||
|
<div class="rounded border p-3 text-sm">
|
||||||
|
<p>Valeur : <code>{{ value ?? 'null' }}</code></p>
|
||||||
|
</div>
|
||||||
|
<div class="flex gap-2">
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
class="rounded bg-m-primary px-3 py-1.5 text-white"
|
||||||
|
@click="value = '2026-W52'"
|
||||||
|
>
|
||||||
|
Forcer 2026-W52
|
||||||
|
</button>
|
||||||
|
<button
|
||||||
|
type="button"
|
||||||
|
class="rounded border px-3 py-1.5"
|
||||||
|
@click="value = null"
|
||||||
|
>
|
||||||
|
Réinitialiser
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="w-[396px] space-y-3">
|
||||||
|
<h2 class="font-semibold">ERP (396px)</h2>
|
||||||
|
<MalioDateWeek
|
||||||
|
v-model="erpValue"
|
||||||
|
label="Semaine"
|
||||||
|
hint="Largeur cible ERP"
|
||||||
|
/>
|
||||||
|
<div class="rounded border p-3 text-sm">
|
||||||
|
<p>Valeur : <code>{{ erpValue ?? 'null' }}</code></p>
|
||||||
|
</div>
|
||||||
|
<MalioDateWeek
|
||||||
|
v-model="bounded"
|
||||||
|
label="Semaine bornée"
|
||||||
|
:min="todayIso"
|
||||||
|
:max="maxIso"
|
||||||
|
hint="Entre aujourd'hui et +60 jours"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup lang="ts">
|
||||||
|
import {ref} from 'vue'
|
||||||
|
|
||||||
|
const pad = (n: number) => String(n).padStart(2, '0')
|
||||||
|
const toIso = (d: Date) => `${d.getFullYear()}-${pad(d.getMonth() + 1)}-${pad(d.getDate())}`
|
||||||
|
const now = new Date()
|
||||||
|
const todayIso = toIso(now)
|
||||||
|
const maxIso = toIso(new Date(now.getTime() + 60 * 86400000))
|
||||||
|
|
||||||
|
const value = ref<string | null>(null)
|
||||||
|
const erpValue = ref<string | null>(null)
|
||||||
|
const bounded = ref<string | null>(null)
|
||||||
|
</script>
|
||||||
75
app/story/date/dateWeek.story.vue
Normal file
75
app/story/date/dateWeek.story.vue
Normal file
@@ -0,0 +1,75 @@
|
|||||||
|
<template>
|
||||||
|
<Story title="Date/DateWeek">
|
||||||
|
<div class="grid grid-cols-1 items-start gap-6 md:grid-cols-2">
|
||||||
|
<div class="rounded-lg border p-4">
|
||||||
|
<h2 class="mb-4 text-xl font-bold">Simple</h2>
|
||||||
|
<MalioDateWeek
|
||||||
|
v-model="simpleValue"
|
||||||
|
label="Semaine"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="rounded-lg border p-4">
|
||||||
|
<h2 class="mb-4 text-xl font-bold">Valeur initiale</h2>
|
||||||
|
<MalioDateWeek
|
||||||
|
v-model="initialValue"
|
||||||
|
label="Semaine de livraison"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="rounded-lg border p-4">
|
||||||
|
<h2 class="mb-4 text-xl font-bold">Avec min/max</h2>
|
||||||
|
<MalioDateWeek
|
||||||
|
v-model="boundedValue"
|
||||||
|
label="Semaine bornée"
|
||||||
|
:min="todayIso"
|
||||||
|
:max="maxIso"
|
||||||
|
hint="Entre aujourd'hui et +60 jours"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="rounded-lg border p-4">
|
||||||
|
<h2 class="mb-4 text-xl font-bold">Non effaçable</h2>
|
||||||
|
<MalioDateWeek
|
||||||
|
v-model="initialValue"
|
||||||
|
label="Semaine verrouillée"
|
||||||
|
:clearable="false"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="rounded-lg border p-4">
|
||||||
|
<h2 class="mb-4 text-xl font-bold">Désactivé</h2>
|
||||||
|
<MalioDateWeek
|
||||||
|
v-model="initialValue"
|
||||||
|
label="Désactivé"
|
||||||
|
disabled
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="rounded-lg border p-4">
|
||||||
|
<h2 class="mb-4 text-xl font-bold">Erreur</h2>
|
||||||
|
<MalioDateWeek
|
||||||
|
v-model="errorValue"
|
||||||
|
label="Semaine"
|
||||||
|
error="Semaine invalide"
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</Story>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup lang="ts">
|
||||||
|
import {ref} from 'vue'
|
||||||
|
import MalioDateWeek from '../../components/malio/date/DateWeek.vue'
|
||||||
|
|
||||||
|
const simpleValue = ref<string | null>(null)
|
||||||
|
const initialValue = ref<string | null>('2026-W21')
|
||||||
|
const boundedValue = ref<string | null>(null)
|
||||||
|
const errorValue = ref<string | null>(null)
|
||||||
|
|
||||||
|
const pad = (n: number) => String(n).padStart(2, '0')
|
||||||
|
const toIso = (d: Date) => `${d.getFullYear()}-${pad(d.getMonth() + 1)}-${pad(d.getDate())}`
|
||||||
|
const now = new Date()
|
||||||
|
const todayIso = toIso(now)
|
||||||
|
const maxIso = toIso(new Date(now.getTime() + 60 * 86400000))
|
||||||
|
</script>
|
||||||
Reference in New Issue
Block a user