128 lines
3.4 KiB
Vue
128 lines
3.4 KiB
Vue
|
import '../assets/index.less';
|
||
|
import Collapse from '../index';
|
||
|
|
||
|
const text = `
|
||
|
A dog is a type of domesticated animal.
|
||
|
Known for its loyalty and faithfulness,
|
||
|
it can be found as a welcome guest in many households across the world.
|
||
|
`;
|
||
|
|
||
|
function random() {
|
||
|
return parseInt(Math.random() * 10, 10) + 1;
|
||
|
}
|
||
|
|
||
|
const arrowPath =
|
||
|
'M869 487.8L491.2 159.9c-2.9-2.5-6.6-3.9-10.5-3.9h-88' +
|
||
|
'.5c-7.4 0-10.8 9.2-5.2 14l350.2 304H152c-4.4 0-8 3.6-8 8v60c0 4.4 3.' +
|
||
|
'6 8 8 8h585.1L386.9 854c-5.6 4.9-2.2 14 5.2 14h91.5c1.9 0 3.8-0.7 5.' +
|
||
|
'2-2L869 536.2c14.7-12.8 14.7-35.6 0-48.4z';
|
||
|
|
||
|
const { Panel } = Collapse;
|
||
|
export default {
|
||
|
data() {
|
||
|
return {
|
||
|
time: random(),
|
||
|
accordion: false,
|
||
|
activeKey: ['4'],
|
||
|
};
|
||
|
},
|
||
|
methods: {
|
||
|
onChange(activeKey) {
|
||
|
this.activeKey = activeKey;
|
||
|
},
|
||
|
getItems() {
|
||
|
const items = [];
|
||
|
for (let i = 0, len = 3; i < len; i++) {
|
||
|
const key = i + 1;
|
||
|
items.push(
|
||
|
<Panel header={`This is panel header ${key}`} key={String(key)} disabled={i === 0}>
|
||
|
<p>{text.repeat(this.time)}</p>
|
||
|
</Panel>,
|
||
|
);
|
||
|
}
|
||
|
items.push(
|
||
|
<Panel header={`This is panel header 4`} key="4">
|
||
|
<Collapse defaultActiveKey="1" expandIcon={this.expandIcon}>
|
||
|
<Panel header={`This is panel nest panel`} key="1" id="header-test">
|
||
|
<p>{text}</p>
|
||
|
</Panel>
|
||
|
</Collapse>
|
||
|
</Panel>,
|
||
|
);
|
||
|
|
||
|
items.push(
|
||
|
<Panel header={`This is panel header 5`} key="5">
|
||
|
<Collapse defaultActiveKey="1">
|
||
|
<Panel header={`This is panel nest panel`} key="1" id="another-test">
|
||
|
<form>
|
||
|
<label for="test">Name: </label>
|
||
|
<input type="text" id="test" />
|
||
|
</form>
|
||
|
</Panel>
|
||
|
</Collapse>
|
||
|
</Panel>,
|
||
|
);
|
||
|
|
||
|
items.push(
|
||
|
<Panel header={`This is panel header 6`} key="6" extra={<span>Extra Node</span>}>
|
||
|
<p>Panel with extra</p>
|
||
|
</Panel>,
|
||
|
);
|
||
|
|
||
|
return items;
|
||
|
},
|
||
|
setActivityKey() {
|
||
|
this.activeKey = ['2'];
|
||
|
},
|
||
|
reRender() {
|
||
|
this.time = random();
|
||
|
},
|
||
|
toggle() {
|
||
|
this.accordion = !this.accordion;
|
||
|
},
|
||
|
expandIcon({ isActive }) {
|
||
|
return (
|
||
|
<i style={{ marginRight: '.5rem' }}>
|
||
|
<svg
|
||
|
viewBox="0 0 1024 1024"
|
||
|
width="1em"
|
||
|
height="1em"
|
||
|
fill="currentColor"
|
||
|
style={{
|
||
|
verticalAlign: '-.125em',
|
||
|
transition: 'transform .2s',
|
||
|
transform: `rotate(${isActive ? 90 : 0}deg)`,
|
||
|
}}
|
||
|
>
|
||
|
<path d={arrowPath} p-id="5827" />
|
||
|
</svg>
|
||
|
</i>
|
||
|
);
|
||
|
},
|
||
|
},
|
||
|
render() {
|
||
|
const accordion = this.accordion;
|
||
|
const btn = accordion ? 'Mode: accordion' : 'Mode: collapse';
|
||
|
const activeKey = this.activeKey;
|
||
|
return (
|
||
|
<div style={{ margin: '20px', width: '400px' }}>
|
||
|
<button onClick={this.reRender}>reRender</button>
|
||
|
<button onClick={this.toggle}>{btn}</button>
|
||
|
<br />
|
||
|
<br />
|
||
|
<button onClick={this.setActivityKey}>active header 2</button>
|
||
|
<br />
|
||
|
<br />
|
||
|
<Collapse
|
||
|
accordion={accordion}
|
||
|
onChange={this.onChange}
|
||
|
activeKey={activeKey}
|
||
|
expandIcon={this.expandIcon}
|
||
|
>
|
||
|
{this.getItems()}
|
||
|
</Collapse>
|
||
|
</div>
|
||
|
);
|
||
|
},
|
||
|
};
|