561 lines
18 KiB
Vue
561 lines
18 KiB
Vue
<docs>
|
||
---
|
||
order: 2
|
||
title:
|
||
zh-CN: 方向
|
||
en-US: Direction
|
||
---
|
||
|
||
## zh-CN
|
||
|
||
这里列出了支持 `rtl` 方向的组件,您可以在演示中切换方向。
|
||
|
||
## en-US
|
||
|
||
Components which support rtl direction are listed here, you can toggle the direction in the demo.
|
||
|
||
</docs>
|
||
|
||
<template>
|
||
<span style="margin-right: 16px">Change direction of components:</span>
|
||
<a-radio-group v-model:value="state.direction">
|
||
<a-radio-button value="ltr">LTR</a-radio-button>
|
||
<a-radio-button value="rtl">RTL</a-radio-button>
|
||
</a-radio-group>
|
||
<a-divider />
|
||
<a-config-provider :direction="state.direction">
|
||
<a-space direction="vertical" class="direction-components">
|
||
<a-row>
|
||
<a-col :span="24">
|
||
<a-divider orientation="left">Cascader example</a-divider>
|
||
<a-cascader
|
||
:options="cascaderOptions"
|
||
placeholder="یک مورد انتخاب کنید"
|
||
:placement="state.popupPlacement"
|
||
@change="onCascaderChange"
|
||
>
|
||
<template #suffixIcon><SearchIcon /></template>
|
||
</a-cascader>
|
||
With search:
|
||
<a-cascader
|
||
:options="cascaderOptions"
|
||
placeholder="Select an item"
|
||
:placement="state.popupPlacement"
|
||
:show-search="{ filter: cascaderFilter }"
|
||
@change="onCascaderChange"
|
||
>
|
||
<template #suffixIcon><SmileOutlined /></template>
|
||
</a-cascader>
|
||
</a-col>
|
||
</a-row>
|
||
<a-row>
|
||
<a-col :span="12">
|
||
<a-divider orientation="left">Switch example</a-divider>
|
||
<a-space>
|
||
<a-switch default-checked />
|
||
<a-switch loading default-checked />
|
||
<a-switch size="small" loading />
|
||
</a-space>
|
||
</a-col>
|
||
<a-col :span="12">
|
||
<a-divider orientation="left">Radio Group example</a-divider>
|
||
<a-radio-group default-value="c" button-style="solid">
|
||
<a-radio-button value="a">تهران</a-radio-button>
|
||
<a-radio-button value="b" disabled>اصفهان</a-radio-button>
|
||
<a-radio-button value="c">فارس</a-radio-button>
|
||
<a-radio-button value="d">خوزستان</a-radio-button>
|
||
</a-radio-group>
|
||
</a-col>
|
||
</a-row>
|
||
<a-row>
|
||
<a-col :span="12">
|
||
<a-divider orientation="left">Button example</a-divider>
|
||
<div class="button-demo">
|
||
<a-button type="primary">
|
||
<template #icon><DownloadOutlined /></template>
|
||
</a-button>
|
||
<a-button type="primary" shape="circle">
|
||
<template #icon><DownloadOutlined /></template>
|
||
</a-button>
|
||
<a-button type="primary" shape="round">
|
||
<template #icon><DownloadOutlined /></template>
|
||
</a-button>
|
||
<a-button type="primary" shape="round">
|
||
<template #icon><DownloadOutlined /></template>
|
||
Download
|
||
</a-button>
|
||
<a-button type="primary">
|
||
<template #icon><DownloadOutlined /></template>
|
||
Download
|
||
</a-button>
|
||
<br />
|
||
<a-button-group>
|
||
<a-button type="primary">
|
||
<LeftOutlined />
|
||
Backward
|
||
</a-button>
|
||
<a-button type="primary">
|
||
Forward
|
||
<RightOutlined />
|
||
</a-button>
|
||
</a-button-group>
|
||
<a-button type="primary" loading>Loading</a-button>
|
||
<a-button type="primary" size="small" loading>Loading</a-button>
|
||
</div>
|
||
</a-col>
|
||
<a-col :span="12">
|
||
<a-divider orientation="left">Tree example</a-divider>
|
||
<a-tree
|
||
v-model:expandedKeys="expandedKeys"
|
||
v-model:selectedKeys="selectedKeys"
|
||
v-model:checkedKeys="checkedKeys"
|
||
show-line
|
||
checkable
|
||
:tree-data="treeData"
|
||
>
|
||
<template #title="{ title, key }">
|
||
<span v-if="key === '0-0-1-0'" style="color: #1890ff">{{ title }}</span>
|
||
<template v-else>{{ title }}</template>
|
||
</template>
|
||
</a-tree>
|
||
</a-col>
|
||
</a-row>
|
||
<a-row>
|
||
<a-col :span="24">
|
||
<a-divider orientation="left">Input (Input Group) example</a-divider>
|
||
<a-space direction="vertical" style="width: 100%">
|
||
<a-input-group size="large">
|
||
<a-row :gutter="8">
|
||
<a-col :span="5">
|
||
<a-input default-value="0571" />
|
||
</a-col>
|
||
<a-col :span="8">
|
||
<a-input default-value="26888888" />
|
||
</a-col>
|
||
</a-row>
|
||
</a-input-group>
|
||
<a-input-group compact>
|
||
<a-input style="width: 20%" default-value="0571" />
|
||
<a-input style="width: 30%" default-value="26888888" />
|
||
</a-input-group>
|
||
<a-input-group compact>
|
||
<a-select default-value="Option1">
|
||
<a-select-option value="Option1">Option1</a-select-option>
|
||
<a-select-option value="Option2">Option2</a-select-option>
|
||
</a-select>
|
||
<a-input style="width: 50%" default-value="input content" />
|
||
<a-inputNumber />
|
||
</a-input-group>
|
||
<a-input-search placeholder="input search text" enter-button="Search" size="large" />
|
||
<div style="margin-bottom: 16px">
|
||
<a-input default-value="mysite">
|
||
<template #selectBefore>
|
||
<a-select default-value="Http://" style="width: 90px">
|
||
<a-select-option value="Http://">Http://</a-select-option>
|
||
<a-select-option value="Https://">Https://</a-select-option>
|
||
</a-select>
|
||
</template>
|
||
<template #selectAfter>
|
||
<a-select default-value=".com" style="width: 80px">
|
||
<a-select-option value=".com">.com</a-select-option>
|
||
<a-select-option value=".jp">.jp</a-select-option>
|
||
<a-select-option value=".cn">.cn</a-select-option>
|
||
<a-select-option value=".org">.org</a-select-option>
|
||
</a-select>
|
||
</template>
|
||
</a-input>
|
||
</div>
|
||
<a-row>
|
||
<a-col :span="12">
|
||
<a-divider orientation="left">Select example</a-divider>
|
||
<a-space wrap>
|
||
<a-select mode="multiple" default-value="مورچه" style="width: 120px">
|
||
<a-select-option value="jack">Jack</a-select-option>
|
||
<a-select-option value="مورچه">مورچه</a-select-option>
|
||
<a-select-option value="disabled" disabled>Disabled</a-select-option>
|
||
<a-select-option value="Yiminghe">yiminghe</a-select-option>
|
||
</a-select>
|
||
<a-select default-value="مورچه" style="width: 120px" disabled>
|
||
<a-select-option value="مورچه">مورچه</a-select-option>
|
||
</a-select>
|
||
<a-select default-value="مورچه" style="width: 120px" loading>
|
||
<a-select-option value="مورچه">مورچه</a-select-option>
|
||
</a-select>
|
||
<a-select
|
||
show-search
|
||
style="width: 200px"
|
||
placeholder="Select a person"
|
||
option-filter-prop="children"
|
||
:filter-option="
|
||
(input, option) =>
|
||
option.props.children.toLowerCase().indexOf(input.toLowerCase()) >= 0
|
||
"
|
||
>
|
||
<a-select-option value="jack">Jack</a-select-option>
|
||
<a-select-option value="سعید">سعید</a-select-option>
|
||
<a-select-option value="tom">Tom</a-select-option>
|
||
</a-select>
|
||
</a-space>
|
||
</a-col>
|
||
<a-col :span="12">
|
||
<a-divider orientation="left">TreeSelect example</a-divider>
|
||
<div>
|
||
<a-tree-select
|
||
show-search
|
||
style="width: 100%"
|
||
:dropdown-style="{ maxHeight: '400px', overflow: 'auto' }"
|
||
placeholder="Please select"
|
||
allow-clear
|
||
tree-default-expand-all
|
||
:tree-data="treeSelectData"
|
||
></a-tree-select>
|
||
</div>
|
||
</a-col>
|
||
</a-row>
|
||
<a-row>
|
||
<a-col :span="24">
|
||
<a-divider orientation="left">Modal example</a-divider>
|
||
<div>
|
||
<a-button type="primary" @click="showModal">Open Modal</a-button>
|
||
<a-modal v-model:open="state.modalVisible" title="پنچره ساده">
|
||
<p>نگاشتههای خود را اینجا قراردهید</p>
|
||
<p>نگاشتههای خود را اینجا قراردهید</p>
|
||
<p>نگاشتههای خود را اینجا قراردهید</p>
|
||
</a-modal>
|
||
</div>
|
||
</a-col>
|
||
</a-row>
|
||
<a-row>
|
||
<a-col :span="24">
|
||
<a-divider orientation="left">Steps example</a-divider>
|
||
<div>
|
||
<a-steps
|
||
progress-dot
|
||
:current="state.currentStep"
|
||
:items="[
|
||
{
|
||
title: 'Finished',
|
||
description: 'This is a description.',
|
||
},
|
||
{
|
||
title: 'In Progress',
|
||
description: 'This is a description.',
|
||
},
|
||
{
|
||
title: 'Waiting',
|
||
description: 'This is a description.',
|
||
},
|
||
]"
|
||
></a-steps>
|
||
<br />
|
||
<a-steps
|
||
:current="state.currentStep"
|
||
:items="[
|
||
{
|
||
title: 'Step 1',
|
||
description: 'This is a description.',
|
||
},
|
||
{
|
||
title: 'Step 2',
|
||
description: 'This is a description.',
|
||
},
|
||
{
|
||
title: 'Step 3',
|
||
description: 'This is a description.',
|
||
},
|
||
]"
|
||
@change="onStepsChange"
|
||
></a-steps>
|
||
</div>
|
||
</a-col>
|
||
</a-row>
|
||
<a-row>
|
||
<a-col :span="12">
|
||
<a-divider orientation="left">Rate example</a-divider>
|
||
<div>
|
||
<a-rate v-model:value="rateValue" />
|
||
<br />
|
||
<strong>* Note:</strong>
|
||
Half star not implemented in RTL direction.
|
||
</div>
|
||
</a-col>
|
||
<a-col :span="12">
|
||
<a-divider orientation="left">Badge example</a-divider>
|
||
<div>
|
||
<div>
|
||
<a-badge :count="state.badgeCount">
|
||
<a href="#" class="head-example" />
|
||
</a-badge>
|
||
<a-button-group>
|
||
<a-button @click="declineBadge">
|
||
<MinusOutlined />
|
||
</a-button>
|
||
<a-button @click="increaseBadge">
|
||
<PlusOutlined />
|
||
</a-button>
|
||
</a-button-group>
|
||
</div>
|
||
<div style="margin-top: 10px">
|
||
<a-badge :dot="state.showBadge">
|
||
<a href="#" class="head-example" />
|
||
</a-badge>
|
||
<a-switch :checked="state.showBadge" @change="onChangeBadge" />
|
||
</div>
|
||
</div>
|
||
</a-col>
|
||
</a-row>
|
||
</a-space>
|
||
</a-col>
|
||
</a-row>
|
||
<a-row>
|
||
<a-col :span="24">
|
||
<a-divider orientation="left">Pagination example</a-divider>
|
||
<a-pagination show-size-changer :default-current="3" :total="500" />
|
||
</a-col>
|
||
</a-row>
|
||
<a-row>
|
||
<a-col :span="24">
|
||
<a-divider orientation="left">Grid System example</a-divider>
|
||
<div class="grid-demo">
|
||
<div class="code-box-demo">
|
||
<p>
|
||
<strong>* Note:</strong>
|
||
Every calculation in RTL grid system is from right side (offset, push, etc.)
|
||
</p>
|
||
<a-row>
|
||
<a-col :span="8">col-8</a-col>
|
||
<a-col :span="8" :offset="8">col-8</a-col>
|
||
</a-row>
|
||
<a-row>
|
||
<a-col :span="6" :offset="6">col-6 col-offset-6</a-col>
|
||
<a-col :span="6" :offset="6">col-6 col-offset-6</a-col>
|
||
</a-row>
|
||
<a-row>
|
||
<a-col :span="12" :offset="6">col-12 col-offset-6</a-col>
|
||
</a-row>
|
||
<a-row>
|
||
<a-col :span="18" :push="6">col-18 col-push-6</a-col>
|
||
<a-col :span="6" :pull="18">col-6 col-pull-18</a-col>
|
||
</a-row>
|
||
</div>
|
||
</div>
|
||
</a-col>
|
||
</a-row>
|
||
</a-space>
|
||
</a-config-provider>
|
||
</template>
|
||
<script lang="ts" setup>
|
||
import { reactive, watch, ref } from 'vue';
|
||
|
||
import {
|
||
SearchOutlined as SearchIcon,
|
||
SmileOutlined,
|
||
DownloadOutlined,
|
||
LeftOutlined,
|
||
RightOutlined,
|
||
MinusOutlined,
|
||
PlusOutlined,
|
||
} from '@ant-design/icons-vue';
|
||
import type { TreeProps, TreeSelectProps, CascaderProps } from 'ant-design-vue';
|
||
|
||
const state = reactive({
|
||
currentStep: 0,
|
||
modalVisible: false,
|
||
|
||
badgeCount: 5,
|
||
showBadge: true,
|
||
direction: 'ltr' as 'ltr' | 'rtl',
|
||
popupPlacement: 'bottomLeft' as CascaderProps['placement'],
|
||
});
|
||
const expandedKeys = ref<string[]>(['0-0-0', '0-0-1']);
|
||
const selectedKeys = ref<string[]>(['0-0-0', '0-0-1']);
|
||
const checkedKeys = ref<string[]>(['0-0-0', '0-0-1']);
|
||
|
||
const treeData: TreeProps['treeData'] = [
|
||
{
|
||
title: 'parent 1',
|
||
key: '0-0',
|
||
children: [
|
||
{
|
||
title: 'parent 1-0',
|
||
key: '0-0-0',
|
||
disabled: true,
|
||
children: [
|
||
{ title: 'leaf', key: '0-0-0-0', disableCheckbox: true },
|
||
{ title: 'leaf', key: '0-0-0-1' },
|
||
],
|
||
},
|
||
{
|
||
title: 'parent 1-1',
|
||
key: '0-0-1',
|
||
children: [{ key: '0-0-1-0', title: 'sss' }],
|
||
},
|
||
],
|
||
},
|
||
];
|
||
|
||
const treeSelectData = ref<TreeSelectProps['treeData']>([
|
||
{
|
||
title: 'parent 1',
|
||
value: 'parent 1',
|
||
children: [
|
||
{
|
||
title: 'parent 1-0',
|
||
value: 'parent 1-0',
|
||
children: [
|
||
{
|
||
title: 'my leaf',
|
||
value: 'leaf1',
|
||
},
|
||
{
|
||
title: 'your leaf',
|
||
value: 'leaf2',
|
||
},
|
||
],
|
||
},
|
||
{
|
||
title: 'parent 1-1',
|
||
value: 'parent 1-1',
|
||
},
|
||
],
|
||
},
|
||
]);
|
||
watch(
|
||
() => state.direction,
|
||
directionValue => {
|
||
if (directionValue === 'rtl') {
|
||
state.popupPlacement = 'bottomRight';
|
||
} else {
|
||
state.popupPlacement = 'bottomLeft';
|
||
}
|
||
},
|
||
);
|
||
const cascaderOptions = [
|
||
{
|
||
value: 'tehran',
|
||
label: 'تهران',
|
||
children: [
|
||
{
|
||
value: 'tehran-c',
|
||
label: 'تهران',
|
||
children: [
|
||
{
|
||
value: 'saadat-abad',
|
||
label: 'سعادت آیاد',
|
||
},
|
||
],
|
||
},
|
||
],
|
||
},
|
||
{
|
||
value: 'ardabil',
|
||
label: 'اردبیل',
|
||
children: [
|
||
{
|
||
value: 'ardabil-c',
|
||
label: 'اردبیل',
|
||
children: [
|
||
{
|
||
value: 'primadar',
|
||
label: 'پیرمادر',
|
||
},
|
||
],
|
||
},
|
||
],
|
||
},
|
||
{
|
||
value: 'gilan',
|
||
label: 'گیلان',
|
||
children: [
|
||
{
|
||
value: 'rasht',
|
||
label: 'رشت',
|
||
children: [
|
||
{
|
||
value: 'district-3',
|
||
label: 'منطقه ۳',
|
||
},
|
||
],
|
||
},
|
||
],
|
||
},
|
||
];
|
||
|
||
// ==== Cascader ====
|
||
const cascaderFilter = (inputValue, path) =>
|
||
path.some(option => option.label.toLowerCase().indexOf(inputValue.toLowerCase()) > -1);
|
||
|
||
const onCascaderChange = value => {
|
||
console.log(value);
|
||
};
|
||
// ==== End Cascader ====
|
||
|
||
// ==== Modal ====
|
||
const showModal = () => {
|
||
state.modalVisible = true;
|
||
};
|
||
|
||
// ==== End Modal ====
|
||
|
||
const onStepsChange = currentStep => {
|
||
console.log('onChange:', currentStep);
|
||
state.currentStep = currentStep;
|
||
};
|
||
|
||
// ==== Badge ====
|
||
|
||
const increaseBadge = () => {
|
||
const badgeCount = state.badgeCount + 1;
|
||
state.badgeCount = badgeCount;
|
||
};
|
||
|
||
const declineBadge = () => {
|
||
let badgeCount = state.badgeCount - 1;
|
||
if (badgeCount < 0) {
|
||
badgeCount = 0;
|
||
}
|
||
state.badgeCount = badgeCount;
|
||
};
|
||
|
||
const onChangeBadge = showBadge => {
|
||
state.showBadge = showBadge;
|
||
};
|
||
const rateValue = ref(2);
|
||
</script>
|
||
<style lang="less" scoped>
|
||
.direction-components {
|
||
width: 100%;
|
||
.button-demo .ant-btn,
|
||
.button-demo .ant-btn-group {
|
||
margin-right: 8px;
|
||
margin-bottom: 12px;
|
||
}
|
||
.button-demo .ant-btn-group > .ant-btn,
|
||
.button-demo .ant-btn-group > span > .ant-btn {
|
||
margin-right: 0;
|
||
margin-left: 0;
|
||
}
|
||
|
||
.head-example {
|
||
display: inline-block;
|
||
width: 42px;
|
||
height: 42px;
|
||
vertical-align: middle;
|
||
background: #eee;
|
||
border-radius: 4px;
|
||
}
|
||
|
||
.ant-badge:not(.ant-badge-not-a-wrapper) {
|
||
margin-right: 20px;
|
||
}
|
||
.ant-badge-rtl:not(.ant-badge-not-a-wrapper) {
|
||
margin-right: 0;
|
||
margin-left: 20px;
|
||
}
|
||
}
|
||
|
||
[data-theme='dark'] .head-example {
|
||
background: rgba(255, 255, 255, 0.12);
|
||
}
|
||
</style>
|