doc: update demo ts error

pull/4936/head
tangjinzhou 2022-01-12 23:51:18 +08:00
parent 239354e313
commit 10fed707f8
11 changed files with 59 additions and 164 deletions

View File

@ -34,7 +34,7 @@ If you need several buttons, we recommend that you use 1 primary button + n seco
</template> </template>
<script lang="ts"> <script lang="ts">
import { DownOutlined } from '@ant-design/icons-vue'; import { DownOutlined } from '@ant-design/icons-vue';
import { MenuProps } from 'ant-design-vue'; import type { MenuProps } from 'ant-design-vue';
import { defineComponent } from 'vue'; import { defineComponent } from 'vue';
export default defineComponent({ export default defineComponent({
components: { components: {

View File

@ -34,7 +34,7 @@ The default is to close the menu when you click on menu items, this feature can
<script lang="ts"> <script lang="ts">
import { defineComponent, ref } from 'vue'; import { defineComponent, ref } from 'vue';
import { DownOutlined } from '@ant-design/icons-vue'; import { DownOutlined } from '@ant-design/icons-vue';
import { MenuProps } from 'ant-design-vue'; import type { MenuProps } from 'ant-design-vue';
export default defineComponent({ export default defineComponent({
components: { components: {

View File

@ -26,7 +26,7 @@ exports[`Modal render correctly 1`] = `
exports[`Modal render correctly 2`] = ` exports[`Modal render correctly 2`] = `
<div> <div>
<div></div> <div style="overflow: hidden; overflow-x: hidden; overflow-y: hidden;" class="ant-scrolling-effect"></div>
<div class="ant-modal-root"> <div class="ant-modal-root">
<div class="ant-modal-mask"></div> <div class="ant-modal-mask"></div>
<div tabindex="-1" class="ant-modal-wrap" role="dialog"> <div tabindex="-1" class="ant-modal-wrap" role="dialog">

View File

@ -34,11 +34,12 @@ For long tableneed to scroll to view the header and scroll barthen you can
</template> </template>
<script lang="ts"> <script lang="ts">
import type { TableColumnsType } from 'ant-design-vue';
import { defineComponent, ref } from 'vue'; import { defineComponent, ref } from 'vue';
export default defineComponent({ export default defineComponent({
setup() { setup() {
const columns = ref([ const columns = ref<TableColumnsType>([
{ {
title: 'Full Name', title: 'Full Name',
width: 100, width: 100,

View File

@ -19,7 +19,7 @@ Only card type Tabs support adding & closable.
<template> <template>
<a-tabs v-model:activeKey="activeKey" type="editable-card" @edit="onEdit"> <a-tabs v-model:activeKey="activeKey" type="editable-card" @edit="onEdit">
<a-tab-pane v-for="pane in panes" :key="pane.key" :tab="pane.title" :closable="!!pane.closable"> <a-tab-pane v-for="pane in panes" :key="pane.key" :tab="pane.title" :closable="pane.closable">
{{ pane.content }} {{ pane.content }}
</a-tab-pane> </a-tab-pane>
</a-tabs> </a-tabs>

View File

@ -51,9 +51,9 @@ Customize render list with Tree component.
</template> </template>
<script lang="ts"> <script lang="ts">
import { computed, defineComponent, ref } from 'vue'; import { computed, defineComponent, ref } from 'vue';
import type { TreeProps } from 'ant-design-vue'; import type { TransferProps, TreeProps } from 'ant-design-vue';
import type { AntTreeNodeCheckedEvent } from 'ant-design-vue/es/tree'; import type { AntTreeNodeCheckedEvent } from 'ant-design-vue/es/tree';
const tData: TreeProps['treeData'] = [ const tData: TransferProps['dataSource'] = [
{ key: '0-0', title: '0-0' }, { key: '0-0', title: '0-0' },
{ {
key: '0-1', key: '0-1',
@ -66,8 +66,8 @@ const tData: TreeProps['treeData'] = [
{ key: '0-2', title: '0-3' }, { key: '0-2', title: '0-3' },
]; ];
const transferDataSource: TreeProps['treeData'] = []; const transferDataSource: TransferProps['dataSource'] = [];
function flatten(list: TreeProps['treeData'] = []) { function flatten(list: TransferProps['dataSource'] = []) {
list.forEach(item => { list.forEach(item => {
transferDataSource.push(item); transferDataSource.push(item);
flatten(item.children); flatten(item.children);
@ -79,26 +79,23 @@ function isChecked(selectedKeys: (string | number)[], eventKey: string | number)
return selectedKeys.indexOf(eventKey) !== -1; return selectedKeys.indexOf(eventKey) !== -1;
} }
function handleTreeData( function handleTreeData(data: TransferProps['dataSource'], targetKeys: string[] = []) {
data: TreeProps['treeData'],
targetKeys: string[] = [],
): TreeProps['treeData'] {
data.forEach(item => { data.forEach(item => {
item['disabled'] = targetKeys.includes(item.key as any); item['disabled'] = targetKeys.includes(item.key as any);
if (item.children) { if (item.children) {
handleTreeData(item.children, targetKeys); handleTreeData(item.children, targetKeys);
} }
}); });
return data; return data as TreeProps['treeData'];
} }
export default defineComponent({ export default defineComponent({
setup() { setup() {
const targetKeys = ref<string[]>([]); const targetKeys = ref<string[]>([]);
const dataSource = ref<TreeProps['treeData']>(transferDataSource); const dataSource = ref(transferDataSource);
const treeData = computed<TreeProps['treeData']>(() => { const treeData = computed(() => {
return handleTreeData(tData, targetKeys.value); return handleTreeData(tData, targetKeys.value);
}); });

View File

@ -38,8 +38,8 @@ export default defineComponent({
{ title: 'Expand to load', key: '1' }, { title: 'Expand to load', key: '1' },
{ title: 'Tree Node', key: '2', isLeaf: true }, { title: 'Tree Node', key: '2', isLeaf: true },
]); ]);
const onLoadData = (treeNode: any) => { const onLoadData: TreeProps['loadData'] = treeNode => {
return new Promise((resolve: (value?: unknown) => void) => { return new Promise(resolve => {
if (treeNode.dataRef.children) { if (treeNode.dataRef.children) {
resolve(); resolve();
return; return;

View File

@ -2,127 +2,55 @@
--- ---
order: 0 order: 0
title: title:
en-US: Basic Usage
zh-CN: 基本用法 zh-CN: 基本用法
en-US: Basic usage
--- ---
## zh-CN ## zh-CN
简单的表格最后一列是各种操作 第一个对话框
## en-US ## en-US
Simple table with actions. Basic modal.
</docs> </docs>
<template> <template>
<a-table :columns="columns" :data-source="data"> <div>
<template #headerCell="{ title, column }"> <div ref="container"></div>
<template v-if="column.key === 'name'"> <a-button type="primary" @click="showModal">Open Modal</a-button>
<span> <a-modal v-model:visible="visible" title="Basic Modal" @ok="handleOk">
<smile-outlined /> <p>Some contents...</p>
Name <p>Some contents...</p>
</span> <p>Some contents...</p>
</template> </a-modal>
<template v-else>{{ title }}</template> </div>
</template>
<template #bodyCell="{ column, record }">
<template v-if="column.key === 'name'">
<a>
{{ record.name }}
</a>
</template>
<template v-else-if="column.key === 'tags'">
<span>
<a-tag
v-for="tag in record.tags"
:key="tag"
:color="tag === 'loser' ? 'volcano' : tag.length > 5 ? 'geekblue' : 'green'"
>
{{ tag.toUpperCase() }}
</a-tag>
</span>
</template>
<template v-else-if="column.key === 'action'">
<span>
<a>Invite {{ record.name }}</a>
<a-divider type="vertical" />
<a>Delete</a>
<a-divider type="vertical" />
<a class="ant-dropdown-link">
More actions
<down-outlined />
</a>
</span>
</template>
<template v-else>{{ record.name }}</template>
</template>
</a-table>
</template> </template>
<script lang="ts"> <script lang="ts">
import { SmileOutlined, DownOutlined } from '@ant-design/icons-vue'; import { defineComponent, ref } from 'vue';
import { defineComponent } from 'vue';
const columns = [
{
name: 'Name',
dataIndex: 'name',
key: 'name',
},
{
title: 'Age',
dataIndex: 'age',
key: 'age',
},
{
title: 'Address',
dataIndex: 'address',
key: 'address',
},
{
title: 'Tags',
key: 'tags',
dataIndex: 'tags',
},
{
title: 'Action',
key: 'action',
},
];
const data = [
{
key: '1',
name: 'John Brown',
age: 32,
address: 'New York No. 1 Lake Park',
tags: ['nice', 'developer'],
},
{
key: '2',
name: 'Jim Green',
age: 42,
address: 'London No. 1 Lake Park',
tags: ['loser'],
},
{
key: '3',
name: 'Joe Black',
age: 32,
address: 'Sidney No. 1 Lake Park',
tags: ['cool', 'teacher'],
},
];
export default defineComponent({ export default defineComponent({
components: {
SmileOutlined,
DownOutlined,
},
setup() { setup() {
const visible = ref<boolean>(false);
const showModal = () => {
visible.value = true;
};
const handleOk = (e: MouseEvent) => {
console.log(e);
visible.value = false;
};
const container = ref();
return { return {
data, container,
columns, visible,
showModal,
handleOk,
getContainer() {
console.log('container', container.value);
return container.value;
},
}; };
}, },
}); });

View File

@ -1,31 +0,0 @@
<template>
<div class="markdown api-container">
<google-ads v-if="showAd" />
<slot v-if="isZhCN" name="cn" />
<slot v-else />
</div>
</template>
<script lang="ts">
import { isZhCN } from '../utils/util';
import GoogleAds from './rice/GoogleAds.vue';
import { inject } from 'vue';
const showAd = location.host.indexOf('antdv.com') > -1;
export default {
name: 'Api',
components: {
GoogleAds,
},
setup() {
return {
demoContext: inject('demoContext', {}),
};
},
data() {
return {
showAd,
isZhCN: isZhCN(this.demoContext.name),
};
},
};
</script>

View File

@ -10,7 +10,6 @@ export default defineComponent({
}, },
setup() { setup() {
return { return {
demoContext: inject('demoContext', {}),
globalConfig: inject(GLOBAL_CONFIG), globalConfig: inject(GLOBAL_CONFIG),
}; };
}, },

View File

@ -16,25 +16,26 @@
<script lang="ts"> <script lang="ts">
import dayjs from 'dayjs'; import dayjs from 'dayjs';
import isBetween from 'dayjs/plugin/isBetween'; import isBetween from 'dayjs/plugin/isBetween';
import { defineComponent } from 'vue';
dayjs.extend(isBetween); dayjs.extend(isBetween);
export default { export default defineComponent({
props: ['isMobile'], props: {
data() { isMobile: Boolean,
},
setup() {
return { return {
visible: true, visible: true,
effectiveTime: { effectiveTime: {
start: '2019-08-05 17:00:00', start: '2019-08-05 17:00:00',
end: '2019-09-05 17:00:00', end: '2019-09-05 17:00:00',
}, },
};
},
methods: {
isEffective({ start, end }) { isEffective({ start, end }) {
return dayjs().isBetween(start, end); return dayjs().isBetween(start, end);
}, },
};
}, },
}; });
</script> </script>
<style lang="less" scoped> <style lang="less" scoped>