Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(date-panel): [date-panel,date-picker] DatePicker support using only date panel #2778

Closed
wants to merge 12 commits into from
221 changes: 221 additions & 0 deletions examples/sites/demos/apis/date-panel.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,221 @@
export default {
mode: ['pc'],
apis: [
{
name: 'date-panel',
type: 'component',
props: [
{
name: 'disabled-date',
type: 'function',
defaultValue: '',
desc: {
'zh-CN': '配置部分禁用',
'en-US': 'Configuration section disabled.'
},
mode: ['pc'],
pcDemo: 'disabled-date'
},
{
name: 'format',
type: 'string',
defaultValue: "'yyyy-MM-dd'",
desc: {
'zh-CN': '面板选中日期格式',
'en-US': 'Select date format on the panel.'
},
mode: ['pc'],
pcDemo: 'format'
},
{
name: 'v-model/modelValue',
type: 'date | string | number',
defaultValue: '',
desc: {
'zh-CN': '绑定值',
'en-US': 'Set the initial value of the calendar component. ;Bound Value.'
},
mode: ['pc'],
pcDemo: 'basic-usage'
},
{
name: 'popper-class',
type: 'string',
defaultValue: '',
desc: {
'zh-CN': '为 DatePicker 面板添加的 class 类名',
'en-US': 'Class name added for DatePanel.'
},
mode: ['pc'],
pcDemo: 'custom-suffix-icon'
},
{
name: 'readonly',
type: 'boolean',
defaultValue: 'false',
desc: {
'zh-CN': '设置日历组件是否只读',
'en-US': 'Set panel component is read-only.'
},
mode: ['pc'],
pcDemo: 'readonly'
},
{
name: 'show-week-number',
type: 'boolean',
defaultValue: 'false',
desc: {
'zh-CN': '是否展示周次序号',
'en-US': 'Display week number.'
},
mode: ['pc'],
pcDemo: 'custom-weeks'
},
{
name: 'format-weeks',
type: '(customWeeks: number, weekFirstDays: string[]) => string',
defaultValue: '',
desc: {
'zh-CN':
'格式化周次序号,该回调函数有两个参数,customWeeks 用来获取自定义周次的序号,weekFirstDays 用来获取每周次中的首个日期',
'en-US':
'Format the week number, this callback function has two parameters: customWeeks is used to obtain the custom week number, and weekFirstDays is used to obtain the first date in the week number'
},
mode: ['pc'],
pcDemo: 'custom-weeks'
},
{
name: 'first-day-of-week',
type: 'number',
defaultValue: '7',
desc: {
'zh-CN': '设置每周的第一天是星期几,默认值是7,也就是星期天',
'en-US':
'Set the first day of each week as the day of the week, with a default value of 7, which is Sunday.'
},
mode: ['pc'],
pcDemo: 'custom-weeks'
}
],
events: [
{
name: 'select-change',
type: '(value: string) => void',
desc: {
'zh-CN': '用户确认选定的值时触发',
'en-US': 'This event is triggered when the user confirms the selected value.'
},
mode: ['pc'],
pcDemo: 'event'
}
],
format: [
{
name: 'a',
desc: {
'zh-CN': 'am/pm',
'en-US': ''
},
discreted66 marked this conversation as resolved.
Show resolved Hide resolved
mode: ['pc'],
pcDemo: ''
},
{
name: 'A',
desc: {
'zh-CN': 'AM/PM',
'en-US': ''
},
mode: ['pc'],
pcDemo: ''
},
{
name: 'd',
desc: {
'zh-CN': '日,不补0',
'en-US': ''
},
mode: ['pc']
},
{
name: 'dd',
desc: {
'zh-CN': '日',
'en-US': ''
},
mode: ['pc']
},
{
name: 'M',
desc: {
'zh-CN': '月,不补0',
'en-US': ''
},
mode: ['pc']
},
{
name: 'MM',
desc: {
'zh-CN': '月',
'en-US': ''
},
mode: ['pc']
},
{
name: 'W',
desc: {
'zh-CN': '周,不补0',
'en-US': ''
},
mode: ['pc']
},
{
name: 'WW',
desc: {
'zh-CN': '周',
'en-US': ''
},
mode: ['pc']
},
{
name: 'yyyy',
desc: {
'zh-CN': '年',
'en-US': ''
},
mode: ['pc']
}
]
}
],
types: [
{
name: 'IPickerOptions',
type: 'interface',
code: `
interface IPickerOptions {
// 每周的第一天是星期几,默认值是7,也就是星期天
firstDayOfWeek: number
// 实现部分禁用,此时只能选择一部分日期
disabledDate: (time: Date) => boolean
// 选中日期后执行的回调,需要与 daterange 或 datetimerange 类型配合使用才生效
onPick: (range: { minDate: Date, maxDate: Date }) => void
// 快捷选项
shortcuts: {
text: string
onClick: (picker: { $emit: (type: string, date: Date) => void }) => void
type: 'startFrom' | 'EndAt'
startDate: Date
endDate: Date
}[]
}
`
},
{
name: 'IType',
type: 'type',
code: `
type IType = 'date' | 'dates' | 'daterange' | 'datetime' | 'datetimerange' | 'week' | 'month' | 'monthrange' | 'quarter' | 'year' | 'years' | 'yearrange'
`
}
]
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
<template>
<div class="demo-date-panel-wrap">
<div>{{ value }}</div>
<tiny-date-panel v-model="value"></tiny-date-panel>
</div>
</template>

<script setup>
import { ref } from 'vue'
import { TinyDatePanel } from '@opentiny/vue'

const value = ref('')
</script>

<style scoped lang="less">
.demo-date-panel-wrap {
width: 560px;

& > * {
margin-top: 12px;
}
}
</style>
22 changes: 22 additions & 0 deletions examples/sites/demos/pc/app/date-panel/basic-usage.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
import { test, expect } from '@playwright/test'

test('[DatePanel] 测试月份/年份/日期选择', async ({ page }) => {
page.on('pageerror', (exception) => expect(exception).toBeNull())
await page.goto('date-panel#basic-usage')

// 点击展示年份面板
await page.getByRole('button', { name: '2025 年' }).click()
await expect(page.getByRole('cell', { name: '2025' })).toBeVisible()

// 选择年份展示月份面板
await page.getByRole('cell', { name: '2025' }).click()
await expect(page.getByRole('cell', { name: '一月', exact: true })).toBeVisible()

// 选择月份展示日期面板
await page.getByRole('cell', { name: '一月', exact: true }).click()
await expect(page.getByRole('cell', { name: '15' }).locator('div')).toBeVisible()

// 选择日期
await page.getByRole('cell', { name: '15' }).locator('div').click()
await expect(page.getByText('-01-15')).toBeVisible()
})
24 changes: 24 additions & 0 deletions examples/sites/demos/pc/app/date-panel/basic-usage.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
<template>
<div class="demo-date-panel-wrap">
<div>{{ value }}</div>
<tiny-date-panel v-model="value"></tiny-date-panel>
</div>
</template>

<script setup>
import { ref } from 'vue'
import { TinyDatePanel } from '@opentiny/vue'


const value = ref('')
</script>

<style scoped lang="less">
.demo-date-panel-wrap {
width: 560px;

& > * {
margin-top: 12px;
}
}
</style>
20 changes: 20 additions & 0 deletions examples/sites/demos/pc/app/date-panel/custom-week.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
import { test, expect } from '@playwright/test'

test('[DatePanel] 测试周次序号', async ({ page }) => {
page.on('pageerror', (exception) => expect(exception).toBeNull())
await page.goto('date-panel#custom-weeks')

// 选择年份月份日期
await page.getByRole('button', { name: '2025 年' }).click()
await page.getByText('2026').click()
await page.getByText('三月').click()
await expect(page.getByText('12w')).toBeVisible()

// 选择下个月
await page.getByLabel('下个月').click()
await expect(page.getByText('17w')).toBeVisible()

// 选择日期
await page.getByText('23', { exact: true }).click()
await expect(page.getByText('-04-23')).toBeVisible()
})
discreted66 marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
<template>
<div class="demo-date-panel-wrap">
<div>{{ value }}</div>
<tiny-date-panel
ref="datePanel"
v-model="value"
:format-weeks="formatWeeks"
:show-week-number="true"
:first-day-of-week="1"
></tiny-date-panel>
</div>
</template>

<script setup>
import { ref } from 'vue'
import { TinyDatePanel } from '@opentiny/vue'
const value = ref('')
const eachWeekFirstDay = ref([])
const formatWeeks = (customWeeks, weekFirstDays) => {
eachWeekFirstDay.value = weekFirstDays
return customWeeks + 'w'
}
</script>

<style scoped lang="less">
.demo-date-panel-wrap {
width: 560px;
}
</style>
30 changes: 30 additions & 0 deletions examples/sites/demos/pc/app/date-panel/custom-weeks.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
<template>
<div class="demo-date-panel-wrap">
<div>{{ value }}</div>
<tiny-date-panel
ref="datePanel"
v-model="value"
:format-weeks="formatWeeks"
:show-week-number="true"
:first-day-of-week="1"
></tiny-date-panel>
</div>
</template>

<script setup>
import { ref } from 'vue'
import { TinyDatePanel } from '@opentiny/vue'

const value = ref('')
const eachWeekFirstDay = ref([])
const formatWeeks = (customWeeks, weekFirstDays) => {
eachWeekFirstDay.value = weekFirstDays
return customWeeks + 'w'
}
</script>

<style scoped lang="less">
.demo-date-panel-wrap {
width: 560px;
}
</style>
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
<template>
<div class="demo-date-panel-wrap">
<div>{{ value }}</div>
<tiny-date-panel v-model="value" :disabledDate="disabledDate"></tiny-date-panel>
</div>
</template>

<script setup>
import { ref } from 'vue'
import { TinyDatePanel } from '@opentiny/vue'
const value = ref('2025-01-02')
const disabledDate = (val) => {
return val.getFullYear() < 2025
}
discreted66 marked this conversation as resolved.
Show resolved Hide resolved
</script>

<style scoped lang="less">
.demo-date-panel-wrap {
width: 560px;
}
</style>
Loading
Loading