2022-01-21 13:58:10 +00:00
|
|
|
|
import { getSeparatedContent } from './utils/valueUtil';
|
|
|
|
|
import type { RefTriggerProps } from './SelectTrigger';
|
|
|
|
|
import SelectTrigger from './SelectTrigger';
|
|
|
|
|
import type { RefSelectorProps } from './Selector';
|
|
|
|
|
import Selector from './Selector';
|
|
|
|
|
import useSelectTriggerControl from './hooks/useSelectTriggerControl';
|
|
|
|
|
import useDelayReset from './hooks/useDelayReset';
|
|
|
|
|
import TransBtn from './TransBtn';
|
|
|
|
|
import useLock from './hooks/useLock';
|
|
|
|
|
import type { BaseSelectContextProps } from './hooks/useBaseProps';
|
|
|
|
|
import { useProvideBaseSelectProps } from './hooks/useBaseProps';
|
|
|
|
|
import type { Key, VueNode } from '../_util/type';
|
|
|
|
|
import type {
|
|
|
|
|
FocusEventHandler,
|
|
|
|
|
KeyboardEventHandler,
|
|
|
|
|
MouseEventHandler,
|
|
|
|
|
} from '../_util/EventInterface';
|
2022-04-23 05:28:00 +00:00
|
|
|
|
import type { ScrollConfig, ScrollTo } from '../vc-virtual-list/List';
|
2022-01-21 13:58:10 +00:00
|
|
|
|
import {
|
|
|
|
|
computed,
|
|
|
|
|
defineComponent,
|
|
|
|
|
getCurrentInstance,
|
|
|
|
|
onBeforeUnmount,
|
|
|
|
|
onMounted,
|
|
|
|
|
provide,
|
Feat v4 (#6329)
* refactor(icon): remove style dir (#6215)
* refactor: rename locale
* refactor: locale-provider
* refactor: modal
* refactor: menu
* fix: custom class (#6217)
* refactor: tooltip
* refactor: grid (#6220)
* refactor: grid
* fix(grid): align & justify responsive
* chore: update demo and snapshot
* fix: row ts type not work
* doc: update demo
* refactor: ts
* refactor: spin (#6222)
* fix: typo (#6218)
* fix: typo
* docs<upload>: docs update
* refactor: spin
* refactor: spin
* refactor: spin
* refactor: spinnn
* refactor: spin
---------
Co-authored-by: lyn <76365499@qq.com>
* fix: spin error #6222
* test: test case error (#6225)
* fix: inject value maybe undefined
* fix: tootip emit correct value
* fix: rollback warning suffix avoid test break
* doc(grid): remove unused type="flex"
* refactor: skeleton (#6224)
* refactor: skeleton
* refactor: skeleton style
* chore: modify skeleton demo style
* fix(button): link and text should not have wave (#6226)
* refactor: dropdown
* refactor: popover & popconfirm
* refactor(tag): less to cssinjs (#6227)
* refactor(empty): less to cssinjs (#6230)
* refactor(empty): less to cssinjs
* chore: remove unuse code
* fix: reactivity lose
* fix: empty props #6230
* refactor: progress style (#6234)
* refactor: progress
* refactor: progress style
* fix: progress attrs
* refactor: progress #6234
* refactor: switch (#6236)
* refactor: switch style
* refactor: delete switch style
* refactor:input (#6237)
* refactor:input
* fix inheritAttrs:false
* fix attrs.class
* feat: input add disabled
* refactor:comment (#6238)
* refactor:comment
* fix inheritAttrs: false & attrs.class
* refactor:pageheader (#6239)
* refactor:pageheader
* fix inheritAttrs: false & attrs.class
* refactor:statistic (#6240)
* refactor:statistic
* fix inheritAttrs: false & attrs.class
* refactor:list (#6241)
* refactor:list
* fix inheritAttrs: false & attrs.class
* feat: update type
* refactor(Space): less to cssinjs & add compact mode (#6229)
* refactor(Space): less to cssinjs & add compact mode
* chore(space): update md
* chore(space): add demo
* chore(space): add some demo
* feat(button): add compact mode
* fix: reactivity lose
* docs: fix props version
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* perf: space compact
* refactor:typography (#6244)
* refactor:typography
* fix return
* fix import type
* fix: typography #6244
* refactor:datepicker (#6245)
* refactor: datepicker type
* refactor: rate style (#6254)
* refactor(layout): less to cssinjs (#6249)
* doc: update layout cover
* refactor(result): less to cssinjs (#6246)
* refactor(result): less to cssinjs
* fix: class name is overridden
* docs: update result cover
* refactor:slider (#6250)
* feat: slider deprecated tooltipVisible
* refactor(crad): less to cssinjs (#6258)
* update
* switch
* Style adjustment
* refactor(Card): less to cssinjs
* Eliminate invalid code
* optimization and adjustment css
* Adjust the css
* Optimize each item
* adjustment css
* refactor: card #6258
* refactor:carousel (#6262)
* refactor:carousel
* docs:update & refactor: carousel type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor:transfer (#6247)
* refactor:transfer
* merge v4 branch & fix theme interface conflict
* docs:update & refactor: transfer type
* perf: transfer
* refactor:checkbox (#6248)
* refactor:checkbox
* docs:update & refactor: checkbox type
* feat: checkbox add disabled context
* refactor:pagination (#6251)
* refactor:pagination
* docs:update & refactor: pagination type
* style: update pagination props type
* refactor: mentions (#6255)
* refactor: mentions
* refactor: mentions menu provider
* doc: update mentions demo
* refcator:upload (#6261)
* refcator:upload
* docs:update & refactor: upload type
* Update style.ts
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* perf: upload motion
* refactor:timeline (#6263)
* refactor:timeline
* docs:update & refactor: timeline type
* perf: timeline
* refactor:steps (#6264)
* refactor:steps
* fix ...attrs
* fix StepsToken error
* docs:update & refactor: steps type
* fix: steps icon clss error
* refactor:collapse (#6266)
* refactor:collapse
* fix collapse props version
* docs:update & refactor: collapse type & fix collapsible
* feat: update collapse type
* refactor:inputnumber (#6265)
* refactor:inputnumber
* docs:update & refactor: inputnumber type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: number add compactSize & disabledContext
* refactor:table (#6267)
* refactor:table
* docs:update & refactor: table type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor: table
* feat: table add expandColumnTitle slot
* refactor:calendar (#6269)
* refactor:calendar
* docs:update
* refactor:timepicker (#6270)
* refactor:timepicker
* docs:update & refactor: timepicker type
* refactor:tree (#6276)
* Feat v4 fix type errors (#6285)
* fix compile type errors
* fix menuprops type import
* fix lint errors
* fix lint errors
* fix format error
* fix node version
* fix run dist error
* fix run lint
* fix as any
* fix string type
* refactor: rename locale file
* feat: tree add leafIcon
* [tabs] :less to cssinjs (#6288)
* update
* switch
* Style adjustment
* refactor(Card): less to cssinjs
* tabs: less to cssinjs 开发ing
* add function cssinjs
* Eliminate irrelevant code
* Eliminate irrelevant code 2
* update components
* Eliminate irrelevant input code
* refactor: tabs #6288
* feat: add segmented (#6286)
* refactor: segmented #6286
* refactor:select (#6295)
* refactor:select
* update doc
* delete useless
* feat: select add context size
* refactor: tree select (#6296)
* feat: tree-select add context size
* perf: table
* docs: update doc toc
* refactor: cascader
* refactor: auto-complete
* refactor: image
* refactor: drawer
* refactor:radio (#6299)
* refactor:radio
* fix attrs
* feat: radio add disabled context
* fix: some type & doc (#6292)
* fix: typo (#6218)
* fix: typo
* docs<upload>: docs update
* fix: type of minute in props disabledDateTime of DatePicker (#6233)
* docs: typo (#6256)
* feat: tooltip added overlayInnerStyle attribute
* Update abstractTooltipProps.ts
* Update Tooltip.tsx
---------
Co-authored-by: lyn <76365499@qq.com>
Co-authored-by: H1mple <35363759+baohangxing@users.noreply.github.com>
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor: form
* fix: directive not work
* fix: use open, remove visible
* doc: update cover
* refactor: remove not use code
* chore: update build script
* doc: update doc
* doc: refactor doc
* chore: update token error
* chore: update style
* refactor: rename _style to style
* fix: tag warning
* fix(dropdown): open invalid (#6316)
* feat: add watermark (#6300)
* feat: add watermark
* feat: add watermark demo
* feat: add mutationObserver
* feat: add watermark demo
* refactor: watermark type
* doc: add theme-editor
* fix: inject value maybe undefined && tag style invalid (#6320)
* fix: inject value maybe undefined
* fix(tag): style invalid
* feat: add qrcode (#6315)
* feat: add qrcode
* fix: qrcode bug
* fix: qrcode value required
* refactor: props deconstruct
* Feat v4 floatbutton (#6294)
* feat: add float-button components
* fix type & demo display
* fix components entry
* fix review bug
* fix bug
* fix .value
* refactor: qrcode #6315
* refactor: float-button
* fix: groupsize context error
* fix: floatbutton animation not work
* Feat v4 theme editor (#6348)
* feat: add theme editor container
* feat: add theme editor layout
* add left panel
* add vue-colorful & fix bug
* 修复hue组件抖动问题
* fix bug && add demo
* fix bug
* fix demo preview
* fix theme editor components demo
* fix: token effect error
* Feat v4 theme editor (#6349)
* feat: add theme editor container
* feat: add theme editor layout
* add left panel
* add vue-colorful & fix bug
* 修复hue组件抖动问题
* fix bug && add demo
* fix bug
* fix demo preview
* fix theme editor components demo
* add theme editor token drawer
* add theme editor token drawer
* fix bug
* open commment
* fix error demo
* fix theme editor bug
* fix: cssinjs effect error
* doc: format code
* fix: tag click event not trigger
* release 4.0.0-alpha.1
* fix: qrcode type
* fix: remove not use file
* doc: update doc site
* doc: update site
* doc: fix theme editor bgcolor (#6358)
* fix: motion not work
* release 4.0.0-alpha.2
* fix: qrcode ; error, close #6362
* fix docs dark theme & add docs coverDark (#6367)
* fix docs dark theme & add docs coverDark
* fix theme Editor edit
* fix: dropdown divider disappear, close #6365 (#6369)
* doc: update baner
* fix: button wave not work
* fix: ant-piker-cell-range-hover-end style error (#6373)
* fix: ant-piker-cell-range-hover-end style error
* feat: be consistent with antd
* feat: be consistent with antd
* fix: ConfigProvider error for style, close #6368
* release 4.0.0-alpha.4
* style: add dark style for `pre` and `code` (#6382)
* docs: version menu (#6390)
* Feat(DatePicker): increase presets prop (#6387)
* feat(date-picker): add PresetDate type
* feat(date-picker): add usePresets hook
* feat(date-picker): add PresetPanel Component
* feat(date-picker): add PresetPanel Component
* feat(demo): update Preset Ranges Examples
* feat(docs): add new prop presets
* feat(docs): add new prop presets with english
* fix(RangePicker): footer is not managed by panels
* chore(Picker): prefixCls default rc-picker
* chore(date-picker): update presetted-ranges demo
* chore(date-picker): update rangePickerProps'presets
* feat(date-picker): presets reactively processing
* chore(date-picker): update type
* refactor(RangePicker): deprecated ranges prop
* chore(date-picker): update type
* chore(PickerPanel): del notuse panelRef
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: datepicker presets error #6387
* docs: update datepicker doc #6387
* feat(Steps): add items prop and variants (#6406)
* refactor(steps): add items prop and variants
* feat(steps): add Label Placement and Inline Steps demo
* feat(steps): Label Placement and Inline Steps snap
* test(steps): Steps demo snap
* feat(Steps): update docs
* fix(Step): progressDot
* chore(useLegacyItems): change from warning to devWarning
* refactor(Steps): Remove useLegacyItems
* refactor(Steps): renderStep
* test(Steps): update test snapshot
* chore(Steps): filterEmpty
* feat(Steps): update docs
* docs: update site
* refactor: steps #6406
* test: update steps
* perf: shallowRef instead ref
* fix(Modal): fix modal locale (#6423)
* feat(StyleProvider): add StyleProvider handle cssinjs features (#6415)
* feat(StyleProvider): StyleProvider
* feat(StyleProvider): refactor to use context
* chore(StyleProvider): update AStyleProviderProps type
* chore(App): reback
* chore(StyleProvider): export StyleProvider
* feat(StyleProvider): update StyleProvider docs
* feat(StyleProvider): update StyleProvider docs
* feat(StyleProvider): add StyleProvider docs routes
* chore(StyleProvider): with useStyleProvider
* docs: update compatiple #6415
* feat(Progress): enhance size prop and add variants (#6409)
* refactor(progress): Progress size and add variants
* feat(progress): add `getsize`
* refactor(progress): Progress size and add variants
* chore(progress): update props type
* chore(progress): update props type
* feat(progress): update demo
* feat(progress): update docs
* test(progress): update test snap
* fix(Circle): Merging classes
* test(progress): update test snap
* feat(progress): add size demo
* test(progress): add size snapshot
* chore(Progress): reback Circle svg class change
* fix: progress borderRadius reactive #6409
* fix(defaultConfigProvider): add getPopupContainer (#6425), close #6419
* fix: qrcode size error, close #6418
* release 4.0.0-alpha.4
* fix: picker import error
* test: add QRCode unit testing (#6441)
* fix
* fix compile type errors
* fix menuprops type import
* fix lint errors
* fix lint errors
* fix format error
* fix node version
* fix run dist error
* fix run lint
* fix as any
* fix string type
* fix steps error & fix docs version select option & fix theme editor error
* fix(badge): badge props count default value error (#6433)
* docs: update site responsive
* fix: modal api method i18n not work, close #6438
* release 4.0.0-alpha.5
* chore(docs): update docs (#6446)
* docs(space): update demo
* docs(affix): update docs
* fix: cssinjs compatibility (#6454)
* feat: add convertLegacyToken
* docs: v4 vuedocs (#6468)
* fix introduce doc
* fix getting-started doc
* add migration-v4 doc
* fix docs
* Update migration-v4.zh-CN.md
* Update migration-v4.zh-CN.md
* Update migration-v4.en-US.md
* Update migration-v4.zh-CN.md
* Update getting-started.en-US.md
* Update getting-started.zh-CN.md
* Update introduce.en-US.md
* Update introduce.zh-CN.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: remove backtop
* feat(anchor): add direction action (#6447)
* refactor(anchor): direction show
* refactor(anchor): update anchor css
* feat(anchor): update demo
* test(anchor): update demo test snap
* feat(anchor): update docs
* Update index.zh-CN.md
* Update index.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: anchor add customTitle slot #6447
* docs: update doc anchor
* feat(menu): icon support function components with items and update demo (#6457)
* fix(menu): icon do not show problem
* fix(menu): icon do not show problem
* feat(menu): update demo
* test(menu): update demo snap
* chore(Menu): update docs
* test(Menu): update demo
* Update MenuItem.tsx
* Update SubMenu.tsx
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* doc: update menu icon
* feat: menu items icon add arg
* fix: antd.min error
* release 4.0.0-alpha.6
* fix: table resizable not work && type error (#6514)
* Refactor(demo): change options to composition api (#6499)
* feat(demo): A-B
* feat(demo): update B-checkbox
* feat(demo): update CheckBox -DatePicker
* feat(demo): update DatePicker - Form
* feat(demo): update Form - List
* feat(demo): update List-pagination
* feat(demo): update List - skeleton
* feat(demo): update skeleton - switch
* feat(demo): update skeleton - switch
* feat(demo): update switch - upload
* feat(demo): update watermark
* fix(demo): del hashId
* fix: submenu type lose theme
* fix: dropdown menu hide error
* fix: dealing with switching topics modal, notification, message does not take effect close #6512 (#6518)
* fix: resolve dark mode not support
* fix: unified expression
* feat(modal): add useModal (#6517)
* feat(modal): add useModal hook
* feat(modal): add HookModal demo
* test(modal): update HookModal demo snap
* feat(modal): update modal docs
* chore(modal): update modal type
* perf: useModal #6517
* release 4.0.0-beta.1
* docs: fix tab demo error
* fix(config-provider): fix ConfigProvider.config is not function close #6528 (#6529)
* Feat(use): add useMessage useNotification (#6527)
* feat(Message): add useMessage hook
* feat(Notification): add useNotification hook
* feat(Message): add Hook demo
* feat(Notification): add Hook demo
* test(Message): update demo snap
* test(Notification): update demo snap
* docs(Message): update docs with FAQ
* docs(Notification): update docs with FAQ
* refactor: useMessage #6527
* refactor: useNotification #6527
* release 4.0.0-beta.2
* docs(button): update demo with space (#6536)
* feat(button): demo space
* test(button): update demo snap
* chore(button): disabled demo Ghost space
* test(button): update disabled demo snap
* docs(introduce): update docs (#6539)
* docs(introduce): update docs
* docs(introduce): add Dollar
* Update introduce.zh-CN.md
* Update introduce.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* docs(customize-theme): update docs (#6540)
* fix introduce doc
* fix getting-started doc
* add migration-v4 doc
* fix docs
* Update migration-v4.zh-CN.md
* Update migration-v4.zh-CN.md
* Update migration-v4.en-US.md
* Update migration-v4.zh-CN.md
* Update getting-started.en-US.md
* Update getting-started.zh-CN.md
* Update introduce.en-US.md
* Update introduce.zh-CN.md
* update customize-theme doc & fix migration-v4 error
* update customize-theme doc
* fix migration-v4 error
* remove SSR & shadowDom
* Update customize-theme.zh-CN.md
* Update customize-theme.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: getPopupContainer not work
* release 4.0.0-beta.3
* release 4.0.0-beta.4
* docs: update grid docs (#6549)
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
* test(alert): update demo with space (#6541)
* docs(alert): update demo with space
* docs(alert): update alert test snap
---------
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
* fix: components bug & update docs (#6548)
* fix bug
* fix test case and update snapshot,fix space merge class
* docs(grid): update migrate docs && delete xxxl in grid docs (#6562)
* fix: segmentd disabled label is undefined (#6556)
* fix: segmentd disabled label is undefined
* fix: segmentd disabled label is undefined
* fix: segmentd disabled label is undefined
* fix(grid): remove grid xxxl attribute (#6572)
* fix: remove grid xxxl attribute
* docs: remove xxxl in grid docs
* fix: tooltip custom color error
* feat: remove Step __legacy
* feat: add tour (#6332)
* feat v4 add tour
* fix type error
* sync tour from antd5.4.6 & fix type error
* fix error
* refactor: tour #6332
* fix: tour center
* fix: picker support v-show
* test: update snap
* test: update tour test
* fix: tour-mask attrs pointer-events (#6577)
* fix: tour animated
* feat: support vue 3.3 slot type
* release 4.0.0-rc.1
* release 4.0.0-rc.2, close #6588
* 4.0.0-rc.3
* chore: remove vue private api
* fix: paginantion error, close #6590
* release 4.0.0-rc.4
* fix: checxbox style
* fix: pagination mini size style
* release 4.0.0-rc.5
* docs: update v4 tabs doc error(#6606) (#6607)
* docs: add ant-design-vue nuxt module (#6620)
* fix: layout-sider and menu transition style(#6637) (#6640)
* docs: fixed the style error of online demo (#6630)
* feat: ✨checkbox label slot support use option label (#6642)
* docs: 📃change the default setting of "treeNodeFilterProp" from "value" to "label"
* revert: ↩revert this config and create another pr to commit
* feat: ✨checkbox label slot support use option label
* test: 🧪update checkbox *.snap file
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: add disabledContext override with form components (#6618)
* fix: add disabledContext override with form components
* test: update snap
* fix: LabelWidth demo filename
* fix: fontsize spelling mistake
* fix(tour): target position (#6629)
* style: format lint
* docs(form): add form disabled demo (#6658)
* fix: comment node error
* release 4.0
* fix: portalWrapper add autoLock prop (#6687), close #6649
* fix: image animation & zindex, close #6675
* docs(QRCode): Synchronize QR code demonstration and add SVG (#6660)
* fix: Synchronize QR code demonstration and add SVG
* fix: responsive loss and invalid border style
* docs: synchronize antd5.6.3 QRCode color in dark mode
* feat: calendar select support info.source param (#6697)
* docs: add ant-design-vue nuxt module
* feat: calendar select support info.source param
* docs: synchronous config-provider demo (#6706)
* revert: #6706
* docs: export space-compact types (#6716)
* release 4.0.0
---------
Co-authored-by: bqy_fe <1743369777@qq.com>
Co-authored-by: zkwolf <chenhao5866@gmail.com>
Co-authored-by: Zev Zhu <45655660+aibayanyu20@users.noreply.github.com>
Co-authored-by: lyn <76365499@qq.com>
Co-authored-by: 果冻橙 <shifeng199307@gmail.com>
Co-authored-by: songsong0707 <74165917+songsong0707@users.noreply.github.com>
Co-authored-by: yang <30883395+webvs2@users.noreply.github.com>
Co-authored-by: selicens <1244620067@qq.com>
Co-authored-by: 一堆菠萝 <53335668+JavanShen@users.noreply.github.com>
Co-authored-by: H1mple <35363759+baohangxing@users.noreply.github.com>
Co-authored-by: Cherry7 <79909910+CCherry07@users.noreply.github.com>
Co-authored-by: Konv Suu <2583695112@qq.com>
Co-authored-by: luoawai <32483950+luoawai@users.noreply.github.com>
Co-authored-by: 鱼见 <657715602@qq.com>
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
Co-authored-by: Cupid Valentine <53572196+valcosmos@users.noreply.github.com>
Co-authored-by: 专业逮虾户aa <30494925+waldonUB@users.noreply.github.com>
Co-authored-by: PanStar <PanStar@users.noreply.github.com>
2023-07-14 03:58:27 +00:00
|
|
|
|
shallowRef,
|
2022-01-21 13:58:10 +00:00
|
|
|
|
toRefs,
|
|
|
|
|
watch,
|
|
|
|
|
watchEffect,
|
|
|
|
|
} from 'vue';
|
|
|
|
|
import type { CSSProperties, ExtractPropTypes, PropType, VNode } from 'vue';
|
|
|
|
|
import PropTypes from '../_util/vue-types';
|
|
|
|
|
import { initDefaultProps, isValidElement } from '../_util/props-util';
|
|
|
|
|
import isMobile from '../vc-util/isMobile';
|
|
|
|
|
import KeyCode from '../_util/KeyCode';
|
|
|
|
|
import { toReactive } from '../_util/toReactive';
|
|
|
|
|
import classNames from '../_util/classNames';
|
|
|
|
|
import createRef from '../_util/createRef';
|
|
|
|
|
import type { BaseOptionType } from './Select';
|
|
|
|
|
import useInjectLegacySelectContext from '../vc-tree-select/LegacyContext';
|
|
|
|
|
import { cloneElement } from '../_util/vnode';
|
2022-04-23 05:28:00 +00:00
|
|
|
|
import type { AlignType } from '../vc-trigger/interface';
|
2022-01-21 13:58:10 +00:00
|
|
|
|
|
|
|
|
|
const DEFAULT_OMIT_PROPS = [
|
|
|
|
|
'value',
|
|
|
|
|
'onChange',
|
|
|
|
|
'removeIcon',
|
|
|
|
|
'placeholder',
|
|
|
|
|
'autofocus',
|
|
|
|
|
'maxTagCount',
|
|
|
|
|
'maxTagTextLength',
|
|
|
|
|
'maxTagPlaceholder',
|
|
|
|
|
'choiceTransitionName',
|
|
|
|
|
'onInputKeyDown',
|
|
|
|
|
'onPopupScroll',
|
|
|
|
|
'tabindex',
|
|
|
|
|
'OptionList',
|
|
|
|
|
'notFoundContent',
|
|
|
|
|
] as const;
|
|
|
|
|
|
|
|
|
|
export type RenderNode = VueNode | ((props: any) => VueNode);
|
|
|
|
|
|
|
|
|
|
export type RenderDOMFunc = (props: any) => HTMLElement;
|
|
|
|
|
|
|
|
|
|
export type Mode = 'multiple' | 'tags' | 'combobox';
|
|
|
|
|
|
|
|
|
|
export type Placement = 'bottomLeft' | 'bottomRight' | 'topLeft' | 'topRight';
|
|
|
|
|
|
|
|
|
|
export type RawValueType = string | number;
|
|
|
|
|
|
|
|
|
|
export interface RefOptionListProps {
|
|
|
|
|
onKeydown: KeyboardEventHandler;
|
|
|
|
|
onKeyup: KeyboardEventHandler;
|
2022-04-23 05:28:00 +00:00
|
|
|
|
scrollTo?: (index: number | ScrollConfig) => void;
|
2022-01-21 13:58:10 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export type CustomTagProps = {
|
|
|
|
|
label: any;
|
|
|
|
|
value: any;
|
|
|
|
|
disabled: boolean;
|
|
|
|
|
onClose: (event?: MouseEvent) => void;
|
|
|
|
|
closable: boolean;
|
|
|
|
|
option: BaseOptionType;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export interface DisplayValueType {
|
|
|
|
|
key?: Key;
|
|
|
|
|
value?: RawValueType;
|
|
|
|
|
label?: any;
|
|
|
|
|
disabled?: boolean;
|
|
|
|
|
option?: BaseOptionType;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export type BaseSelectRef = {
|
|
|
|
|
focus: () => void;
|
|
|
|
|
blur: () => void;
|
|
|
|
|
scrollTo: ScrollTo;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const baseSelectPrivateProps = () => {
|
|
|
|
|
return {
|
|
|
|
|
prefixCls: String,
|
|
|
|
|
id: String,
|
|
|
|
|
omitDomProps: Array as PropType<string[]>,
|
|
|
|
|
|
|
|
|
|
// >>> Value
|
|
|
|
|
displayValues: Array as PropType<DisplayValueType[]>,
|
|
|
|
|
onDisplayValuesChange: Function as PropType<
|
|
|
|
|
(
|
|
|
|
|
values: DisplayValueType[],
|
|
|
|
|
info: {
|
|
|
|
|
type: 'add' | 'remove' | 'clear';
|
|
|
|
|
values: DisplayValueType[];
|
|
|
|
|
},
|
|
|
|
|
) => void
|
|
|
|
|
>,
|
|
|
|
|
|
|
|
|
|
// >>> Active
|
|
|
|
|
/** Current dropdown list active item string value */
|
|
|
|
|
activeValue: String,
|
|
|
|
|
/** Link search input with target element */
|
|
|
|
|
activeDescendantId: String,
|
|
|
|
|
onActiveValueChange: Function as PropType<(value: string | null) => void>,
|
|
|
|
|
|
|
|
|
|
// >>> Search
|
|
|
|
|
searchValue: String,
|
|
|
|
|
/** Trigger onSearch, return false to prevent trigger open event */
|
|
|
|
|
onSearch: Function as PropType<
|
|
|
|
|
(
|
|
|
|
|
searchValue: string,
|
|
|
|
|
info: {
|
|
|
|
|
source:
|
|
|
|
|
| 'typing' //User typing
|
|
|
|
|
| 'effect' // Code logic trigger
|
|
|
|
|
| 'submit' // tag mode only
|
|
|
|
|
| 'blur'; // Not trigger event
|
|
|
|
|
},
|
|
|
|
|
) => void
|
|
|
|
|
>,
|
|
|
|
|
/** Trigger when search text match the `tokenSeparators`. Will provide split content */
|
|
|
|
|
onSearchSplit: Function as PropType<(words: string[]) => void>,
|
|
|
|
|
maxLength: Number,
|
|
|
|
|
|
|
|
|
|
OptionList: PropTypes.any,
|
|
|
|
|
|
|
|
|
|
/** Tell if provided `options` is empty */
|
|
|
|
|
emptyOptions: Boolean,
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export type DropdownObject = {
|
|
|
|
|
menuNode?: VueNode;
|
|
|
|
|
props?: Record<string, any>;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export type DropdownRender = (opt?: DropdownObject) => VueNode;
|
|
|
|
|
export const baseSelectPropsWithoutPrivate = () => {
|
|
|
|
|
return {
|
|
|
|
|
showSearch: { type: Boolean, default: undefined },
|
|
|
|
|
tagRender: { type: Function as PropType<(props: CustomTagProps) => any> },
|
2022-01-27 07:12:15 +00:00
|
|
|
|
optionLabelRender: { type: Function as PropType<(option: Record<string, any>) => any> },
|
2022-01-21 13:58:10 +00:00
|
|
|
|
direction: { type: String as PropType<'ltr' | 'rtl'> },
|
|
|
|
|
|
|
|
|
|
// MISC
|
|
|
|
|
tabindex: Number,
|
|
|
|
|
autofocus: Boolean,
|
|
|
|
|
notFoundContent: PropTypes.any,
|
|
|
|
|
placeholder: PropTypes.any,
|
|
|
|
|
onClear: Function as PropType<() => void>,
|
|
|
|
|
|
|
|
|
|
choiceTransitionName: String,
|
|
|
|
|
|
|
|
|
|
// >>> Mode
|
|
|
|
|
mode: String as PropType<Mode>,
|
|
|
|
|
|
|
|
|
|
// >>> Status
|
|
|
|
|
disabled: { type: Boolean, default: undefined },
|
|
|
|
|
loading: { type: Boolean, default: undefined },
|
|
|
|
|
|
|
|
|
|
// >>> Open
|
|
|
|
|
open: { type: Boolean, default: undefined },
|
|
|
|
|
defaultOpen: { type: Boolean, default: undefined },
|
|
|
|
|
onDropdownVisibleChange: { type: Function as PropType<(open: boolean) => void> },
|
|
|
|
|
|
|
|
|
|
// >>> Customize Input
|
|
|
|
|
/** @private Internal usage. Do not use in your production. */
|
|
|
|
|
getInputElement: { type: Function as PropType<() => any> },
|
|
|
|
|
/** @private Internal usage. Do not use in your production. */
|
|
|
|
|
getRawInputElement: { type: Function as PropType<() => any> },
|
|
|
|
|
|
|
|
|
|
// >>> Selector
|
|
|
|
|
maxTagTextLength: Number,
|
|
|
|
|
maxTagCount: { type: [String, Number] as PropType<number | 'responsive'> },
|
|
|
|
|
maxTagPlaceholder: PropTypes.any,
|
|
|
|
|
|
|
|
|
|
// >>> Search
|
|
|
|
|
tokenSeparators: { type: Array as PropType<string[]> },
|
|
|
|
|
|
|
|
|
|
// >>> Icons
|
|
|
|
|
allowClear: { type: Boolean, default: undefined },
|
|
|
|
|
showArrow: { type: Boolean, default: undefined },
|
|
|
|
|
inputIcon: PropTypes.any,
|
|
|
|
|
/** Clear all icon */
|
|
|
|
|
clearIcon: PropTypes.any,
|
|
|
|
|
/** Selector remove icon */
|
|
|
|
|
removeIcon: PropTypes.any,
|
|
|
|
|
|
|
|
|
|
// >>> Dropdown
|
|
|
|
|
animation: String,
|
|
|
|
|
transitionName: String,
|
|
|
|
|
dropdownStyle: { type: Object as PropType<CSSProperties> },
|
|
|
|
|
dropdownClassName: String,
|
|
|
|
|
dropdownMatchSelectWidth: {
|
|
|
|
|
type: [Boolean, Number] as PropType<boolean | number>,
|
|
|
|
|
default: undefined,
|
|
|
|
|
},
|
|
|
|
|
dropdownRender: { type: Function as PropType<DropdownRender> },
|
2022-04-23 05:28:00 +00:00
|
|
|
|
dropdownAlign: Object as PropType<AlignType>,
|
2022-01-21 13:58:10 +00:00
|
|
|
|
placement: {
|
|
|
|
|
type: String as PropType<Placement>,
|
|
|
|
|
},
|
|
|
|
|
getPopupContainer: { type: Function as PropType<RenderDOMFunc> },
|
|
|
|
|
|
|
|
|
|
// >>> Focus
|
|
|
|
|
showAction: { type: Array as PropType<('focus' | 'click')[]> },
|
|
|
|
|
onBlur: { type: Function as PropType<(e: FocusEvent) => void> },
|
|
|
|
|
onFocus: { type: Function as PropType<(e: FocusEvent) => void> },
|
|
|
|
|
|
|
|
|
|
// >>> Rest Events
|
|
|
|
|
onKeyup: Function as PropType<(e: KeyboardEvent) => void>,
|
|
|
|
|
onKeydown: Function as PropType<(e: KeyboardEvent) => void>,
|
|
|
|
|
onMousedown: Function as PropType<(e: MouseEvent) => void>,
|
|
|
|
|
onPopupScroll: Function as PropType<(e: UIEvent) => void>,
|
|
|
|
|
onInputKeyDown: Function as PropType<(e: KeyboardEvent) => void>,
|
|
|
|
|
onMouseenter: Function as PropType<(e: MouseEvent) => void>,
|
|
|
|
|
onMouseleave: Function as PropType<(e: MouseEvent) => void>,
|
|
|
|
|
onClick: Function as PropType<(e: MouseEvent) => void>,
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
const baseSelectProps = () => {
|
|
|
|
|
return {
|
|
|
|
|
...baseSelectPrivateProps(),
|
|
|
|
|
...baseSelectPropsWithoutPrivate(),
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export type BaseSelectPrivateProps = Partial<
|
|
|
|
|
ExtractPropTypes<ReturnType<typeof baseSelectPrivateProps>>
|
|
|
|
|
>;
|
|
|
|
|
|
|
|
|
|
export type BaseSelectProps = Partial<ExtractPropTypes<ReturnType<typeof baseSelectProps>>>;
|
|
|
|
|
|
|
|
|
|
export type BaseSelectPropsWithoutPrivate = Omit<BaseSelectProps, keyof BaseSelectPrivateProps>;
|
|
|
|
|
|
|
|
|
|
export function isMultiple(mode: Mode) {
|
|
|
|
|
return mode === 'tags' || mode === 'multiple';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export default defineComponent({
|
2022-09-26 13:33:41 +00:00
|
|
|
|
compatConfig: { MODE: 3 },
|
2022-01-21 13:58:10 +00:00
|
|
|
|
name: 'BaseSelect',
|
|
|
|
|
inheritAttrs: false,
|
|
|
|
|
props: initDefaultProps(baseSelectProps(), { showAction: [], notFoundContent: 'Not Found' }),
|
|
|
|
|
setup(props, { attrs, expose, slots }) {
|
|
|
|
|
const multiple = computed(() => isMultiple(props.mode));
|
|
|
|
|
|
|
|
|
|
const mergedShowSearch = computed(() =>
|
|
|
|
|
props.showSearch !== undefined
|
|
|
|
|
? props.showSearch
|
|
|
|
|
: multiple.value || props.mode === 'combobox',
|
|
|
|
|
);
|
Feat v4 (#6329)
* refactor(icon): remove style dir (#6215)
* refactor: rename locale
* refactor: locale-provider
* refactor: modal
* refactor: menu
* fix: custom class (#6217)
* refactor: tooltip
* refactor: grid (#6220)
* refactor: grid
* fix(grid): align & justify responsive
* chore: update demo and snapshot
* fix: row ts type not work
* doc: update demo
* refactor: ts
* refactor: spin (#6222)
* fix: typo (#6218)
* fix: typo
* docs<upload>: docs update
* refactor: spin
* refactor: spin
* refactor: spin
* refactor: spinnn
* refactor: spin
---------
Co-authored-by: lyn <76365499@qq.com>
* fix: spin error #6222
* test: test case error (#6225)
* fix: inject value maybe undefined
* fix: tootip emit correct value
* fix: rollback warning suffix avoid test break
* doc(grid): remove unused type="flex"
* refactor: skeleton (#6224)
* refactor: skeleton
* refactor: skeleton style
* chore: modify skeleton demo style
* fix(button): link and text should not have wave (#6226)
* refactor: dropdown
* refactor: popover & popconfirm
* refactor(tag): less to cssinjs (#6227)
* refactor(empty): less to cssinjs (#6230)
* refactor(empty): less to cssinjs
* chore: remove unuse code
* fix: reactivity lose
* fix: empty props #6230
* refactor: progress style (#6234)
* refactor: progress
* refactor: progress style
* fix: progress attrs
* refactor: progress #6234
* refactor: switch (#6236)
* refactor: switch style
* refactor: delete switch style
* refactor:input (#6237)
* refactor:input
* fix inheritAttrs:false
* fix attrs.class
* feat: input add disabled
* refactor:comment (#6238)
* refactor:comment
* fix inheritAttrs: false & attrs.class
* refactor:pageheader (#6239)
* refactor:pageheader
* fix inheritAttrs: false & attrs.class
* refactor:statistic (#6240)
* refactor:statistic
* fix inheritAttrs: false & attrs.class
* refactor:list (#6241)
* refactor:list
* fix inheritAttrs: false & attrs.class
* feat: update type
* refactor(Space): less to cssinjs & add compact mode (#6229)
* refactor(Space): less to cssinjs & add compact mode
* chore(space): update md
* chore(space): add demo
* chore(space): add some demo
* feat(button): add compact mode
* fix: reactivity lose
* docs: fix props version
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* perf: space compact
* refactor:typography (#6244)
* refactor:typography
* fix return
* fix import type
* fix: typography #6244
* refactor:datepicker (#6245)
* refactor: datepicker type
* refactor: rate style (#6254)
* refactor(layout): less to cssinjs (#6249)
* doc: update layout cover
* refactor(result): less to cssinjs (#6246)
* refactor(result): less to cssinjs
* fix: class name is overridden
* docs: update result cover
* refactor:slider (#6250)
* feat: slider deprecated tooltipVisible
* refactor(crad): less to cssinjs (#6258)
* update
* switch
* Style adjustment
* refactor(Card): less to cssinjs
* Eliminate invalid code
* optimization and adjustment css
* Adjust the css
* Optimize each item
* adjustment css
* refactor: card #6258
* refactor:carousel (#6262)
* refactor:carousel
* docs:update & refactor: carousel type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor:transfer (#6247)
* refactor:transfer
* merge v4 branch & fix theme interface conflict
* docs:update & refactor: transfer type
* perf: transfer
* refactor:checkbox (#6248)
* refactor:checkbox
* docs:update & refactor: checkbox type
* feat: checkbox add disabled context
* refactor:pagination (#6251)
* refactor:pagination
* docs:update & refactor: pagination type
* style: update pagination props type
* refactor: mentions (#6255)
* refactor: mentions
* refactor: mentions menu provider
* doc: update mentions demo
* refcator:upload (#6261)
* refcator:upload
* docs:update & refactor: upload type
* Update style.ts
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* perf: upload motion
* refactor:timeline (#6263)
* refactor:timeline
* docs:update & refactor: timeline type
* perf: timeline
* refactor:steps (#6264)
* refactor:steps
* fix ...attrs
* fix StepsToken error
* docs:update & refactor: steps type
* fix: steps icon clss error
* refactor:collapse (#6266)
* refactor:collapse
* fix collapse props version
* docs:update & refactor: collapse type & fix collapsible
* feat: update collapse type
* refactor:inputnumber (#6265)
* refactor:inputnumber
* docs:update & refactor: inputnumber type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: number add compactSize & disabledContext
* refactor:table (#6267)
* refactor:table
* docs:update & refactor: table type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor: table
* feat: table add expandColumnTitle slot
* refactor:calendar (#6269)
* refactor:calendar
* docs:update
* refactor:timepicker (#6270)
* refactor:timepicker
* docs:update & refactor: timepicker type
* refactor:tree (#6276)
* Feat v4 fix type errors (#6285)
* fix compile type errors
* fix menuprops type import
* fix lint errors
* fix lint errors
* fix format error
* fix node version
* fix run dist error
* fix run lint
* fix as any
* fix string type
* refactor: rename locale file
* feat: tree add leafIcon
* [tabs] :less to cssinjs (#6288)
* update
* switch
* Style adjustment
* refactor(Card): less to cssinjs
* tabs: less to cssinjs 开发ing
* add function cssinjs
* Eliminate irrelevant code
* Eliminate irrelevant code 2
* update components
* Eliminate irrelevant input code
* refactor: tabs #6288
* feat: add segmented (#6286)
* refactor: segmented #6286
* refactor:select (#6295)
* refactor:select
* update doc
* delete useless
* feat: select add context size
* refactor: tree select (#6296)
* feat: tree-select add context size
* perf: table
* docs: update doc toc
* refactor: cascader
* refactor: auto-complete
* refactor: image
* refactor: drawer
* refactor:radio (#6299)
* refactor:radio
* fix attrs
* feat: radio add disabled context
* fix: some type & doc (#6292)
* fix: typo (#6218)
* fix: typo
* docs<upload>: docs update
* fix: type of minute in props disabledDateTime of DatePicker (#6233)
* docs: typo (#6256)
* feat: tooltip added overlayInnerStyle attribute
* Update abstractTooltipProps.ts
* Update Tooltip.tsx
---------
Co-authored-by: lyn <76365499@qq.com>
Co-authored-by: H1mple <35363759+baohangxing@users.noreply.github.com>
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor: form
* fix: directive not work
* fix: use open, remove visible
* doc: update cover
* refactor: remove not use code
* chore: update build script
* doc: update doc
* doc: refactor doc
* chore: update token error
* chore: update style
* refactor: rename _style to style
* fix: tag warning
* fix(dropdown): open invalid (#6316)
* feat: add watermark (#6300)
* feat: add watermark
* feat: add watermark demo
* feat: add mutationObserver
* feat: add watermark demo
* refactor: watermark type
* doc: add theme-editor
* fix: inject value maybe undefined && tag style invalid (#6320)
* fix: inject value maybe undefined
* fix(tag): style invalid
* feat: add qrcode (#6315)
* feat: add qrcode
* fix: qrcode bug
* fix: qrcode value required
* refactor: props deconstruct
* Feat v4 floatbutton (#6294)
* feat: add float-button components
* fix type & demo display
* fix components entry
* fix review bug
* fix bug
* fix .value
* refactor: qrcode #6315
* refactor: float-button
* fix: groupsize context error
* fix: floatbutton animation not work
* Feat v4 theme editor (#6348)
* feat: add theme editor container
* feat: add theme editor layout
* add left panel
* add vue-colorful & fix bug
* 修复hue组件抖动问题
* fix bug && add demo
* fix bug
* fix demo preview
* fix theme editor components demo
* fix: token effect error
* Feat v4 theme editor (#6349)
* feat: add theme editor container
* feat: add theme editor layout
* add left panel
* add vue-colorful & fix bug
* 修复hue组件抖动问题
* fix bug && add demo
* fix bug
* fix demo preview
* fix theme editor components demo
* add theme editor token drawer
* add theme editor token drawer
* fix bug
* open commment
* fix error demo
* fix theme editor bug
* fix: cssinjs effect error
* doc: format code
* fix: tag click event not trigger
* release 4.0.0-alpha.1
* fix: qrcode type
* fix: remove not use file
* doc: update doc site
* doc: update site
* doc: fix theme editor bgcolor (#6358)
* fix: motion not work
* release 4.0.0-alpha.2
* fix: qrcode ; error, close #6362
* fix docs dark theme & add docs coverDark (#6367)
* fix docs dark theme & add docs coverDark
* fix theme Editor edit
* fix: dropdown divider disappear, close #6365 (#6369)
* doc: update baner
* fix: button wave not work
* fix: ant-piker-cell-range-hover-end style error (#6373)
* fix: ant-piker-cell-range-hover-end style error
* feat: be consistent with antd
* feat: be consistent with antd
* fix: ConfigProvider error for style, close #6368
* release 4.0.0-alpha.4
* style: add dark style for `pre` and `code` (#6382)
* docs: version menu (#6390)
* Feat(DatePicker): increase presets prop (#6387)
* feat(date-picker): add PresetDate type
* feat(date-picker): add usePresets hook
* feat(date-picker): add PresetPanel Component
* feat(date-picker): add PresetPanel Component
* feat(demo): update Preset Ranges Examples
* feat(docs): add new prop presets
* feat(docs): add new prop presets with english
* fix(RangePicker): footer is not managed by panels
* chore(Picker): prefixCls default rc-picker
* chore(date-picker): update presetted-ranges demo
* chore(date-picker): update rangePickerProps'presets
* feat(date-picker): presets reactively processing
* chore(date-picker): update type
* refactor(RangePicker): deprecated ranges prop
* chore(date-picker): update type
* chore(PickerPanel): del notuse panelRef
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: datepicker presets error #6387
* docs: update datepicker doc #6387
* feat(Steps): add items prop and variants (#6406)
* refactor(steps): add items prop and variants
* feat(steps): add Label Placement and Inline Steps demo
* feat(steps): Label Placement and Inline Steps snap
* test(steps): Steps demo snap
* feat(Steps): update docs
* fix(Step): progressDot
* chore(useLegacyItems): change from warning to devWarning
* refactor(Steps): Remove useLegacyItems
* refactor(Steps): renderStep
* test(Steps): update test snapshot
* chore(Steps): filterEmpty
* feat(Steps): update docs
* docs: update site
* refactor: steps #6406
* test: update steps
* perf: shallowRef instead ref
* fix(Modal): fix modal locale (#6423)
* feat(StyleProvider): add StyleProvider handle cssinjs features (#6415)
* feat(StyleProvider): StyleProvider
* feat(StyleProvider): refactor to use context
* chore(StyleProvider): update AStyleProviderProps type
* chore(App): reback
* chore(StyleProvider): export StyleProvider
* feat(StyleProvider): update StyleProvider docs
* feat(StyleProvider): update StyleProvider docs
* feat(StyleProvider): add StyleProvider docs routes
* chore(StyleProvider): with useStyleProvider
* docs: update compatiple #6415
* feat(Progress): enhance size prop and add variants (#6409)
* refactor(progress): Progress size and add variants
* feat(progress): add `getsize`
* refactor(progress): Progress size and add variants
* chore(progress): update props type
* chore(progress): update props type
* feat(progress): update demo
* feat(progress): update docs
* test(progress): update test snap
* fix(Circle): Merging classes
* test(progress): update test snap
* feat(progress): add size demo
* test(progress): add size snapshot
* chore(Progress): reback Circle svg class change
* fix: progress borderRadius reactive #6409
* fix(defaultConfigProvider): add getPopupContainer (#6425), close #6419
* fix: qrcode size error, close #6418
* release 4.0.0-alpha.4
* fix: picker import error
* test: add QRCode unit testing (#6441)
* fix
* fix compile type errors
* fix menuprops type import
* fix lint errors
* fix lint errors
* fix format error
* fix node version
* fix run dist error
* fix run lint
* fix as any
* fix string type
* fix steps error & fix docs version select option & fix theme editor error
* fix(badge): badge props count default value error (#6433)
* docs: update site responsive
* fix: modal api method i18n not work, close #6438
* release 4.0.0-alpha.5
* chore(docs): update docs (#6446)
* docs(space): update demo
* docs(affix): update docs
* fix: cssinjs compatibility (#6454)
* feat: add convertLegacyToken
* docs: v4 vuedocs (#6468)
* fix introduce doc
* fix getting-started doc
* add migration-v4 doc
* fix docs
* Update migration-v4.zh-CN.md
* Update migration-v4.zh-CN.md
* Update migration-v4.en-US.md
* Update migration-v4.zh-CN.md
* Update getting-started.en-US.md
* Update getting-started.zh-CN.md
* Update introduce.en-US.md
* Update introduce.zh-CN.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: remove backtop
* feat(anchor): add direction action (#6447)
* refactor(anchor): direction show
* refactor(anchor): update anchor css
* feat(anchor): update demo
* test(anchor): update demo test snap
* feat(anchor): update docs
* Update index.zh-CN.md
* Update index.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: anchor add customTitle slot #6447
* docs: update doc anchor
* feat(menu): icon support function components with items and update demo (#6457)
* fix(menu): icon do not show problem
* fix(menu): icon do not show problem
* feat(menu): update demo
* test(menu): update demo snap
* chore(Menu): update docs
* test(Menu): update demo
* Update MenuItem.tsx
* Update SubMenu.tsx
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* doc: update menu icon
* feat: menu items icon add arg
* fix: antd.min error
* release 4.0.0-alpha.6
* fix: table resizable not work && type error (#6514)
* Refactor(demo): change options to composition api (#6499)
* feat(demo): A-B
* feat(demo): update B-checkbox
* feat(demo): update CheckBox -DatePicker
* feat(demo): update DatePicker - Form
* feat(demo): update Form - List
* feat(demo): update List-pagination
* feat(demo): update List - skeleton
* feat(demo): update skeleton - switch
* feat(demo): update skeleton - switch
* feat(demo): update switch - upload
* feat(demo): update watermark
* fix(demo): del hashId
* fix: submenu type lose theme
* fix: dropdown menu hide error
* fix: dealing with switching topics modal, notification, message does not take effect close #6512 (#6518)
* fix: resolve dark mode not support
* fix: unified expression
* feat(modal): add useModal (#6517)
* feat(modal): add useModal hook
* feat(modal): add HookModal demo
* test(modal): update HookModal demo snap
* feat(modal): update modal docs
* chore(modal): update modal type
* perf: useModal #6517
* release 4.0.0-beta.1
* docs: fix tab demo error
* fix(config-provider): fix ConfigProvider.config is not function close #6528 (#6529)
* Feat(use): add useMessage useNotification (#6527)
* feat(Message): add useMessage hook
* feat(Notification): add useNotification hook
* feat(Message): add Hook demo
* feat(Notification): add Hook demo
* test(Message): update demo snap
* test(Notification): update demo snap
* docs(Message): update docs with FAQ
* docs(Notification): update docs with FAQ
* refactor: useMessage #6527
* refactor: useNotification #6527
* release 4.0.0-beta.2
* docs(button): update demo with space (#6536)
* feat(button): demo space
* test(button): update demo snap
* chore(button): disabled demo Ghost space
* test(button): update disabled demo snap
* docs(introduce): update docs (#6539)
* docs(introduce): update docs
* docs(introduce): add Dollar
* Update introduce.zh-CN.md
* Update introduce.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* docs(customize-theme): update docs (#6540)
* fix introduce doc
* fix getting-started doc
* add migration-v4 doc
* fix docs
* Update migration-v4.zh-CN.md
* Update migration-v4.zh-CN.md
* Update migration-v4.en-US.md
* Update migration-v4.zh-CN.md
* Update getting-started.en-US.md
* Update getting-started.zh-CN.md
* Update introduce.en-US.md
* Update introduce.zh-CN.md
* update customize-theme doc & fix migration-v4 error
* update customize-theme doc
* fix migration-v4 error
* remove SSR & shadowDom
* Update customize-theme.zh-CN.md
* Update customize-theme.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: getPopupContainer not work
* release 4.0.0-beta.3
* release 4.0.0-beta.4
* docs: update grid docs (#6549)
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
* test(alert): update demo with space (#6541)
* docs(alert): update demo with space
* docs(alert): update alert test snap
---------
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
* fix: components bug & update docs (#6548)
* fix bug
* fix test case and update snapshot,fix space merge class
* docs(grid): update migrate docs && delete xxxl in grid docs (#6562)
* fix: segmentd disabled label is undefined (#6556)
* fix: segmentd disabled label is undefined
* fix: segmentd disabled label is undefined
* fix: segmentd disabled label is undefined
* fix(grid): remove grid xxxl attribute (#6572)
* fix: remove grid xxxl attribute
* docs: remove xxxl in grid docs
* fix: tooltip custom color error
* feat: remove Step __legacy
* feat: add tour (#6332)
* feat v4 add tour
* fix type error
* sync tour from antd5.4.6 & fix type error
* fix error
* refactor: tour #6332
* fix: tour center
* fix: picker support v-show
* test: update snap
* test: update tour test
* fix: tour-mask attrs pointer-events (#6577)
* fix: tour animated
* feat: support vue 3.3 slot type
* release 4.0.0-rc.1
* release 4.0.0-rc.2, close #6588
* 4.0.0-rc.3
* chore: remove vue private api
* fix: paginantion error, close #6590
* release 4.0.0-rc.4
* fix: checxbox style
* fix: pagination mini size style
* release 4.0.0-rc.5
* docs: update v4 tabs doc error(#6606) (#6607)
* docs: add ant-design-vue nuxt module (#6620)
* fix: layout-sider and menu transition style(#6637) (#6640)
* docs: fixed the style error of online demo (#6630)
* feat: ✨checkbox label slot support use option label (#6642)
* docs: 📃change the default setting of "treeNodeFilterProp" from "value" to "label"
* revert: ↩revert this config and create another pr to commit
* feat: ✨checkbox label slot support use option label
* test: 🧪update checkbox *.snap file
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: add disabledContext override with form components (#6618)
* fix: add disabledContext override with form components
* test: update snap
* fix: LabelWidth demo filename
* fix: fontsize spelling mistake
* fix(tour): target position (#6629)
* style: format lint
* docs(form): add form disabled demo (#6658)
* fix: comment node error
* release 4.0
* fix: portalWrapper add autoLock prop (#6687), close #6649
* fix: image animation & zindex, close #6675
* docs(QRCode): Synchronize QR code demonstration and add SVG (#6660)
* fix: Synchronize QR code demonstration and add SVG
* fix: responsive loss and invalid border style
* docs: synchronize antd5.6.3 QRCode color in dark mode
* feat: calendar select support info.source param (#6697)
* docs: add ant-design-vue nuxt module
* feat: calendar select support info.source param
* docs: synchronous config-provider demo (#6706)
* revert: #6706
* docs: export space-compact types (#6716)
* release 4.0.0
---------
Co-authored-by: bqy_fe <1743369777@qq.com>
Co-authored-by: zkwolf <chenhao5866@gmail.com>
Co-authored-by: Zev Zhu <45655660+aibayanyu20@users.noreply.github.com>
Co-authored-by: lyn <76365499@qq.com>
Co-authored-by: 果冻橙 <shifeng199307@gmail.com>
Co-authored-by: songsong0707 <74165917+songsong0707@users.noreply.github.com>
Co-authored-by: yang <30883395+webvs2@users.noreply.github.com>
Co-authored-by: selicens <1244620067@qq.com>
Co-authored-by: 一堆菠萝 <53335668+JavanShen@users.noreply.github.com>
Co-authored-by: H1mple <35363759+baohangxing@users.noreply.github.com>
Co-authored-by: Cherry7 <79909910+CCherry07@users.noreply.github.com>
Co-authored-by: Konv Suu <2583695112@qq.com>
Co-authored-by: luoawai <32483950+luoawai@users.noreply.github.com>
Co-authored-by: 鱼见 <657715602@qq.com>
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
Co-authored-by: Cupid Valentine <53572196+valcosmos@users.noreply.github.com>
Co-authored-by: 专业逮虾户aa <30494925+waldonUB@users.noreply.github.com>
Co-authored-by: PanStar <PanStar@users.noreply.github.com>
2023-07-14 03:58:27 +00:00
|
|
|
|
const mobile = shallowRef(false);
|
2022-01-21 13:58:10 +00:00
|
|
|
|
onMounted(() => {
|
|
|
|
|
mobile.value = isMobile();
|
|
|
|
|
});
|
|
|
|
|
const legacyTreeSelectContext = useInjectLegacySelectContext();
|
|
|
|
|
// ============================== Refs ==============================
|
Feat v4 (#6329)
* refactor(icon): remove style dir (#6215)
* refactor: rename locale
* refactor: locale-provider
* refactor: modal
* refactor: menu
* fix: custom class (#6217)
* refactor: tooltip
* refactor: grid (#6220)
* refactor: grid
* fix(grid): align & justify responsive
* chore: update demo and snapshot
* fix: row ts type not work
* doc: update demo
* refactor: ts
* refactor: spin (#6222)
* fix: typo (#6218)
* fix: typo
* docs<upload>: docs update
* refactor: spin
* refactor: spin
* refactor: spin
* refactor: spinnn
* refactor: spin
---------
Co-authored-by: lyn <76365499@qq.com>
* fix: spin error #6222
* test: test case error (#6225)
* fix: inject value maybe undefined
* fix: tootip emit correct value
* fix: rollback warning suffix avoid test break
* doc(grid): remove unused type="flex"
* refactor: skeleton (#6224)
* refactor: skeleton
* refactor: skeleton style
* chore: modify skeleton demo style
* fix(button): link and text should not have wave (#6226)
* refactor: dropdown
* refactor: popover & popconfirm
* refactor(tag): less to cssinjs (#6227)
* refactor(empty): less to cssinjs (#6230)
* refactor(empty): less to cssinjs
* chore: remove unuse code
* fix: reactivity lose
* fix: empty props #6230
* refactor: progress style (#6234)
* refactor: progress
* refactor: progress style
* fix: progress attrs
* refactor: progress #6234
* refactor: switch (#6236)
* refactor: switch style
* refactor: delete switch style
* refactor:input (#6237)
* refactor:input
* fix inheritAttrs:false
* fix attrs.class
* feat: input add disabled
* refactor:comment (#6238)
* refactor:comment
* fix inheritAttrs: false & attrs.class
* refactor:pageheader (#6239)
* refactor:pageheader
* fix inheritAttrs: false & attrs.class
* refactor:statistic (#6240)
* refactor:statistic
* fix inheritAttrs: false & attrs.class
* refactor:list (#6241)
* refactor:list
* fix inheritAttrs: false & attrs.class
* feat: update type
* refactor(Space): less to cssinjs & add compact mode (#6229)
* refactor(Space): less to cssinjs & add compact mode
* chore(space): update md
* chore(space): add demo
* chore(space): add some demo
* feat(button): add compact mode
* fix: reactivity lose
* docs: fix props version
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* perf: space compact
* refactor:typography (#6244)
* refactor:typography
* fix return
* fix import type
* fix: typography #6244
* refactor:datepicker (#6245)
* refactor: datepicker type
* refactor: rate style (#6254)
* refactor(layout): less to cssinjs (#6249)
* doc: update layout cover
* refactor(result): less to cssinjs (#6246)
* refactor(result): less to cssinjs
* fix: class name is overridden
* docs: update result cover
* refactor:slider (#6250)
* feat: slider deprecated tooltipVisible
* refactor(crad): less to cssinjs (#6258)
* update
* switch
* Style adjustment
* refactor(Card): less to cssinjs
* Eliminate invalid code
* optimization and adjustment css
* Adjust the css
* Optimize each item
* adjustment css
* refactor: card #6258
* refactor:carousel (#6262)
* refactor:carousel
* docs:update & refactor: carousel type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor:transfer (#6247)
* refactor:transfer
* merge v4 branch & fix theme interface conflict
* docs:update & refactor: transfer type
* perf: transfer
* refactor:checkbox (#6248)
* refactor:checkbox
* docs:update & refactor: checkbox type
* feat: checkbox add disabled context
* refactor:pagination (#6251)
* refactor:pagination
* docs:update & refactor: pagination type
* style: update pagination props type
* refactor: mentions (#6255)
* refactor: mentions
* refactor: mentions menu provider
* doc: update mentions demo
* refcator:upload (#6261)
* refcator:upload
* docs:update & refactor: upload type
* Update style.ts
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* perf: upload motion
* refactor:timeline (#6263)
* refactor:timeline
* docs:update & refactor: timeline type
* perf: timeline
* refactor:steps (#6264)
* refactor:steps
* fix ...attrs
* fix StepsToken error
* docs:update & refactor: steps type
* fix: steps icon clss error
* refactor:collapse (#6266)
* refactor:collapse
* fix collapse props version
* docs:update & refactor: collapse type & fix collapsible
* feat: update collapse type
* refactor:inputnumber (#6265)
* refactor:inputnumber
* docs:update & refactor: inputnumber type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: number add compactSize & disabledContext
* refactor:table (#6267)
* refactor:table
* docs:update & refactor: table type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor: table
* feat: table add expandColumnTitle slot
* refactor:calendar (#6269)
* refactor:calendar
* docs:update
* refactor:timepicker (#6270)
* refactor:timepicker
* docs:update & refactor: timepicker type
* refactor:tree (#6276)
* Feat v4 fix type errors (#6285)
* fix compile type errors
* fix menuprops type import
* fix lint errors
* fix lint errors
* fix format error
* fix node version
* fix run dist error
* fix run lint
* fix as any
* fix string type
* refactor: rename locale file
* feat: tree add leafIcon
* [tabs] :less to cssinjs (#6288)
* update
* switch
* Style adjustment
* refactor(Card): less to cssinjs
* tabs: less to cssinjs 开发ing
* add function cssinjs
* Eliminate irrelevant code
* Eliminate irrelevant code 2
* update components
* Eliminate irrelevant input code
* refactor: tabs #6288
* feat: add segmented (#6286)
* refactor: segmented #6286
* refactor:select (#6295)
* refactor:select
* update doc
* delete useless
* feat: select add context size
* refactor: tree select (#6296)
* feat: tree-select add context size
* perf: table
* docs: update doc toc
* refactor: cascader
* refactor: auto-complete
* refactor: image
* refactor: drawer
* refactor:radio (#6299)
* refactor:radio
* fix attrs
* feat: radio add disabled context
* fix: some type & doc (#6292)
* fix: typo (#6218)
* fix: typo
* docs<upload>: docs update
* fix: type of minute in props disabledDateTime of DatePicker (#6233)
* docs: typo (#6256)
* feat: tooltip added overlayInnerStyle attribute
* Update abstractTooltipProps.ts
* Update Tooltip.tsx
---------
Co-authored-by: lyn <76365499@qq.com>
Co-authored-by: H1mple <35363759+baohangxing@users.noreply.github.com>
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor: form
* fix: directive not work
* fix: use open, remove visible
* doc: update cover
* refactor: remove not use code
* chore: update build script
* doc: update doc
* doc: refactor doc
* chore: update token error
* chore: update style
* refactor: rename _style to style
* fix: tag warning
* fix(dropdown): open invalid (#6316)
* feat: add watermark (#6300)
* feat: add watermark
* feat: add watermark demo
* feat: add mutationObserver
* feat: add watermark demo
* refactor: watermark type
* doc: add theme-editor
* fix: inject value maybe undefined && tag style invalid (#6320)
* fix: inject value maybe undefined
* fix(tag): style invalid
* feat: add qrcode (#6315)
* feat: add qrcode
* fix: qrcode bug
* fix: qrcode value required
* refactor: props deconstruct
* Feat v4 floatbutton (#6294)
* feat: add float-button components
* fix type & demo display
* fix components entry
* fix review bug
* fix bug
* fix .value
* refactor: qrcode #6315
* refactor: float-button
* fix: groupsize context error
* fix: floatbutton animation not work
* Feat v4 theme editor (#6348)
* feat: add theme editor container
* feat: add theme editor layout
* add left panel
* add vue-colorful & fix bug
* 修复hue组件抖动问题
* fix bug && add demo
* fix bug
* fix demo preview
* fix theme editor components demo
* fix: token effect error
* Feat v4 theme editor (#6349)
* feat: add theme editor container
* feat: add theme editor layout
* add left panel
* add vue-colorful & fix bug
* 修复hue组件抖动问题
* fix bug && add demo
* fix bug
* fix demo preview
* fix theme editor components demo
* add theme editor token drawer
* add theme editor token drawer
* fix bug
* open commment
* fix error demo
* fix theme editor bug
* fix: cssinjs effect error
* doc: format code
* fix: tag click event not trigger
* release 4.0.0-alpha.1
* fix: qrcode type
* fix: remove not use file
* doc: update doc site
* doc: update site
* doc: fix theme editor bgcolor (#6358)
* fix: motion not work
* release 4.0.0-alpha.2
* fix: qrcode ; error, close #6362
* fix docs dark theme & add docs coverDark (#6367)
* fix docs dark theme & add docs coverDark
* fix theme Editor edit
* fix: dropdown divider disappear, close #6365 (#6369)
* doc: update baner
* fix: button wave not work
* fix: ant-piker-cell-range-hover-end style error (#6373)
* fix: ant-piker-cell-range-hover-end style error
* feat: be consistent with antd
* feat: be consistent with antd
* fix: ConfigProvider error for style, close #6368
* release 4.0.0-alpha.4
* style: add dark style for `pre` and `code` (#6382)
* docs: version menu (#6390)
* Feat(DatePicker): increase presets prop (#6387)
* feat(date-picker): add PresetDate type
* feat(date-picker): add usePresets hook
* feat(date-picker): add PresetPanel Component
* feat(date-picker): add PresetPanel Component
* feat(demo): update Preset Ranges Examples
* feat(docs): add new prop presets
* feat(docs): add new prop presets with english
* fix(RangePicker): footer is not managed by panels
* chore(Picker): prefixCls default rc-picker
* chore(date-picker): update presetted-ranges demo
* chore(date-picker): update rangePickerProps'presets
* feat(date-picker): presets reactively processing
* chore(date-picker): update type
* refactor(RangePicker): deprecated ranges prop
* chore(date-picker): update type
* chore(PickerPanel): del notuse panelRef
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: datepicker presets error #6387
* docs: update datepicker doc #6387
* feat(Steps): add items prop and variants (#6406)
* refactor(steps): add items prop and variants
* feat(steps): add Label Placement and Inline Steps demo
* feat(steps): Label Placement and Inline Steps snap
* test(steps): Steps demo snap
* feat(Steps): update docs
* fix(Step): progressDot
* chore(useLegacyItems): change from warning to devWarning
* refactor(Steps): Remove useLegacyItems
* refactor(Steps): renderStep
* test(Steps): update test snapshot
* chore(Steps): filterEmpty
* feat(Steps): update docs
* docs: update site
* refactor: steps #6406
* test: update steps
* perf: shallowRef instead ref
* fix(Modal): fix modal locale (#6423)
* feat(StyleProvider): add StyleProvider handle cssinjs features (#6415)
* feat(StyleProvider): StyleProvider
* feat(StyleProvider): refactor to use context
* chore(StyleProvider): update AStyleProviderProps type
* chore(App): reback
* chore(StyleProvider): export StyleProvider
* feat(StyleProvider): update StyleProvider docs
* feat(StyleProvider): update StyleProvider docs
* feat(StyleProvider): add StyleProvider docs routes
* chore(StyleProvider): with useStyleProvider
* docs: update compatiple #6415
* feat(Progress): enhance size prop and add variants (#6409)
* refactor(progress): Progress size and add variants
* feat(progress): add `getsize`
* refactor(progress): Progress size and add variants
* chore(progress): update props type
* chore(progress): update props type
* feat(progress): update demo
* feat(progress): update docs
* test(progress): update test snap
* fix(Circle): Merging classes
* test(progress): update test snap
* feat(progress): add size demo
* test(progress): add size snapshot
* chore(Progress): reback Circle svg class change
* fix: progress borderRadius reactive #6409
* fix(defaultConfigProvider): add getPopupContainer (#6425), close #6419
* fix: qrcode size error, close #6418
* release 4.0.0-alpha.4
* fix: picker import error
* test: add QRCode unit testing (#6441)
* fix
* fix compile type errors
* fix menuprops type import
* fix lint errors
* fix lint errors
* fix format error
* fix node version
* fix run dist error
* fix run lint
* fix as any
* fix string type
* fix steps error & fix docs version select option & fix theme editor error
* fix(badge): badge props count default value error (#6433)
* docs: update site responsive
* fix: modal api method i18n not work, close #6438
* release 4.0.0-alpha.5
* chore(docs): update docs (#6446)
* docs(space): update demo
* docs(affix): update docs
* fix: cssinjs compatibility (#6454)
* feat: add convertLegacyToken
* docs: v4 vuedocs (#6468)
* fix introduce doc
* fix getting-started doc
* add migration-v4 doc
* fix docs
* Update migration-v4.zh-CN.md
* Update migration-v4.zh-CN.md
* Update migration-v4.en-US.md
* Update migration-v4.zh-CN.md
* Update getting-started.en-US.md
* Update getting-started.zh-CN.md
* Update introduce.en-US.md
* Update introduce.zh-CN.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: remove backtop
* feat(anchor): add direction action (#6447)
* refactor(anchor): direction show
* refactor(anchor): update anchor css
* feat(anchor): update demo
* test(anchor): update demo test snap
* feat(anchor): update docs
* Update index.zh-CN.md
* Update index.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: anchor add customTitle slot #6447
* docs: update doc anchor
* feat(menu): icon support function components with items and update demo (#6457)
* fix(menu): icon do not show problem
* fix(menu): icon do not show problem
* feat(menu): update demo
* test(menu): update demo snap
* chore(Menu): update docs
* test(Menu): update demo
* Update MenuItem.tsx
* Update SubMenu.tsx
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* doc: update menu icon
* feat: menu items icon add arg
* fix: antd.min error
* release 4.0.0-alpha.6
* fix: table resizable not work && type error (#6514)
* Refactor(demo): change options to composition api (#6499)
* feat(demo): A-B
* feat(demo): update B-checkbox
* feat(demo): update CheckBox -DatePicker
* feat(demo): update DatePicker - Form
* feat(demo): update Form - List
* feat(demo): update List-pagination
* feat(demo): update List - skeleton
* feat(demo): update skeleton - switch
* feat(demo): update skeleton - switch
* feat(demo): update switch - upload
* feat(demo): update watermark
* fix(demo): del hashId
* fix: submenu type lose theme
* fix: dropdown menu hide error
* fix: dealing with switching topics modal, notification, message does not take effect close #6512 (#6518)
* fix: resolve dark mode not support
* fix: unified expression
* feat(modal): add useModal (#6517)
* feat(modal): add useModal hook
* feat(modal): add HookModal demo
* test(modal): update HookModal demo snap
* feat(modal): update modal docs
* chore(modal): update modal type
* perf: useModal #6517
* release 4.0.0-beta.1
* docs: fix tab demo error
* fix(config-provider): fix ConfigProvider.config is not function close #6528 (#6529)
* Feat(use): add useMessage useNotification (#6527)
* feat(Message): add useMessage hook
* feat(Notification): add useNotification hook
* feat(Message): add Hook demo
* feat(Notification): add Hook demo
* test(Message): update demo snap
* test(Notification): update demo snap
* docs(Message): update docs with FAQ
* docs(Notification): update docs with FAQ
* refactor: useMessage #6527
* refactor: useNotification #6527
* release 4.0.0-beta.2
* docs(button): update demo with space (#6536)
* feat(button): demo space
* test(button): update demo snap
* chore(button): disabled demo Ghost space
* test(button): update disabled demo snap
* docs(introduce): update docs (#6539)
* docs(introduce): update docs
* docs(introduce): add Dollar
* Update introduce.zh-CN.md
* Update introduce.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* docs(customize-theme): update docs (#6540)
* fix introduce doc
* fix getting-started doc
* add migration-v4 doc
* fix docs
* Update migration-v4.zh-CN.md
* Update migration-v4.zh-CN.md
* Update migration-v4.en-US.md
* Update migration-v4.zh-CN.md
* Update getting-started.en-US.md
* Update getting-started.zh-CN.md
* Update introduce.en-US.md
* Update introduce.zh-CN.md
* update customize-theme doc & fix migration-v4 error
* update customize-theme doc
* fix migration-v4 error
* remove SSR & shadowDom
* Update customize-theme.zh-CN.md
* Update customize-theme.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: getPopupContainer not work
* release 4.0.0-beta.3
* release 4.0.0-beta.4
* docs: update grid docs (#6549)
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
* test(alert): update demo with space (#6541)
* docs(alert): update demo with space
* docs(alert): update alert test snap
---------
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
* fix: components bug & update docs (#6548)
* fix bug
* fix test case and update snapshot,fix space merge class
* docs(grid): update migrate docs && delete xxxl in grid docs (#6562)
* fix: segmentd disabled label is undefined (#6556)
* fix: segmentd disabled label is undefined
* fix: segmentd disabled label is undefined
* fix: segmentd disabled label is undefined
* fix(grid): remove grid xxxl attribute (#6572)
* fix: remove grid xxxl attribute
* docs: remove xxxl in grid docs
* fix: tooltip custom color error
* feat: remove Step __legacy
* feat: add tour (#6332)
* feat v4 add tour
* fix type error
* sync tour from antd5.4.6 & fix type error
* fix error
* refactor: tour #6332
* fix: tour center
* fix: picker support v-show
* test: update snap
* test: update tour test
* fix: tour-mask attrs pointer-events (#6577)
* fix: tour animated
* feat: support vue 3.3 slot type
* release 4.0.0-rc.1
* release 4.0.0-rc.2, close #6588
* 4.0.0-rc.3
* chore: remove vue private api
* fix: paginantion error, close #6590
* release 4.0.0-rc.4
* fix: checxbox style
* fix: pagination mini size style
* release 4.0.0-rc.5
* docs: update v4 tabs doc error(#6606) (#6607)
* docs: add ant-design-vue nuxt module (#6620)
* fix: layout-sider and menu transition style(#6637) (#6640)
* docs: fixed the style error of online demo (#6630)
* feat: ✨checkbox label slot support use option label (#6642)
* docs: 📃change the default setting of "treeNodeFilterProp" from "value" to "label"
* revert: ↩revert this config and create another pr to commit
* feat: ✨checkbox label slot support use option label
* test: 🧪update checkbox *.snap file
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: add disabledContext override with form components (#6618)
* fix: add disabledContext override with form components
* test: update snap
* fix: LabelWidth demo filename
* fix: fontsize spelling mistake
* fix(tour): target position (#6629)
* style: format lint
* docs(form): add form disabled demo (#6658)
* fix: comment node error
* release 4.0
* fix: portalWrapper add autoLock prop (#6687), close #6649
* fix: image animation & zindex, close #6675
* docs(QRCode): Synchronize QR code demonstration and add SVG (#6660)
* fix: Synchronize QR code demonstration and add SVG
* fix: responsive loss and invalid border style
* docs: synchronize antd5.6.3 QRCode color in dark mode
* feat: calendar select support info.source param (#6697)
* docs: add ant-design-vue nuxt module
* feat: calendar select support info.source param
* docs: synchronous config-provider demo (#6706)
* revert: #6706
* docs: export space-compact types (#6716)
* release 4.0.0
---------
Co-authored-by: bqy_fe <1743369777@qq.com>
Co-authored-by: zkwolf <chenhao5866@gmail.com>
Co-authored-by: Zev Zhu <45655660+aibayanyu20@users.noreply.github.com>
Co-authored-by: lyn <76365499@qq.com>
Co-authored-by: 果冻橙 <shifeng199307@gmail.com>
Co-authored-by: songsong0707 <74165917+songsong0707@users.noreply.github.com>
Co-authored-by: yang <30883395+webvs2@users.noreply.github.com>
Co-authored-by: selicens <1244620067@qq.com>
Co-authored-by: 一堆菠萝 <53335668+JavanShen@users.noreply.github.com>
Co-authored-by: H1mple <35363759+baohangxing@users.noreply.github.com>
Co-authored-by: Cherry7 <79909910+CCherry07@users.noreply.github.com>
Co-authored-by: Konv Suu <2583695112@qq.com>
Co-authored-by: luoawai <32483950+luoawai@users.noreply.github.com>
Co-authored-by: 鱼见 <657715602@qq.com>
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
Co-authored-by: Cupid Valentine <53572196+valcosmos@users.noreply.github.com>
Co-authored-by: 专业逮虾户aa <30494925+waldonUB@users.noreply.github.com>
Co-authored-by: PanStar <PanStar@users.noreply.github.com>
2023-07-14 03:58:27 +00:00
|
|
|
|
const containerRef = shallowRef<HTMLDivElement>(null);
|
2022-01-21 13:58:10 +00:00
|
|
|
|
const selectorDomRef = createRef();
|
Feat v4 (#6329)
* refactor(icon): remove style dir (#6215)
* refactor: rename locale
* refactor: locale-provider
* refactor: modal
* refactor: menu
* fix: custom class (#6217)
* refactor: tooltip
* refactor: grid (#6220)
* refactor: grid
* fix(grid): align & justify responsive
* chore: update demo and snapshot
* fix: row ts type not work
* doc: update demo
* refactor: ts
* refactor: spin (#6222)
* fix: typo (#6218)
* fix: typo
* docs<upload>: docs update
* refactor: spin
* refactor: spin
* refactor: spin
* refactor: spinnn
* refactor: spin
---------
Co-authored-by: lyn <76365499@qq.com>
* fix: spin error #6222
* test: test case error (#6225)
* fix: inject value maybe undefined
* fix: tootip emit correct value
* fix: rollback warning suffix avoid test break
* doc(grid): remove unused type="flex"
* refactor: skeleton (#6224)
* refactor: skeleton
* refactor: skeleton style
* chore: modify skeleton demo style
* fix(button): link and text should not have wave (#6226)
* refactor: dropdown
* refactor: popover & popconfirm
* refactor(tag): less to cssinjs (#6227)
* refactor(empty): less to cssinjs (#6230)
* refactor(empty): less to cssinjs
* chore: remove unuse code
* fix: reactivity lose
* fix: empty props #6230
* refactor: progress style (#6234)
* refactor: progress
* refactor: progress style
* fix: progress attrs
* refactor: progress #6234
* refactor: switch (#6236)
* refactor: switch style
* refactor: delete switch style
* refactor:input (#6237)
* refactor:input
* fix inheritAttrs:false
* fix attrs.class
* feat: input add disabled
* refactor:comment (#6238)
* refactor:comment
* fix inheritAttrs: false & attrs.class
* refactor:pageheader (#6239)
* refactor:pageheader
* fix inheritAttrs: false & attrs.class
* refactor:statistic (#6240)
* refactor:statistic
* fix inheritAttrs: false & attrs.class
* refactor:list (#6241)
* refactor:list
* fix inheritAttrs: false & attrs.class
* feat: update type
* refactor(Space): less to cssinjs & add compact mode (#6229)
* refactor(Space): less to cssinjs & add compact mode
* chore(space): update md
* chore(space): add demo
* chore(space): add some demo
* feat(button): add compact mode
* fix: reactivity lose
* docs: fix props version
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* perf: space compact
* refactor:typography (#6244)
* refactor:typography
* fix return
* fix import type
* fix: typography #6244
* refactor:datepicker (#6245)
* refactor: datepicker type
* refactor: rate style (#6254)
* refactor(layout): less to cssinjs (#6249)
* doc: update layout cover
* refactor(result): less to cssinjs (#6246)
* refactor(result): less to cssinjs
* fix: class name is overridden
* docs: update result cover
* refactor:slider (#6250)
* feat: slider deprecated tooltipVisible
* refactor(crad): less to cssinjs (#6258)
* update
* switch
* Style adjustment
* refactor(Card): less to cssinjs
* Eliminate invalid code
* optimization and adjustment css
* Adjust the css
* Optimize each item
* adjustment css
* refactor: card #6258
* refactor:carousel (#6262)
* refactor:carousel
* docs:update & refactor: carousel type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor:transfer (#6247)
* refactor:transfer
* merge v4 branch & fix theme interface conflict
* docs:update & refactor: transfer type
* perf: transfer
* refactor:checkbox (#6248)
* refactor:checkbox
* docs:update & refactor: checkbox type
* feat: checkbox add disabled context
* refactor:pagination (#6251)
* refactor:pagination
* docs:update & refactor: pagination type
* style: update pagination props type
* refactor: mentions (#6255)
* refactor: mentions
* refactor: mentions menu provider
* doc: update mentions demo
* refcator:upload (#6261)
* refcator:upload
* docs:update & refactor: upload type
* Update style.ts
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* perf: upload motion
* refactor:timeline (#6263)
* refactor:timeline
* docs:update & refactor: timeline type
* perf: timeline
* refactor:steps (#6264)
* refactor:steps
* fix ...attrs
* fix StepsToken error
* docs:update & refactor: steps type
* fix: steps icon clss error
* refactor:collapse (#6266)
* refactor:collapse
* fix collapse props version
* docs:update & refactor: collapse type & fix collapsible
* feat: update collapse type
* refactor:inputnumber (#6265)
* refactor:inputnumber
* docs:update & refactor: inputnumber type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: number add compactSize & disabledContext
* refactor:table (#6267)
* refactor:table
* docs:update & refactor: table type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor: table
* feat: table add expandColumnTitle slot
* refactor:calendar (#6269)
* refactor:calendar
* docs:update
* refactor:timepicker (#6270)
* refactor:timepicker
* docs:update & refactor: timepicker type
* refactor:tree (#6276)
* Feat v4 fix type errors (#6285)
* fix compile type errors
* fix menuprops type import
* fix lint errors
* fix lint errors
* fix format error
* fix node version
* fix run dist error
* fix run lint
* fix as any
* fix string type
* refactor: rename locale file
* feat: tree add leafIcon
* [tabs] :less to cssinjs (#6288)
* update
* switch
* Style adjustment
* refactor(Card): less to cssinjs
* tabs: less to cssinjs 开发ing
* add function cssinjs
* Eliminate irrelevant code
* Eliminate irrelevant code 2
* update components
* Eliminate irrelevant input code
* refactor: tabs #6288
* feat: add segmented (#6286)
* refactor: segmented #6286
* refactor:select (#6295)
* refactor:select
* update doc
* delete useless
* feat: select add context size
* refactor: tree select (#6296)
* feat: tree-select add context size
* perf: table
* docs: update doc toc
* refactor: cascader
* refactor: auto-complete
* refactor: image
* refactor: drawer
* refactor:radio (#6299)
* refactor:radio
* fix attrs
* feat: radio add disabled context
* fix: some type & doc (#6292)
* fix: typo (#6218)
* fix: typo
* docs<upload>: docs update
* fix: type of minute in props disabledDateTime of DatePicker (#6233)
* docs: typo (#6256)
* feat: tooltip added overlayInnerStyle attribute
* Update abstractTooltipProps.ts
* Update Tooltip.tsx
---------
Co-authored-by: lyn <76365499@qq.com>
Co-authored-by: H1mple <35363759+baohangxing@users.noreply.github.com>
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor: form
* fix: directive not work
* fix: use open, remove visible
* doc: update cover
* refactor: remove not use code
* chore: update build script
* doc: update doc
* doc: refactor doc
* chore: update token error
* chore: update style
* refactor: rename _style to style
* fix: tag warning
* fix(dropdown): open invalid (#6316)
* feat: add watermark (#6300)
* feat: add watermark
* feat: add watermark demo
* feat: add mutationObserver
* feat: add watermark demo
* refactor: watermark type
* doc: add theme-editor
* fix: inject value maybe undefined && tag style invalid (#6320)
* fix: inject value maybe undefined
* fix(tag): style invalid
* feat: add qrcode (#6315)
* feat: add qrcode
* fix: qrcode bug
* fix: qrcode value required
* refactor: props deconstruct
* Feat v4 floatbutton (#6294)
* feat: add float-button components
* fix type & demo display
* fix components entry
* fix review bug
* fix bug
* fix .value
* refactor: qrcode #6315
* refactor: float-button
* fix: groupsize context error
* fix: floatbutton animation not work
* Feat v4 theme editor (#6348)
* feat: add theme editor container
* feat: add theme editor layout
* add left panel
* add vue-colorful & fix bug
* 修复hue组件抖动问题
* fix bug && add demo
* fix bug
* fix demo preview
* fix theme editor components demo
* fix: token effect error
* Feat v4 theme editor (#6349)
* feat: add theme editor container
* feat: add theme editor layout
* add left panel
* add vue-colorful & fix bug
* 修复hue组件抖动问题
* fix bug && add demo
* fix bug
* fix demo preview
* fix theme editor components demo
* add theme editor token drawer
* add theme editor token drawer
* fix bug
* open commment
* fix error demo
* fix theme editor bug
* fix: cssinjs effect error
* doc: format code
* fix: tag click event not trigger
* release 4.0.0-alpha.1
* fix: qrcode type
* fix: remove not use file
* doc: update doc site
* doc: update site
* doc: fix theme editor bgcolor (#6358)
* fix: motion not work
* release 4.0.0-alpha.2
* fix: qrcode ; error, close #6362
* fix docs dark theme & add docs coverDark (#6367)
* fix docs dark theme & add docs coverDark
* fix theme Editor edit
* fix: dropdown divider disappear, close #6365 (#6369)
* doc: update baner
* fix: button wave not work
* fix: ant-piker-cell-range-hover-end style error (#6373)
* fix: ant-piker-cell-range-hover-end style error
* feat: be consistent with antd
* feat: be consistent with antd
* fix: ConfigProvider error for style, close #6368
* release 4.0.0-alpha.4
* style: add dark style for `pre` and `code` (#6382)
* docs: version menu (#6390)
* Feat(DatePicker): increase presets prop (#6387)
* feat(date-picker): add PresetDate type
* feat(date-picker): add usePresets hook
* feat(date-picker): add PresetPanel Component
* feat(date-picker): add PresetPanel Component
* feat(demo): update Preset Ranges Examples
* feat(docs): add new prop presets
* feat(docs): add new prop presets with english
* fix(RangePicker): footer is not managed by panels
* chore(Picker): prefixCls default rc-picker
* chore(date-picker): update presetted-ranges demo
* chore(date-picker): update rangePickerProps'presets
* feat(date-picker): presets reactively processing
* chore(date-picker): update type
* refactor(RangePicker): deprecated ranges prop
* chore(date-picker): update type
* chore(PickerPanel): del notuse panelRef
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: datepicker presets error #6387
* docs: update datepicker doc #6387
* feat(Steps): add items prop and variants (#6406)
* refactor(steps): add items prop and variants
* feat(steps): add Label Placement and Inline Steps demo
* feat(steps): Label Placement and Inline Steps snap
* test(steps): Steps demo snap
* feat(Steps): update docs
* fix(Step): progressDot
* chore(useLegacyItems): change from warning to devWarning
* refactor(Steps): Remove useLegacyItems
* refactor(Steps): renderStep
* test(Steps): update test snapshot
* chore(Steps): filterEmpty
* feat(Steps): update docs
* docs: update site
* refactor: steps #6406
* test: update steps
* perf: shallowRef instead ref
* fix(Modal): fix modal locale (#6423)
* feat(StyleProvider): add StyleProvider handle cssinjs features (#6415)
* feat(StyleProvider): StyleProvider
* feat(StyleProvider): refactor to use context
* chore(StyleProvider): update AStyleProviderProps type
* chore(App): reback
* chore(StyleProvider): export StyleProvider
* feat(StyleProvider): update StyleProvider docs
* feat(StyleProvider): update StyleProvider docs
* feat(StyleProvider): add StyleProvider docs routes
* chore(StyleProvider): with useStyleProvider
* docs: update compatiple #6415
* feat(Progress): enhance size prop and add variants (#6409)
* refactor(progress): Progress size and add variants
* feat(progress): add `getsize`
* refactor(progress): Progress size and add variants
* chore(progress): update props type
* chore(progress): update props type
* feat(progress): update demo
* feat(progress): update docs
* test(progress): update test snap
* fix(Circle): Merging classes
* test(progress): update test snap
* feat(progress): add size demo
* test(progress): add size snapshot
* chore(Progress): reback Circle svg class change
* fix: progress borderRadius reactive #6409
* fix(defaultConfigProvider): add getPopupContainer (#6425), close #6419
* fix: qrcode size error, close #6418
* release 4.0.0-alpha.4
* fix: picker import error
* test: add QRCode unit testing (#6441)
* fix
* fix compile type errors
* fix menuprops type import
* fix lint errors
* fix lint errors
* fix format error
* fix node version
* fix run dist error
* fix run lint
* fix as any
* fix string type
* fix steps error & fix docs version select option & fix theme editor error
* fix(badge): badge props count default value error (#6433)
* docs: update site responsive
* fix: modal api method i18n not work, close #6438
* release 4.0.0-alpha.5
* chore(docs): update docs (#6446)
* docs(space): update demo
* docs(affix): update docs
* fix: cssinjs compatibility (#6454)
* feat: add convertLegacyToken
* docs: v4 vuedocs (#6468)
* fix introduce doc
* fix getting-started doc
* add migration-v4 doc
* fix docs
* Update migration-v4.zh-CN.md
* Update migration-v4.zh-CN.md
* Update migration-v4.en-US.md
* Update migration-v4.zh-CN.md
* Update getting-started.en-US.md
* Update getting-started.zh-CN.md
* Update introduce.en-US.md
* Update introduce.zh-CN.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: remove backtop
* feat(anchor): add direction action (#6447)
* refactor(anchor): direction show
* refactor(anchor): update anchor css
* feat(anchor): update demo
* test(anchor): update demo test snap
* feat(anchor): update docs
* Update index.zh-CN.md
* Update index.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: anchor add customTitle slot #6447
* docs: update doc anchor
* feat(menu): icon support function components with items and update demo (#6457)
* fix(menu): icon do not show problem
* fix(menu): icon do not show problem
* feat(menu): update demo
* test(menu): update demo snap
* chore(Menu): update docs
* test(Menu): update demo
* Update MenuItem.tsx
* Update SubMenu.tsx
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* doc: update menu icon
* feat: menu items icon add arg
* fix: antd.min error
* release 4.0.0-alpha.6
* fix: table resizable not work && type error (#6514)
* Refactor(demo): change options to composition api (#6499)
* feat(demo): A-B
* feat(demo): update B-checkbox
* feat(demo): update CheckBox -DatePicker
* feat(demo): update DatePicker - Form
* feat(demo): update Form - List
* feat(demo): update List-pagination
* feat(demo): update List - skeleton
* feat(demo): update skeleton - switch
* feat(demo): update skeleton - switch
* feat(demo): update switch - upload
* feat(demo): update watermark
* fix(demo): del hashId
* fix: submenu type lose theme
* fix: dropdown menu hide error
* fix: dealing with switching topics modal, notification, message does not take effect close #6512 (#6518)
* fix: resolve dark mode not support
* fix: unified expression
* feat(modal): add useModal (#6517)
* feat(modal): add useModal hook
* feat(modal): add HookModal demo
* test(modal): update HookModal demo snap
* feat(modal): update modal docs
* chore(modal): update modal type
* perf: useModal #6517
* release 4.0.0-beta.1
* docs: fix tab demo error
* fix(config-provider): fix ConfigProvider.config is not function close #6528 (#6529)
* Feat(use): add useMessage useNotification (#6527)
* feat(Message): add useMessage hook
* feat(Notification): add useNotification hook
* feat(Message): add Hook demo
* feat(Notification): add Hook demo
* test(Message): update demo snap
* test(Notification): update demo snap
* docs(Message): update docs with FAQ
* docs(Notification): update docs with FAQ
* refactor: useMessage #6527
* refactor: useNotification #6527
* release 4.0.0-beta.2
* docs(button): update demo with space (#6536)
* feat(button): demo space
* test(button): update demo snap
* chore(button): disabled demo Ghost space
* test(button): update disabled demo snap
* docs(introduce): update docs (#6539)
* docs(introduce): update docs
* docs(introduce): add Dollar
* Update introduce.zh-CN.md
* Update introduce.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* docs(customize-theme): update docs (#6540)
* fix introduce doc
* fix getting-started doc
* add migration-v4 doc
* fix docs
* Update migration-v4.zh-CN.md
* Update migration-v4.zh-CN.md
* Update migration-v4.en-US.md
* Update migration-v4.zh-CN.md
* Update getting-started.en-US.md
* Update getting-started.zh-CN.md
* Update introduce.en-US.md
* Update introduce.zh-CN.md
* update customize-theme doc & fix migration-v4 error
* update customize-theme doc
* fix migration-v4 error
* remove SSR & shadowDom
* Update customize-theme.zh-CN.md
* Update customize-theme.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: getPopupContainer not work
* release 4.0.0-beta.3
* release 4.0.0-beta.4
* docs: update grid docs (#6549)
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
* test(alert): update demo with space (#6541)
* docs(alert): update demo with space
* docs(alert): update alert test snap
---------
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
* fix: components bug & update docs (#6548)
* fix bug
* fix test case and update snapshot,fix space merge class
* docs(grid): update migrate docs && delete xxxl in grid docs (#6562)
* fix: segmentd disabled label is undefined (#6556)
* fix: segmentd disabled label is undefined
* fix: segmentd disabled label is undefined
* fix: segmentd disabled label is undefined
* fix(grid): remove grid xxxl attribute (#6572)
* fix: remove grid xxxl attribute
* docs: remove xxxl in grid docs
* fix: tooltip custom color error
* feat: remove Step __legacy
* feat: add tour (#6332)
* feat v4 add tour
* fix type error
* sync tour from antd5.4.6 & fix type error
* fix error
* refactor: tour #6332
* fix: tour center
* fix: picker support v-show
* test: update snap
* test: update tour test
* fix: tour-mask attrs pointer-events (#6577)
* fix: tour animated
* feat: support vue 3.3 slot type
* release 4.0.0-rc.1
* release 4.0.0-rc.2, close #6588
* 4.0.0-rc.3
* chore: remove vue private api
* fix: paginantion error, close #6590
* release 4.0.0-rc.4
* fix: checxbox style
* fix: pagination mini size style
* release 4.0.0-rc.5
* docs: update v4 tabs doc error(#6606) (#6607)
* docs: add ant-design-vue nuxt module (#6620)
* fix: layout-sider and menu transition style(#6637) (#6640)
* docs: fixed the style error of online demo (#6630)
* feat: ✨checkbox label slot support use option label (#6642)
* docs: 📃change the default setting of "treeNodeFilterProp" from "value" to "label"
* revert: ↩revert this config and create another pr to commit
* feat: ✨checkbox label slot support use option label
* test: 🧪update checkbox *.snap file
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: add disabledContext override with form components (#6618)
* fix: add disabledContext override with form components
* test: update snap
* fix: LabelWidth demo filename
* fix: fontsize spelling mistake
* fix(tour): target position (#6629)
* style: format lint
* docs(form): add form disabled demo (#6658)
* fix: comment node error
* release 4.0
* fix: portalWrapper add autoLock prop (#6687), close #6649
* fix: image animation & zindex, close #6675
* docs(QRCode): Synchronize QR code demonstration and add SVG (#6660)
* fix: Synchronize QR code demonstration and add SVG
* fix: responsive loss and invalid border style
* docs: synchronize antd5.6.3 QRCode color in dark mode
* feat: calendar select support info.source param (#6697)
* docs: add ant-design-vue nuxt module
* feat: calendar select support info.source param
* docs: synchronous config-provider demo (#6706)
* revert: #6706
* docs: export space-compact types (#6716)
* release 4.0.0
---------
Co-authored-by: bqy_fe <1743369777@qq.com>
Co-authored-by: zkwolf <chenhao5866@gmail.com>
Co-authored-by: Zev Zhu <45655660+aibayanyu20@users.noreply.github.com>
Co-authored-by: lyn <76365499@qq.com>
Co-authored-by: 果冻橙 <shifeng199307@gmail.com>
Co-authored-by: songsong0707 <74165917+songsong0707@users.noreply.github.com>
Co-authored-by: yang <30883395+webvs2@users.noreply.github.com>
Co-authored-by: selicens <1244620067@qq.com>
Co-authored-by: 一堆菠萝 <53335668+JavanShen@users.noreply.github.com>
Co-authored-by: H1mple <35363759+baohangxing@users.noreply.github.com>
Co-authored-by: Cherry7 <79909910+CCherry07@users.noreply.github.com>
Co-authored-by: Konv Suu <2583695112@qq.com>
Co-authored-by: luoawai <32483950+luoawai@users.noreply.github.com>
Co-authored-by: 鱼见 <657715602@qq.com>
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
Co-authored-by: Cupid Valentine <53572196+valcosmos@users.noreply.github.com>
Co-authored-by: 专业逮虾户aa <30494925+waldonUB@users.noreply.github.com>
Co-authored-by: PanStar <PanStar@users.noreply.github.com>
2023-07-14 03:58:27 +00:00
|
|
|
|
const triggerRef = shallowRef<RefTriggerProps>(null);
|
|
|
|
|
const selectorRef = shallowRef<RefSelectorProps>(null);
|
|
|
|
|
const listRef = shallowRef<RefOptionListProps>(null);
|
2022-01-21 13:58:10 +00:00
|
|
|
|
|
|
|
|
|
/** Used for component focused management */
|
|
|
|
|
const [mockFocused, setMockFocused, cancelSetMockFocused] = useDelayReset();
|
|
|
|
|
|
|
|
|
|
const focus = () => {
|
|
|
|
|
selectorRef.value?.focus();
|
|
|
|
|
};
|
|
|
|
|
const blur = () => {
|
|
|
|
|
selectorRef.value?.blur();
|
|
|
|
|
};
|
|
|
|
|
expose({
|
|
|
|
|
focus,
|
|
|
|
|
blur,
|
|
|
|
|
scrollTo: arg => listRef.value?.scrollTo(arg),
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
const mergedSearchValue = computed(() => {
|
|
|
|
|
if (props.mode !== 'combobox') {
|
|
|
|
|
return props.searchValue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const val = props.displayValues[0]?.value;
|
|
|
|
|
|
|
|
|
|
return typeof val === 'string' || typeof val === 'number' ? String(val) : '';
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// ============================== Open ==============================
|
|
|
|
|
const initOpen = props.open !== undefined ? props.open : props.defaultOpen;
|
Feat v4 (#6329)
* refactor(icon): remove style dir (#6215)
* refactor: rename locale
* refactor: locale-provider
* refactor: modal
* refactor: menu
* fix: custom class (#6217)
* refactor: tooltip
* refactor: grid (#6220)
* refactor: grid
* fix(grid): align & justify responsive
* chore: update demo and snapshot
* fix: row ts type not work
* doc: update demo
* refactor: ts
* refactor: spin (#6222)
* fix: typo (#6218)
* fix: typo
* docs<upload>: docs update
* refactor: spin
* refactor: spin
* refactor: spin
* refactor: spinnn
* refactor: spin
---------
Co-authored-by: lyn <76365499@qq.com>
* fix: spin error #6222
* test: test case error (#6225)
* fix: inject value maybe undefined
* fix: tootip emit correct value
* fix: rollback warning suffix avoid test break
* doc(grid): remove unused type="flex"
* refactor: skeleton (#6224)
* refactor: skeleton
* refactor: skeleton style
* chore: modify skeleton demo style
* fix(button): link and text should not have wave (#6226)
* refactor: dropdown
* refactor: popover & popconfirm
* refactor(tag): less to cssinjs (#6227)
* refactor(empty): less to cssinjs (#6230)
* refactor(empty): less to cssinjs
* chore: remove unuse code
* fix: reactivity lose
* fix: empty props #6230
* refactor: progress style (#6234)
* refactor: progress
* refactor: progress style
* fix: progress attrs
* refactor: progress #6234
* refactor: switch (#6236)
* refactor: switch style
* refactor: delete switch style
* refactor:input (#6237)
* refactor:input
* fix inheritAttrs:false
* fix attrs.class
* feat: input add disabled
* refactor:comment (#6238)
* refactor:comment
* fix inheritAttrs: false & attrs.class
* refactor:pageheader (#6239)
* refactor:pageheader
* fix inheritAttrs: false & attrs.class
* refactor:statistic (#6240)
* refactor:statistic
* fix inheritAttrs: false & attrs.class
* refactor:list (#6241)
* refactor:list
* fix inheritAttrs: false & attrs.class
* feat: update type
* refactor(Space): less to cssinjs & add compact mode (#6229)
* refactor(Space): less to cssinjs & add compact mode
* chore(space): update md
* chore(space): add demo
* chore(space): add some demo
* feat(button): add compact mode
* fix: reactivity lose
* docs: fix props version
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* perf: space compact
* refactor:typography (#6244)
* refactor:typography
* fix return
* fix import type
* fix: typography #6244
* refactor:datepicker (#6245)
* refactor: datepicker type
* refactor: rate style (#6254)
* refactor(layout): less to cssinjs (#6249)
* doc: update layout cover
* refactor(result): less to cssinjs (#6246)
* refactor(result): less to cssinjs
* fix: class name is overridden
* docs: update result cover
* refactor:slider (#6250)
* feat: slider deprecated tooltipVisible
* refactor(crad): less to cssinjs (#6258)
* update
* switch
* Style adjustment
* refactor(Card): less to cssinjs
* Eliminate invalid code
* optimization and adjustment css
* Adjust the css
* Optimize each item
* adjustment css
* refactor: card #6258
* refactor:carousel (#6262)
* refactor:carousel
* docs:update & refactor: carousel type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor:transfer (#6247)
* refactor:transfer
* merge v4 branch & fix theme interface conflict
* docs:update & refactor: transfer type
* perf: transfer
* refactor:checkbox (#6248)
* refactor:checkbox
* docs:update & refactor: checkbox type
* feat: checkbox add disabled context
* refactor:pagination (#6251)
* refactor:pagination
* docs:update & refactor: pagination type
* style: update pagination props type
* refactor: mentions (#6255)
* refactor: mentions
* refactor: mentions menu provider
* doc: update mentions demo
* refcator:upload (#6261)
* refcator:upload
* docs:update & refactor: upload type
* Update style.ts
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* perf: upload motion
* refactor:timeline (#6263)
* refactor:timeline
* docs:update & refactor: timeline type
* perf: timeline
* refactor:steps (#6264)
* refactor:steps
* fix ...attrs
* fix StepsToken error
* docs:update & refactor: steps type
* fix: steps icon clss error
* refactor:collapse (#6266)
* refactor:collapse
* fix collapse props version
* docs:update & refactor: collapse type & fix collapsible
* feat: update collapse type
* refactor:inputnumber (#6265)
* refactor:inputnumber
* docs:update & refactor: inputnumber type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: number add compactSize & disabledContext
* refactor:table (#6267)
* refactor:table
* docs:update & refactor: table type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor: table
* feat: table add expandColumnTitle slot
* refactor:calendar (#6269)
* refactor:calendar
* docs:update
* refactor:timepicker (#6270)
* refactor:timepicker
* docs:update & refactor: timepicker type
* refactor:tree (#6276)
* Feat v4 fix type errors (#6285)
* fix compile type errors
* fix menuprops type import
* fix lint errors
* fix lint errors
* fix format error
* fix node version
* fix run dist error
* fix run lint
* fix as any
* fix string type
* refactor: rename locale file
* feat: tree add leafIcon
* [tabs] :less to cssinjs (#6288)
* update
* switch
* Style adjustment
* refactor(Card): less to cssinjs
* tabs: less to cssinjs 开发ing
* add function cssinjs
* Eliminate irrelevant code
* Eliminate irrelevant code 2
* update components
* Eliminate irrelevant input code
* refactor: tabs #6288
* feat: add segmented (#6286)
* refactor: segmented #6286
* refactor:select (#6295)
* refactor:select
* update doc
* delete useless
* feat: select add context size
* refactor: tree select (#6296)
* feat: tree-select add context size
* perf: table
* docs: update doc toc
* refactor: cascader
* refactor: auto-complete
* refactor: image
* refactor: drawer
* refactor:radio (#6299)
* refactor:radio
* fix attrs
* feat: radio add disabled context
* fix: some type & doc (#6292)
* fix: typo (#6218)
* fix: typo
* docs<upload>: docs update
* fix: type of minute in props disabledDateTime of DatePicker (#6233)
* docs: typo (#6256)
* feat: tooltip added overlayInnerStyle attribute
* Update abstractTooltipProps.ts
* Update Tooltip.tsx
---------
Co-authored-by: lyn <76365499@qq.com>
Co-authored-by: H1mple <35363759+baohangxing@users.noreply.github.com>
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor: form
* fix: directive not work
* fix: use open, remove visible
* doc: update cover
* refactor: remove not use code
* chore: update build script
* doc: update doc
* doc: refactor doc
* chore: update token error
* chore: update style
* refactor: rename _style to style
* fix: tag warning
* fix(dropdown): open invalid (#6316)
* feat: add watermark (#6300)
* feat: add watermark
* feat: add watermark demo
* feat: add mutationObserver
* feat: add watermark demo
* refactor: watermark type
* doc: add theme-editor
* fix: inject value maybe undefined && tag style invalid (#6320)
* fix: inject value maybe undefined
* fix(tag): style invalid
* feat: add qrcode (#6315)
* feat: add qrcode
* fix: qrcode bug
* fix: qrcode value required
* refactor: props deconstruct
* Feat v4 floatbutton (#6294)
* feat: add float-button components
* fix type & demo display
* fix components entry
* fix review bug
* fix bug
* fix .value
* refactor: qrcode #6315
* refactor: float-button
* fix: groupsize context error
* fix: floatbutton animation not work
* Feat v4 theme editor (#6348)
* feat: add theme editor container
* feat: add theme editor layout
* add left panel
* add vue-colorful & fix bug
* 修复hue组件抖动问题
* fix bug && add demo
* fix bug
* fix demo preview
* fix theme editor components demo
* fix: token effect error
* Feat v4 theme editor (#6349)
* feat: add theme editor container
* feat: add theme editor layout
* add left panel
* add vue-colorful & fix bug
* 修复hue组件抖动问题
* fix bug && add demo
* fix bug
* fix demo preview
* fix theme editor components demo
* add theme editor token drawer
* add theme editor token drawer
* fix bug
* open commment
* fix error demo
* fix theme editor bug
* fix: cssinjs effect error
* doc: format code
* fix: tag click event not trigger
* release 4.0.0-alpha.1
* fix: qrcode type
* fix: remove not use file
* doc: update doc site
* doc: update site
* doc: fix theme editor bgcolor (#6358)
* fix: motion not work
* release 4.0.0-alpha.2
* fix: qrcode ; error, close #6362
* fix docs dark theme & add docs coverDark (#6367)
* fix docs dark theme & add docs coverDark
* fix theme Editor edit
* fix: dropdown divider disappear, close #6365 (#6369)
* doc: update baner
* fix: button wave not work
* fix: ant-piker-cell-range-hover-end style error (#6373)
* fix: ant-piker-cell-range-hover-end style error
* feat: be consistent with antd
* feat: be consistent with antd
* fix: ConfigProvider error for style, close #6368
* release 4.0.0-alpha.4
* style: add dark style for `pre` and `code` (#6382)
* docs: version menu (#6390)
* Feat(DatePicker): increase presets prop (#6387)
* feat(date-picker): add PresetDate type
* feat(date-picker): add usePresets hook
* feat(date-picker): add PresetPanel Component
* feat(date-picker): add PresetPanel Component
* feat(demo): update Preset Ranges Examples
* feat(docs): add new prop presets
* feat(docs): add new prop presets with english
* fix(RangePicker): footer is not managed by panels
* chore(Picker): prefixCls default rc-picker
* chore(date-picker): update presetted-ranges demo
* chore(date-picker): update rangePickerProps'presets
* feat(date-picker): presets reactively processing
* chore(date-picker): update type
* refactor(RangePicker): deprecated ranges prop
* chore(date-picker): update type
* chore(PickerPanel): del notuse panelRef
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: datepicker presets error #6387
* docs: update datepicker doc #6387
* feat(Steps): add items prop and variants (#6406)
* refactor(steps): add items prop and variants
* feat(steps): add Label Placement and Inline Steps demo
* feat(steps): Label Placement and Inline Steps snap
* test(steps): Steps demo snap
* feat(Steps): update docs
* fix(Step): progressDot
* chore(useLegacyItems): change from warning to devWarning
* refactor(Steps): Remove useLegacyItems
* refactor(Steps): renderStep
* test(Steps): update test snapshot
* chore(Steps): filterEmpty
* feat(Steps): update docs
* docs: update site
* refactor: steps #6406
* test: update steps
* perf: shallowRef instead ref
* fix(Modal): fix modal locale (#6423)
* feat(StyleProvider): add StyleProvider handle cssinjs features (#6415)
* feat(StyleProvider): StyleProvider
* feat(StyleProvider): refactor to use context
* chore(StyleProvider): update AStyleProviderProps type
* chore(App): reback
* chore(StyleProvider): export StyleProvider
* feat(StyleProvider): update StyleProvider docs
* feat(StyleProvider): update StyleProvider docs
* feat(StyleProvider): add StyleProvider docs routes
* chore(StyleProvider): with useStyleProvider
* docs: update compatiple #6415
* feat(Progress): enhance size prop and add variants (#6409)
* refactor(progress): Progress size and add variants
* feat(progress): add `getsize`
* refactor(progress): Progress size and add variants
* chore(progress): update props type
* chore(progress): update props type
* feat(progress): update demo
* feat(progress): update docs
* test(progress): update test snap
* fix(Circle): Merging classes
* test(progress): update test snap
* feat(progress): add size demo
* test(progress): add size snapshot
* chore(Progress): reback Circle svg class change
* fix: progress borderRadius reactive #6409
* fix(defaultConfigProvider): add getPopupContainer (#6425), close #6419
* fix: qrcode size error, close #6418
* release 4.0.0-alpha.4
* fix: picker import error
* test: add QRCode unit testing (#6441)
* fix
* fix compile type errors
* fix menuprops type import
* fix lint errors
* fix lint errors
* fix format error
* fix node version
* fix run dist error
* fix run lint
* fix as any
* fix string type
* fix steps error & fix docs version select option & fix theme editor error
* fix(badge): badge props count default value error (#6433)
* docs: update site responsive
* fix: modal api method i18n not work, close #6438
* release 4.0.0-alpha.5
* chore(docs): update docs (#6446)
* docs(space): update demo
* docs(affix): update docs
* fix: cssinjs compatibility (#6454)
* feat: add convertLegacyToken
* docs: v4 vuedocs (#6468)
* fix introduce doc
* fix getting-started doc
* add migration-v4 doc
* fix docs
* Update migration-v4.zh-CN.md
* Update migration-v4.zh-CN.md
* Update migration-v4.en-US.md
* Update migration-v4.zh-CN.md
* Update getting-started.en-US.md
* Update getting-started.zh-CN.md
* Update introduce.en-US.md
* Update introduce.zh-CN.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: remove backtop
* feat(anchor): add direction action (#6447)
* refactor(anchor): direction show
* refactor(anchor): update anchor css
* feat(anchor): update demo
* test(anchor): update demo test snap
* feat(anchor): update docs
* Update index.zh-CN.md
* Update index.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: anchor add customTitle slot #6447
* docs: update doc anchor
* feat(menu): icon support function components with items and update demo (#6457)
* fix(menu): icon do not show problem
* fix(menu): icon do not show problem
* feat(menu): update demo
* test(menu): update demo snap
* chore(Menu): update docs
* test(Menu): update demo
* Update MenuItem.tsx
* Update SubMenu.tsx
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* doc: update menu icon
* feat: menu items icon add arg
* fix: antd.min error
* release 4.0.0-alpha.6
* fix: table resizable not work && type error (#6514)
* Refactor(demo): change options to composition api (#6499)
* feat(demo): A-B
* feat(demo): update B-checkbox
* feat(demo): update CheckBox -DatePicker
* feat(demo): update DatePicker - Form
* feat(demo): update Form - List
* feat(demo): update List-pagination
* feat(demo): update List - skeleton
* feat(demo): update skeleton - switch
* feat(demo): update skeleton - switch
* feat(demo): update switch - upload
* feat(demo): update watermark
* fix(demo): del hashId
* fix: submenu type lose theme
* fix: dropdown menu hide error
* fix: dealing with switching topics modal, notification, message does not take effect close #6512 (#6518)
* fix: resolve dark mode not support
* fix: unified expression
* feat(modal): add useModal (#6517)
* feat(modal): add useModal hook
* feat(modal): add HookModal demo
* test(modal): update HookModal demo snap
* feat(modal): update modal docs
* chore(modal): update modal type
* perf: useModal #6517
* release 4.0.0-beta.1
* docs: fix tab demo error
* fix(config-provider): fix ConfigProvider.config is not function close #6528 (#6529)
* Feat(use): add useMessage useNotification (#6527)
* feat(Message): add useMessage hook
* feat(Notification): add useNotification hook
* feat(Message): add Hook demo
* feat(Notification): add Hook demo
* test(Message): update demo snap
* test(Notification): update demo snap
* docs(Message): update docs with FAQ
* docs(Notification): update docs with FAQ
* refactor: useMessage #6527
* refactor: useNotification #6527
* release 4.0.0-beta.2
* docs(button): update demo with space (#6536)
* feat(button): demo space
* test(button): update demo snap
* chore(button): disabled demo Ghost space
* test(button): update disabled demo snap
* docs(introduce): update docs (#6539)
* docs(introduce): update docs
* docs(introduce): add Dollar
* Update introduce.zh-CN.md
* Update introduce.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* docs(customize-theme): update docs (#6540)
* fix introduce doc
* fix getting-started doc
* add migration-v4 doc
* fix docs
* Update migration-v4.zh-CN.md
* Update migration-v4.zh-CN.md
* Update migration-v4.en-US.md
* Update migration-v4.zh-CN.md
* Update getting-started.en-US.md
* Update getting-started.zh-CN.md
* Update introduce.en-US.md
* Update introduce.zh-CN.md
* update customize-theme doc & fix migration-v4 error
* update customize-theme doc
* fix migration-v4 error
* remove SSR & shadowDom
* Update customize-theme.zh-CN.md
* Update customize-theme.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: getPopupContainer not work
* release 4.0.0-beta.3
* release 4.0.0-beta.4
* docs: update grid docs (#6549)
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
* test(alert): update demo with space (#6541)
* docs(alert): update demo with space
* docs(alert): update alert test snap
---------
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
* fix: components bug & update docs (#6548)
* fix bug
* fix test case and update snapshot,fix space merge class
* docs(grid): update migrate docs && delete xxxl in grid docs (#6562)
* fix: segmentd disabled label is undefined (#6556)
* fix: segmentd disabled label is undefined
* fix: segmentd disabled label is undefined
* fix: segmentd disabled label is undefined
* fix(grid): remove grid xxxl attribute (#6572)
* fix: remove grid xxxl attribute
* docs: remove xxxl in grid docs
* fix: tooltip custom color error
* feat: remove Step __legacy
* feat: add tour (#6332)
* feat v4 add tour
* fix type error
* sync tour from antd5.4.6 & fix type error
* fix error
* refactor: tour #6332
* fix: tour center
* fix: picker support v-show
* test: update snap
* test: update tour test
* fix: tour-mask attrs pointer-events (#6577)
* fix: tour animated
* feat: support vue 3.3 slot type
* release 4.0.0-rc.1
* release 4.0.0-rc.2, close #6588
* 4.0.0-rc.3
* chore: remove vue private api
* fix: paginantion error, close #6590
* release 4.0.0-rc.4
* fix: checxbox style
* fix: pagination mini size style
* release 4.0.0-rc.5
* docs: update v4 tabs doc error(#6606) (#6607)
* docs: add ant-design-vue nuxt module (#6620)
* fix: layout-sider and menu transition style(#6637) (#6640)
* docs: fixed the style error of online demo (#6630)
* feat: ✨checkbox label slot support use option label (#6642)
* docs: 📃change the default setting of "treeNodeFilterProp" from "value" to "label"
* revert: ↩revert this config and create another pr to commit
* feat: ✨checkbox label slot support use option label
* test: 🧪update checkbox *.snap file
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: add disabledContext override with form components (#6618)
* fix: add disabledContext override with form components
* test: update snap
* fix: LabelWidth demo filename
* fix: fontsize spelling mistake
* fix(tour): target position (#6629)
* style: format lint
* docs(form): add form disabled demo (#6658)
* fix: comment node error
* release 4.0
* fix: portalWrapper add autoLock prop (#6687), close #6649
* fix: image animation & zindex, close #6675
* docs(QRCode): Synchronize QR code demonstration and add SVG (#6660)
* fix: Synchronize QR code demonstration and add SVG
* fix: responsive loss and invalid border style
* docs: synchronize antd5.6.3 QRCode color in dark mode
* feat: calendar select support info.source param (#6697)
* docs: add ant-design-vue nuxt module
* feat: calendar select support info.source param
* docs: synchronous config-provider demo (#6706)
* revert: #6706
* docs: export space-compact types (#6716)
* release 4.0.0
---------
Co-authored-by: bqy_fe <1743369777@qq.com>
Co-authored-by: zkwolf <chenhao5866@gmail.com>
Co-authored-by: Zev Zhu <45655660+aibayanyu20@users.noreply.github.com>
Co-authored-by: lyn <76365499@qq.com>
Co-authored-by: 果冻橙 <shifeng199307@gmail.com>
Co-authored-by: songsong0707 <74165917+songsong0707@users.noreply.github.com>
Co-authored-by: yang <30883395+webvs2@users.noreply.github.com>
Co-authored-by: selicens <1244620067@qq.com>
Co-authored-by: 一堆菠萝 <53335668+JavanShen@users.noreply.github.com>
Co-authored-by: H1mple <35363759+baohangxing@users.noreply.github.com>
Co-authored-by: Cherry7 <79909910+CCherry07@users.noreply.github.com>
Co-authored-by: Konv Suu <2583695112@qq.com>
Co-authored-by: luoawai <32483950+luoawai@users.noreply.github.com>
Co-authored-by: 鱼见 <657715602@qq.com>
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
Co-authored-by: Cupid Valentine <53572196+valcosmos@users.noreply.github.com>
Co-authored-by: 专业逮虾户aa <30494925+waldonUB@users.noreply.github.com>
Co-authored-by: PanStar <PanStar@users.noreply.github.com>
2023-07-14 03:58:27 +00:00
|
|
|
|
const innerOpen = shallowRef(initOpen);
|
|
|
|
|
const mergedOpen = shallowRef(initOpen);
|
2022-01-21 13:58:10 +00:00
|
|
|
|
const setInnerOpen = (val: boolean) => {
|
|
|
|
|
innerOpen.value = props.open !== undefined ? props.open : val;
|
|
|
|
|
mergedOpen.value = innerOpen.value;
|
|
|
|
|
};
|
|
|
|
|
watch(
|
|
|
|
|
() => props.open,
|
|
|
|
|
() => {
|
|
|
|
|
setInnerOpen(props.open);
|
|
|
|
|
},
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// Not trigger `open` in `combobox` when `notFoundContent` is empty
|
|
|
|
|
const emptyListContent = computed(() => !props.notFoundContent && props.emptyOptions);
|
|
|
|
|
|
|
|
|
|
watchEffect(() => {
|
|
|
|
|
mergedOpen.value = innerOpen.value;
|
|
|
|
|
if (
|
|
|
|
|
props.disabled ||
|
|
|
|
|
(emptyListContent.value && mergedOpen.value && props.mode === 'combobox')
|
|
|
|
|
) {
|
|
|
|
|
mergedOpen.value = false;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
const triggerOpen = computed(() => (emptyListContent.value ? false : mergedOpen.value));
|
|
|
|
|
|
|
|
|
|
const onToggleOpen = (newOpen?: boolean) => {
|
|
|
|
|
const nextOpen = newOpen !== undefined ? newOpen : !mergedOpen.value;
|
|
|
|
|
|
|
|
|
|
if (innerOpen.value !== nextOpen && !props.disabled) {
|
|
|
|
|
setInnerOpen(nextOpen);
|
|
|
|
|
if (props.onDropdownVisibleChange) {
|
|
|
|
|
props.onDropdownVisibleChange(nextOpen);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const tokenWithEnter = computed(() =>
|
|
|
|
|
(props.tokenSeparators || []).some(tokenSeparator => ['\n', '\r\n'].includes(tokenSeparator)),
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
const onInternalSearch = (searchText: string, fromTyping: boolean, isCompositing: boolean) => {
|
|
|
|
|
let ret = true;
|
|
|
|
|
let newSearchText = searchText;
|
|
|
|
|
props.onActiveValueChange?.(null);
|
|
|
|
|
|
|
|
|
|
// Check if match the `tokenSeparators`
|
|
|
|
|
const patchLabels: string[] = isCompositing
|
|
|
|
|
? null
|
|
|
|
|
: getSeparatedContent(searchText, props.tokenSeparators);
|
|
|
|
|
|
|
|
|
|
// Ignore combobox since it's not split-able
|
|
|
|
|
if (props.mode !== 'combobox' && patchLabels) {
|
|
|
|
|
newSearchText = '';
|
|
|
|
|
|
|
|
|
|
props.onSearchSplit?.(patchLabels);
|
|
|
|
|
|
|
|
|
|
// Should close when paste finish
|
|
|
|
|
onToggleOpen(false);
|
|
|
|
|
|
|
|
|
|
// Tell Selector that break next actions
|
|
|
|
|
ret = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (props.onSearch && mergedSearchValue.value !== newSearchText) {
|
|
|
|
|
props.onSearch(newSearchText, {
|
|
|
|
|
source: fromTyping ? 'typing' : 'effect',
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// Only triggered when menu is closed & mode is tags
|
|
|
|
|
// If menu is open, OptionList will take charge
|
|
|
|
|
// If mode isn't tags, press enter is not meaningful when you can't see any option
|
|
|
|
|
const onInternalSearchSubmit = (searchText: string) => {
|
|
|
|
|
// prevent empty tags from appearing when you click the Enter button
|
|
|
|
|
if (!searchText || !searchText.trim()) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
props.onSearch?.(searchText, { source: 'submit' });
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// Close will clean up single mode search text
|
|
|
|
|
watch(
|
|
|
|
|
mergedOpen,
|
|
|
|
|
() => {
|
|
|
|
|
if (!mergedOpen.value && !multiple.value && props.mode !== 'combobox') {
|
|
|
|
|
onInternalSearch('', false, false);
|
|
|
|
|
}
|
|
|
|
|
},
|
2022-04-23 06:29:08 +00:00
|
|
|
|
{ immediate: true, flush: 'post' },
|
2022-01-21 13:58:10 +00:00
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// ============================ Disabled ============================
|
|
|
|
|
// Close dropdown & remove focus state when disabled change
|
|
|
|
|
watch(
|
|
|
|
|
() => props.disabled,
|
|
|
|
|
() => {
|
|
|
|
|
if (innerOpen.value && !!props.disabled) {
|
|
|
|
|
setInnerOpen(false);
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
{ immediate: true },
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// ============================ Keyboard ============================
|
|
|
|
|
/**
|
|
|
|
|
* We record input value here to check if can press to clean up by backspace
|
|
|
|
|
* - null: Key is not down, this is reset by key up
|
|
|
|
|
* - true: Search text is empty when first time backspace down
|
|
|
|
|
* - false: Search text is not empty when first time backspace down
|
|
|
|
|
*/
|
|
|
|
|
const [getClearLock, setClearLock] = useLock();
|
|
|
|
|
|
|
|
|
|
// KeyDown
|
|
|
|
|
const onInternalKeyDown: KeyboardEventHandler = (event, ...rest) => {
|
|
|
|
|
const clearLock = getClearLock();
|
|
|
|
|
const { which } = event;
|
|
|
|
|
|
|
|
|
|
if (which === KeyCode.ENTER) {
|
|
|
|
|
// Do not submit form when type in the input
|
|
|
|
|
if (props.mode !== 'combobox') {
|
|
|
|
|
event.preventDefault();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// We only manage open state here, close logic should handle by list component
|
|
|
|
|
if (!mergedOpen.value) {
|
|
|
|
|
onToggleOpen(true);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
setClearLock(!!mergedSearchValue.value);
|
|
|
|
|
|
|
|
|
|
// Remove value by `backspace`
|
|
|
|
|
if (
|
|
|
|
|
which === KeyCode.BACKSPACE &&
|
|
|
|
|
!clearLock &&
|
|
|
|
|
multiple.value &&
|
|
|
|
|
!mergedSearchValue.value &&
|
|
|
|
|
props.displayValues.length
|
|
|
|
|
) {
|
|
|
|
|
const cloneDisplayValues = [...props.displayValues];
|
|
|
|
|
let removedDisplayValue = null;
|
|
|
|
|
|
|
|
|
|
for (let i = cloneDisplayValues.length - 1; i >= 0; i -= 1) {
|
|
|
|
|
const current = cloneDisplayValues[i];
|
|
|
|
|
|
|
|
|
|
if (!current.disabled) {
|
|
|
|
|
cloneDisplayValues.splice(i, 1);
|
|
|
|
|
removedDisplayValue = current;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (removedDisplayValue) {
|
|
|
|
|
props.onDisplayValuesChange(cloneDisplayValues, {
|
|
|
|
|
type: 'remove',
|
|
|
|
|
values: [removedDisplayValue],
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (mergedOpen.value && listRef.value) {
|
|
|
|
|
listRef.value.onKeydown(event, ...rest);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
props.onKeydown?.(event, ...rest);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// KeyUp
|
|
|
|
|
const onInternalKeyUp: KeyboardEventHandler = (event: KeyboardEvent, ...rest) => {
|
|
|
|
|
if (mergedOpen.value && listRef.value) {
|
|
|
|
|
listRef.value.onKeyup(event, ...rest);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (props.onKeyup) {
|
|
|
|
|
props.onKeyup(event, ...rest);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// ============================ Selector ============================
|
|
|
|
|
const onSelectorRemove = (val: DisplayValueType) => {
|
|
|
|
|
const newValues = props.displayValues.filter(i => i !== val);
|
|
|
|
|
|
|
|
|
|
props.onDisplayValuesChange(newValues, {
|
|
|
|
|
type: 'remove',
|
|
|
|
|
values: [val],
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// ========================== Focus / Blur ==========================
|
|
|
|
|
/** Record real focus status */
|
Feat v4 (#6329)
* refactor(icon): remove style dir (#6215)
* refactor: rename locale
* refactor: locale-provider
* refactor: modal
* refactor: menu
* fix: custom class (#6217)
* refactor: tooltip
* refactor: grid (#6220)
* refactor: grid
* fix(grid): align & justify responsive
* chore: update demo and snapshot
* fix: row ts type not work
* doc: update demo
* refactor: ts
* refactor: spin (#6222)
* fix: typo (#6218)
* fix: typo
* docs<upload>: docs update
* refactor: spin
* refactor: spin
* refactor: spin
* refactor: spinnn
* refactor: spin
---------
Co-authored-by: lyn <76365499@qq.com>
* fix: spin error #6222
* test: test case error (#6225)
* fix: inject value maybe undefined
* fix: tootip emit correct value
* fix: rollback warning suffix avoid test break
* doc(grid): remove unused type="flex"
* refactor: skeleton (#6224)
* refactor: skeleton
* refactor: skeleton style
* chore: modify skeleton demo style
* fix(button): link and text should not have wave (#6226)
* refactor: dropdown
* refactor: popover & popconfirm
* refactor(tag): less to cssinjs (#6227)
* refactor(empty): less to cssinjs (#6230)
* refactor(empty): less to cssinjs
* chore: remove unuse code
* fix: reactivity lose
* fix: empty props #6230
* refactor: progress style (#6234)
* refactor: progress
* refactor: progress style
* fix: progress attrs
* refactor: progress #6234
* refactor: switch (#6236)
* refactor: switch style
* refactor: delete switch style
* refactor:input (#6237)
* refactor:input
* fix inheritAttrs:false
* fix attrs.class
* feat: input add disabled
* refactor:comment (#6238)
* refactor:comment
* fix inheritAttrs: false & attrs.class
* refactor:pageheader (#6239)
* refactor:pageheader
* fix inheritAttrs: false & attrs.class
* refactor:statistic (#6240)
* refactor:statistic
* fix inheritAttrs: false & attrs.class
* refactor:list (#6241)
* refactor:list
* fix inheritAttrs: false & attrs.class
* feat: update type
* refactor(Space): less to cssinjs & add compact mode (#6229)
* refactor(Space): less to cssinjs & add compact mode
* chore(space): update md
* chore(space): add demo
* chore(space): add some demo
* feat(button): add compact mode
* fix: reactivity lose
* docs: fix props version
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* perf: space compact
* refactor:typography (#6244)
* refactor:typography
* fix return
* fix import type
* fix: typography #6244
* refactor:datepicker (#6245)
* refactor: datepicker type
* refactor: rate style (#6254)
* refactor(layout): less to cssinjs (#6249)
* doc: update layout cover
* refactor(result): less to cssinjs (#6246)
* refactor(result): less to cssinjs
* fix: class name is overridden
* docs: update result cover
* refactor:slider (#6250)
* feat: slider deprecated tooltipVisible
* refactor(crad): less to cssinjs (#6258)
* update
* switch
* Style adjustment
* refactor(Card): less to cssinjs
* Eliminate invalid code
* optimization and adjustment css
* Adjust the css
* Optimize each item
* adjustment css
* refactor: card #6258
* refactor:carousel (#6262)
* refactor:carousel
* docs:update & refactor: carousel type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor:transfer (#6247)
* refactor:transfer
* merge v4 branch & fix theme interface conflict
* docs:update & refactor: transfer type
* perf: transfer
* refactor:checkbox (#6248)
* refactor:checkbox
* docs:update & refactor: checkbox type
* feat: checkbox add disabled context
* refactor:pagination (#6251)
* refactor:pagination
* docs:update & refactor: pagination type
* style: update pagination props type
* refactor: mentions (#6255)
* refactor: mentions
* refactor: mentions menu provider
* doc: update mentions demo
* refcator:upload (#6261)
* refcator:upload
* docs:update & refactor: upload type
* Update style.ts
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* perf: upload motion
* refactor:timeline (#6263)
* refactor:timeline
* docs:update & refactor: timeline type
* perf: timeline
* refactor:steps (#6264)
* refactor:steps
* fix ...attrs
* fix StepsToken error
* docs:update & refactor: steps type
* fix: steps icon clss error
* refactor:collapse (#6266)
* refactor:collapse
* fix collapse props version
* docs:update & refactor: collapse type & fix collapsible
* feat: update collapse type
* refactor:inputnumber (#6265)
* refactor:inputnumber
* docs:update & refactor: inputnumber type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: number add compactSize & disabledContext
* refactor:table (#6267)
* refactor:table
* docs:update & refactor: table type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor: table
* feat: table add expandColumnTitle slot
* refactor:calendar (#6269)
* refactor:calendar
* docs:update
* refactor:timepicker (#6270)
* refactor:timepicker
* docs:update & refactor: timepicker type
* refactor:tree (#6276)
* Feat v4 fix type errors (#6285)
* fix compile type errors
* fix menuprops type import
* fix lint errors
* fix lint errors
* fix format error
* fix node version
* fix run dist error
* fix run lint
* fix as any
* fix string type
* refactor: rename locale file
* feat: tree add leafIcon
* [tabs] :less to cssinjs (#6288)
* update
* switch
* Style adjustment
* refactor(Card): less to cssinjs
* tabs: less to cssinjs 开发ing
* add function cssinjs
* Eliminate irrelevant code
* Eliminate irrelevant code 2
* update components
* Eliminate irrelevant input code
* refactor: tabs #6288
* feat: add segmented (#6286)
* refactor: segmented #6286
* refactor:select (#6295)
* refactor:select
* update doc
* delete useless
* feat: select add context size
* refactor: tree select (#6296)
* feat: tree-select add context size
* perf: table
* docs: update doc toc
* refactor: cascader
* refactor: auto-complete
* refactor: image
* refactor: drawer
* refactor:radio (#6299)
* refactor:radio
* fix attrs
* feat: radio add disabled context
* fix: some type & doc (#6292)
* fix: typo (#6218)
* fix: typo
* docs<upload>: docs update
* fix: type of minute in props disabledDateTime of DatePicker (#6233)
* docs: typo (#6256)
* feat: tooltip added overlayInnerStyle attribute
* Update abstractTooltipProps.ts
* Update Tooltip.tsx
---------
Co-authored-by: lyn <76365499@qq.com>
Co-authored-by: H1mple <35363759+baohangxing@users.noreply.github.com>
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor: form
* fix: directive not work
* fix: use open, remove visible
* doc: update cover
* refactor: remove not use code
* chore: update build script
* doc: update doc
* doc: refactor doc
* chore: update token error
* chore: update style
* refactor: rename _style to style
* fix: tag warning
* fix(dropdown): open invalid (#6316)
* feat: add watermark (#6300)
* feat: add watermark
* feat: add watermark demo
* feat: add mutationObserver
* feat: add watermark demo
* refactor: watermark type
* doc: add theme-editor
* fix: inject value maybe undefined && tag style invalid (#6320)
* fix: inject value maybe undefined
* fix(tag): style invalid
* feat: add qrcode (#6315)
* feat: add qrcode
* fix: qrcode bug
* fix: qrcode value required
* refactor: props deconstruct
* Feat v4 floatbutton (#6294)
* feat: add float-button components
* fix type & demo display
* fix components entry
* fix review bug
* fix bug
* fix .value
* refactor: qrcode #6315
* refactor: float-button
* fix: groupsize context error
* fix: floatbutton animation not work
* Feat v4 theme editor (#6348)
* feat: add theme editor container
* feat: add theme editor layout
* add left panel
* add vue-colorful & fix bug
* 修复hue组件抖动问题
* fix bug && add demo
* fix bug
* fix demo preview
* fix theme editor components demo
* fix: token effect error
* Feat v4 theme editor (#6349)
* feat: add theme editor container
* feat: add theme editor layout
* add left panel
* add vue-colorful & fix bug
* 修复hue组件抖动问题
* fix bug && add demo
* fix bug
* fix demo preview
* fix theme editor components demo
* add theme editor token drawer
* add theme editor token drawer
* fix bug
* open commment
* fix error demo
* fix theme editor bug
* fix: cssinjs effect error
* doc: format code
* fix: tag click event not trigger
* release 4.0.0-alpha.1
* fix: qrcode type
* fix: remove not use file
* doc: update doc site
* doc: update site
* doc: fix theme editor bgcolor (#6358)
* fix: motion not work
* release 4.0.0-alpha.2
* fix: qrcode ; error, close #6362
* fix docs dark theme & add docs coverDark (#6367)
* fix docs dark theme & add docs coverDark
* fix theme Editor edit
* fix: dropdown divider disappear, close #6365 (#6369)
* doc: update baner
* fix: button wave not work
* fix: ant-piker-cell-range-hover-end style error (#6373)
* fix: ant-piker-cell-range-hover-end style error
* feat: be consistent with antd
* feat: be consistent with antd
* fix: ConfigProvider error for style, close #6368
* release 4.0.0-alpha.4
* style: add dark style for `pre` and `code` (#6382)
* docs: version menu (#6390)
* Feat(DatePicker): increase presets prop (#6387)
* feat(date-picker): add PresetDate type
* feat(date-picker): add usePresets hook
* feat(date-picker): add PresetPanel Component
* feat(date-picker): add PresetPanel Component
* feat(demo): update Preset Ranges Examples
* feat(docs): add new prop presets
* feat(docs): add new prop presets with english
* fix(RangePicker): footer is not managed by panels
* chore(Picker): prefixCls default rc-picker
* chore(date-picker): update presetted-ranges demo
* chore(date-picker): update rangePickerProps'presets
* feat(date-picker): presets reactively processing
* chore(date-picker): update type
* refactor(RangePicker): deprecated ranges prop
* chore(date-picker): update type
* chore(PickerPanel): del notuse panelRef
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: datepicker presets error #6387
* docs: update datepicker doc #6387
* feat(Steps): add items prop and variants (#6406)
* refactor(steps): add items prop and variants
* feat(steps): add Label Placement and Inline Steps demo
* feat(steps): Label Placement and Inline Steps snap
* test(steps): Steps demo snap
* feat(Steps): update docs
* fix(Step): progressDot
* chore(useLegacyItems): change from warning to devWarning
* refactor(Steps): Remove useLegacyItems
* refactor(Steps): renderStep
* test(Steps): update test snapshot
* chore(Steps): filterEmpty
* feat(Steps): update docs
* docs: update site
* refactor: steps #6406
* test: update steps
* perf: shallowRef instead ref
* fix(Modal): fix modal locale (#6423)
* feat(StyleProvider): add StyleProvider handle cssinjs features (#6415)
* feat(StyleProvider): StyleProvider
* feat(StyleProvider): refactor to use context
* chore(StyleProvider): update AStyleProviderProps type
* chore(App): reback
* chore(StyleProvider): export StyleProvider
* feat(StyleProvider): update StyleProvider docs
* feat(StyleProvider): update StyleProvider docs
* feat(StyleProvider): add StyleProvider docs routes
* chore(StyleProvider): with useStyleProvider
* docs: update compatiple #6415
* feat(Progress): enhance size prop and add variants (#6409)
* refactor(progress): Progress size and add variants
* feat(progress): add `getsize`
* refactor(progress): Progress size and add variants
* chore(progress): update props type
* chore(progress): update props type
* feat(progress): update demo
* feat(progress): update docs
* test(progress): update test snap
* fix(Circle): Merging classes
* test(progress): update test snap
* feat(progress): add size demo
* test(progress): add size snapshot
* chore(Progress): reback Circle svg class change
* fix: progress borderRadius reactive #6409
* fix(defaultConfigProvider): add getPopupContainer (#6425), close #6419
* fix: qrcode size error, close #6418
* release 4.0.0-alpha.4
* fix: picker import error
* test: add QRCode unit testing (#6441)
* fix
* fix compile type errors
* fix menuprops type import
* fix lint errors
* fix lint errors
* fix format error
* fix node version
* fix run dist error
* fix run lint
* fix as any
* fix string type
* fix steps error & fix docs version select option & fix theme editor error
* fix(badge): badge props count default value error (#6433)
* docs: update site responsive
* fix: modal api method i18n not work, close #6438
* release 4.0.0-alpha.5
* chore(docs): update docs (#6446)
* docs(space): update demo
* docs(affix): update docs
* fix: cssinjs compatibility (#6454)
* feat: add convertLegacyToken
* docs: v4 vuedocs (#6468)
* fix introduce doc
* fix getting-started doc
* add migration-v4 doc
* fix docs
* Update migration-v4.zh-CN.md
* Update migration-v4.zh-CN.md
* Update migration-v4.en-US.md
* Update migration-v4.zh-CN.md
* Update getting-started.en-US.md
* Update getting-started.zh-CN.md
* Update introduce.en-US.md
* Update introduce.zh-CN.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: remove backtop
* feat(anchor): add direction action (#6447)
* refactor(anchor): direction show
* refactor(anchor): update anchor css
* feat(anchor): update demo
* test(anchor): update demo test snap
* feat(anchor): update docs
* Update index.zh-CN.md
* Update index.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: anchor add customTitle slot #6447
* docs: update doc anchor
* feat(menu): icon support function components with items and update demo (#6457)
* fix(menu): icon do not show problem
* fix(menu): icon do not show problem
* feat(menu): update demo
* test(menu): update demo snap
* chore(Menu): update docs
* test(Menu): update demo
* Update MenuItem.tsx
* Update SubMenu.tsx
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* doc: update menu icon
* feat: menu items icon add arg
* fix: antd.min error
* release 4.0.0-alpha.6
* fix: table resizable not work && type error (#6514)
* Refactor(demo): change options to composition api (#6499)
* feat(demo): A-B
* feat(demo): update B-checkbox
* feat(demo): update CheckBox -DatePicker
* feat(demo): update DatePicker - Form
* feat(demo): update Form - List
* feat(demo): update List-pagination
* feat(demo): update List - skeleton
* feat(demo): update skeleton - switch
* feat(demo): update skeleton - switch
* feat(demo): update switch - upload
* feat(demo): update watermark
* fix(demo): del hashId
* fix: submenu type lose theme
* fix: dropdown menu hide error
* fix: dealing with switching topics modal, notification, message does not take effect close #6512 (#6518)
* fix: resolve dark mode not support
* fix: unified expression
* feat(modal): add useModal (#6517)
* feat(modal): add useModal hook
* feat(modal): add HookModal demo
* test(modal): update HookModal demo snap
* feat(modal): update modal docs
* chore(modal): update modal type
* perf: useModal #6517
* release 4.0.0-beta.1
* docs: fix tab demo error
* fix(config-provider): fix ConfigProvider.config is not function close #6528 (#6529)
* Feat(use): add useMessage useNotification (#6527)
* feat(Message): add useMessage hook
* feat(Notification): add useNotification hook
* feat(Message): add Hook demo
* feat(Notification): add Hook demo
* test(Message): update demo snap
* test(Notification): update demo snap
* docs(Message): update docs with FAQ
* docs(Notification): update docs with FAQ
* refactor: useMessage #6527
* refactor: useNotification #6527
* release 4.0.0-beta.2
* docs(button): update demo with space (#6536)
* feat(button): demo space
* test(button): update demo snap
* chore(button): disabled demo Ghost space
* test(button): update disabled demo snap
* docs(introduce): update docs (#6539)
* docs(introduce): update docs
* docs(introduce): add Dollar
* Update introduce.zh-CN.md
* Update introduce.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* docs(customize-theme): update docs (#6540)
* fix introduce doc
* fix getting-started doc
* add migration-v4 doc
* fix docs
* Update migration-v4.zh-CN.md
* Update migration-v4.zh-CN.md
* Update migration-v4.en-US.md
* Update migration-v4.zh-CN.md
* Update getting-started.en-US.md
* Update getting-started.zh-CN.md
* Update introduce.en-US.md
* Update introduce.zh-CN.md
* update customize-theme doc & fix migration-v4 error
* update customize-theme doc
* fix migration-v4 error
* remove SSR & shadowDom
* Update customize-theme.zh-CN.md
* Update customize-theme.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: getPopupContainer not work
* release 4.0.0-beta.3
* release 4.0.0-beta.4
* docs: update grid docs (#6549)
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
* test(alert): update demo with space (#6541)
* docs(alert): update demo with space
* docs(alert): update alert test snap
---------
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
* fix: components bug & update docs (#6548)
* fix bug
* fix test case and update snapshot,fix space merge class
* docs(grid): update migrate docs && delete xxxl in grid docs (#6562)
* fix: segmentd disabled label is undefined (#6556)
* fix: segmentd disabled label is undefined
* fix: segmentd disabled label is undefined
* fix: segmentd disabled label is undefined
* fix(grid): remove grid xxxl attribute (#6572)
* fix: remove grid xxxl attribute
* docs: remove xxxl in grid docs
* fix: tooltip custom color error
* feat: remove Step __legacy
* feat: add tour (#6332)
* feat v4 add tour
* fix type error
* sync tour from antd5.4.6 & fix type error
* fix error
* refactor: tour #6332
* fix: tour center
* fix: picker support v-show
* test: update snap
* test: update tour test
* fix: tour-mask attrs pointer-events (#6577)
* fix: tour animated
* feat: support vue 3.3 slot type
* release 4.0.0-rc.1
* release 4.0.0-rc.2, close #6588
* 4.0.0-rc.3
* chore: remove vue private api
* fix: paginantion error, close #6590
* release 4.0.0-rc.4
* fix: checxbox style
* fix: pagination mini size style
* release 4.0.0-rc.5
* docs: update v4 tabs doc error(#6606) (#6607)
* docs: add ant-design-vue nuxt module (#6620)
* fix: layout-sider and menu transition style(#6637) (#6640)
* docs: fixed the style error of online demo (#6630)
* feat: ✨checkbox label slot support use option label (#6642)
* docs: 📃change the default setting of "treeNodeFilterProp" from "value" to "label"
* revert: ↩revert this config and create another pr to commit
* feat: ✨checkbox label slot support use option label
* test: 🧪update checkbox *.snap file
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: add disabledContext override with form components (#6618)
* fix: add disabledContext override with form components
* test: update snap
* fix: LabelWidth demo filename
* fix: fontsize spelling mistake
* fix(tour): target position (#6629)
* style: format lint
* docs(form): add form disabled demo (#6658)
* fix: comment node error
* release 4.0
* fix: portalWrapper add autoLock prop (#6687), close #6649
* fix: image animation & zindex, close #6675
* docs(QRCode): Synchronize QR code demonstration and add SVG (#6660)
* fix: Synchronize QR code demonstration and add SVG
* fix: responsive loss and invalid border style
* docs: synchronize antd5.6.3 QRCode color in dark mode
* feat: calendar select support info.source param (#6697)
* docs: add ant-design-vue nuxt module
* feat: calendar select support info.source param
* docs: synchronous config-provider demo (#6706)
* revert: #6706
* docs: export space-compact types (#6716)
* release 4.0.0
---------
Co-authored-by: bqy_fe <1743369777@qq.com>
Co-authored-by: zkwolf <chenhao5866@gmail.com>
Co-authored-by: Zev Zhu <45655660+aibayanyu20@users.noreply.github.com>
Co-authored-by: lyn <76365499@qq.com>
Co-authored-by: 果冻橙 <shifeng199307@gmail.com>
Co-authored-by: songsong0707 <74165917+songsong0707@users.noreply.github.com>
Co-authored-by: yang <30883395+webvs2@users.noreply.github.com>
Co-authored-by: selicens <1244620067@qq.com>
Co-authored-by: 一堆菠萝 <53335668+JavanShen@users.noreply.github.com>
Co-authored-by: H1mple <35363759+baohangxing@users.noreply.github.com>
Co-authored-by: Cherry7 <79909910+CCherry07@users.noreply.github.com>
Co-authored-by: Konv Suu <2583695112@qq.com>
Co-authored-by: luoawai <32483950+luoawai@users.noreply.github.com>
Co-authored-by: 鱼见 <657715602@qq.com>
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
Co-authored-by: Cupid Valentine <53572196+valcosmos@users.noreply.github.com>
Co-authored-by: 专业逮虾户aa <30494925+waldonUB@users.noreply.github.com>
Co-authored-by: PanStar <PanStar@users.noreply.github.com>
2023-07-14 03:58:27 +00:00
|
|
|
|
const focusRef = shallowRef(false);
|
2022-01-21 13:58:10 +00:00
|
|
|
|
|
|
|
|
|
const onContainerFocus: FocusEventHandler = (...args) => {
|
|
|
|
|
setMockFocused(true);
|
|
|
|
|
|
|
|
|
|
if (!props.disabled) {
|
|
|
|
|
if (props.onFocus && !focusRef.value) {
|
|
|
|
|
props.onFocus(...args);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// `showAction` should handle `focus` if set
|
|
|
|
|
if (props.showAction && props.showAction.includes('focus')) {
|
|
|
|
|
onToggleOpen(true);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
focusRef.value = true;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const onContainerBlur: FocusEventHandler = (...args) => {
|
|
|
|
|
setMockFocused(false, () => {
|
|
|
|
|
focusRef.value = false;
|
|
|
|
|
onToggleOpen(false);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
if (props.disabled) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
const searchVal = mergedSearchValue.value;
|
|
|
|
|
if (searchVal) {
|
|
|
|
|
// `tags` mode should move `searchValue` into values
|
|
|
|
|
if (props.mode === 'tags') {
|
|
|
|
|
props.onSearch(searchVal, { source: 'submit' });
|
|
|
|
|
} else if (props.mode === 'multiple') {
|
|
|
|
|
// `multiple` mode only clean the search value but not trigger event
|
|
|
|
|
props.onSearch('', {
|
|
|
|
|
source: 'blur',
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (props.onBlur) {
|
|
|
|
|
props.onBlur(...args);
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
provide('VCSelectContainerEvent', {
|
|
|
|
|
focus: onContainerFocus,
|
|
|
|
|
blur: onContainerBlur,
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// Give focus back of Select
|
|
|
|
|
const activeTimeoutIds: any[] = [];
|
|
|
|
|
|
|
|
|
|
onMounted(() => {
|
|
|
|
|
activeTimeoutIds.forEach(timeoutId => clearTimeout(timeoutId));
|
|
|
|
|
activeTimeoutIds.splice(0, activeTimeoutIds.length);
|
|
|
|
|
});
|
|
|
|
|
onBeforeUnmount(() => {
|
|
|
|
|
activeTimeoutIds.forEach(timeoutId => clearTimeout(timeoutId));
|
|
|
|
|
activeTimeoutIds.splice(0, activeTimeoutIds.length);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
const onInternalMouseDown: MouseEventHandler = (event, ...restArgs) => {
|
|
|
|
|
const { target } = event;
|
|
|
|
|
const popupElement: HTMLDivElement = triggerRef.value?.getPopupElement();
|
|
|
|
|
|
|
|
|
|
// We should give focus back to selector if clicked item is not focusable
|
|
|
|
|
if (popupElement && popupElement.contains(target as HTMLElement)) {
|
|
|
|
|
const timeoutId: any = setTimeout(() => {
|
|
|
|
|
const index = activeTimeoutIds.indexOf(timeoutId);
|
|
|
|
|
if (index !== -1) {
|
|
|
|
|
activeTimeoutIds.splice(index, 1);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
cancelSetMockFocused();
|
|
|
|
|
|
|
|
|
|
if (!mobile.value && !popupElement.contains(document.activeElement)) {
|
|
|
|
|
selectorRef.value?.focus();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
activeTimeoutIds.push(timeoutId);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
props.onMousedown?.(event, ...restArgs);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// ============================= Dropdown ==============================
|
Feat v4 (#6329)
* refactor(icon): remove style dir (#6215)
* refactor: rename locale
* refactor: locale-provider
* refactor: modal
* refactor: menu
* fix: custom class (#6217)
* refactor: tooltip
* refactor: grid (#6220)
* refactor: grid
* fix(grid): align & justify responsive
* chore: update demo and snapshot
* fix: row ts type not work
* doc: update demo
* refactor: ts
* refactor: spin (#6222)
* fix: typo (#6218)
* fix: typo
* docs<upload>: docs update
* refactor: spin
* refactor: spin
* refactor: spin
* refactor: spinnn
* refactor: spin
---------
Co-authored-by: lyn <76365499@qq.com>
* fix: spin error #6222
* test: test case error (#6225)
* fix: inject value maybe undefined
* fix: tootip emit correct value
* fix: rollback warning suffix avoid test break
* doc(grid): remove unused type="flex"
* refactor: skeleton (#6224)
* refactor: skeleton
* refactor: skeleton style
* chore: modify skeleton demo style
* fix(button): link and text should not have wave (#6226)
* refactor: dropdown
* refactor: popover & popconfirm
* refactor(tag): less to cssinjs (#6227)
* refactor(empty): less to cssinjs (#6230)
* refactor(empty): less to cssinjs
* chore: remove unuse code
* fix: reactivity lose
* fix: empty props #6230
* refactor: progress style (#6234)
* refactor: progress
* refactor: progress style
* fix: progress attrs
* refactor: progress #6234
* refactor: switch (#6236)
* refactor: switch style
* refactor: delete switch style
* refactor:input (#6237)
* refactor:input
* fix inheritAttrs:false
* fix attrs.class
* feat: input add disabled
* refactor:comment (#6238)
* refactor:comment
* fix inheritAttrs: false & attrs.class
* refactor:pageheader (#6239)
* refactor:pageheader
* fix inheritAttrs: false & attrs.class
* refactor:statistic (#6240)
* refactor:statistic
* fix inheritAttrs: false & attrs.class
* refactor:list (#6241)
* refactor:list
* fix inheritAttrs: false & attrs.class
* feat: update type
* refactor(Space): less to cssinjs & add compact mode (#6229)
* refactor(Space): less to cssinjs & add compact mode
* chore(space): update md
* chore(space): add demo
* chore(space): add some demo
* feat(button): add compact mode
* fix: reactivity lose
* docs: fix props version
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* perf: space compact
* refactor:typography (#6244)
* refactor:typography
* fix return
* fix import type
* fix: typography #6244
* refactor:datepicker (#6245)
* refactor: datepicker type
* refactor: rate style (#6254)
* refactor(layout): less to cssinjs (#6249)
* doc: update layout cover
* refactor(result): less to cssinjs (#6246)
* refactor(result): less to cssinjs
* fix: class name is overridden
* docs: update result cover
* refactor:slider (#6250)
* feat: slider deprecated tooltipVisible
* refactor(crad): less to cssinjs (#6258)
* update
* switch
* Style adjustment
* refactor(Card): less to cssinjs
* Eliminate invalid code
* optimization and adjustment css
* Adjust the css
* Optimize each item
* adjustment css
* refactor: card #6258
* refactor:carousel (#6262)
* refactor:carousel
* docs:update & refactor: carousel type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor:transfer (#6247)
* refactor:transfer
* merge v4 branch & fix theme interface conflict
* docs:update & refactor: transfer type
* perf: transfer
* refactor:checkbox (#6248)
* refactor:checkbox
* docs:update & refactor: checkbox type
* feat: checkbox add disabled context
* refactor:pagination (#6251)
* refactor:pagination
* docs:update & refactor: pagination type
* style: update pagination props type
* refactor: mentions (#6255)
* refactor: mentions
* refactor: mentions menu provider
* doc: update mentions demo
* refcator:upload (#6261)
* refcator:upload
* docs:update & refactor: upload type
* Update style.ts
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* perf: upload motion
* refactor:timeline (#6263)
* refactor:timeline
* docs:update & refactor: timeline type
* perf: timeline
* refactor:steps (#6264)
* refactor:steps
* fix ...attrs
* fix StepsToken error
* docs:update & refactor: steps type
* fix: steps icon clss error
* refactor:collapse (#6266)
* refactor:collapse
* fix collapse props version
* docs:update & refactor: collapse type & fix collapsible
* feat: update collapse type
* refactor:inputnumber (#6265)
* refactor:inputnumber
* docs:update & refactor: inputnumber type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: number add compactSize & disabledContext
* refactor:table (#6267)
* refactor:table
* docs:update & refactor: table type
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor: table
* feat: table add expandColumnTitle slot
* refactor:calendar (#6269)
* refactor:calendar
* docs:update
* refactor:timepicker (#6270)
* refactor:timepicker
* docs:update & refactor: timepicker type
* refactor:tree (#6276)
* Feat v4 fix type errors (#6285)
* fix compile type errors
* fix menuprops type import
* fix lint errors
* fix lint errors
* fix format error
* fix node version
* fix run dist error
* fix run lint
* fix as any
* fix string type
* refactor: rename locale file
* feat: tree add leafIcon
* [tabs] :less to cssinjs (#6288)
* update
* switch
* Style adjustment
* refactor(Card): less to cssinjs
* tabs: less to cssinjs 开发ing
* add function cssinjs
* Eliminate irrelevant code
* Eliminate irrelevant code 2
* update components
* Eliminate irrelevant input code
* refactor: tabs #6288
* feat: add segmented (#6286)
* refactor: segmented #6286
* refactor:select (#6295)
* refactor:select
* update doc
* delete useless
* feat: select add context size
* refactor: tree select (#6296)
* feat: tree-select add context size
* perf: table
* docs: update doc toc
* refactor: cascader
* refactor: auto-complete
* refactor: image
* refactor: drawer
* refactor:radio (#6299)
* refactor:radio
* fix attrs
* feat: radio add disabled context
* fix: some type & doc (#6292)
* fix: typo (#6218)
* fix: typo
* docs<upload>: docs update
* fix: type of minute in props disabledDateTime of DatePicker (#6233)
* docs: typo (#6256)
* feat: tooltip added overlayInnerStyle attribute
* Update abstractTooltipProps.ts
* Update Tooltip.tsx
---------
Co-authored-by: lyn <76365499@qq.com>
Co-authored-by: H1mple <35363759+baohangxing@users.noreply.github.com>
Co-authored-by: tangjinzhou <415800467@qq.com>
* refactor: form
* fix: directive not work
* fix: use open, remove visible
* doc: update cover
* refactor: remove not use code
* chore: update build script
* doc: update doc
* doc: refactor doc
* chore: update token error
* chore: update style
* refactor: rename _style to style
* fix: tag warning
* fix(dropdown): open invalid (#6316)
* feat: add watermark (#6300)
* feat: add watermark
* feat: add watermark demo
* feat: add mutationObserver
* feat: add watermark demo
* refactor: watermark type
* doc: add theme-editor
* fix: inject value maybe undefined && tag style invalid (#6320)
* fix: inject value maybe undefined
* fix(tag): style invalid
* feat: add qrcode (#6315)
* feat: add qrcode
* fix: qrcode bug
* fix: qrcode value required
* refactor: props deconstruct
* Feat v4 floatbutton (#6294)
* feat: add float-button components
* fix type & demo display
* fix components entry
* fix review bug
* fix bug
* fix .value
* refactor: qrcode #6315
* refactor: float-button
* fix: groupsize context error
* fix: floatbutton animation not work
* Feat v4 theme editor (#6348)
* feat: add theme editor container
* feat: add theme editor layout
* add left panel
* add vue-colorful & fix bug
* 修复hue组件抖动问题
* fix bug && add demo
* fix bug
* fix demo preview
* fix theme editor components demo
* fix: token effect error
* Feat v4 theme editor (#6349)
* feat: add theme editor container
* feat: add theme editor layout
* add left panel
* add vue-colorful & fix bug
* 修复hue组件抖动问题
* fix bug && add demo
* fix bug
* fix demo preview
* fix theme editor components demo
* add theme editor token drawer
* add theme editor token drawer
* fix bug
* open commment
* fix error demo
* fix theme editor bug
* fix: cssinjs effect error
* doc: format code
* fix: tag click event not trigger
* release 4.0.0-alpha.1
* fix: qrcode type
* fix: remove not use file
* doc: update doc site
* doc: update site
* doc: fix theme editor bgcolor (#6358)
* fix: motion not work
* release 4.0.0-alpha.2
* fix: qrcode ; error, close #6362
* fix docs dark theme & add docs coverDark (#6367)
* fix docs dark theme & add docs coverDark
* fix theme Editor edit
* fix: dropdown divider disappear, close #6365 (#6369)
* doc: update baner
* fix: button wave not work
* fix: ant-piker-cell-range-hover-end style error (#6373)
* fix: ant-piker-cell-range-hover-end style error
* feat: be consistent with antd
* feat: be consistent with antd
* fix: ConfigProvider error for style, close #6368
* release 4.0.0-alpha.4
* style: add dark style for `pre` and `code` (#6382)
* docs: version menu (#6390)
* Feat(DatePicker): increase presets prop (#6387)
* feat(date-picker): add PresetDate type
* feat(date-picker): add usePresets hook
* feat(date-picker): add PresetPanel Component
* feat(date-picker): add PresetPanel Component
* feat(demo): update Preset Ranges Examples
* feat(docs): add new prop presets
* feat(docs): add new prop presets with english
* fix(RangePicker): footer is not managed by panels
* chore(Picker): prefixCls default rc-picker
* chore(date-picker): update presetted-ranges demo
* chore(date-picker): update rangePickerProps'presets
* feat(date-picker): presets reactively processing
* chore(date-picker): update type
* refactor(RangePicker): deprecated ranges prop
* chore(date-picker): update type
* chore(PickerPanel): del notuse panelRef
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: datepicker presets error #6387
* docs: update datepicker doc #6387
* feat(Steps): add items prop and variants (#6406)
* refactor(steps): add items prop and variants
* feat(steps): add Label Placement and Inline Steps demo
* feat(steps): Label Placement and Inline Steps snap
* test(steps): Steps demo snap
* feat(Steps): update docs
* fix(Step): progressDot
* chore(useLegacyItems): change from warning to devWarning
* refactor(Steps): Remove useLegacyItems
* refactor(Steps): renderStep
* test(Steps): update test snapshot
* chore(Steps): filterEmpty
* feat(Steps): update docs
* docs: update site
* refactor: steps #6406
* test: update steps
* perf: shallowRef instead ref
* fix(Modal): fix modal locale (#6423)
* feat(StyleProvider): add StyleProvider handle cssinjs features (#6415)
* feat(StyleProvider): StyleProvider
* feat(StyleProvider): refactor to use context
* chore(StyleProvider): update AStyleProviderProps type
* chore(App): reback
* chore(StyleProvider): export StyleProvider
* feat(StyleProvider): update StyleProvider docs
* feat(StyleProvider): update StyleProvider docs
* feat(StyleProvider): add StyleProvider docs routes
* chore(StyleProvider): with useStyleProvider
* docs: update compatiple #6415
* feat(Progress): enhance size prop and add variants (#6409)
* refactor(progress): Progress size and add variants
* feat(progress): add `getsize`
* refactor(progress): Progress size and add variants
* chore(progress): update props type
* chore(progress): update props type
* feat(progress): update demo
* feat(progress): update docs
* test(progress): update test snap
* fix(Circle): Merging classes
* test(progress): update test snap
* feat(progress): add size demo
* test(progress): add size snapshot
* chore(Progress): reback Circle svg class change
* fix: progress borderRadius reactive #6409
* fix(defaultConfigProvider): add getPopupContainer (#6425), close #6419
* fix: qrcode size error, close #6418
* release 4.0.0-alpha.4
* fix: picker import error
* test: add QRCode unit testing (#6441)
* fix
* fix compile type errors
* fix menuprops type import
* fix lint errors
* fix lint errors
* fix format error
* fix node version
* fix run dist error
* fix run lint
* fix as any
* fix string type
* fix steps error & fix docs version select option & fix theme editor error
* fix(badge): badge props count default value error (#6433)
* docs: update site responsive
* fix: modal api method i18n not work, close #6438
* release 4.0.0-alpha.5
* chore(docs): update docs (#6446)
* docs(space): update demo
* docs(affix): update docs
* fix: cssinjs compatibility (#6454)
* feat: add convertLegacyToken
* docs: v4 vuedocs (#6468)
* fix introduce doc
* fix getting-started doc
* add migration-v4 doc
* fix docs
* Update migration-v4.zh-CN.md
* Update migration-v4.zh-CN.md
* Update migration-v4.en-US.md
* Update migration-v4.zh-CN.md
* Update getting-started.en-US.md
* Update getting-started.zh-CN.md
* Update introduce.en-US.md
* Update introduce.zh-CN.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: remove backtop
* feat(anchor): add direction action (#6447)
* refactor(anchor): direction show
* refactor(anchor): update anchor css
* feat(anchor): update demo
* test(anchor): update demo test snap
* feat(anchor): update docs
* Update index.zh-CN.md
* Update index.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* feat: anchor add customTitle slot #6447
* docs: update doc anchor
* feat(menu): icon support function components with items and update demo (#6457)
* fix(menu): icon do not show problem
* fix(menu): icon do not show problem
* feat(menu): update demo
* test(menu): update demo snap
* chore(Menu): update docs
* test(Menu): update demo
* Update MenuItem.tsx
* Update SubMenu.tsx
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* doc: update menu icon
* feat: menu items icon add arg
* fix: antd.min error
* release 4.0.0-alpha.6
* fix: table resizable not work && type error (#6514)
* Refactor(demo): change options to composition api (#6499)
* feat(demo): A-B
* feat(demo): update B-checkbox
* feat(demo): update CheckBox -DatePicker
* feat(demo): update DatePicker - Form
* feat(demo): update Form - List
* feat(demo): update List-pagination
* feat(demo): update List - skeleton
* feat(demo): update skeleton - switch
* feat(demo): update skeleton - switch
* feat(demo): update switch - upload
* feat(demo): update watermark
* fix(demo): del hashId
* fix: submenu type lose theme
* fix: dropdown menu hide error
* fix: dealing with switching topics modal, notification, message does not take effect close #6512 (#6518)
* fix: resolve dark mode not support
* fix: unified expression
* feat(modal): add useModal (#6517)
* feat(modal): add useModal hook
* feat(modal): add HookModal demo
* test(modal): update HookModal demo snap
* feat(modal): update modal docs
* chore(modal): update modal type
* perf: useModal #6517
* release 4.0.0-beta.1
* docs: fix tab demo error
* fix(config-provider): fix ConfigProvider.config is not function close #6528 (#6529)
* Feat(use): add useMessage useNotification (#6527)
* feat(Message): add useMessage hook
* feat(Notification): add useNotification hook
* feat(Message): add Hook demo
* feat(Notification): add Hook demo
* test(Message): update demo snap
* test(Notification): update demo snap
* docs(Message): update docs with FAQ
* docs(Notification): update docs with FAQ
* refactor: useMessage #6527
* refactor: useNotification #6527
* release 4.0.0-beta.2
* docs(button): update demo with space (#6536)
* feat(button): demo space
* test(button): update demo snap
* chore(button): disabled demo Ghost space
* test(button): update disabled demo snap
* docs(introduce): update docs (#6539)
* docs(introduce): update docs
* docs(introduce): add Dollar
* Update introduce.zh-CN.md
* Update introduce.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* docs(customize-theme): update docs (#6540)
* fix introduce doc
* fix getting-started doc
* add migration-v4 doc
* fix docs
* Update migration-v4.zh-CN.md
* Update migration-v4.zh-CN.md
* Update migration-v4.en-US.md
* Update migration-v4.zh-CN.md
* Update getting-started.en-US.md
* Update getting-started.zh-CN.md
* Update introduce.en-US.md
* Update introduce.zh-CN.md
* update customize-theme doc & fix migration-v4 error
* update customize-theme doc
* fix migration-v4 error
* remove SSR & shadowDom
* Update customize-theme.zh-CN.md
* Update customize-theme.en-US.md
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: getPopupContainer not work
* release 4.0.0-beta.3
* release 4.0.0-beta.4
* docs: update grid docs (#6549)
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
* test(alert): update demo with space (#6541)
* docs(alert): update demo with space
* docs(alert): update alert test snap
---------
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
* fix: components bug & update docs (#6548)
* fix bug
* fix test case and update snapshot,fix space merge class
* docs(grid): update migrate docs && delete xxxl in grid docs (#6562)
* fix: segmentd disabled label is undefined (#6556)
* fix: segmentd disabled label is undefined
* fix: segmentd disabled label is undefined
* fix: segmentd disabled label is undefined
* fix(grid): remove grid xxxl attribute (#6572)
* fix: remove grid xxxl attribute
* docs: remove xxxl in grid docs
* fix: tooltip custom color error
* feat: remove Step __legacy
* feat: add tour (#6332)
* feat v4 add tour
* fix type error
* sync tour from antd5.4.6 & fix type error
* fix error
* refactor: tour #6332
* fix: tour center
* fix: picker support v-show
* test: update snap
* test: update tour test
* fix: tour-mask attrs pointer-events (#6577)
* fix: tour animated
* feat: support vue 3.3 slot type
* release 4.0.0-rc.1
* release 4.0.0-rc.2, close #6588
* 4.0.0-rc.3
* chore: remove vue private api
* fix: paginantion error, close #6590
* release 4.0.0-rc.4
* fix: checxbox style
* fix: pagination mini size style
* release 4.0.0-rc.5
* docs: update v4 tabs doc error(#6606) (#6607)
* docs: add ant-design-vue nuxt module (#6620)
* fix: layout-sider and menu transition style(#6637) (#6640)
* docs: fixed the style error of online demo (#6630)
* feat: ✨checkbox label slot support use option label (#6642)
* docs: 📃change the default setting of "treeNodeFilterProp" from "value" to "label"
* revert: ↩revert this config and create another pr to commit
* feat: ✨checkbox label slot support use option label
* test: 🧪update checkbox *.snap file
---------
Co-authored-by: tangjinzhou <415800467@qq.com>
* fix: add disabledContext override with form components (#6618)
* fix: add disabledContext override with form components
* test: update snap
* fix: LabelWidth demo filename
* fix: fontsize spelling mistake
* fix(tour): target position (#6629)
* style: format lint
* docs(form): add form disabled demo (#6658)
* fix: comment node error
* release 4.0
* fix: portalWrapper add autoLock prop (#6687), close #6649
* fix: image animation & zindex, close #6675
* docs(QRCode): Synchronize QR code demonstration and add SVG (#6660)
* fix: Synchronize QR code demonstration and add SVG
* fix: responsive loss and invalid border style
* docs: synchronize antd5.6.3 QRCode color in dark mode
* feat: calendar select support info.source param (#6697)
* docs: add ant-design-vue nuxt module
* feat: calendar select support info.source param
* docs: synchronous config-provider demo (#6706)
* revert: #6706
* docs: export space-compact types (#6716)
* release 4.0.0
---------
Co-authored-by: bqy_fe <1743369777@qq.com>
Co-authored-by: zkwolf <chenhao5866@gmail.com>
Co-authored-by: Zev Zhu <45655660+aibayanyu20@users.noreply.github.com>
Co-authored-by: lyn <76365499@qq.com>
Co-authored-by: 果冻橙 <shifeng199307@gmail.com>
Co-authored-by: songsong0707 <74165917+songsong0707@users.noreply.github.com>
Co-authored-by: yang <30883395+webvs2@users.noreply.github.com>
Co-authored-by: selicens <1244620067@qq.com>
Co-authored-by: 一堆菠萝 <53335668+JavanShen@users.noreply.github.com>
Co-authored-by: H1mple <35363759+baohangxing@users.noreply.github.com>
Co-authored-by: Cherry7 <79909910+CCherry07@users.noreply.github.com>
Co-authored-by: Konv Suu <2583695112@qq.com>
Co-authored-by: luoawai <32483950+luoawai@users.noreply.github.com>
Co-authored-by: 鱼见 <657715602@qq.com>
Co-authored-by: zhuzhengjian <zhuzhengjian@hoteamsoft.com>
Co-authored-by: Cupid Valentine <53572196+valcosmos@users.noreply.github.com>
Co-authored-by: 专业逮虾户aa <30494925+waldonUB@users.noreply.github.com>
Co-authored-by: PanStar <PanStar@users.noreply.github.com>
2023-07-14 03:58:27 +00:00
|
|
|
|
const containerWidth = shallowRef<number>(null);
|
2022-01-21 13:58:10 +00:00
|
|
|
|
const instance = getCurrentInstance();
|
|
|
|
|
const onPopupMouseEnter = () => {
|
|
|
|
|
// We need force update here since popup dom is render async
|
|
|
|
|
instance.update();
|
|
|
|
|
};
|
|
|
|
|
onMounted(() => {
|
|
|
|
|
watch(
|
|
|
|
|
triggerOpen,
|
|
|
|
|
() => {
|
|
|
|
|
if (triggerOpen.value) {
|
|
|
|
|
const newWidth = Math.ceil(containerRef.value?.offsetWidth);
|
|
|
|
|
if (containerWidth.value !== newWidth && !Number.isNaN(newWidth)) {
|
|
|
|
|
containerWidth.value = newWidth;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
},
|
2022-04-23 06:29:08 +00:00
|
|
|
|
{ immediate: true, flush: 'post' },
|
2022-01-21 13:58:10 +00:00
|
|
|
|
);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// Close when click on non-select element
|
|
|
|
|
useSelectTriggerControl([containerRef, triggerRef], triggerOpen, onToggleOpen);
|
|
|
|
|
useProvideBaseSelectProps(
|
|
|
|
|
toReactive({
|
|
|
|
|
...toRefs(props),
|
|
|
|
|
open: mergedOpen,
|
|
|
|
|
triggerOpen,
|
|
|
|
|
showSearch: mergedShowSearch,
|
|
|
|
|
multiple,
|
|
|
|
|
toggleOpen: onToggleOpen,
|
|
|
|
|
} as unknown as BaseSelectContextProps),
|
|
|
|
|
);
|
|
|
|
|
return () => {
|
|
|
|
|
const {
|
|
|
|
|
prefixCls,
|
|
|
|
|
id,
|
|
|
|
|
|
|
|
|
|
open,
|
|
|
|
|
defaultOpen,
|
|
|
|
|
|
|
|
|
|
mode,
|
|
|
|
|
|
|
|
|
|
// Search related
|
|
|
|
|
showSearch,
|
|
|
|
|
searchValue,
|
|
|
|
|
onSearch,
|
|
|
|
|
|
|
|
|
|
// Icons
|
|
|
|
|
allowClear,
|
|
|
|
|
clearIcon,
|
|
|
|
|
showArrow,
|
|
|
|
|
inputIcon,
|
|
|
|
|
|
|
|
|
|
// Others
|
|
|
|
|
disabled,
|
|
|
|
|
loading,
|
|
|
|
|
getInputElement,
|
|
|
|
|
getPopupContainer,
|
|
|
|
|
placement,
|
|
|
|
|
|
|
|
|
|
// Dropdown
|
|
|
|
|
animation,
|
|
|
|
|
transitionName,
|
|
|
|
|
dropdownStyle,
|
|
|
|
|
dropdownClassName,
|
|
|
|
|
dropdownMatchSelectWidth,
|
|
|
|
|
dropdownRender,
|
|
|
|
|
dropdownAlign,
|
|
|
|
|
showAction,
|
|
|
|
|
direction,
|
|
|
|
|
|
|
|
|
|
// Tags
|
|
|
|
|
tokenSeparators,
|
|
|
|
|
tagRender,
|
2022-01-27 07:12:15 +00:00
|
|
|
|
optionLabelRender,
|
2022-01-21 13:58:10 +00:00
|
|
|
|
|
|
|
|
|
// Events
|
|
|
|
|
onPopupScroll,
|
|
|
|
|
onDropdownVisibleChange,
|
|
|
|
|
onFocus,
|
|
|
|
|
onBlur,
|
|
|
|
|
onKeyup,
|
|
|
|
|
onKeydown,
|
|
|
|
|
onMousedown,
|
|
|
|
|
|
|
|
|
|
onClear,
|
|
|
|
|
omitDomProps,
|
|
|
|
|
getRawInputElement,
|
|
|
|
|
displayValues,
|
|
|
|
|
onDisplayValuesChange,
|
|
|
|
|
emptyOptions,
|
|
|
|
|
activeDescendantId,
|
|
|
|
|
activeValue,
|
|
|
|
|
OptionList,
|
|
|
|
|
|
|
|
|
|
...restProps
|
|
|
|
|
} = { ...props, ...attrs } as BaseSelectProps;
|
|
|
|
|
// ============================= Input ==============================
|
|
|
|
|
// Only works in `combobox`
|
|
|
|
|
const customizeInputElement: any =
|
|
|
|
|
(mode === 'combobox' && getInputElement && getInputElement()) || null;
|
|
|
|
|
|
|
|
|
|
// Used for customize replacement for `vc-cascader`
|
|
|
|
|
const customizeRawInputElement: any =
|
|
|
|
|
typeof getRawInputElement === 'function' && getRawInputElement();
|
|
|
|
|
const domProps = {
|
|
|
|
|
...restProps,
|
2023-04-21 05:55:28 +00:00
|
|
|
|
} as Omit<keyof typeof restProps, (typeof DEFAULT_OMIT_PROPS)[number]>;
|
2022-01-21 13:58:10 +00:00
|
|
|
|
|
|
|
|
|
// Used for raw custom input trigger
|
|
|
|
|
let onTriggerVisibleChange: null | ((newOpen: boolean) => void);
|
|
|
|
|
if (customizeRawInputElement) {
|
|
|
|
|
onTriggerVisibleChange = (newOpen: boolean) => {
|
|
|
|
|
onToggleOpen(newOpen);
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
DEFAULT_OMIT_PROPS.forEach(propName => {
|
|
|
|
|
delete domProps[propName];
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
omitDomProps?.forEach(propName => {
|
|
|
|
|
delete domProps[propName];
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// ============================= Arrow ==============================
|
|
|
|
|
const mergedShowArrow =
|
|
|
|
|
showArrow !== undefined ? showArrow : loading || (!multiple.value && mode !== 'combobox');
|
|
|
|
|
let arrowNode: VNode | JSX.Element;
|
|
|
|
|
|
|
|
|
|
if (mergedShowArrow) {
|
|
|
|
|
arrowNode = (
|
|
|
|
|
<TransBtn
|
|
|
|
|
class={classNames(`${prefixCls}-arrow`, {
|
|
|
|
|
[`${prefixCls}-arrow-loading`]: loading,
|
|
|
|
|
})}
|
|
|
|
|
customizeIcon={inputIcon}
|
|
|
|
|
customizeIconProps={{
|
|
|
|
|
loading,
|
|
|
|
|
searchValue: mergedSearchValue.value,
|
|
|
|
|
open: mergedOpen.value,
|
|
|
|
|
focused: mockFocused.value,
|
|
|
|
|
showSearch: mergedShowSearch.value,
|
|
|
|
|
}}
|
|
|
|
|
/>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// ============================= Clear ==============================
|
|
|
|
|
let clearNode: VNode | JSX.Element;
|
|
|
|
|
const onClearMouseDown: MouseEventHandler = () => {
|
|
|
|
|
onClear?.();
|
|
|
|
|
|
|
|
|
|
onDisplayValuesChange([], {
|
|
|
|
|
type: 'clear',
|
|
|
|
|
values: displayValues,
|
|
|
|
|
});
|
|
|
|
|
onInternalSearch('', false, false);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
if (!disabled && allowClear && (displayValues.length || mergedSearchValue.value)) {
|
|
|
|
|
clearNode = (
|
|
|
|
|
<TransBtn
|
|
|
|
|
class={`${prefixCls}-clear`}
|
|
|
|
|
onMousedown={onClearMouseDown}
|
|
|
|
|
customizeIcon={clearIcon}
|
|
|
|
|
>
|
|
|
|
|
×
|
|
|
|
|
</TransBtn>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// =========================== OptionList ===========================
|
|
|
|
|
const optionList = (
|
|
|
|
|
<OptionList
|
|
|
|
|
ref={listRef}
|
|
|
|
|
v-slots={{ ...legacyTreeSelectContext.customSlots, option: slots.option }}
|
|
|
|
|
/>
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
// ============================= Select =============================
|
|
|
|
|
const mergedClassName = classNames(prefixCls, attrs.class, {
|
|
|
|
|
[`${prefixCls}-focused`]: mockFocused.value,
|
|
|
|
|
[`${prefixCls}-multiple`]: multiple.value,
|
|
|
|
|
[`${prefixCls}-single`]: !multiple.value,
|
|
|
|
|
[`${prefixCls}-allow-clear`]: allowClear,
|
|
|
|
|
[`${prefixCls}-show-arrow`]: mergedShowArrow,
|
|
|
|
|
[`${prefixCls}-disabled`]: disabled,
|
|
|
|
|
[`${prefixCls}-loading`]: loading,
|
|
|
|
|
[`${prefixCls}-open`]: mergedOpen.value,
|
|
|
|
|
[`${prefixCls}-customize-input`]: customizeInputElement,
|
|
|
|
|
[`${prefixCls}-show-search`]: mergedShowSearch.value,
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// >>> Selector
|
|
|
|
|
const selectorNode = (
|
|
|
|
|
<SelectTrigger
|
|
|
|
|
ref={triggerRef}
|
|
|
|
|
disabled={disabled}
|
|
|
|
|
prefixCls={prefixCls}
|
|
|
|
|
visible={triggerOpen.value}
|
|
|
|
|
popupElement={optionList}
|
|
|
|
|
containerWidth={containerWidth.value}
|
|
|
|
|
animation={animation}
|
|
|
|
|
transitionName={transitionName}
|
|
|
|
|
dropdownStyle={dropdownStyle}
|
|
|
|
|
dropdownClassName={dropdownClassName}
|
|
|
|
|
direction={direction}
|
|
|
|
|
dropdownMatchSelectWidth={dropdownMatchSelectWidth}
|
|
|
|
|
dropdownRender={dropdownRender}
|
|
|
|
|
dropdownAlign={dropdownAlign}
|
|
|
|
|
placement={placement}
|
|
|
|
|
getPopupContainer={getPopupContainer}
|
|
|
|
|
empty={emptyOptions}
|
|
|
|
|
getTriggerDOMNode={() => selectorDomRef.current}
|
|
|
|
|
onPopupVisibleChange={onTriggerVisibleChange}
|
|
|
|
|
onPopupMouseEnter={onPopupMouseEnter}
|
|
|
|
|
v-slots={{
|
|
|
|
|
default: () => {
|
|
|
|
|
return customizeRawInputElement ? (
|
|
|
|
|
isValidElement(customizeRawInputElement) &&
|
|
|
|
|
cloneElement(
|
|
|
|
|
customizeRawInputElement,
|
|
|
|
|
{
|
|
|
|
|
ref: selectorDomRef,
|
|
|
|
|
},
|
|
|
|
|
false,
|
|
|
|
|
true,
|
|
|
|
|
)
|
|
|
|
|
) : (
|
|
|
|
|
<Selector
|
|
|
|
|
{...props}
|
|
|
|
|
domRef={selectorDomRef}
|
|
|
|
|
prefixCls={prefixCls}
|
|
|
|
|
inputElement={customizeInputElement}
|
|
|
|
|
ref={selectorRef}
|
|
|
|
|
id={id}
|
|
|
|
|
showSearch={mergedShowSearch.value}
|
|
|
|
|
mode={mode}
|
|
|
|
|
activeDescendantId={activeDescendantId}
|
|
|
|
|
tagRender={tagRender}
|
2022-01-27 07:12:15 +00:00
|
|
|
|
optionLabelRender={optionLabelRender}
|
2022-01-21 13:58:10 +00:00
|
|
|
|
values={displayValues}
|
|
|
|
|
open={mergedOpen.value}
|
|
|
|
|
onToggleOpen={onToggleOpen}
|
|
|
|
|
activeValue={activeValue}
|
|
|
|
|
searchValue={mergedSearchValue.value}
|
|
|
|
|
onSearch={onInternalSearch}
|
|
|
|
|
onSearchSubmit={onInternalSearchSubmit}
|
|
|
|
|
onRemove={onSelectorRemove}
|
|
|
|
|
tokenWithEnter={tokenWithEnter.value}
|
|
|
|
|
/>
|
|
|
|
|
);
|
|
|
|
|
},
|
|
|
|
|
}}
|
|
|
|
|
></SelectTrigger>
|
|
|
|
|
);
|
|
|
|
|
// >>> Render
|
|
|
|
|
let renderNode: VNode | JSX.Element;
|
|
|
|
|
|
|
|
|
|
// Render raw
|
|
|
|
|
if (customizeRawInputElement) {
|
|
|
|
|
renderNode = selectorNode;
|
|
|
|
|
} else {
|
|
|
|
|
renderNode = (
|
|
|
|
|
<div
|
|
|
|
|
{...domProps}
|
|
|
|
|
class={mergedClassName}
|
|
|
|
|
ref={containerRef}
|
|
|
|
|
onMousedown={onInternalMouseDown}
|
|
|
|
|
onKeydown={onInternalKeyDown}
|
|
|
|
|
onKeyup={onInternalKeyUp}
|
|
|
|
|
// onFocus={onContainerFocus}
|
|
|
|
|
// onBlur={onContainerBlur}
|
|
|
|
|
>
|
|
|
|
|
{mockFocused.value && !mergedOpen.value && (
|
|
|
|
|
<span
|
|
|
|
|
style={{
|
|
|
|
|
width: 0,
|
|
|
|
|
height: 0,
|
2023-04-21 05:55:28 +00:00
|
|
|
|
position: 'absolute',
|
2022-01-21 13:58:10 +00:00
|
|
|
|
overflow: 'hidden',
|
|
|
|
|
opacity: 0,
|
|
|
|
|
}}
|
|
|
|
|
aria-live="polite"
|
|
|
|
|
>
|
|
|
|
|
{/* Merge into one string to make screen reader work as expect */}
|
|
|
|
|
{`${displayValues
|
|
|
|
|
.map(({ label, value }) =>
|
|
|
|
|
['number', 'string'].includes(typeof label) ? label : value,
|
|
|
|
|
)
|
|
|
|
|
.join(', ')}`}
|
|
|
|
|
</span>
|
|
|
|
|
)}
|
|
|
|
|
{selectorNode}
|
|
|
|
|
|
|
|
|
|
{arrowNode}
|
|
|
|
|
{clearNode}
|
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
return renderNode;
|
|
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
});
|