@cloudbase/weda-ui 3.3.0 → 3.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/web/components/form/form/index.js +42 -38
- package/dist/src/web/components/form/userOrgSelect/departTreeSelect/departTreeSelect.h5.js +12 -4
- package/dist/src/web/components/form/userOrgSelect/userTreeSelect.h5.js +6 -2
- package/dist/src/web/components/navigationBar/index.js +9 -4
- package/package.json +3 -3
- package/dist/configs/actions/showModal.json +0 -48
- package/dist/configs/actions/showToast.json +0 -41
- package/dist/configs/components/auth.json +0 -16
- package/dist/configs/components/button.json +0 -239
- package/dist/configs/components/calendar.json +0 -81
- package/dist/configs/components/carousel.json +0 -292
- package/dist/configs/components/chart/bar.json +0 -728
- package/dist/configs/components/chart/line.json +0 -681
- package/dist/configs/components/chart/pie.json +0 -500
- package/dist/configs/components/chart/statisticsCard.json +0 -376
- package/dist/configs/components/container.json +0 -50
- package/dist/configs/components/dataView.json +0 -239
- package/dist/configs/components/drawer.json +0 -115
- package/dist/configs/components/form/checkbox.json +0 -179
- package/dist/configs/components/form/departTreeSelect.json +0 -124
- package/dist/configs/components/form/form.json +0 -69
- package/dist/configs/components/form/input.json +0 -154
- package/dist/configs/components/form/location.json +0 -216
- package/dist/configs/components/form/radio.json +0 -203
- package/dist/configs/components/form/richText.json +0 -133
- package/dist/configs/components/form/select.json +0 -431
- package/dist/configs/components/form/switch.json +0 -58
- package/dist/configs/components/form/textarea.json +0 -116
- package/dist/configs/components/form/tips.json +0 -34
- package/dist/configs/components/form/uploader.json +0 -171
- package/dist/configs/components/form/uploaderFile.json +0 -158
- package/dist/configs/components/form/userTreeSelect.json +0 -128
- package/dist/configs/components/formdetail.json +0 -105
- package/dist/configs/components/graphicCard.json +0 -413
- package/dist/configs/components/image.json +0 -187
- package/dist/configs/components/link.json +0 -79
- package/dist/configs/components/listView.json +0 -378
- package/dist/configs/components/lottery.json +0 -163
- package/dist/configs/components/modal.json +0 -72
- package/dist/configs/components/navLayout.json +0 -368
- package/dist/configs/components/navigationBar.json +0 -62
- package/dist/configs/components/richtextview.json +0 -26
- package/dist/configs/components/scrollVeiw.json +0 -253
- package/dist/configs/components/slot.json +0 -17
- package/dist/configs/components/swiper.json +0 -90
- package/dist/configs/components/tabs.json +0 -122
- package/dist/configs/components/text.json +0 -95
- package/dist/configs/components/wedaVideo.json +0 -89
- package/dist/configs/components/wxOpenApi/phone.json +0 -127
- package/dist/configs/components/wxOpenApi/phoneCode.json +0 -109
- package/dist/configs/components/wxOpenApi/share.json +0 -160
- package/dist/configs/components/wxOpenApi/userInfo.json +0 -156
- package/dist/configs/index.d.ts +0 -103
- package/dist/configs/index.js +0 -111
- package/dist/docs/common/format.d.ts +0 -13
- package/dist/docs/common/format.js +0 -122
- package/dist/docs/common/tableView.d.ts +0 -30
- package/dist/docs/common/tableView.js +0 -159
- package/dist/index.d.ts +0 -2
- package/dist/index.js +0 -3
- package/dist/setupTests.d.ts +0 -1
- package/dist/setupTests.js +0 -14
- package/dist/src/web/components/chart/common/error-boundary.d.ts +0 -5
- package/dist/src/web/components/chart/common/error-boundary.js +0 -26
- package/dist/src/web/utils/getUserService.d.ts +0 -11
- package/dist/src/web/utils/getUserService.js +0 -156
- package/dist/src/web/utils/tmap.d.ts +0 -3
- package/dist/src/web/utils/tmap.js +0 -21
- package/dist/web/actions/index.d.ts +0 -2
- package/dist/web/actions/index.js +0 -2
- package/dist/web/actions/showModal/index.d.ts +0 -4
- package/dist/web/actions/showModal/index.js +0 -67
- package/dist/web/actions/showToast/index.d.ts +0 -1
- package/dist/web/actions/showToast/index.js +0 -3
- package/dist/web/components/button/index.d.ts +0 -32
- package/dist/web/components/button/index.js +0 -48
- package/dist/web/components/calendar/index.d.ts +0 -19
- package/dist/web/components/calendar/index.js +0 -189
- package/dist/web/components/calendar/util.d.ts +0 -13
- package/dist/web/components/calendar/util.js +0 -74
- package/dist/web/components/carousel/index.d.ts +0 -41
- package/dist/web/components/carousel/index.js +0 -244
- package/dist/web/components/chart/bar/index.d.ts +0 -41
- package/dist/web/components/chart/bar/index.js +0 -56
- package/dist/web/components/chart/common/config/bar.d.ts +0 -48
- package/dist/web/components/chart/common/config/bar.js +0 -49
- package/dist/web/components/chart/common/config/global.d.ts +0 -13
- package/dist/web/components/chart/common/config/global.js +0 -16
- package/dist/web/components/chart/common/config/line.d.ts +0 -46
- package/dist/web/components/chart/common/config/line.js +0 -49
- package/dist/web/components/chart/common/config/pie.d.ts +0 -29
- package/dist/web/components/chart/common/config/pie.js +0 -36
- package/dist/web/components/chart/common/core/eChartBar.d.ts +0 -68
- package/dist/web/components/chart/common/core/eChartBar.js +0 -198
- package/dist/web/components/chart/common/core/eChartBase.d.ts +0 -128
- package/dist/web/components/chart/common/core/eChartBase.js +0 -352
- package/dist/web/components/chart/common/core/eChartLine.d.ts +0 -62
- package/dist/web/components/chart/common/core/eChartLine.js +0 -170
- package/dist/web/components/chart/common/core/eChartPie.d.ts +0 -50
- package/dist/web/components/chart/common/core/eChartPie.js +0 -132
- package/dist/web/components/chart/common/core/type.d.ts +0 -35
- package/dist/web/components/chart/common/core/type.js +0 -9
- package/dist/web/components/chart/common/echarts.d.ts +0 -2
- package/dist/web/components/chart/common/echarts.js +0 -24
- package/dist/web/components/chart/common/useChart.d.ts +0 -8
- package/dist/web/components/chart/common/useChart.js +0 -60
- package/dist/web/components/chart/line/index.d.ts +0 -39
- package/dist/web/components/chart/line/index.js +0 -53
- package/dist/web/components/chart/pie/index.d.ts +0 -27
- package/dist/web/components/chart/pie/index.js +0 -40
- package/dist/web/components/chart/statisticsCard/index.d.ts +0 -85
- package/dist/web/components/chart/statisticsCard/index.js +0 -203
- package/dist/web/components/chart/statisticsCard/interface.d.ts +0 -13
- package/dist/web/components/chart/statisticsCard/interface.js +0 -1
- package/dist/web/components/container/index.d.ts +0 -6
- package/dist/web/components/container/index.js +0 -6
- package/dist/web/components/dataView/index.d.ts +0 -6
- package/dist/web/components/dataView/index.js +0 -8
- package/dist/web/components/dataView/interface.d.ts +0 -5
- package/dist/web/components/dataView/interface.js +0 -1
- package/dist/web/components/drawer/index.d.ts +0 -13
- package/dist/web/components/drawer/index.js +0 -12
- package/dist/web/components/form/checkbox/index.d.ts +0 -13
- package/dist/web/components/form/checkbox/index.js +0 -167
- package/dist/web/components/form/enumSelect/MultipleSelect.d.ts +0 -78
- package/dist/web/components/form/enumSelect/MultipleSelect.js +0 -52
- package/dist/web/components/form/enumSelect/NormalSelect.d.ts +0 -83
- package/dist/web/components/form/enumSelect/NormalSelect.js +0 -52
- package/dist/web/components/form/enumSelect/SelectContainer.d.ts +0 -16
- package/dist/web/components/form/enumSelect/SelectContainer.js +0 -30
- package/dist/web/components/form/enumSelect/index.d.ts +0 -82
- package/dist/web/components/form/enumSelect/index.js +0 -6
- package/dist/web/components/form/enumSelect/props/defaultProps.d.ts +0 -34
- package/dist/web/components/form/enumSelect/props/defaultProps.js +0 -40
- package/dist/web/components/form/enumSelect/props/propsTypes.d.ts +0 -39
- package/dist/web/components/form/enumSelect/props/propsTypes.js +0 -47
- package/dist/web/components/form/form/index.d.ts +0 -32
- package/dist/web/components/form/form/index.js +0 -108
- package/dist/web/components/form/formcell/index.d.ts +0 -8
- package/dist/web/components/form/formcell/index.js +0 -40
- package/dist/web/components/form/input/index.d.ts +0 -14
- package/dist/web/components/form/input/index.js +0 -86
- package/dist/web/components/form/location/common/mapChoose.d.ts +0 -15
- package/dist/web/components/form/location/common/mapChoose.js +0 -495
- package/dist/web/components/form/location/common/mapView.d.ts +0 -19
- package/dist/web/components/form/location/common/mapView.js +0 -172
- package/dist/web/components/form/location/common/propsConfig.d.ts +0 -59
- package/dist/web/components/form/location/common/propsConfig.js +0 -50
- package/dist/web/components/form/location/common/selectModal.d.ts +0 -21
- package/dist/web/components/form/location/common/selectModal.js +0 -44
- package/dist/web/components/form/location/common/useLocationInfo.d.ts +0 -36
- package/dist/web/components/form/location/common/useLocationInfo.js +0 -104
- package/dist/web/components/form/location/components/LocationH5/location.h5.d.ts +0 -8
- package/dist/web/components/form/location/components/LocationH5/location.h5.js +0 -325
- package/dist/web/components/form/location/components/LocationPC/Header.d.ts +0 -12
- package/dist/web/components/form/location/components/LocationPC/Header.js +0 -43
- package/dist/web/components/form/location/components/LocationPC/location.PC.d.ts +0 -8
- package/dist/web/components/form/location/components/LocationPC/location.PC.js +0 -224
- package/dist/web/components/form/location/constants.d.ts +0 -2
- package/dist/web/components/form/location/constants.js +0 -3
- package/dist/web/components/form/location/index.d.ts +0 -1
- package/dist/web/components/form/location/index.js +0 -17
- package/dist/web/components/form/radio/index.d.ts +0 -11
- package/dist/web/components/form/radio/index.js +0 -115
- package/dist/web/components/form/renderDecorator.d.ts +0 -6
- package/dist/web/components/form/renderDecorator.js +0 -20
- package/dist/web/components/form/select/dropdown-select/ui.d.ts +0 -15
- package/dist/web/components/form/select/dropdown-select/ui.js +0 -55
- package/dist/web/components/form/select/h5.d.ts +0 -16
- package/dist/web/components/form/select/h5.js +0 -410
- package/dist/web/components/form/select/index.d.ts +0 -65
- package/dist/web/components/form/select/index.js +0 -232
- package/dist/web/components/form/select/region/index.d.ts +0 -6
- package/dist/web/components/form/select/region/index.js +0 -147
- package/dist/web/components/form/select/time.d.ts +0 -9
- package/dist/web/components/form/select/time.js +0 -146
- package/dist/web/components/form/select/use-options.d.ts +0 -26
- package/dist/web/components/form/select/use-options.js +0 -103
- package/dist/web/components/form/select/year.d.ts +0 -7
- package/dist/web/components/form/select/year.js +0 -72
- package/dist/web/components/form/switch/index.d.ts +0 -6
- package/dist/web/components/form/switch/index.js +0 -58
- package/dist/web/components/form/textarea/index.d.ts +0 -12
- package/dist/web/components/form/textarea/index.js +0 -66
- package/dist/web/components/form/tips/index.d.ts +0 -8
- package/dist/web/components/form/tips/index.js +0 -17
- package/dist/web/components/form/uploader/index.d.ts +0 -3
- package/dist/web/components/form/uploader/index.js +0 -42
- package/dist/web/components/form/uploader/uploader.h5.d.ts +0 -20
- package/dist/web/components/form/uploader/uploader.h5.js +0 -224
- package/dist/web/components/form/uploader/uploader.pc.d.ts +0 -29
- package/dist/web/components/form/uploader/uploader.pc.js +0 -214
- package/dist/web/components/form/uploaderFile/index.d.ts +0 -4
- package/dist/web/components/form/uploaderFile/index.js +0 -19
- package/dist/web/components/form/uploaderFile/uploadFile.h5.d.ts +0 -23
- package/dist/web/components/form/uploaderFile/uploadFile.h5.js +0 -337
- package/dist/web/components/form/uploaderFile/uploadFile.pc.d.ts +0 -24
- package/dist/web/components/form/uploaderFile/uploadFile.pc.js +0 -313
- package/dist/web/components/form/userOrgSelect/comTool.d.ts +0 -7
- package/dist/web/components/form/userOrgSelect/comTool.js +0 -89
- package/dist/web/components/form/userOrgSelect/departTreeSelect/departTreeSelect.h5.d.ts +0 -20
- package/dist/web/components/form/userOrgSelect/departTreeSelect/departTreeSelect.h5.js +0 -259
- package/dist/web/components/form/userOrgSelect/departTreeSelect/departTreeSelect.pc.d.ts +0 -4
- package/dist/web/components/form/userOrgSelect/departTreeSelect/departTreeSelect.pc.js +0 -153
- package/dist/web/components/form/userOrgSelect/departTreeSelect/index.d.ts +0 -2
- package/dist/web/components/form/userOrgSelect/departTreeSelect/index.js +0 -17
- package/dist/web/components/form/userOrgSelect/index.d.ts +0 -2
- package/dist/web/components/form/userOrgSelect/index.js +0 -17
- package/dist/web/components/form/userOrgSelect/userOrgSelect.less +0 -643
- package/dist/web/components/form/userOrgSelect/userTreeSelect.h5.d.ts +0 -24
- package/dist/web/components/form/userOrgSelect/userTreeSelect.h5.js +0 -276
- package/dist/web/components/form/userOrgSelect/userTreeSelect.pc.d.ts +0 -9
- package/dist/web/components/form/userOrgSelect/userTreeSelect.pc.js +0 -229
- package/dist/web/components/form/userOrgSelect/utils.d.ts +0 -35
- package/dist/web/components/form/userOrgSelect/utils.js +0 -72
- package/dist/web/components/formdetail/index.d.ts +0 -28
- package/dist/web/components/formdetail/index.js +0 -170
- package/dist/web/components/graphicCard/index.d.ts +0 -31
- package/dist/web/components/graphicCard/index.js +0 -166
- package/dist/web/components/image/image.d.ts +0 -9
- package/dist/web/components/image/image.js +0 -119
- package/dist/web/components/image/index.d.ts +0 -13
- package/dist/web/components/image/index.js +0 -91
- package/dist/web/components/index.d.ts +0 -50
- package/dist/web/components/index.js +0 -97
- package/dist/web/components/link/index.d.ts +0 -24
- package/dist/web/components/link/index.js +0 -71
- package/dist/web/components/listView/index.d.ts +0 -7
- package/dist/web/components/listView/index.js +0 -286
- package/dist/web/components/listView/interface.d.ts +0 -127
- package/dist/web/components/listView/interface.js +0 -1
- package/dist/web/components/lottery/index.d.ts +0 -22
- package/dist/web/components/lottery/index.js +0 -391
- package/dist/web/components/lottery/lotteryUtil.d.ts +0 -23
- package/dist/web/components/lottery/lotteryUtil.js +0 -181
- package/dist/web/components/modal/index.d.ts +0 -17
- package/dist/web/components/modal/index.js +0 -11
- package/dist/web/components/modal/modal.h5.d.ts +0 -4
- package/dist/web/components/modal/modal.h5.js +0 -46
- package/dist/web/components/modal/modal.pc.d.ts +0 -3
- package/dist/web/components/modal/modal.pc.js +0 -31
- package/dist/web/components/navLayout/index.d.ts +0 -46
- package/dist/web/components/navLayout/index.js +0 -116
- package/dist/web/components/navigationBar/common.d.ts +0 -15
- package/dist/web/components/navigationBar/common.js +0 -127
- package/dist/web/components/navigationBar/h5Menu.d.ts +0 -14
- package/dist/web/components/navigationBar/h5Menu.js +0 -72
- package/dist/web/components/navigationBar/horizontalMenu.d.ts +0 -12
- package/dist/web/components/navigationBar/horizontalMenu.js +0 -99
- package/dist/web/components/navigationBar/index.d.ts +0 -13
- package/dist/web/components/navigationBar/index.js +0 -157
- package/dist/web/components/navigationBar/verticalMenu.d.ts +0 -13
- package/dist/web/components/navigationBar/verticalMenu.js +0 -38
- package/dist/web/components/phone/index.d.ts +0 -18
- package/dist/web/components/phone/index.js +0 -4
- package/dist/web/components/phoneCode/index.d.ts +0 -18
- package/dist/web/components/phoneCode/index.js +0 -4
- package/dist/web/components/picker/datePicker.d.ts +0 -10
- package/dist/web/components/picker/datePicker.js +0 -31
- package/dist/web/components/picker/picker.d.ts +0 -6
- package/dist/web/components/picker/picker.js +0 -45
- package/dist/web/components/picker/timePicker.d.ts +0 -7
- package/dist/web/components/picker/timePicker.js +0 -42
- package/dist/web/components/richText/const.d.ts +0 -1
- package/dist/web/components/richText/const.js +0 -2
- package/dist/web/components/richText/index.d.ts +0 -50
- package/dist/web/components/richText/index.js +0 -352
- package/dist/web/components/richTextView/index.d.ts +0 -7
- package/dist/web/components/richTextView/index.js +0 -44
- package/dist/web/components/scrollView/index.d.ts +0 -27
- package/dist/web/components/scrollView/index.js +0 -95
- package/dist/web/components/share/index.d.ts +0 -34
- package/dist/web/components/share/index.js +0 -4
- package/dist/web/components/slot/index.d.ts +0 -6
- package/dist/web/components/slot/index.js +0 -9
- package/dist/web/components/swiper/index.d.ts +0 -24
- package/dist/web/components/swiper/index.js +0 -153
- package/dist/web/components/tabs/index.d.ts +0 -13
- package/dist/web/components/tabs/index.js +0 -15
- package/dist/web/components/tabs/tabs.h5.d.ts +0 -4
- package/dist/web/components/tabs/tabs.h5.js +0 -42
- package/dist/web/components/tabs/tabs.pc.d.ts +0 -3
- package/dist/web/components/tabs/tabs.pc.js +0 -40
- package/dist/web/components/text/index.d.ts +0 -14
- package/dist/web/components/text/index.js +0 -17
- package/dist/web/components/uploaderFileView/index.d.ts +0 -10
- package/dist/web/components/uploaderFileView/index.js +0 -61
- package/dist/web/components/uploaderView/index.d.ts +0 -17
- package/dist/web/components/uploaderView/index.js +0 -48
- package/dist/web/components/userInfo/index.d.ts +0 -26
- package/dist/web/components/userInfo/index.js +0 -4
- package/dist/web/components/wedaVideo/index.d.ts +0 -17
- package/dist/web/components/wedaVideo/index.js +0 -160
- package/dist/web/index.d.ts +0 -8
- package/dist/web/index.js +0 -4
- package/dist/web/utils/classnames.d.ts +0 -2
- package/dist/web/utils/classnames.js +0 -37
- package/dist/web/utils/constant.d.ts +0 -23
- package/dist/web/utils/constant.js +0 -24
- package/dist/web/utils/debounce.d.ts +0 -2
- package/dist/web/utils/debounce.js +0 -92
- package/dist/web/utils/getLocalCounter.d.ts +0 -1
- package/dist/web/utils/getLocalCounter.js +0 -4
- package/dist/web/utils/getUserService.d.ts +0 -17
- package/dist/web/utils/getUserService.js +0 -148
- package/dist/web/utils/isObjectEqual.d.ts +0 -2
- package/dist/web/utils/isObjectEqual.js +0 -12
- package/dist/web/utils/loading-fallback.d.ts +0 -2
- package/dist/web/utils/loading-fallback.js +0 -2
- package/dist/web/utils/lodash.d.ts +0 -1
- package/dist/web/utils/lodash.js +0 -2
- package/dist/web/utils/platform.d.ts +0 -18
- package/dist/web/utils/platform.js +0 -193
- package/dist/web/utils/tcb.d.ts +0 -27
- package/dist/web/utils/tcb.js +0 -105
- package/dist/web/utils/tmap.d.ts +0 -3
- package/dist/web/utils/tmap.js +0 -21
- package/dist/web/utils/use-cloud-id-temp-url.d.ts +0 -1
- package/dist/web/utils/use-cloud-id-temp-url.js +0 -13
- package/dist/web/utils/useSetState.d.ts +0 -1
- package/dist/web/utils/useSetState.js +0 -8
- package/dist/web/utils/useSyncValue.d.ts +0 -4
- package/dist/web/utils/useSyncValue.js +0 -15
- package/dist/web/utils/weui.d.ts +0 -1
- package/dist/web/utils/weui.js +0 -2
|
@@ -1,352 +0,0 @@
|
|
|
1
|
-
import React, { useEffect, useMemo, useRef, useState } from 'react';
|
|
2
|
-
import { useSetState } from '../../utils/useSetState';
|
|
3
|
-
import classNames from '../../utils/classnames';
|
|
4
|
-
import Editor, { EditorState, convertEditorStateToHTML } from 'kedao';
|
|
5
|
-
import { insertMedias, handleKeyCommand } from 'kedao/lib/utils';
|
|
6
|
-
import { createStateFromContent } from 'kedao/lib/editor';
|
|
7
|
-
import { getCloudInstance } from '../../utils/tcb';
|
|
8
|
-
import { message, Button, Input, Modal, Progress, Upload, Text, } from 'tea-component';
|
|
9
|
-
import { v4 as uuidv4 } from 'uuid';
|
|
10
|
-
import { defaultBase64 } from './const';
|
|
11
|
-
import { renderDecorator } from '../form/renderDecorator';
|
|
12
|
-
import { usePlatform } from '../../utils/platform';
|
|
13
|
-
import './index.css';
|
|
14
|
-
import styleM from './richtext.module.css';
|
|
15
|
-
import { useSyncedRef } from '@react-hookz/web';
|
|
16
|
-
import { useTempUrl } from '../../utils/use-cloud-id-temp-url';
|
|
17
|
-
// 默认图片类型
|
|
18
|
-
const IMAGE_TYPES = [
|
|
19
|
-
'image/jpeg',
|
|
20
|
-
'image/png',
|
|
21
|
-
'image/gif',
|
|
22
|
-
'image/bmp',
|
|
23
|
-
'image/tiff',
|
|
24
|
-
'image/svg+xml',
|
|
25
|
-
];
|
|
26
|
-
const defaultControls = [
|
|
27
|
-
'undo',
|
|
28
|
-
'redo',
|
|
29
|
-
'separator',
|
|
30
|
-
'headings',
|
|
31
|
-
'separator',
|
|
32
|
-
'font-size',
|
|
33
|
-
'separator',
|
|
34
|
-
'line-height',
|
|
35
|
-
'letter-spacing',
|
|
36
|
-
'text-color',
|
|
37
|
-
'bold',
|
|
38
|
-
'italic',
|
|
39
|
-
'underline',
|
|
40
|
-
'strike-through',
|
|
41
|
-
'superscript',
|
|
42
|
-
'subscript',
|
|
43
|
-
'remove-styles',
|
|
44
|
-
'emoji',
|
|
45
|
-
'text-indent',
|
|
46
|
-
'text-align',
|
|
47
|
-
'list-ul',
|
|
48
|
-
'list-ol',
|
|
49
|
-
'blockquote',
|
|
50
|
-
'code',
|
|
51
|
-
'link',
|
|
52
|
-
'hr',
|
|
53
|
-
'media',
|
|
54
|
-
'clear',
|
|
55
|
-
];
|
|
56
|
-
export default function RichText({
|
|
57
|
-
// 系统属性
|
|
58
|
-
id, style, className, events,
|
|
59
|
-
// 组件属性
|
|
60
|
-
label, labelVisible, value: initialValue, readOnly, layout, requiredFlag, onChange, maxSize, acceptTypes, cloudPath, disabled, decorator, }) {
|
|
61
|
-
const [editorState, setEditorState] = useState();
|
|
62
|
-
const latestEditorState = useSyncedRef(editorState);
|
|
63
|
-
const cls = classNames({
|
|
64
|
-
'weda-ui': true,
|
|
65
|
-
'weda-richText': true,
|
|
66
|
-
[className]: className,
|
|
67
|
-
});
|
|
68
|
-
const platform = usePlatform();
|
|
69
|
-
const isH5 = platform === 'h5';
|
|
70
|
-
const subCls = classNames({
|
|
71
|
-
'weui-cell': isH5,
|
|
72
|
-
// 'weui-cell_active': isH5,
|
|
73
|
-
'weui-cell_form': isH5,
|
|
74
|
-
'weui-cell_disabled': isH5 && disabled,
|
|
75
|
-
});
|
|
76
|
-
const previousValueRef = useRef();
|
|
77
|
-
const onDataChange = function (value) {
|
|
78
|
-
if (previousValueRef.current !== value) {
|
|
79
|
-
events.change &&
|
|
80
|
-
events.change({ value: value === '<p></p>' ? '' : value });
|
|
81
|
-
if (onChange) {
|
|
82
|
-
if (value === '<p></p>') {
|
|
83
|
-
onChange('');
|
|
84
|
-
}
|
|
85
|
-
else {
|
|
86
|
-
onChange(value);
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
previousValueRef.current = value;
|
|
91
|
-
};
|
|
92
|
-
useEffect(() => {
|
|
93
|
-
const state = createStateFromContent(initialValue, {});
|
|
94
|
-
setEditorState(state);
|
|
95
|
-
}, []);
|
|
96
|
-
const excludeControls = useMemo(() => {
|
|
97
|
-
const result = [
|
|
98
|
-
'media',
|
|
99
|
-
'fullscreen',
|
|
100
|
-
'line-height',
|
|
101
|
-
'letter-spacing',
|
|
102
|
-
'emoji',
|
|
103
|
-
'superscript',
|
|
104
|
-
'subscript',
|
|
105
|
-
];
|
|
106
|
-
if (isH5) {
|
|
107
|
-
result.push('separator', 'undo', 'redo', 'blockquote', 'code', 'link', 'hr', 'list-ul', 'list-ol', 'hr', 'clear', 'text-indent',
|
|
108
|
-
// 'font-size',
|
|
109
|
-
'headings', 'remove-styles', 'text-align');
|
|
110
|
-
}
|
|
111
|
-
return result;
|
|
112
|
-
}, [isH5]);
|
|
113
|
-
const extendControls = useMemo(() => {
|
|
114
|
-
if (!isH5) {
|
|
115
|
-
return [
|
|
116
|
-
{
|
|
117
|
-
key: 'richtext-uploader',
|
|
118
|
-
type: 'component',
|
|
119
|
-
component: (React.createElement(CustomUploader, { acceptTypes: acceptTypes, maxSize: maxSize, cloudPath: cloudPath, onChange: (url) => {
|
|
120
|
-
const state = insertMedias(latestEditorState.current, [
|
|
121
|
-
{ type: 'IMAGE', url },
|
|
122
|
-
]);
|
|
123
|
-
setEditorState((curState) => {
|
|
124
|
-
const currentSelection = curState.getSelection();
|
|
125
|
-
EditorState.forceSelection(state, currentSelection);
|
|
126
|
-
return state;
|
|
127
|
-
});
|
|
128
|
-
} })),
|
|
129
|
-
},
|
|
130
|
-
];
|
|
131
|
-
}
|
|
132
|
-
}, [
|
|
133
|
-
acceptTypes,
|
|
134
|
-
maxSize,
|
|
135
|
-
cloudPath,
|
|
136
|
-
latestEditorState,
|
|
137
|
-
insertMedias,
|
|
138
|
-
setEditorState,
|
|
139
|
-
isH5,
|
|
140
|
-
]);
|
|
141
|
-
// 修改img显示逻辑
|
|
142
|
-
const blockRenderFn = (contentBlock, { editor, editorState }) => {
|
|
143
|
-
var _a;
|
|
144
|
-
if (contentBlock.getType() === 'atomic') {
|
|
145
|
-
const entityKey = contentBlock.getEntityAt(0);
|
|
146
|
-
if (!entityKey) {
|
|
147
|
-
return null;
|
|
148
|
-
}
|
|
149
|
-
const entity = (_a = editorState === null || editorState === void 0 ? void 0 : editorState.getCurrentContent()) === null || _a === void 0 ? void 0 : _a.getEntity(entityKey);
|
|
150
|
-
if (entity.getType() === 'IMAGE') {
|
|
151
|
-
return {
|
|
152
|
-
component: RichTextImg,
|
|
153
|
-
editable: false,
|
|
154
|
-
props: { editor, editorState }, // 传入的内容可以在组件中通过this.props.blockProps获取到
|
|
155
|
-
};
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
};
|
|
159
|
-
const richTextEl = (React.createElement("div", { className: subCls },
|
|
160
|
-
React.createElement("div", { style: style, className: styleM.richtextInner },
|
|
161
|
-
React.createElement(Editor, { key: id, value: editorState, readOnly: readOnly, disabled: disabled, language: "zh", blockRendererFn: blockRenderFn, onBlur: (s) => {
|
|
162
|
-
setEditorState(s);
|
|
163
|
-
const html = convertEditorStateToHTML(s, {});
|
|
164
|
-
onDataChange(html);
|
|
165
|
-
if (html.length > 32768) {
|
|
166
|
-
message.warning({
|
|
167
|
-
content: '富文本长度过长,可能导致保存失败',
|
|
168
|
-
});
|
|
169
|
-
}
|
|
170
|
-
}, controls: defaultControls, excludeControls: excludeControls,
|
|
171
|
-
/** @ts-ignore jsx */
|
|
172
|
-
extendControls: extendControls, handleKeyCommand: (command, editState) => {
|
|
173
|
-
const newState = handleKeyCommand(editState, command);
|
|
174
|
-
if (newState) {
|
|
175
|
-
setEditorState(newState);
|
|
176
|
-
return true;
|
|
177
|
-
}
|
|
178
|
-
return false;
|
|
179
|
-
} }))));
|
|
180
|
-
return renderDecorator(richTextEl, decorator)({
|
|
181
|
-
id,
|
|
182
|
-
className: cls,
|
|
183
|
-
style,
|
|
184
|
-
label: labelVisible ? label : null,
|
|
185
|
-
layout,
|
|
186
|
-
multiCell: false,
|
|
187
|
-
requiredFlag,
|
|
188
|
-
});
|
|
189
|
-
}
|
|
190
|
-
export const CustomUploader = (props) => {
|
|
191
|
-
const { onChange = () => { }, acceptTypes, maxSize, cloudPath } = props;
|
|
192
|
-
const [{ fileList, percent, visible, uploading, inputUrl, previewImg }, setState,] = useSetState({
|
|
193
|
-
fileList: [],
|
|
194
|
-
percent: 0,
|
|
195
|
-
visible: false,
|
|
196
|
-
uploading: false,
|
|
197
|
-
inputUrl: '',
|
|
198
|
-
previewImg: defaultBase64,
|
|
199
|
-
});
|
|
200
|
-
// 获取base64
|
|
201
|
-
const getBase64 = (file) => {
|
|
202
|
-
const reader = new FileReader();
|
|
203
|
-
reader.onloadend = () => {
|
|
204
|
-
/** @ts-ignore jsx */
|
|
205
|
-
setState({ previewImg: reader.result });
|
|
206
|
-
};
|
|
207
|
-
reader.readAsDataURL(file);
|
|
208
|
-
};
|
|
209
|
-
// 计算上传进度
|
|
210
|
-
const onProgress = (progressEvent) => {
|
|
211
|
-
let percentCompleted = 0;
|
|
212
|
-
try {
|
|
213
|
-
percentCompleted = Math.round((progressEvent.loaded * 100) / progressEvent.total);
|
|
214
|
-
percentCompleted < 100 ? percentCompleted : 100;
|
|
215
|
-
}
|
|
216
|
-
catch (e) {
|
|
217
|
-
console.error(e);
|
|
218
|
-
message.error({
|
|
219
|
-
content: '上传图片失败',
|
|
220
|
-
});
|
|
221
|
-
}
|
|
222
|
-
setState({ uploading: true, percent: percentCompleted });
|
|
223
|
-
};
|
|
224
|
-
return (React.createElement(React.Fragment, null,
|
|
225
|
-
React.createElement("button", { role: "richtext", type: "button", "data-title": "\u5A92\u4F53\u4E0A\u4F20", className: "control-item button", onClick: () => setState({ visible: true }) },
|
|
226
|
-
React.createElement("svg", { width: "17", height: "16", viewBox: "0 0 17 16", fill: "none", xmlns: "http://www.w3.org/2000/svg" },
|
|
227
|
-
React.createElement("path", { fillRule: "evenodd", clipRule: "evenodd", d: "M13.6205 1.61428V3.60631L15.6105 3.6063L15.6105 5.1063L13.6205 5.10631V7.08572H12.1205V5.10633L10.1391 5.10635L10.139 3.60635L12.1205 3.60633V1.61428H13.6205ZM8.84998 2.38572H2.49536C1.94308 2.38572 1.49536 2.83343 1.49536 3.38572V11.6761V13.3857C1.49536 13.403 1.4958 13.4201 1.49666 13.4372C1.5019 13.5405 1.52282 13.6397 1.5571 13.7324C1.69808 14.1138 2.06497 14.3857 2.49536 14.3857H4.49757H4.76178H12.4954C13.0476 14.3857 13.4954 13.938 13.4954 13.3857V13.2088L13.4954 13.2088V11.0909L13.4954 11.0909V8.38572H11.9954V9.59579L10.2484 7.85452L9.71895 7.32678L9.18948 7.85452L6.4372 10.5979L5.03662 9.20183L4.50715 8.67408L3.97769 9.20183L2.99536 10.181V3.88572H8.84998V2.38572ZM2.99536 12.8857V12.2988L4.50715 10.792L5.37481 11.6568L4.14188 12.8857H2.99536ZM11.9954 12.8857H6.26667L9.71895 9.44465L11.9954 11.7137V12.8857Z", fill: "#6A6F7B" }))),
|
|
228
|
-
React.createElement(Modal, { onClose: () => {
|
|
229
|
-
setState({ visible: false });
|
|
230
|
-
}, visible: visible, maskClosable: true },
|
|
231
|
-
React.createElement("p", null, "\u8F93\u5165\u94FE\u63A5\u63D2\u5165\u56FE\u7247"),
|
|
232
|
-
React.createElement("div", { className: "richText-upload-link" },
|
|
233
|
-
React.createElement(Input, { value: inputUrl, placeholder: "\u8F93\u5165\u56FE\u7247\u5730\u5740", onChange: (value) => setState({ inputUrl: value }) }),
|
|
234
|
-
"\u00A0",
|
|
235
|
-
React.createElement(Button, { type: "primary", onClick: () => {
|
|
236
|
-
onChange(inputUrl);
|
|
237
|
-
setState({ visible: false });
|
|
238
|
-
} }, "\u786E\u8BA4")),
|
|
239
|
-
React.createElement("p", { style: { marginBottom: '16px' } }, "\u6216\u62D6\u62FD\u4E0A\u4F20\u63D2\u5165\u56FE\u7247"),
|
|
240
|
-
React.createElement(Upload, { accept: acceptTypes.join(), maxSize: 1024 * 1024, beforeUpload: (file) => {
|
|
241
|
-
getBase64(file);
|
|
242
|
-
let typeRegex = new RegExp(`^((${acceptTypes.join(')|(').replace('+', '\\+')}))$`);
|
|
243
|
-
if (acceptTypes.join().includes('*')) {
|
|
244
|
-
typeRegex = new RegExp(`^image/.+$`);
|
|
245
|
-
}
|
|
246
|
-
if (!typeRegex.test(file.type)) {
|
|
247
|
-
message.error({
|
|
248
|
-
content: '文件格式不支持',
|
|
249
|
-
});
|
|
250
|
-
return false;
|
|
251
|
-
}
|
|
252
|
-
if (file.size > maxSize * 1024 * 1024) {
|
|
253
|
-
message.error({
|
|
254
|
-
content: `文件大小超过上限${maxSize}M`,
|
|
255
|
-
});
|
|
256
|
-
return false;
|
|
257
|
-
}
|
|
258
|
-
setState({
|
|
259
|
-
uploading: true,
|
|
260
|
-
percent: 0,
|
|
261
|
-
fileList: [
|
|
262
|
-
{
|
|
263
|
-
name: file.name,
|
|
264
|
-
},
|
|
265
|
-
],
|
|
266
|
-
});
|
|
267
|
-
getCloudInstance().then(async (tcb) => {
|
|
268
|
-
try {
|
|
269
|
-
const fileType = file.name.split('.').pop().toLowerCase();
|
|
270
|
-
const path = `${cloudPath}/uploader-${uuidv4()}.${fileType}`;
|
|
271
|
-
const { fileID } = await tcb.uploadFile({
|
|
272
|
-
cloudPath: path,
|
|
273
|
-
filePath: file,
|
|
274
|
-
onUploadProgress: onProgress,
|
|
275
|
-
});
|
|
276
|
-
onChange(fileID);
|
|
277
|
-
setState({
|
|
278
|
-
visible: false,
|
|
279
|
-
fileList: [],
|
|
280
|
-
});
|
|
281
|
-
}
|
|
282
|
-
catch (e) {
|
|
283
|
-
setState({
|
|
284
|
-
fileList: [],
|
|
285
|
-
});
|
|
286
|
-
console.error(e);
|
|
287
|
-
message.error({
|
|
288
|
-
content: '上传图片失败' + e.message,
|
|
289
|
-
});
|
|
290
|
-
}
|
|
291
|
-
finally {
|
|
292
|
-
setState({ uploading: false, percent: 100 });
|
|
293
|
-
}
|
|
294
|
-
});
|
|
295
|
-
return false;
|
|
296
|
-
} }, ({ open, isDragging }) => (React.createElement(Upload.Dragger, { filename: fileList[0] && fileList[0].name, percent: percent, image: previewImg, className: "richtext_upload_dragger" }, isDragging ? ('释放鼠标') : (React.createElement(React.Fragment, null,
|
|
297
|
-
React.createElement("a", { onClick: open }, "\u70B9\u51FB\u4E0A\u4F20"),
|
|
298
|
-
React.createElement(Text, { theme: "weak" }, "/\u62D6\u62FD\u5230\u6B64\u533A\u57DF")))))),
|
|
299
|
-
uploading && (React.createElement(Progress, { style: { marginTop: '10px' }, percent: percent })))));
|
|
300
|
-
};
|
|
301
|
-
const Img = React.memo(function Img(props) {
|
|
302
|
-
const { src, style, onError } = props;
|
|
303
|
-
const { data: realSrc, error } = useTempUrl(src);
|
|
304
|
-
const realstyle = useMemo(() => {
|
|
305
|
-
if (error) {
|
|
306
|
-
return { ...style, width: '80px' };
|
|
307
|
-
}
|
|
308
|
-
return style;
|
|
309
|
-
}, [error, style]);
|
|
310
|
-
return (React.createElement("img", { src: error ? defaultBase64 : realSrc, style: realstyle, onError: () => {
|
|
311
|
-
onError === null || onError === void 0 ? void 0 : onError();
|
|
312
|
-
} }));
|
|
313
|
-
});
|
|
314
|
-
const imgStyle = { maxWidth: '100%' };
|
|
315
|
-
export const RichTextImg = ({ contentState, block }) => {
|
|
316
|
-
const blockData = contentState.getEntity(block.getEntityAt(0)).getData();
|
|
317
|
-
const { url } = blockData || {};
|
|
318
|
-
return (url && (React.createElement(React.Fragment, null,
|
|
319
|
-
React.createElement("div", { className: "bf-media" },
|
|
320
|
-
React.createElement("div", { draggable: "true", className: "bf-image", style: { float: 'left' } },
|
|
321
|
-
React.createElement("div", { style: { position: 'relative', display: 'inline-block' } },
|
|
322
|
-
React.createElement(Img, { src: url, style: imgStyle }),
|
|
323
|
-
React.createElement("div", { className: "bf-pre-csize" }))),
|
|
324
|
-
React.createElement("div", { style: {
|
|
325
|
-
clear: 'both',
|
|
326
|
-
height: '0px',
|
|
327
|
-
lineHeight: 0,
|
|
328
|
-
float: 'none',
|
|
329
|
-
} })))));
|
|
330
|
-
};
|
|
331
|
-
RichText.defaultProps = {
|
|
332
|
-
// 系统属性
|
|
333
|
-
events: {},
|
|
334
|
-
style: {},
|
|
335
|
-
// 组件属性
|
|
336
|
-
label: '标题',
|
|
337
|
-
labelVisible: true,
|
|
338
|
-
name: 'formRichText',
|
|
339
|
-
value: '',
|
|
340
|
-
readOnly: true,
|
|
341
|
-
disabled: true,
|
|
342
|
-
layout: 'vertical',
|
|
343
|
-
requiredFlag: false,
|
|
344
|
-
maxSize: 10,
|
|
345
|
-
acceptTypes: IMAGE_TYPES,
|
|
346
|
-
cloudPath: 'weda-richtext-upload',
|
|
347
|
-
};
|
|
348
|
-
CustomUploader.defaultProps = {
|
|
349
|
-
maxSize: 10,
|
|
350
|
-
acceptTypes: IMAGE_TYPES,
|
|
351
|
-
cloudPath: 'weda-richtext-upload',
|
|
352
|
-
};
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
|
-
import './index.css';
|
|
3
|
-
import type { CommonPropsType } from '../../types';
|
|
4
|
-
export interface PropsType extends CommonPropsType {
|
|
5
|
-
value: string;
|
|
6
|
-
}
|
|
7
|
-
export default function RichTextView({ value, className, style, id, }: PropsType): JSX.Element;
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
import React, { useEffect, useState } from 'react';
|
|
2
|
-
import classNames from '../../utils/classnames';
|
|
3
|
-
import { getTempFileURL } from '../../utils/tcb';
|
|
4
|
-
import './index.css';
|
|
5
|
-
import { LOAD_ERR_IMG_BASE64 } from '../../utils/constant';
|
|
6
|
-
import destr from 'destr';
|
|
7
|
-
export default function RichTextView({ value = '', className, style, id, }) {
|
|
8
|
-
const parseValue = destr(value);
|
|
9
|
-
const cls = classNames({
|
|
10
|
-
'weda-ui': true,
|
|
11
|
-
'weda-RichTextView': true,
|
|
12
|
-
[className]: className,
|
|
13
|
-
});
|
|
14
|
-
const [displayValue, setDisplayValue] = useState('');
|
|
15
|
-
const regex = new RegExp(/<img [^>]*src=\\*"([^"]*?)\\*"/g);
|
|
16
|
-
const iferror = `javascript:this.width='80';this.src='${LOAD_ERR_IMG_BASE64}';this.onerror=null`;
|
|
17
|
-
let tempValue = parseValue
|
|
18
|
-
.toString()
|
|
19
|
-
.replace(/<img /g, `<img onerror=${iferror} style="max-width:100%" `);
|
|
20
|
-
const getSrc = async (img) => {
|
|
21
|
-
const url = img.replace(regex, '$1');
|
|
22
|
-
if (img.includes('cloud://')) {
|
|
23
|
-
const newURL = await getTempFileURL(url);
|
|
24
|
-
if (newURL) {
|
|
25
|
-
tempValue = tempValue.replace(new RegExp(url, 'g'), newURL);
|
|
26
|
-
setDisplayValue(tempValue);
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
};
|
|
30
|
-
useEffect(() => {
|
|
31
|
-
setDisplayValue(tempValue);
|
|
32
|
-
try {
|
|
33
|
-
const imgs = parseValue.match(regex);
|
|
34
|
-
if (imgs && imgs.length > 0) {
|
|
35
|
-
imgs.forEach((img) => {
|
|
36
|
-
getSrc(img);
|
|
37
|
-
});
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
catch (e) { }
|
|
41
|
-
}, [value]);
|
|
42
|
-
return (displayValue && (React.createElement("div", { className: cls, style: style, id: id },
|
|
43
|
-
React.createElement("div", { dangerouslySetInnerHTML: { __html: displayValue } }))));
|
|
44
|
-
}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
|
-
import type { CommonPropsType } from '../../types';
|
|
3
|
-
export interface PropsType extends CommonPropsType {
|
|
4
|
-
scrollX?: boolean;
|
|
5
|
-
scrollY?: boolean;
|
|
6
|
-
scrollTop?: number;
|
|
7
|
-
scrollLeft?: number;
|
|
8
|
-
scrollIntoView?: string;
|
|
9
|
-
upperThreshold?: number;
|
|
10
|
-
lowerThreshold?: number;
|
|
11
|
-
domRef?: any;
|
|
12
|
-
}
|
|
13
|
-
export default function ScrollView({ id, scrollX, scrollY, style, scrollTop, scrollLeft, scrollIntoView, className, children, upperThreshold, lowerThreshold, domRef, events, }: {
|
|
14
|
-
id: any;
|
|
15
|
-
scrollX?: boolean;
|
|
16
|
-
scrollY?: boolean;
|
|
17
|
-
style: any;
|
|
18
|
-
scrollTop: any;
|
|
19
|
-
scrollLeft: any;
|
|
20
|
-
scrollIntoView: any;
|
|
21
|
-
className: any;
|
|
22
|
-
children: any;
|
|
23
|
-
upperThreshold?: number;
|
|
24
|
-
lowerThreshold?: number;
|
|
25
|
-
domRef: any;
|
|
26
|
-
events: any;
|
|
27
|
-
}): JSX.Element;
|
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
import classNames from '../../utils/classnames';
|
|
3
|
-
export default function ScrollView({ id, scrollX = false, scrollY = true, style, scrollTop, scrollLeft, scrollIntoView, className, children, upperThreshold = 50, lowerThreshold = 50, domRef, events, }) {
|
|
4
|
-
const [toUpper, setToUpper] = React.useState(false);
|
|
5
|
-
const [toLower, setToLower] = React.useState(false);
|
|
6
|
-
const [scrollLeftPos, setScrollLeftPos] = React.useState(0);
|
|
7
|
-
const [scrollTopPos, setScrollTopPos] = React.useState(0);
|
|
8
|
-
const scrollViewRef = domRef || React.useRef(null);
|
|
9
|
-
const handleOnScroll = function (e) {
|
|
10
|
-
const detail = {
|
|
11
|
-
scrollLeft: e.target.scrollLeft,
|
|
12
|
-
scrollTop: e.target.scrollTop,
|
|
13
|
-
scrollHeight: e.target.scrollHeight,
|
|
14
|
-
scrollWidth: e.target.scrollWidth,
|
|
15
|
-
};
|
|
16
|
-
const deltaY = scrollY ? e.target.scrollTop - scrollTopPos : 0;
|
|
17
|
-
const deltaX = scrollX ? e.target.scrollLeft - scrollLeftPos : 0;
|
|
18
|
-
let delta;
|
|
19
|
-
// 横向滚动
|
|
20
|
-
if (Math.abs(deltaX) > Math.abs(deltaY)) {
|
|
21
|
-
delta = deltaX;
|
|
22
|
-
setScrollLeftPos(e.target.scrollLeft);
|
|
23
|
-
if (scrollX && e.target.scrollLeft <= upperThreshold) {
|
|
24
|
-
delta < 0 && setToUpper(true);
|
|
25
|
-
}
|
|
26
|
-
else {
|
|
27
|
-
setToUpper(false);
|
|
28
|
-
}
|
|
29
|
-
if (scrollX &&
|
|
30
|
-
e.target.scrollLeft + e.target.offsetWidth + lowerThreshold >=
|
|
31
|
-
e.target.scrollWidth) {
|
|
32
|
-
delta > 0 && setToLower(true);
|
|
33
|
-
}
|
|
34
|
-
else {
|
|
35
|
-
setToLower(false);
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
else {
|
|
39
|
-
delta = deltaY;
|
|
40
|
-
setScrollTopPos(e.target.scrollTop);
|
|
41
|
-
if (scrollY && e.target.scrollTop <= upperThreshold) {
|
|
42
|
-
delta < 0 && setToUpper(true);
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
setToUpper(false);
|
|
46
|
-
}
|
|
47
|
-
if (scrollY &&
|
|
48
|
-
e.target.scrollTop + e.target.offsetHeight + lowerThreshold >=
|
|
49
|
-
e.target.scrollHeight) {
|
|
50
|
-
delta > 0 && setToLower(true);
|
|
51
|
-
}
|
|
52
|
-
else {
|
|
53
|
-
setToLower(false);
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
// console.log("delta", deltaY, deltaX
|
|
57
|
-
events.scroll(detail, { originEvent: e });
|
|
58
|
-
};
|
|
59
|
-
React.useEffect(() => {
|
|
60
|
-
scrollViewRef.current.scrollTop = scrollTop;
|
|
61
|
-
}, [scrollTop]);
|
|
62
|
-
React.useEffect(() => {
|
|
63
|
-
scrollViewRef.current.scrollLeft = scrollLeft;
|
|
64
|
-
}, [scrollLeft]);
|
|
65
|
-
React.useEffect(() => {
|
|
66
|
-
toUpper && events.scrolltoupper();
|
|
67
|
-
}, [toUpper]);
|
|
68
|
-
React.useEffect(() => {
|
|
69
|
-
toLower && events.scrolltolower();
|
|
70
|
-
}, [toLower]);
|
|
71
|
-
React.useEffect(() => {
|
|
72
|
-
if (scrollIntoView) {
|
|
73
|
-
const children = scrollViewRef.current.children;
|
|
74
|
-
const item = Array.from(children).find((item) => item && item.id === scrollIntoView);
|
|
75
|
-
scrollY && (scrollViewRef.current.scrollTop = item.offsetTop);
|
|
76
|
-
scrollX && (scrollViewRef.current.scrollLeft = item.offsetLeft);
|
|
77
|
-
// console.log('children', children, item)
|
|
78
|
-
}
|
|
79
|
-
}, [scrollIntoView]);
|
|
80
|
-
const webStyles = {
|
|
81
|
-
position: 'relative',
|
|
82
|
-
width: '100%',
|
|
83
|
-
height: '100%',
|
|
84
|
-
// whiteSpace: scroll === 'y' ? 'normal' : 'nowrap',
|
|
85
|
-
overflowX: `${scrollX ? 'auto' : 'hidden'}`,
|
|
86
|
-
overflowY: `${scrollY ? 'auto' : 'hidden'}`,
|
|
87
|
-
...style,
|
|
88
|
-
};
|
|
89
|
-
const cls = classNames({
|
|
90
|
-
'weda-ui': true,
|
|
91
|
-
'g-scroll-view': true,
|
|
92
|
-
[className]: className,
|
|
93
|
-
});
|
|
94
|
-
return (React.createElement("div", { id: id, style: webStyles, ref: scrollViewRef, className: cls, onScrollCapture: handleOnScroll }, children));
|
|
95
|
-
}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
|
-
import type { CommonPropsType } from '../../types';
|
|
3
|
-
declare const Share: (props: PropsType) => JSX.Element;
|
|
4
|
-
export interface PropsType extends CommonPropsType {
|
|
5
|
-
/**
|
|
6
|
-
* 按钮标题
|
|
7
|
-
*/
|
|
8
|
-
text?: string;
|
|
9
|
-
/**
|
|
10
|
-
* 按钮风格
|
|
11
|
-
*/
|
|
12
|
-
type?: 'primary' | 'warn' | 'wechat' | 'default';
|
|
13
|
-
/**
|
|
14
|
-
* 按钮大小
|
|
15
|
-
*/
|
|
16
|
-
size?: 'default' | 'mini' | 'large';
|
|
17
|
-
/**
|
|
18
|
-
* 分享标题
|
|
19
|
-
*/
|
|
20
|
-
title?: string;
|
|
21
|
-
/**
|
|
22
|
-
* 选择页面
|
|
23
|
-
*/
|
|
24
|
-
path?: string;
|
|
25
|
-
/**
|
|
26
|
-
* 携带参数
|
|
27
|
-
*/
|
|
28
|
-
withParams?: boolean;
|
|
29
|
-
/**
|
|
30
|
-
* 参数
|
|
31
|
-
*/
|
|
32
|
-
params?: any;
|
|
33
|
-
}
|
|
34
|
-
export default Share;
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
export default function Slot({ compositeParent, name, className }) {
|
|
3
|
-
if (!compositeParent) {
|
|
4
|
-
console.warn('Slot组件只能用于实现复合组件');
|
|
5
|
-
// 兼容编辑器点击,可选中 Slot 组件
|
|
6
|
-
return (React.createElement("div", { className: 'weda-ui' + className ? ` ${className}` : '' }, 'Slot - ' + name));
|
|
7
|
-
}
|
|
8
|
-
return compositeParent.props.data[name] || null;
|
|
9
|
-
}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
|
-
import './index.css';
|
|
3
|
-
import type { CommonPropsType } from '../../types';
|
|
4
|
-
export interface PropsType extends CommonPropsType {
|
|
5
|
-
/**
|
|
6
|
-
* 是否启用指示点
|
|
7
|
-
*/
|
|
8
|
-
indicatorDots: boolean;
|
|
9
|
-
/**
|
|
10
|
-
* 是否自动切换
|
|
11
|
-
*/
|
|
12
|
-
autoplay: boolean;
|
|
13
|
-
/**
|
|
14
|
-
* 当前索引值
|
|
15
|
-
*/
|
|
16
|
-
current: number;
|
|
17
|
-
interval: number;
|
|
18
|
-
duration: number;
|
|
19
|
-
circular: boolean;
|
|
20
|
-
vertical: boolean;
|
|
21
|
-
indicatorColor: string;
|
|
22
|
-
indicatorActiveColor: string;
|
|
23
|
-
}
|
|
24
|
-
export default function Swiper({ children, className, style, autoplay, circular, vertical, indicatorDots, indicatorColor, indicatorActiveColor, duration, interval, current, events, id, }: PropsType): JSX.Element;
|