studiokit-scaffolding-js 7.0.12-next.1.3 → 7.0.12-next.2.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/lib/components/ActionList.js +164 -37
- package/lib/components/AlertDialog.js +128 -12
- package/lib/components/AlertWithIcon.js +88 -29
- package/lib/components/ConnectedModal.js +35 -12
- package/lib/components/Dropdowns/GroupsDropdown.js +63 -45
- package/lib/components/Dropdowns/ManagedNavDropdown.js +92 -67
- package/lib/components/Dropdowns/UserDropdown.js +105 -24
- package/lib/components/Dropdowns/index.js +4 -10
- package/lib/components/EntityOwnerList.js +47 -21
- package/lib/components/Error.js +101 -12
- package/lib/components/ErrorBoundary.js +127 -38
- package/lib/components/ErrorMessage.js +39 -12
- package/lib/components/Forms/DateField.js +56 -45
- package/lib/components/Forms/TimeField.js +76 -45
- package/lib/components/Forms/index.js +3 -5
- package/lib/components/Groups/CreateEditCopySaveButtons.js +109 -14
- package/lib/components/Groups/ExternalGroups/Attach.js +206 -151
- package/lib/components/Groups/ExternalGroups/Table.js +176 -48
- package/lib/components/Groups/GroupCreateOrEditCommonProps.js +2 -2
- package/lib/components/Groups/RosterSyncInfo.js +142 -23
- package/lib/components/HOC/AccessibleAppComponent.js +88 -72
- package/lib/components/HOC/ActivityRequiredComponent.js +68 -33
- package/lib/components/HOC/AsyncComponent.js +49 -41
- package/lib/components/HOC/AuthenticatedComponent.js +55 -44
- package/lib/components/HOC/CollectionComponent.js +154 -104
- package/lib/components/HOC/CollectionFirstItemComponent.js +45 -40
- package/lib/components/HOC/CollectionItemComponent.js +152 -100
- package/lib/components/HOC/ConnectedModalComponent.js +87 -69
- package/lib/components/HOC/DataDependentComponent.js +26 -27
- package/lib/components/HOC/EntityComponent.js +57 -53
- package/lib/components/HOC/FullscreenModalComponent.js +139 -108
- package/lib/components/HOC/GroupActivityRequiredComponent.js +27 -20
- package/lib/components/HOC/GuidComponent.js +20 -20
- package/lib/components/HOC/ModelContextDependencyVerifyComponent.js +32 -29
- package/lib/components/HOC/ModelErrorRedirectComponent.js +37 -39
- package/lib/components/HOC/SearchPersistorComponent.js +237 -173
- package/lib/components/HOC/UnauthenticatedComponent.js +32 -30
- package/lib/components/HOC/UserComponent.js +6 -8
- package/lib/components/Icons/IconAlphaList.js +28 -8
- package/lib/components/Icons/IconExternalUser.js +28 -8
- package/lib/components/Icons/IconImpersonation.js +28 -8
- package/lib/components/Icons/IconStopImpersonating.js +28 -8
- package/lib/components/Icons/IconTable.js +29 -9
- package/lib/components/Icons/IconTableDeleteCol.js +28 -8
- package/lib/components/Icons/IconTableDeleteRow.js +28 -8
- package/lib/components/Icons/IconTableInsertCol.js +28 -8
- package/lib/components/Icons/IconTableInsertRow.js +28 -8
- package/lib/components/Impersonation/Button.js +71 -16
- package/lib/components/Impersonation/Link.js +72 -16
- package/lib/components/Impersonation/UserDetail.js +60 -11
- package/lib/components/Loading.js +23 -8
- package/lib/components/LockDownBrowser/Check.js +188 -51
- package/lib/components/LockDownBrowser/ExitButton.js +22 -13
- package/lib/components/LockDownBrowser/Launch.js +64 -64
- package/lib/components/Lti/Confirm.js +147 -14
- package/lib/components/Lti/CreateNonLtiGroupAlertDialog.js +165 -36
- package/lib/components/Lti/Launch.js +99 -25
- package/lib/components/Lti/LaunchGroup.js +81 -16
- package/lib/components/ManageTable.js +304 -90
- package/lib/components/ManageTableNoDataComponent.js +38 -7
- package/lib/components/NewVersionAlert.js +76 -49
- package/lib/components/NotFound.js +81 -11
- package/lib/components/Notifications.js +179 -129
- package/lib/components/PaginationNextButton.js +28 -9
- package/lib/components/PaginationPreviousButton.js +28 -9
- package/lib/components/Quill/CustomToolbar.js +427 -222
- package/lib/components/Quill/Formats/Image.js +67 -67
- package/lib/components/Quill/Formats/List.js +38 -47
- package/lib/components/Quill/Formats/Video.js +23 -26
- package/lib/components/Quill/ImageDropModule.js +136 -114
- package/lib/components/Quill/ImageWarning.js +41 -12
- package/lib/components/Quill/ImageWithAltTextModal.js +420 -89
- package/lib/components/Quill/Specs/CustomImageSpec.js +32 -31
- package/lib/components/Quill/Specs/CustomVideoSpec.js +22 -23
- package/lib/components/Quill/TableModule/Blots/BaseTableBlot.js +89 -97
- package/lib/components/Quill/TableModule/Blots/TableBlot.js +47 -50
- package/lib/components/Quill/TableModule/Blots/TableBodyBlot.js +48 -51
- package/lib/components/Quill/TableModule/Blots/TableCellBlot.js +219 -224
- package/lib/components/Quill/TableModule/Blots/TableContainer.js +75 -86
- package/lib/components/Quill/TableModule/Blots/TableRowBlot.js +70 -73
- package/lib/components/Quill/TableModule/constants.js +40 -42
- package/lib/components/Quill/TableModule/index.js +357 -305
- package/lib/components/Quill/TableModule/utils.js +39 -48
- package/lib/components/Quill/accessibilityFix.js +219 -223
- package/lib/components/Quill/index.js +30 -33
- package/lib/components/RefreshIndicator/Bordered.js +44 -10
- package/lib/components/RefreshIndicator/Inline.js +43 -12
- package/lib/components/RefreshIndicator/index.js +257 -62
- package/lib/components/SearchControls.js +211 -14
- package/lib/components/SentryRoute.js +5 -7
- package/lib/components/Tables/RoleFilter.js +66 -38
- package/lib/components/Tables/TextFilter.js +58 -18
- package/lib/components/UserRoles/Add.js +193 -99
- package/lib/components/UserRoles/Context.js +3 -6
- package/lib/components/UserRoles/RoleCell.js +176 -75
- package/lib/components/UserRoles/Select.js +151 -20
- package/lib/components/UserRoles/Table.js +215 -82
- package/lib/components/UserRoles/index.js +526 -386
- package/lib/config/eslint/index.js +26 -29
- package/lib/config/eslint/lib/order.js +21 -28
- package/lib/config/eslint/lib/prettier.js +15 -19
- package/lib/config/eslint/lib/typescript.js +87 -113
- package/lib/config/eslint/react.js +18 -15
- package/lib/constants/baseActivity.js +26 -28
- package/lib/constants/baseRole.js +10 -12
- package/lib/constants/configuration.js +43 -55
- package/lib/constants/externalProviderType.js +6 -8
- package/lib/constants/fetchErrorData.js +10 -12
- package/lib/constants/index.js +13 -15
- package/lib/constants/lockDownBrowser.js +23 -25
- package/lib/constants/mockData.js +370 -300
- package/lib/constants/modelStatus.js +11 -13
- package/lib/constants/notificationType.js +8 -10
- package/lib/constants/operatingSystem.js +8 -10
- package/lib/constants/shard.js +7 -9
- package/lib/constants/table.js +18 -22
- package/lib/constants/tier.js +8 -10
- package/lib/constants/userRole.js +11 -8
- package/lib/endpointMappings.js +191 -182
- package/lib/hooks/useCollection.js +79 -65
- package/lib/hooks/useCollectionConfiguration.js +220 -80
- package/lib/hooks/useCollectionItem.js +151 -57
- package/lib/hooks/useGuid.js +16 -9
- package/lib/hooks/usePrevious.js +14 -13
- package/lib/index.js +11 -26
- package/lib/redux/actionCreator.js +44 -35
- package/lib/redux/actions/AuthAction.js +45 -32
- package/lib/redux/actions/ModalAction.js +6 -8
- package/lib/redux/actions/ModelAction.js +95 -43
- package/lib/redux/actions/NotificationAction.js +6 -8
- package/lib/redux/actions/SearchAction.js +5 -7
- package/lib/redux/actions/index.js +6 -8
- package/lib/redux/configureReducers.js +48 -46
- package/lib/redux/configureStore.js +77 -91
- package/lib/redux/helpers.js +2 -5
- package/lib/redux/reducers/authReducer.js +44 -43
- package/lib/redux/reducers/index.js +7 -14
- package/lib/redux/reducers/modalsReducer.js +43 -31
- package/lib/redux/reducers/modelsReducer.js +131 -137
- package/lib/redux/reducers/notificationsReducer.js +20 -20
- package/lib/redux/reducers/searchReducer.js +13 -13
- package/lib/redux/sagas/appInsightsSaga.js +19 -21
- package/lib/redux/sagas/authSaga.js +248 -234
- package/lib/redux/sagas/caliperSaga.js +142 -131
- package/lib/redux/sagas/clockOffsetSaga.js +29 -32
- package/lib/redux/sagas/configurationSaga.js +8 -10
- package/lib/redux/sagas/downtimeApiErrorSaga.js +16 -19
- package/lib/redux/sagas/errorSaga.js +23 -24
- package/lib/redux/sagas/googleAnalyticsSaga.js +24 -27
- package/lib/redux/sagas/identityProviderSaga.js +19 -21
- package/lib/redux/sagas/initialDataLoadSaga.js +34 -31
- package/lib/redux/sagas/lockDownBrowserErrorSaga.js +25 -22
- package/lib/redux/sagas/modelFetchSaga.js +302 -286
- package/lib/redux/sagas/noStoreSaga.js +60 -61
- package/lib/redux/sagas/postLoginDataSaga.js +37 -32
- package/lib/redux/sagas/postLoginRedirectSaga.js +22 -27
- package/lib/redux/sagas/rootSaga.js +77 -60
- package/lib/redux/sagas/sentrySaga.js +25 -28
- package/lib/redux/sagas/userIdSaga.js +13 -15
- package/lib/services/codeProviderService.js +21 -21
- package/lib/services/dateService.js +6 -8
- package/lib/services/documentService.js +10 -11
- package/lib/services/fetchService.js +103 -95
- package/lib/services/persistenceService.js +27 -30
- package/lib/services/ticketProviderService.js +25 -25
- package/lib/services/tokenPersistenceService.js +8 -10
- package/lib/services/windowService.js +14 -16
- package/lib/startup.js +110 -101
- package/lib/types/AppConfiguration.js +2 -2
- package/lib/types/Artifact.js +7 -9
- package/lib/types/BaseReduxState.js +2 -2
- package/lib/types/Client.js +2 -2
- package/lib/types/Collection.js +2 -2
- package/lib/types/Configuration.js +2 -2
- package/lib/types/DeepLinkingResponseRequest.js +2 -2
- package/lib/types/DeletableModel.js +2 -2
- package/lib/types/Event.js +2 -2
- package/lib/types/ExternalGroup.js +2 -2
- package/lib/types/ExternalProvider.js +2 -2
- package/lib/types/ExternalTerm.js +2 -2
- package/lib/types/Group.js +2 -2
- package/lib/types/IdentityProvider.js +2 -2
- package/lib/types/LtiLaunch.js +2 -2
- package/lib/types/NameOnlyEntity.js +2 -2
- package/lib/types/Notification.js +2 -2
- package/lib/types/OptionalRecord.js +2 -2
- package/lib/types/OwnerSchedule.js +2 -2
- package/lib/types/PropertyOfType.js +2 -2
- package/lib/types/Quill.js +2 -2
- package/lib/types/RoleDescription.js +2 -2
- package/lib/types/Search.js +2 -2
- package/lib/types/SimpleLocation.js +2 -2
- package/lib/types/UniTime.js +2 -2
- package/lib/types/User.js +2 -2
- package/lib/types/UserRole.js +2 -2
- package/lib/types/auth/AuthState.js +2 -2
- package/lib/types/auth/CasV1LoginRequestBody.js +2 -2
- package/lib/types/auth/ClientCredentials.js +2 -2
- package/lib/types/auth/CodeProviderService.js +2 -2
- package/lib/types/auth/LocalLoginRequestBody.js +2 -2
- package/lib/types/auth/TicketProviderService.js +2 -2
- package/lib/types/auth/TokenPersistenceService.js +2 -2
- package/lib/types/auth/index.js +8 -10
- package/lib/types/externals.d.js +2 -0
- package/lib/types/index.js +29 -31
- package/lib/types/net/EndpointConfig.js +2 -2
- package/lib/types/net/EndpointMapping.js +2 -2
- package/lib/types/net/EndpointMappings.js +2 -2
- package/lib/types/net/ErrorHandler.js +2 -2
- package/lib/types/net/FetchConfig.js +2 -2
- package/lib/types/net/FetchErrorData.js +6 -8
- package/lib/types/net/FetchResult.js +2 -2
- package/lib/types/net/HTTPMethod.js +2 -2
- package/lib/types/net/HTTPStatusCode.js +12 -14
- package/lib/types/net/Metadata.js +2 -2
- package/lib/types/net/Model.js +2 -2
- package/lib/types/net/ModelCollection.js +2 -2
- package/lib/types/net/ModelsState.js +2 -2
- package/lib/types/net/OAuthToken.js +2 -2
- package/lib/types/net/OAuthTokenOrNull.js +2 -2
- package/lib/types/net/TokenAccessFunction.js +2 -2
- package/lib/types/net/index.js +17 -19
- package/lib/utils/baseActivity.js +83 -85
- package/lib/utils/baseRole.js +32 -36
- package/lib/utils/collection.js +403 -297
- package/lib/utils/cookies.js +19 -23
- package/lib/utils/date.js +188 -205
- package/lib/utils/dom.js +130 -131
- package/lib/utils/domainIdentifier.js +4 -8
- package/lib/utils/entityUserRole.js +2 -5
- package/lib/utils/error.js +14 -19
- package/lib/utils/events.js +32 -31
- package/lib/utils/externalGroup.js +20 -25
- package/lib/utils/externalProviders.js +4 -7
- package/lib/utils/externalTerms.js +6 -6
- package/lib/utils/fetch.js +168 -176
- package/lib/utils/group.js +14 -11
- package/lib/utils/groupDates.js +38 -46
- package/lib/utils/groupRoles.js +23 -32
- package/lib/utils/lockDownBrowser.js +12 -15
- package/lib/utils/logger.js +23 -28
- package/lib/utils/lti.js +4 -7
- package/lib/utils/model.js +28 -43
- package/lib/utils/number.js +9 -13
- package/lib/utils/promise.js +23 -26
- package/lib/utils/quill.js +55 -60
- package/lib/utils/route.js +52 -60
- package/lib/utils/search.js +72 -87
- package/lib/utils/shard.js +33 -42
- package/lib/utils/sort.js +47 -50
- package/lib/utils/string.js +10 -12
- package/lib/utils/table.js +29 -33
- package/lib/utils/timezone.js +7 -12
- package/lib/utils/url.js +130 -144
- package/lib/utils/user.js +54 -64
- package/lib/utils/userAgent.js +7 -14
- package/lib/utils/userRole.js +36 -39
- package/package.json +17 -3
|
@@ -1,235 +1,440 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
const IconTableInsertRow_1 = require("../Icons/IconTableInsertRow");
|
|
16
|
-
const accessibilityFix_1 = require("./accessibilityFix");
|
|
17
|
-
const constants_1 = require("./TableModule/constants");
|
|
1
|
+
import { c as _c } from "react-compiler-runtime";
|
|
2
|
+
import IconAddBox from '@material-ui/icons/AddBox';
|
|
3
|
+
import IconMoreHoriz from '@material-ui/icons/MoreHoriz';
|
|
4
|
+
import { isUndefined } from 'lodash';
|
|
5
|
+
import React, { Fragment, useEffect, useMemo, useState } from 'react';
|
|
6
|
+
import { IconAlphaList } from '../Icons/IconAlphaList';
|
|
7
|
+
import { mdiTable } from '../Icons/IconTable';
|
|
8
|
+
import { IconTableDeleteCol } from '../Icons/IconTableDeleteCol';
|
|
9
|
+
import { IconTableDeleteRow } from '../Icons/IconTableDeleteRow';
|
|
10
|
+
import { IconTableInsertCol } from '../Icons/IconTableInsertCol';
|
|
11
|
+
import { IconTableInsertRow } from '../Icons/IconTableInsertRow';
|
|
12
|
+
import { applyAccessibilityHacks } from './accessibilityFix';
|
|
13
|
+
import { TABLE_ACTION } from './TableModule/constants';
|
|
14
|
+
|
|
18
15
|
/** Options for Quill, used for defining options in the CustomToolbar, and for enabling formats in Quill */
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
16
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
17
|
+
export let QUILL_OPTION = /*#__PURE__*/function (QUILL_OPTION) {
|
|
18
|
+
QUILL_OPTION[QUILL_OPTION["HEADER"] = 2] = "HEADER";
|
|
19
|
+
QUILL_OPTION[QUILL_OPTION["FONT"] = 4] = "FONT";
|
|
20
|
+
QUILL_OPTION[QUILL_OPTION["SIZE"] = 8] = "SIZE";
|
|
21
|
+
QUILL_OPTION[QUILL_OPTION["BOLD"] = 16] = "BOLD";
|
|
22
|
+
QUILL_OPTION[QUILL_OPTION["ITALIC"] = 32] = "ITALIC";
|
|
23
|
+
QUILL_OPTION[QUILL_OPTION["UNDERLINE"] = 64] = "UNDERLINE";
|
|
24
|
+
/** NOTE: there is only a single "script" format, but there are separate options for the toolbar buttons */
|
|
25
|
+
QUILL_OPTION[QUILL_OPTION["SCRIPT_SUB"] = 128] = "SCRIPT_SUB";
|
|
26
|
+
/** NOTE: there is only a single "script" format, but there are separate options for the toolbar buttons */
|
|
27
|
+
QUILL_OPTION[QUILL_OPTION["SCRIPT_SUPER"] = 256] = "SCRIPT_SUPER";
|
|
28
|
+
QUILL_OPTION[QUILL_OPTION["STRIKE_THROUGH"] = 512] = "STRIKE_THROUGH";
|
|
29
|
+
QUILL_OPTION[QUILL_OPTION["BLOCKQUOTE"] = 1024] = "BLOCKQUOTE";
|
|
30
|
+
QUILL_OPTION[QUILL_OPTION["CODE_BLOCK"] = 2048] = "CODE_BLOCK";
|
|
31
|
+
QUILL_OPTION[QUILL_OPTION["ALIGN"] = 4096] = "ALIGN";
|
|
32
|
+
/** NOTE: there is only a single "list" format, but there are separate options for the toolbar buttons */
|
|
33
|
+
QUILL_OPTION[QUILL_OPTION["LIST_ORDERED"] = 8192] = "LIST_ORDERED";
|
|
34
|
+
/** NOTE: there is only a single "list" format, but there are separate options for the toolbar buttons */
|
|
35
|
+
QUILL_OPTION[QUILL_OPTION["LIST_BULLET"] = 16384] = "LIST_BULLET";
|
|
36
|
+
/** NOTE: there is only a single "list" format, but there are separate options for the toolbar buttons */
|
|
37
|
+
QUILL_OPTION[QUILL_OPTION["LIST_ALPHA"] = 32768] = "LIST_ALPHA";
|
|
38
|
+
QUILL_OPTION[QUILL_OPTION["INDENT"] = 65536] = "INDENT";
|
|
39
|
+
QUILL_OPTION[QUILL_OPTION["LINK"] = 131072] = "LINK";
|
|
40
|
+
QUILL_OPTION[QUILL_OPTION["IMAGE"] = 262144] = "IMAGE";
|
|
41
|
+
QUILL_OPTION[QUILL_OPTION["VIDEO"] = 524288] = "VIDEO";
|
|
42
|
+
QUILL_OPTION[QUILL_OPTION["FORMULA"] = 1048576] = "FORMULA";
|
|
43
|
+
QUILL_OPTION[QUILL_OPTION["TABLE"] = 2097152] = "TABLE";
|
|
44
|
+
/** NOTE: variable support is not currently in scaffolding, just the toolbar option */
|
|
45
|
+
QUILL_OPTION[QUILL_OPTION["VARIABLE"] = 4194304] = "VARIABLE";
|
|
46
|
+
/** NOTE: there is no "clean" format, this is only used to display the toolbar button */
|
|
47
|
+
QUILL_OPTION[QUILL_OPTION["CLEAN"] = 8388608] = "CLEAN";
|
|
48
|
+
return QUILL_OPTION;
|
|
49
|
+
}({});
|
|
50
|
+
const getNameForOption = option => {
|
|
51
|
+
switch (option) {
|
|
52
|
+
case QUILL_OPTION.HEADER:
|
|
53
|
+
return 'header';
|
|
54
|
+
case QUILL_OPTION.FONT:
|
|
55
|
+
return 'font';
|
|
56
|
+
case QUILL_OPTION.SIZE:
|
|
57
|
+
return 'size';
|
|
58
|
+
case QUILL_OPTION.BOLD:
|
|
59
|
+
return 'bold';
|
|
60
|
+
case QUILL_OPTION.ITALIC:
|
|
61
|
+
return 'italic';
|
|
62
|
+
case QUILL_OPTION.UNDERLINE:
|
|
63
|
+
return 'underline';
|
|
64
|
+
case QUILL_OPTION.STRIKE_THROUGH:
|
|
65
|
+
return 'strike';
|
|
66
|
+
case QUILL_OPTION.BLOCKQUOTE:
|
|
67
|
+
return 'blockquote';
|
|
68
|
+
case QUILL_OPTION.CODE_BLOCK:
|
|
69
|
+
return 'code-block';
|
|
70
|
+
case QUILL_OPTION.ALIGN:
|
|
71
|
+
return 'align';
|
|
72
|
+
case QUILL_OPTION.INDENT:
|
|
73
|
+
return 'indent';
|
|
74
|
+
case QUILL_OPTION.LINK:
|
|
75
|
+
return 'link';
|
|
76
|
+
case QUILL_OPTION.IMAGE:
|
|
77
|
+
return 'image';
|
|
78
|
+
case QUILL_OPTION.VIDEO:
|
|
79
|
+
return 'video';
|
|
80
|
+
case QUILL_OPTION.FORMULA:
|
|
81
|
+
return 'formula';
|
|
82
|
+
case QUILL_OPTION.VARIABLE:
|
|
83
|
+
return 'variable';
|
|
84
|
+
case QUILL_OPTION.LIST_ORDERED:
|
|
85
|
+
return 'ordered';
|
|
86
|
+
case QUILL_OPTION.LIST_BULLET:
|
|
87
|
+
return 'bullet';
|
|
88
|
+
case QUILL_OPTION.LIST_ALPHA:
|
|
89
|
+
return 'alpha';
|
|
90
|
+
case QUILL_OPTION.SCRIPT_SUB:
|
|
91
|
+
return 'sub';
|
|
92
|
+
case QUILL_OPTION.SCRIPT_SUPER:
|
|
93
|
+
return 'super';
|
|
94
|
+
case QUILL_OPTION.TABLE:
|
|
95
|
+
return 'table';
|
|
96
|
+
case QUILL_OPTION.CLEAN:
|
|
97
|
+
return 'clean';
|
|
98
|
+
default:
|
|
99
|
+
throw new Error(`Unsupported option: ${option}`);
|
|
100
|
+
}
|
|
103
101
|
};
|
|
102
|
+
|
|
104
103
|
/** Returns the Quill format for a given option, which enables that given feature in Quill */
|
|
105
|
-
const getFormatsForOption =
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
104
|
+
const getFormatsForOption = option => {
|
|
105
|
+
switch (option) {
|
|
106
|
+
case QUILL_OPTION.HEADER:
|
|
107
|
+
case QUILL_OPTION.FONT:
|
|
108
|
+
case QUILL_OPTION.SIZE:
|
|
109
|
+
case QUILL_OPTION.BOLD:
|
|
110
|
+
case QUILL_OPTION.ITALIC:
|
|
111
|
+
case QUILL_OPTION.UNDERLINE:
|
|
112
|
+
case QUILL_OPTION.STRIKE_THROUGH:
|
|
113
|
+
case QUILL_OPTION.BLOCKQUOTE:
|
|
114
|
+
case QUILL_OPTION.CODE_BLOCK:
|
|
115
|
+
case QUILL_OPTION.ALIGN:
|
|
116
|
+
case QUILL_OPTION.INDENT:
|
|
117
|
+
case QUILL_OPTION.LINK:
|
|
118
|
+
case QUILL_OPTION.IMAGE:
|
|
119
|
+
case QUILL_OPTION.VIDEO:
|
|
120
|
+
case QUILL_OPTION.FORMULA:
|
|
121
|
+
case QUILL_OPTION.VARIABLE:
|
|
122
|
+
return [getNameForOption(option)];
|
|
123
|
+
case QUILL_OPTION.LIST_ORDERED:
|
|
124
|
+
case QUILL_OPTION.LIST_BULLET:
|
|
125
|
+
case QUILL_OPTION.LIST_ALPHA:
|
|
126
|
+
return ['list'];
|
|
127
|
+
case QUILL_OPTION.SCRIPT_SUB:
|
|
128
|
+
case QUILL_OPTION.SCRIPT_SUPER:
|
|
129
|
+
return ['script'];
|
|
130
|
+
case QUILL_OPTION.TABLE:
|
|
131
|
+
return ['table-container', 'table', 'tbody', 'tr', 'td'];
|
|
132
|
+
case QUILL_OPTION.CLEAN:
|
|
133
|
+
return [];
|
|
134
|
+
default:
|
|
135
|
+
throw new Error(`Unsupported option: ${option}`);
|
|
136
|
+
}
|
|
138
137
|
};
|
|
138
|
+
|
|
139
139
|
/** Flatten the nested section options for the toolbar into a flat array of options. */
|
|
140
|
-
const getFormatsForOptions =
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
140
|
+
export const getFormatsForOptions = sectionOptionsArray => {
|
|
141
|
+
// flatten section options to array of options
|
|
142
|
+
// map options to formats and flatten those formats
|
|
143
|
+
// get distinct values using Set, then convert back to Array
|
|
144
|
+
return Array.from(new Set(sectionOptionsArray.flat(2).flatMap(option => getFormatsForOption(option))));
|
|
145
145
|
};
|
|
146
|
-
|
|
147
|
-
const
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
146
|
+
const getToolbarSectionForOption = option => {
|
|
147
|
+
const optionName = getNameForOption(option);
|
|
148
|
+
switch (option) {
|
|
149
|
+
case QUILL_OPTION.HEADER:
|
|
150
|
+
return disabled => /*#__PURE__*/_jsxs(_Fragment, {
|
|
151
|
+
children: [/*#__PURE__*/_jsx("button", {
|
|
152
|
+
className: "ql-header",
|
|
153
|
+
value: "1",
|
|
154
|
+
disabled: disabled
|
|
155
|
+
}), /*#__PURE__*/_jsx("button", {
|
|
156
|
+
className: "ql-header",
|
|
157
|
+
value: "2",
|
|
158
|
+
disabled: disabled
|
|
159
|
+
})]
|
|
160
|
+
});
|
|
161
|
+
case QUILL_OPTION.FONT:
|
|
162
|
+
case QUILL_OPTION.SIZE:
|
|
163
|
+
case QUILL_OPTION.ALIGN:
|
|
164
|
+
return disabled => /*#__PURE__*/_jsx("select", {
|
|
165
|
+
className: `ql-${optionName}`,
|
|
166
|
+
disabled: disabled
|
|
167
|
+
});
|
|
168
|
+
case QUILL_OPTION.BOLD:
|
|
169
|
+
case QUILL_OPTION.ITALIC:
|
|
170
|
+
case QUILL_OPTION.UNDERLINE:
|
|
171
|
+
case QUILL_OPTION.STRIKE_THROUGH:
|
|
172
|
+
case QUILL_OPTION.BLOCKQUOTE:
|
|
173
|
+
case QUILL_OPTION.CODE_BLOCK:
|
|
174
|
+
case QUILL_OPTION.LINK:
|
|
175
|
+
case QUILL_OPTION.IMAGE:
|
|
176
|
+
case QUILL_OPTION.VIDEO:
|
|
177
|
+
case QUILL_OPTION.FORMULA:
|
|
178
|
+
case QUILL_OPTION.CLEAN:
|
|
179
|
+
return disabled => /*#__PURE__*/_jsx("button", {
|
|
180
|
+
className: `ql-${optionName}`,
|
|
181
|
+
disabled: disabled
|
|
182
|
+
});
|
|
183
|
+
case QUILL_OPTION.SCRIPT_SUB:
|
|
184
|
+
case QUILL_OPTION.SCRIPT_SUPER:
|
|
185
|
+
return disabled => /*#__PURE__*/_jsx("button", {
|
|
186
|
+
className: "ql-script",
|
|
187
|
+
value: optionName,
|
|
188
|
+
disabled: disabled
|
|
189
|
+
});
|
|
190
|
+
case QUILL_OPTION.LIST_ORDERED:
|
|
191
|
+
case QUILL_OPTION.LIST_BULLET:
|
|
192
|
+
return disabled => /*#__PURE__*/_jsx("button", {
|
|
193
|
+
className: "ql-list",
|
|
194
|
+
value: optionName,
|
|
195
|
+
disabled: disabled
|
|
196
|
+
});
|
|
197
|
+
case QUILL_OPTION.LIST_ALPHA:
|
|
198
|
+
return disabled => /*#__PURE__*/_jsx("button", {
|
|
199
|
+
className: "ql-list",
|
|
200
|
+
value: optionName,
|
|
201
|
+
disabled: disabled,
|
|
202
|
+
title: "Toggle alpha list",
|
|
203
|
+
"aria-label": "Toggle alpha list",
|
|
204
|
+
children: /*#__PURE__*/_jsx(IconAlphaList, {
|
|
205
|
+
style: {
|
|
206
|
+
width: 'auto'
|
|
207
|
+
}
|
|
208
|
+
})
|
|
209
|
+
});
|
|
210
|
+
case QUILL_OPTION.INDENT:
|
|
211
|
+
return disabled => /*#__PURE__*/_jsxs(_Fragment, {
|
|
212
|
+
children: [/*#__PURE__*/_jsx("button", {
|
|
213
|
+
className: "ql-indent",
|
|
214
|
+
value: "-1",
|
|
215
|
+
disabled: disabled
|
|
216
|
+
}), /*#__PURE__*/_jsx("button", {
|
|
217
|
+
className: "ql-indent",
|
|
218
|
+
value: "+1",
|
|
219
|
+
disabled: disabled
|
|
220
|
+
})]
|
|
221
|
+
});
|
|
222
|
+
case QUILL_OPTION.TABLE:
|
|
223
|
+
return disabled => /*#__PURE__*/_jsxs(_Fragment, {
|
|
224
|
+
children: [/*#__PURE__*/_jsx("select", {
|
|
225
|
+
className: "ql-table",
|
|
226
|
+
disabled: disabled,
|
|
227
|
+
children: Array.from(Array(5).keys()).flatMap(row => {
|
|
228
|
+
return Array.from(Array(5).keys()).map(col => {
|
|
229
|
+
return /*#__PURE__*/_jsx("option", {
|
|
230
|
+
value: `${TABLE_ACTION.NEW_TABLE}${row + 1}_${col + 1}`
|
|
231
|
+
}, `${row}-${col}`);
|
|
232
|
+
});
|
|
233
|
+
})
|
|
234
|
+
}), /*#__PURE__*/_jsx("button", {
|
|
235
|
+
className: "ql-table",
|
|
236
|
+
value: "insert-row",
|
|
237
|
+
disabled: disabled,
|
|
238
|
+
children: /*#__PURE__*/_jsx(IconTableInsertRow, {
|
|
239
|
+
style: {
|
|
240
|
+
width: 'auto'
|
|
241
|
+
}
|
|
242
|
+
})
|
|
243
|
+
}), /*#__PURE__*/_jsx("button", {
|
|
244
|
+
className: "ql-table",
|
|
245
|
+
value: "delete-row",
|
|
246
|
+
disabled: disabled,
|
|
247
|
+
children: /*#__PURE__*/_jsx(IconTableDeleteRow, {
|
|
248
|
+
style: {
|
|
249
|
+
width: 'auto'
|
|
250
|
+
}
|
|
251
|
+
})
|
|
252
|
+
}), /*#__PURE__*/_jsx("button", {
|
|
253
|
+
className: "ql-table",
|
|
254
|
+
value: "insert-col",
|
|
255
|
+
disabled: disabled,
|
|
256
|
+
children: /*#__PURE__*/_jsx(IconTableInsertCol, {
|
|
257
|
+
style: {
|
|
258
|
+
width: 'auto'
|
|
259
|
+
}
|
|
260
|
+
})
|
|
261
|
+
}), /*#__PURE__*/_jsx("button", {
|
|
262
|
+
className: "ql-table",
|
|
263
|
+
value: "delete-col",
|
|
264
|
+
disabled: disabled,
|
|
265
|
+
children: /*#__PURE__*/_jsx(IconTableDeleteCol, {
|
|
266
|
+
style: {
|
|
267
|
+
width: 'auto'
|
|
268
|
+
}
|
|
269
|
+
})
|
|
270
|
+
})]
|
|
271
|
+
});
|
|
272
|
+
case QUILL_OPTION.VARIABLE:
|
|
273
|
+
return disabled => /*#__PURE__*/_jsxs("button", {
|
|
274
|
+
className: `ql-createVariable f6 fw5${disabled ? '' : ' color-primary'}`,
|
|
275
|
+
style: {
|
|
276
|
+
width: '100%'
|
|
277
|
+
},
|
|
278
|
+
disabled: disabled,
|
|
279
|
+
type: "button",
|
|
280
|
+
"aria-label": "Insert variable",
|
|
281
|
+
title: "Insert variable",
|
|
282
|
+
children: [/*#__PURE__*/_jsx(IconAddBox, {
|
|
283
|
+
className: "ma0"
|
|
284
|
+
}), "Variable"]
|
|
285
|
+
});
|
|
286
|
+
default:
|
|
287
|
+
throw new Error(`Unsupported option: ${option}`);
|
|
288
|
+
}
|
|
189
289
|
};
|
|
190
|
-
const getToolbarSectionsForOptions =
|
|
191
|
-
|
|
192
|
-
|
|
290
|
+
const getToolbarSectionsForOptions = sectionOptionsArray => {
|
|
291
|
+
return sectionOptionsArray.map((sectionOptions, sectionIndex) => {
|
|
292
|
+
return disabled => /*#__PURE__*/_jsx(_Fragment, {
|
|
293
|
+
children: sectionOptions.map((sectionOption, optionIndex) => /*#__PURE__*/_jsx(Fragment, {
|
|
294
|
+
children: getToolbarSectionForOption(sectionOption)(disabled)
|
|
295
|
+
}, `${sectionIndex}-${optionIndex}`))
|
|
193
296
|
});
|
|
297
|
+
});
|
|
194
298
|
};
|
|
195
299
|
// Following this example: https://codepen.io/alexkrolick/pen/gmroPj?editors=0010
|
|
196
300
|
// All the options available here: https://github.com/quilljs/quill/blob/develop/docs/_includes/standalone/full.html
|
|
197
|
-
const CustomToolbar = props => {
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
301
|
+
export const CustomToolbar = props => {
|
|
302
|
+
const $ = _c(24);
|
|
303
|
+
const {
|
|
304
|
+
guid,
|
|
305
|
+
sectionOptions,
|
|
306
|
+
moreSectionOptions,
|
|
307
|
+
className,
|
|
308
|
+
disabled,
|
|
309
|
+
reactQuillRef,
|
|
310
|
+
isVisibleWhenDisabled
|
|
311
|
+
} = props;
|
|
312
|
+
const [isInitialized, setIsInitialized] = useState(false);
|
|
313
|
+
const [isShowingMoreOptions, setIsShowingMoreOptions] = useState(false);
|
|
314
|
+
let t0;
|
|
315
|
+
if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
|
|
316
|
+
t0 = /*#__PURE__*/React.createRef();
|
|
317
|
+
$[0] = t0;
|
|
318
|
+
} else {
|
|
319
|
+
t0 = $[0];
|
|
320
|
+
}
|
|
321
|
+
const ref = t0;
|
|
322
|
+
let t1;
|
|
323
|
+
let t2;
|
|
324
|
+
if ($[1] !== disabled || $[2] !== isInitialized || $[3] !== isVisibleWhenDisabled || $[4] !== reactQuillRef) {
|
|
325
|
+
t1 = () => {
|
|
326
|
+
if (!isInitialized && reactQuillRef && (!disabled || isVisibleWhenDisabled)) {
|
|
327
|
+
applyAccessibilityHacks(ref, reactQuillRef.getEditor());
|
|
328
|
+
const label = ref.current?.querySelector(".ql-table .ql-picker-label");
|
|
329
|
+
if (label) {
|
|
330
|
+
const svg = label.childNodes[0];
|
|
331
|
+
const polygons = svg.querySelectorAll("polygon");
|
|
332
|
+
polygons.forEach(_temp);
|
|
333
|
+
svg.setAttribute("viewBox", "0 0 24 24");
|
|
334
|
+
svg.classList.add("ql-fill");
|
|
335
|
+
const path = svg.querySelector("path");
|
|
336
|
+
if (!path) {
|
|
337
|
+
const path_0 = document.createElementNS("http://www.w3.org/2000/svg", "path");
|
|
338
|
+
path_0.setAttribute("d", mdiTable);
|
|
339
|
+
svg.appendChild(path_0);
|
|
340
|
+
}
|
|
225
341
|
}
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
342
|
+
setIsInitialized(true);
|
|
343
|
+
}
|
|
344
|
+
};
|
|
345
|
+
t2 = [disabled, isInitialized, isVisibleWhenDisabled, reactQuillRef, ref];
|
|
346
|
+
$[1] = disabled;
|
|
347
|
+
$[2] = isInitialized;
|
|
348
|
+
$[3] = isVisibleWhenDisabled;
|
|
349
|
+
$[4] = reactQuillRef;
|
|
350
|
+
$[5] = t1;
|
|
351
|
+
$[6] = t2;
|
|
352
|
+
} else {
|
|
353
|
+
t1 = $[5];
|
|
354
|
+
t2 = $[6];
|
|
355
|
+
}
|
|
356
|
+
useEffect(t1, t2);
|
|
357
|
+
let t3;
|
|
358
|
+
if ($[7] !== sectionOptions) {
|
|
359
|
+
t3 = getToolbarSectionsForOptions(sectionOptions);
|
|
360
|
+
$[7] = sectionOptions;
|
|
361
|
+
$[8] = t3;
|
|
362
|
+
} else {
|
|
363
|
+
t3 = $[8];
|
|
364
|
+
}
|
|
365
|
+
const toolbarSections = t3;
|
|
366
|
+
let t4;
|
|
367
|
+
if ($[9] !== moreSectionOptions) {
|
|
368
|
+
t4 = isUndefined(moreSectionOptions);
|
|
369
|
+
$[9] = moreSectionOptions;
|
|
370
|
+
$[10] = t4;
|
|
371
|
+
} else {
|
|
372
|
+
t4 = $[10];
|
|
373
|
+
}
|
|
374
|
+
const hasMoreOptions = !t4;
|
|
375
|
+
let t5;
|
|
376
|
+
if ($[11] !== moreSectionOptions) {
|
|
377
|
+
t5 = !isUndefined(moreSectionOptions) ? getToolbarSectionsForOptions(moreSectionOptions) : [];
|
|
378
|
+
$[11] = moreSectionOptions;
|
|
379
|
+
$[12] = t5;
|
|
380
|
+
} else {
|
|
381
|
+
t5 = $[12];
|
|
382
|
+
}
|
|
383
|
+
const moreToolbarSections = t5;
|
|
384
|
+
const t6 = `quill-toolbar-${guid}`;
|
|
385
|
+
const t7 = `${className ? ` ${className}` : ""}${disabled ? " disabled" : ""}${!isVisibleWhenDisabled && disabled ? " disabled-invisible" : ""}`;
|
|
386
|
+
let t8;
|
|
387
|
+
if ($[13] !== disabled || $[14] !== hasMoreOptions || $[15] !== isShowingMoreOptions || $[16] !== isVisibleWhenDisabled || $[17] !== moreToolbarSections || $[18] !== toolbarSections) {
|
|
388
|
+
t8 = (!disabled || isVisibleWhenDisabled) && /*#__PURE__*/_jsxs(_Fragment, {
|
|
389
|
+
children: [toolbarSections.map((section, i) => /*#__PURE__*/_jsx("span", {
|
|
390
|
+
className: "ql-formats",
|
|
391
|
+
children: section(disabled)
|
|
392
|
+
}, i)), hasMoreOptions && /*#__PURE__*/_jsx("button", {
|
|
393
|
+
className: `more-options f6 fw5${isShowingMoreOptions ? " expanded color-primary" : ""}`,
|
|
394
|
+
type: "button",
|
|
395
|
+
title: "More options",
|
|
396
|
+
"aria-expanded": isShowingMoreOptions,
|
|
397
|
+
onClick: () => setIsShowingMoreOptions(!isShowingMoreOptions),
|
|
398
|
+
children: /*#__PURE__*/_jsx(IconMoreHoriz, {
|
|
399
|
+
className: "ma0"
|
|
400
|
+
})
|
|
401
|
+
}), hasMoreOptions && /*#__PURE__*/_jsx("div", {
|
|
402
|
+
className: `more-options-toolbar ql-snow${isShowingMoreOptions ? " expanded" : " invisible"}`,
|
|
403
|
+
"aria-hidden": !isShowingMoreOptions,
|
|
404
|
+
children: moreToolbarSections.map((section_0, i_0) => /*#__PURE__*/_jsx("span", {
|
|
405
|
+
className: "ql-formats",
|
|
406
|
+
children: section_0(disabled)
|
|
407
|
+
}, i_0))
|
|
408
|
+
})]
|
|
409
|
+
});
|
|
410
|
+
$[13] = disabled;
|
|
411
|
+
$[14] = hasMoreOptions;
|
|
412
|
+
$[15] = isShowingMoreOptions;
|
|
413
|
+
$[16] = isVisibleWhenDisabled;
|
|
414
|
+
$[17] = moreToolbarSections;
|
|
415
|
+
$[18] = toolbarSections;
|
|
416
|
+
$[19] = t8;
|
|
417
|
+
} else {
|
|
418
|
+
t8 = $[19];
|
|
419
|
+
}
|
|
420
|
+
let t9;
|
|
421
|
+
if ($[20] !== t6 || $[21] !== t7 || $[22] !== t8) {
|
|
422
|
+
t9 = /*#__PURE__*/_jsx("div", {
|
|
423
|
+
id: t6,
|
|
424
|
+
className: t7,
|
|
425
|
+
ref: ref,
|
|
426
|
+
children: t8
|
|
427
|
+
});
|
|
428
|
+
$[20] = t6;
|
|
429
|
+
$[21] = t7;
|
|
430
|
+
$[22] = t8;
|
|
431
|
+
$[23] = t9;
|
|
432
|
+
} else {
|
|
433
|
+
t9 = $[23];
|
|
434
|
+
}
|
|
435
|
+
return t9;
|
|
234
436
|
};
|
|
235
|
-
|
|
437
|
+
function _temp(polygon) {
|
|
438
|
+
polygon.remove();
|
|
439
|
+
}
|
|
440
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["IconAddBox","IconMoreHoriz","isUndefined","React","Fragment","useEffect","useMemo","useState","IconAlphaList","mdiTable","IconTableDeleteCol","IconTableDeleteRow","IconTableInsertCol","IconTableInsertRow","applyAccessibilityHacks","TABLE_ACTION","jsx","_jsx","_Fragment","jsxs","_jsxs","QUILL_OPTION","getNameForOption","option","HEADER","FONT","SIZE","BOLD","ITALIC","UNDERLINE","STRIKE_THROUGH","BLOCKQUOTE","CODE_BLOCK","ALIGN","INDENT","LINK","IMAGE","VIDEO","FORMULA","VARIABLE","LIST_ORDERED","LIST_BULLET","LIST_ALPHA","SCRIPT_SUB","SCRIPT_SUPER","TABLE","CLEAN","Error","getFormatsForOption","getFormatsForOptions","sectionOptionsArray","Array","from","Set","flat","flatMap","getToolbarSectionForOption","optionName","disabled","children","className","value","title","style","width","keys","row","map","col","NEW_TABLE","type","getToolbarSectionsForOptions","sectionOptions","sectionIndex","sectionOption","optionIndex","CustomToolbar","props","$","_c","guid","moreSectionOptions","reactQuillRef","isVisibleWhenDisabled","isInitialized","setIsInitialized","isShowingMoreOptions","setIsShowingMoreOptions","t0","Symbol","for","createRef","ref","t1","t2","getEditor","label","current","querySelector","svg","childNodes","polygons","querySelectorAll","forEach","_temp","setAttribute","classList","add","path","path_0","document","createElementNS","appendChild","t3","toolbarSections","t4","hasMoreOptions","t5","moreToolbarSections","t6","t7","t8","section","i","onClick","section_0","i_0","t9","id","polygon","remove"],"sources":["../../../src/components/Quill/CustomToolbar.tsx"],"sourcesContent":["import IconAddBox from '@material-ui/icons/AddBox'\nimport IconMoreHoriz from '@material-ui/icons/MoreHoriz'\nimport { isUndefined } from 'lodash'\nimport React, { Fragment, FunctionComponent, useEffect, useMemo, useState } from 'react'\nimport ReactQuill from 'react-quill'\nimport { IconAlphaList } from '../Icons/IconAlphaList'\nimport { mdiTable } from '../Icons/IconTable'\nimport { IconTableDeleteCol } from '../Icons/IconTableDeleteCol'\nimport { IconTableDeleteRow } from '../Icons/IconTableDeleteRow'\nimport { IconTableInsertCol } from '../Icons/IconTableInsertCol'\nimport { IconTableInsertRow } from '../Icons/IconTableInsertRow'\nimport { applyAccessibilityHacks } from './accessibilityFix'\nimport { TABLE_ACTION } from './TableModule/constants'\n\n/** Options for Quill, used for defining options in the CustomToolbar, and for enabling formats in Quill */\nexport enum QUILL_OPTION {\n\tHEADER = 1 << 1,\n\tFONT = 1 << 2,\n\tSIZE = 1 << 3,\n\tBOLD = 1 << 4,\n\tITALIC = 1 << 5,\n\tUNDERLINE = 1 << 6,\n\t/** NOTE: there is only a single \"script\" format, but there are separate options for the toolbar buttons */\n\tSCRIPT_SUB = 1 << 7,\n\t/** NOTE: there is only a single \"script\" format, but there are separate options for the toolbar buttons */\n\tSCRIPT_SUPER = 1 << 8,\n\tSTRIKE_THROUGH = 1 << 9,\n\tBLOCKQUOTE = 1 << 10,\n\tCODE_BLOCK = 1 << 11,\n\tALIGN = 1 << 12,\n\t/** NOTE: there is only a single \"list\" format, but there are separate options for the toolbar buttons */\n\tLIST_ORDERED = 1 << 13,\n\t/** NOTE: there is only a single \"list\" format, but there are separate options for the toolbar buttons */\n\tLIST_BULLET = 1 << 14,\n\t/** NOTE: there is only a single \"list\" format, but there are separate options for the toolbar buttons */\n\tLIST_ALPHA = 1 << 15,\n\tINDENT = 1 << 16,\n\tLINK = 1 << 17,\n\tIMAGE = 1 << 18,\n\tVIDEO = 1 << 19,\n\tFORMULA = 1 << 20,\n\tTABLE = 1 << 21,\n\t/** NOTE: variable support is not currently in scaffolding, just the toolbar option */\n\tVARIABLE = 1 << 22,\n\t/** NOTE: there is no \"clean\" format, this is only used to display the toolbar button */\n\tCLEAN = 1 << 23\n}\n\nconst getNameForOption = (option: QUILL_OPTION): string => {\n\tswitch (option) {\n\t\tcase QUILL_OPTION.HEADER:\n\t\t\treturn 'header'\n\t\tcase QUILL_OPTION.FONT:\n\t\t\treturn 'font'\n\t\tcase QUILL_OPTION.SIZE:\n\t\t\treturn 'size'\n\t\tcase QUILL_OPTION.BOLD:\n\t\t\treturn 'bold'\n\t\tcase QUILL_OPTION.ITALIC:\n\t\t\treturn 'italic'\n\t\tcase QUILL_OPTION.UNDERLINE:\n\t\t\treturn 'underline'\n\t\tcase QUILL_OPTION.STRIKE_THROUGH:\n\t\t\treturn 'strike'\n\t\tcase QUILL_OPTION.BLOCKQUOTE:\n\t\t\treturn 'blockquote'\n\t\tcase QUILL_OPTION.CODE_BLOCK:\n\t\t\treturn 'code-block'\n\t\tcase QUILL_OPTION.ALIGN:\n\t\t\treturn 'align'\n\t\tcase QUILL_OPTION.INDENT:\n\t\t\treturn 'indent'\n\t\tcase QUILL_OPTION.LINK:\n\t\t\treturn 'link'\n\t\tcase QUILL_OPTION.IMAGE:\n\t\t\treturn 'image'\n\t\tcase QUILL_OPTION.VIDEO:\n\t\t\treturn 'video'\n\t\tcase QUILL_OPTION.FORMULA:\n\t\t\treturn 'formula'\n\t\tcase QUILL_OPTION.VARIABLE:\n\t\t\treturn 'variable'\n\t\tcase QUILL_OPTION.LIST_ORDERED:\n\t\t\treturn 'ordered'\n\t\tcase QUILL_OPTION.LIST_BULLET:\n\t\t\treturn 'bullet'\n\t\tcase QUILL_OPTION.LIST_ALPHA:\n\t\t\treturn 'alpha'\n\t\tcase QUILL_OPTION.SCRIPT_SUB:\n\t\t\treturn 'sub'\n\t\tcase QUILL_OPTION.SCRIPT_SUPER:\n\t\t\treturn 'super'\n\t\tcase QUILL_OPTION.TABLE:\n\t\t\treturn 'table'\n\t\tcase QUILL_OPTION.CLEAN:\n\t\t\treturn 'clean'\n\t\tdefault:\n\t\t\tthrow new Error(`Unsupported option: ${option}`)\n\t}\n}\n\n/** Returns the Quill format for a given option, which enables that given feature in Quill */\nconst getFormatsForOption = (option: QUILL_OPTION): string[] => {\n\tswitch (option) {\n\t\tcase QUILL_OPTION.HEADER:\n\t\tcase QUILL_OPTION.FONT:\n\t\tcase QUILL_OPTION.SIZE:\n\t\tcase QUILL_OPTION.BOLD:\n\t\tcase QUILL_OPTION.ITALIC:\n\t\tcase QUILL_OPTION.UNDERLINE:\n\t\tcase QUILL_OPTION.STRIKE_THROUGH:\n\t\tcase QUILL_OPTION.BLOCKQUOTE:\n\t\tcase QUILL_OPTION.CODE_BLOCK:\n\t\tcase QUILL_OPTION.ALIGN:\n\t\tcase QUILL_OPTION.INDENT:\n\t\tcase QUILL_OPTION.LINK:\n\t\tcase QUILL_OPTION.IMAGE:\n\t\tcase QUILL_OPTION.VIDEO:\n\t\tcase QUILL_OPTION.FORMULA:\n\t\tcase QUILL_OPTION.VARIABLE:\n\t\t\treturn [getNameForOption(option)]\n\t\tcase QUILL_OPTION.LIST_ORDERED:\n\t\tcase QUILL_OPTION.LIST_BULLET:\n\t\tcase QUILL_OPTION.LIST_ALPHA:\n\t\t\treturn ['list']\n\t\tcase QUILL_OPTION.SCRIPT_SUB:\n\t\tcase QUILL_OPTION.SCRIPT_SUPER:\n\t\t\treturn ['script']\n\t\tcase QUILL_OPTION.TABLE:\n\t\t\treturn ['table-container', 'table', 'tbody', 'tr', 'td']\n\t\tcase QUILL_OPTION.CLEAN:\n\t\t\treturn []\n\t\tdefault:\n\t\t\tthrow new Error(`Unsupported option: ${option}`)\n\t}\n}\n\n/** Flatten the nested section options for the toolbar into a flat array of options. */\nexport const getFormatsForOptions = (sectionOptionsArray: QUILL_OPTION[][]): string[] => {\n\t// flatten section options to array of options\n\t// map options to formats and flatten those formats\n\t// get distinct values using Set, then convert back to Array\n\treturn Array.from(new Set(sectionOptionsArray.flat(2).flatMap(option => getFormatsForOption(option))))\n}\n\nexport type ToolbarSection = (disabled?: boolean) => React.JSX.Element\n\nconst getToolbarSectionForOption = (option: QUILL_OPTION): ToolbarSection => {\n\tconst optionName = getNameForOption(option)\n\tswitch (option) {\n\t\tcase QUILL_OPTION.HEADER:\n\t\t\treturn (disabled?: boolean) => (\n\t\t\t\t<>\n\t\t\t\t\t<button className=\"ql-header\" value=\"1\" disabled={disabled} />\n\t\t\t\t\t<button className=\"ql-header\" value=\"2\" disabled={disabled} />\n\t\t\t\t</>\n\t\t\t)\n\t\tcase QUILL_OPTION.FONT:\n\t\tcase QUILL_OPTION.SIZE:\n\t\tcase QUILL_OPTION.ALIGN:\n\t\t\treturn (disabled?: boolean) => <select className={`ql-${optionName}`} disabled={disabled} />\n\t\tcase QUILL_OPTION.BOLD:\n\t\tcase QUILL_OPTION.ITALIC:\n\t\tcase QUILL_OPTION.UNDERLINE:\n\t\tcase QUILL_OPTION.STRIKE_THROUGH:\n\t\tcase QUILL_OPTION.BLOCKQUOTE:\n\t\tcase QUILL_OPTION.CODE_BLOCK:\n\t\tcase QUILL_OPTION.LINK:\n\t\tcase QUILL_OPTION.IMAGE:\n\t\tcase QUILL_OPTION.VIDEO:\n\t\tcase QUILL_OPTION.FORMULA:\n\t\tcase QUILL_OPTION.CLEAN:\n\t\t\treturn (disabled?: boolean) => <button className={`ql-${optionName}`} disabled={disabled} />\n\t\tcase QUILL_OPTION.SCRIPT_SUB:\n\t\tcase QUILL_OPTION.SCRIPT_SUPER:\n\t\t\treturn (disabled?: boolean) => <button className=\"ql-script\" value={optionName} disabled={disabled} />\n\t\tcase QUILL_OPTION.LIST_ORDERED:\n\t\tcase QUILL_OPTION.LIST_BULLET:\n\t\t\treturn (disabled?: boolean) => <button className=\"ql-list\" value={optionName} disabled={disabled} />\n\t\tcase QUILL_OPTION.LIST_ALPHA:\n\t\t\treturn (disabled?: boolean) => (\n\t\t\t\t<button\n\t\t\t\t\tclassName=\"ql-list\"\n\t\t\t\t\tvalue={optionName}\n\t\t\t\t\tdisabled={disabled}\n\t\t\t\t\ttitle=\"Toggle alpha list\"\n\t\t\t\t\taria-label=\"Toggle alpha list\">\n\t\t\t\t\t<IconAlphaList style={{ width: 'auto' }} />\n\t\t\t\t</button>\n\t\t\t)\n\t\tcase QUILL_OPTION.INDENT:\n\t\t\treturn (disabled?: boolean) => (\n\t\t\t\t<>\n\t\t\t\t\t<button className=\"ql-indent\" value=\"-1\" disabled={disabled} />\n\t\t\t\t\t<button className=\"ql-indent\" value=\"+1\" disabled={disabled} />\n\t\t\t\t</>\n\t\t\t)\n\t\tcase QUILL_OPTION.TABLE:\n\t\t\treturn (disabled?: boolean) => (\n\t\t\t\t<>\n\t\t\t\t\t<select className=\"ql-table\" disabled={disabled}>\n\t\t\t\t\t\t{Array.from(Array(5).keys()).flatMap(row => {\n\t\t\t\t\t\t\treturn Array.from(Array(5).keys()).map(col => {\n\t\t\t\t\t\t\t\treturn (\n\t\t\t\t\t\t\t\t\t<option\n\t\t\t\t\t\t\t\t\t\tkey={`${row}-${col}`}\n\t\t\t\t\t\t\t\t\t\tvalue={`${TABLE_ACTION.NEW_TABLE}${row + 1}_${col + 1}`}\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t)\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t})}\n\t\t\t\t\t</select>\n\t\t\t\t\t<button className=\"ql-table\" value=\"insert-row\" disabled={disabled}>\n\t\t\t\t\t\t<IconTableInsertRow style={{ width: 'auto' }} />\n\t\t\t\t\t</button>\n\t\t\t\t\t<button className=\"ql-table\" value=\"delete-row\" disabled={disabled}>\n\t\t\t\t\t\t<IconTableDeleteRow style={{ width: 'auto' }} />\n\t\t\t\t\t</button>\n\t\t\t\t\t<button className=\"ql-table\" value=\"insert-col\" disabled={disabled}>\n\t\t\t\t\t\t<IconTableInsertCol style={{ width: 'auto' }} />\n\t\t\t\t\t</button>\n\t\t\t\t\t<button className=\"ql-table\" value=\"delete-col\" disabled={disabled}>\n\t\t\t\t\t\t<IconTableDeleteCol style={{ width: 'auto' }} />\n\t\t\t\t\t</button>\n\t\t\t\t</>\n\t\t\t)\n\t\tcase QUILL_OPTION.VARIABLE:\n\t\t\treturn (disabled?: boolean) => (\n\t\t\t\t<button\n\t\t\t\t\tclassName={`ql-createVariable f6 fw5${disabled ? '' : ' color-primary'}`}\n\t\t\t\t\tstyle={{ width: '100%' }}\n\t\t\t\t\tdisabled={disabled}\n\t\t\t\t\ttype=\"button\"\n\t\t\t\t\taria-label=\"Insert variable\"\n\t\t\t\t\ttitle=\"Insert variable\">\n\t\t\t\t\t<IconAddBox className=\"ma0\" />\n\t\t\t\t\tVariable\n\t\t\t\t</button>\n\t\t\t)\n\t\tdefault:\n\t\t\tthrow new Error(`Unsupported option: ${option}`)\n\t}\n}\n\nconst getToolbarSectionsForOptions = (sectionOptionsArray: QUILL_OPTION[][]): ToolbarSection[] => {\n\treturn sectionOptionsArray.map((sectionOptions, sectionIndex) => {\n\t\treturn (disabled?: boolean) => (\n\t\t\t<>\n\t\t\t\t{sectionOptions.map((sectionOption, optionIndex) => (\n\t\t\t\t\t<Fragment key={`${sectionIndex}-${optionIndex}`}>\n\t\t\t\t\t\t{getToolbarSectionForOption(sectionOption)(disabled)}\n\t\t\t\t\t</Fragment>\n\t\t\t\t))}\n\t\t\t</>\n\t\t)\n\t})\n}\n\nexport interface CustomToolbarProps {\n\tguid: string\n\t/** An array of toolbar option arrays. Each top level array will equate to a toolbar section, with spacing between each section. */\n\tsectionOptions: QUILL_OPTION[][]\n\t/** (Optional) An array of toolbar option arrays. When provided, a \"more options\" button is provided and a secondary toolbar can be expanded and collapsed. */\n\tmoreSectionOptions?: QUILL_OPTION[][]\n\tclassName?: string\n\tdisabled?: boolean\n\treactQuillRef: ReactQuill | null\n\tisVisibleWhenDisabled?: boolean\n}\n\n// Following this example: https://codepen.io/alexkrolick/pen/gmroPj?editors=0010\n// All the options available here: https://github.com/quilljs/quill/blob/develop/docs/_includes/standalone/full.html\nexport const CustomToolbar: FunctionComponent<CustomToolbarProps> = props => {\n\tconst { guid, sectionOptions, moreSectionOptions, className, disabled, reactQuillRef, isVisibleWhenDisabled } =\n\t\tprops\n\n\tconst [isInitialized, setIsInitialized] = useState(false)\n\tconst [isShowingMoreOptions, setIsShowingMoreOptions] = useState(false)\n\tconst ref = React.createRef<HTMLDivElement>()\n\n\tuseEffect(() => {\n\t\t// initialize the toolbar after reactQuill exists and the buttons are displayed\n\t\tif (!isInitialized && reactQuillRef && (!disabled || isVisibleWhenDisabled)) {\n\t\t\tapplyAccessibilityHacks(ref, reactQuillRef.getEditor())\n\n\t\t\t// manually modify the table picker select svg icon\n\t\t\tconst label = ref.current?.querySelector('.ql-table .ql-picker-label')\n\t\t\tif (label) {\n\t\t\t\tconst svg = label.childNodes[0] as SVGElement\n\t\t\t\tconst polygons = svg.querySelectorAll('polygon')\n\t\t\t\tpolygons.forEach(polygon => {\n\t\t\t\t\tpolygon.remove()\n\t\t\t\t})\n\t\t\t\tsvg.setAttribute('viewBox', '0 0 24 24')\n\t\t\t\tsvg.classList.add('ql-fill')\n\t\t\t\tconst path = svg.querySelector('path')\n\t\t\t\tif (!path) {\n\t\t\t\t\tconst path = document.createElementNS('http://www.w3.org/2000/svg', 'path')\n\t\t\t\t\tpath.setAttribute('d', mdiTable)\n\t\t\t\t\tsvg.appendChild(path)\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tsetIsInitialized(true)\n\t\t}\n\t}, [disabled, isInitialized, isVisibleWhenDisabled, reactQuillRef, ref])\n\n\tconst toolbarSections = useMemo(() => getToolbarSectionsForOptions(sectionOptions), [sectionOptions])\n\tconst hasMoreOptions = !isUndefined(moreSectionOptions)\n\tconst moreToolbarSections = useMemo(\n\t\t() => (!isUndefined(moreSectionOptions) ? getToolbarSectionsForOptions(moreSectionOptions) : []),\n\t\t[moreSectionOptions]\n\t)\n\n\treturn (\n\t\t<div\n\t\t\tid={`quill-toolbar-${guid}`}\n\t\t\tclassName={`${className ? ` ${className}` : ''}${disabled ? ' disabled' : ''}${\n\t\t\t\t!isVisibleWhenDisabled && disabled ? ' disabled-invisible' : ''\n\t\t\t}`}\n\t\t\tref={ref}>\n\t\t\t{(!disabled || isVisibleWhenDisabled) && (\n\t\t\t\t<>\n\t\t\t\t\t{toolbarSections.map((section, i) => (\n\t\t\t\t\t\t<span className=\"ql-formats\" key={i}>\n\t\t\t\t\t\t\t{section(disabled)}\n\t\t\t\t\t\t</span>\n\t\t\t\t\t))}\n\t\t\t\t\t{hasMoreOptions && (\n\t\t\t\t\t\t<button\n\t\t\t\t\t\t\tclassName={`more-options f6 fw5${isShowingMoreOptions ? ' expanded color-primary' : ''}`}\n\t\t\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t\t\ttitle=\"More options\"\n\t\t\t\t\t\t\taria-expanded={isShowingMoreOptions}\n\t\t\t\t\t\t\tonClick={() => setIsShowingMoreOptions(!isShowingMoreOptions)}>\n\t\t\t\t\t\t\t<IconMoreHoriz className=\"ma0\" />\n\t\t\t\t\t\t</button>\n\t\t\t\t\t)}\n\t\t\t\t\t{\n\t\t\t\t\t\t// This is a sub-div so it's contained in the div with the id/guid for the forward ref.\n\t\t\t\t\t\t// CSS handles appearance so it renders as if it were a sibling div.\n\t\t\t\t\t\thasMoreOptions && (\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tclassName={`more-options-toolbar ql-snow${\n\t\t\t\t\t\t\t\t\tisShowingMoreOptions ? ' expanded' : ' invisible'\n\t\t\t\t\t\t\t\t}`}\n\t\t\t\t\t\t\t\taria-hidden={!isShowingMoreOptions}>\n\t\t\t\t\t\t\t\t{moreToolbarSections.map((section, i) => (\n\t\t\t\t\t\t\t\t\t<span className=\"ql-formats\" key={i}>\n\t\t\t\t\t\t\t\t\t\t{section(disabled)}\n\t\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t))}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t)\n\t\t\t\t\t}\n\t\t\t\t</>\n\t\t\t)}\n\t\t</div>\n\t)\n}\n"],"mappings":"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","ignoreList":[]}
|