From 20dae8f33e284280490dbb8e88a8070e49d6ad49 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=BD=AC=E4=BA=8C?= Date: Mon, 25 Sep 2017 21:12:43 +0800 Subject: [PATCH] feat: Add option for component: 'mention' --- components/mention/demo/placement.md | 37 ++++++++++++++++++++++++++++ components/mention/index.tsx | 7 +++++- components/mention/style/index.less | 4 +++ package.json | 2 +- 4 files changed, 48 insertions(+), 2 deletions(-) create mode 100644 components/mention/demo/placement.md diff --git a/components/mention/demo/placement.md b/components/mention/demo/placement.md new file mode 100644 index 0000000000..63aa421797 --- /dev/null +++ b/components/mention/demo/placement.md @@ -0,0 +1,37 @@ +--- +order: 0 +title: + zh-CN: 向上展开 + en-US: Expand up +--- + +## zh-CN + +向上展开建议。 + +## en-US + +Expand the suggestions up. + +````jsx +import { Mention } from 'antd'; +const { toString } = Mention; + +function onChange(contentState) { + console.log(toString(contentState)); +} + +function onSelect(suggestion) { + console.log('onSelect', suggestion); +} + +ReactDOM.render( + +, mountNode); +```` diff --git a/components/mention/index.tsx b/components/mention/index.tsx index d3cd502b0d..846d866e31 100644 --- a/components/mention/index.tsx +++ b/components/mention/index.tsx @@ -4,6 +4,8 @@ import classNames from 'classnames'; import shallowequal from 'shallowequal'; import Icon from '../icon'; +export type MentionPlacement = 'top' | 'bottom'; + export interface MentionProps { prefixCls?: string; suggestionStyle?: React.CSSProperties; @@ -24,6 +26,7 @@ export interface MentionProps { onBlur?: Function; readOnly?: boolean; disabled?: boolean; + placement?: MentionPlacement; } export interface MentionState { @@ -38,6 +41,7 @@ export default class Mention extends React.Component notFoundContent: '无匹配结果,轻敲空格完成输入', loading: false, multiLines: false, + placement: 'bottom', }; static Nav = Nav; static toString = toString; @@ -117,10 +121,11 @@ export default class Mention extends React.Component this.mentionEle = ele; } render() { - const { className = '', prefixCls, loading } = this.props; + const { className = '', prefixCls, loading, placement } = this.props; const { suggestions, focus } = this.state; const cls = classNames(className, { [`${prefixCls}-active`]: focus, + [`${prefixCls}-placement-top`]: placement === 'top', }); const notFoundContent = loading diff --git a/components/mention/style/index.less b/components/mention/style/index.less index 371a74c1ac..08507283cf 100644 --- a/components/mention/style/index.less +++ b/components/mention/style/index.less @@ -61,6 +61,10 @@ overflow-x: hidden; overflow-y: auto; + &-placement-top { + margin-top: -0.1em; + } + &-notfound&-item { color: @disabled-color; diff --git a/package.json b/package.json index dad2ae6847..2d94eeccc1 100644 --- a/package.json +++ b/package.json @@ -56,7 +56,7 @@ "rc-collapse": "~1.7.5", "rc-dialog": "~6.5.10", "rc-dropdown": "~1.5.0", - "rc-editor-mention": "~0.6.12", + "rc-editor-mention": "^1.0.2", "rc-form": "~1.4.0", "rc-input-number": "~3.6.0", "rc-menu": "~5.1.0",