mirror of
https://gitee.com/element-plus/element-plus.git
synced 2024-12-04 12:17:37 +08:00
839a702af7
* feat(components): [date-picker] add icon slots * chore: update date-picker.md * feat: add `prev-year`、`next-year` with year range * Apply suggestions from code review --------- Co-authored-by: qiang <qw13131wang@gmail.com>
136 lines
5.6 KiB
Vue
136 lines
5.6 KiB
Vue
<template>
|
|
<div class="demo-datetime-picker-icon">
|
|
<div class="block">
|
|
<el-date-picker
|
|
v-model="value1"
|
|
type="datetime"
|
|
placeholder="Pick a Date"
|
|
format="YYYY-MM-DD HH:mm:ss"
|
|
date-format="MMM DD, YYYY"
|
|
time-format="HH:mm"
|
|
>
|
|
<template #prev-month>
|
|
<el-icon><CaretLeft /></el-icon>
|
|
</template>
|
|
<template #next-month>
|
|
<el-icon><CaretRight /></el-icon>
|
|
</template>
|
|
<template #prev-year>
|
|
<el-icon>
|
|
<svg
|
|
viewBox="0 0 20 20"
|
|
version="1.1"
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
>
|
|
<g stroke-width="1" fill-rule="evenodd">
|
|
<g fill="currentColor">
|
|
<path
|
|
d="M8.73171,16.7949 C9.03264,17.0795 9.50733,17.0663 9.79196,16.7654 C10.0766,16.4644 10.0634,15.9897 9.76243,15.7051 L4.52339,10.75 L17.2471,10.75 C17.6613,10.75 17.9971,10.4142 17.9971,10 C17.9971,9.58579 17.6613,9.25 17.2471,9.25 L4.52112,9.25 L9.76243,4.29275 C10.0634,4.00812 10.0766,3.53343 9.79196,3.2325 C9.50733,2.93156 9.03264,2.91834 8.73171,3.20297 L2.31449,9.27241 C2.14819,9.4297 2.04819,9.62981 2.01448,9.8386 C2.00308,9.89058 1.99707,9.94459 1.99707,10 C1.99707,10.0576 2.00356,10.1137 2.01585,10.1675 C2.05084,10.3733 2.15039,10.5702 2.31449,10.7254 L8.73171,16.7949 Z"
|
|
/>
|
|
</g>
|
|
</g>
|
|
</svg>
|
|
</el-icon>
|
|
</template>
|
|
<template #next-year>
|
|
<el-icon>
|
|
<svg
|
|
viewBox="0 0 20 20"
|
|
version="1.1"
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
>
|
|
<g stroke-width="1" fill-rule="evenodd">
|
|
<g fill="currentColor">
|
|
<path
|
|
d="M11.2654,3.20511 C10.9644,2.92049 10.4897,2.93371 10.2051,3.23464 C9.92049,3.53558 9.93371,4.01027 10.2346,4.29489 L15.4737,9.25 L2.75,9.25 C2.33579,9.25 2,9.58579 2,10.0000012 C2,10.4142 2.33579,10.75 2.75,10.75 L15.476,10.75 L10.2346,15.7073 C9.93371,15.9919 9.92049,16.4666 10.2051,16.7675 C10.4897,17.0684 10.9644,17.0817 11.2654,16.797 L17.6826,10.7276 C17.8489,10.5703 17.9489,10.3702 17.9826,10.1614 C17.994,10.1094 18,10.0554 18,10.0000012 C18,9.94241 17.9935,9.88633 17.9812,9.83246 C17.9462,9.62667 17.8467,9.42976 17.6826,9.27455 L11.2654,3.20511 Z"
|
|
/>
|
|
</g>
|
|
</g>
|
|
</svg>
|
|
</el-icon>
|
|
</template>
|
|
</el-date-picker>
|
|
</div>
|
|
<div class="line" />
|
|
<div class="block">
|
|
<el-date-picker
|
|
v-model="value2"
|
|
type="datetimerange"
|
|
start-placeholder="Start date"
|
|
end-placeholder="End date"
|
|
format="YYYY-MM-DD HH:mm:ss"
|
|
date-format="YYYY/MM/DD ddd"
|
|
time-format="A hh:mm:ss"
|
|
unlink-panels
|
|
>
|
|
<template #prev-month>
|
|
<el-icon><CaretLeft /></el-icon>
|
|
</template>
|
|
<template #next-month>
|
|
<el-icon><CaretRight /></el-icon>
|
|
</template>
|
|
<template #prev-year>
|
|
<el-icon>
|
|
<svg
|
|
viewBox="0 0 20 20"
|
|
version="1.1"
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
>
|
|
<g stroke-width="1" fill-rule="evenodd">
|
|
<g fill="currentColor">
|
|
<path
|
|
d="M8.73171,16.7949 C9.03264,17.0795 9.50733,17.0663 9.79196,16.7654 C10.0766,16.4644 10.0634,15.9897 9.76243,15.7051 L4.52339,10.75 L17.2471,10.75 C17.6613,10.75 17.9971,10.4142 17.9971,10 C17.9971,9.58579 17.6613,9.25 17.2471,9.25 L4.52112,9.25 L9.76243,4.29275 C10.0634,4.00812 10.0766,3.53343 9.79196,3.2325 C9.50733,2.93156 9.03264,2.91834 8.73171,3.20297 L2.31449,9.27241 C2.14819,9.4297 2.04819,9.62981 2.01448,9.8386 C2.00308,9.89058 1.99707,9.94459 1.99707,10 C1.99707,10.0576 2.00356,10.1137 2.01585,10.1675 C2.05084,10.3733 2.15039,10.5702 2.31449,10.7254 L8.73171,16.7949 Z"
|
|
/>
|
|
</g>
|
|
</g>
|
|
</svg>
|
|
</el-icon>
|
|
</template>
|
|
<template #next-year>
|
|
<el-icon>
|
|
<svg
|
|
viewBox="0 0 20 20"
|
|
version="1.1"
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
>
|
|
<g stroke-width="1" fill-rule="evenodd">
|
|
<g fill="currentColor">
|
|
<path
|
|
d="M11.2654,3.20511 C10.9644,2.92049 10.4897,2.93371 10.2051,3.23464 C9.92049,3.53558 9.93371,4.01027 10.2346,4.29489 L15.4737,9.25 L2.75,9.25 C2.33579,9.25 2,9.58579 2,10.0000012 C2,10.4142 2.33579,10.75 2.75,10.75 L15.476,10.75 L10.2346,15.7073 C9.93371,15.9919 9.92049,16.4666 10.2051,16.7675 C10.4897,17.0684 10.9644,17.0817 11.2654,16.797 L17.6826,10.7276 C17.8489,10.5703 17.9489,10.3702 17.9826,10.1614 C17.994,10.1094 18,10.0554 18,10.0000012 C18,9.94241 17.9935,9.88633 17.9812,9.83246 C17.9462,9.62667 17.8467,9.42976 17.6826,9.27455 L11.2654,3.20511 Z"
|
|
/>
|
|
</g>
|
|
</g>
|
|
</svg>
|
|
</el-icon>
|
|
</template>
|
|
</el-date-picker>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import { ref } from 'vue'
|
|
import { CaretLeft, CaretRight } from '@element-plus/icons-vue'
|
|
|
|
const value1 = ref('')
|
|
const value2 = ref('')
|
|
</script>
|
|
<style scoped>
|
|
.demo-datetime-picker-icon {
|
|
display: flex;
|
|
width: 100%;
|
|
padding: 0;
|
|
flex-wrap: wrap;
|
|
justify-content: space-around;
|
|
align-items: stretch;
|
|
}
|
|
.demo-datetime-picker-icon .block {
|
|
padding: 30px 0;
|
|
text-align: center;
|
|
}
|
|
.line {
|
|
width: 1px;
|
|
background-color: var(--el-border-color);
|
|
}
|
|
</style>
|