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,96 +1,427 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
const
|
|
15
|
-
const ImageWarning_1 = require("./ImageWarning");
|
|
16
|
-
const index_1 = require("./index");
|
|
17
|
-
const Delta = react_quill_1.Quill.import('delta');
|
|
1
|
+
import { c as _c } from "react-compiler-runtime";
|
|
2
|
+
import { Button, SvgIcon } from '@material-ui/core';
|
|
3
|
+
import IconHelp from '@material-ui/icons/Help';
|
|
4
|
+
import IconSwap from '@material-ui/icons/SwapVert';
|
|
5
|
+
import { isEmpty } from 'lodash';
|
|
6
|
+
import { useEffect, useRef, useState } from 'react';
|
|
7
|
+
import { FormControl, FormGroup, FormLabel, Modal, OverlayTrigger, Popover, Row } from 'react-bootstrap';
|
|
8
|
+
import { Quill } from 'react-quill';
|
|
9
|
+
import ConnectedModal from '../ConnectedModal';
|
|
10
|
+
import { ErrorMessage } from '../ErrorMessage';
|
|
11
|
+
import { ImageWarning } from './ImageWarning';
|
|
12
|
+
import { buildFileSelector } from './index';
|
|
13
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
14
|
+
const Delta = Quill.import('delta');
|
|
18
15
|
const mdiUpload = 'M9,16V10H5L12,3L19,10H15V16H9M5,20V18H19V20H5Z';
|
|
19
|
-
const IconUpload = (
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
16
|
+
const IconUpload = /*#__PURE__*/_jsx(SvgIcon, {
|
|
17
|
+
role: "presentation",
|
|
18
|
+
children: /*#__PURE__*/_jsx("path", {
|
|
19
|
+
d: mdiUpload
|
|
20
|
+
})
|
|
21
|
+
});
|
|
22
|
+
export const ImageWithAltTextModal = t0 => {
|
|
23
|
+
const $ = _c(70);
|
|
24
|
+
const {
|
|
25
|
+
isOpen,
|
|
26
|
+
onClose,
|
|
27
|
+
imageToEdit,
|
|
28
|
+
supportedImageExtensions,
|
|
29
|
+
reactQuillRef,
|
|
30
|
+
range
|
|
31
|
+
} = t0;
|
|
32
|
+
let t1;
|
|
33
|
+
if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
|
|
34
|
+
t1 = buildFileSelector();
|
|
35
|
+
$[0] = t1;
|
|
36
|
+
} else {
|
|
37
|
+
t1 = $[0];
|
|
38
|
+
}
|
|
39
|
+
const fileSelector = useRef(t1);
|
|
40
|
+
const [alt, setAlt] = useState(imageToEdit?.alt);
|
|
41
|
+
const [src, setSrc] = useState(imageToEdit?.src);
|
|
42
|
+
const [nonPublic, setNonPublic] = useState(imageToEdit?.nonPublic);
|
|
43
|
+
const [isSelectedFileInvalid, setIsSelectedFileInvalid] = useState(false);
|
|
44
|
+
let t2;
|
|
45
|
+
let t3;
|
|
46
|
+
if ($[1] !== imageToEdit) {
|
|
47
|
+
t2 = () => {
|
|
48
|
+
if (imageToEdit) {
|
|
49
|
+
setAlt(imageToEdit.alt);
|
|
50
|
+
setSrc(imageToEdit.src);
|
|
51
|
+
setNonPublic(imageToEdit.nonPublic);
|
|
52
|
+
}
|
|
42
53
|
};
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
setAlt(file.name);
|
|
61
|
-
}
|
|
62
|
-
};
|
|
63
|
-
// get the file as a dataURI in base64
|
|
64
|
-
reader.readAsDataURL(file);
|
|
65
|
-
setNonPublic(false);
|
|
66
|
-
}
|
|
67
|
-
};
|
|
54
|
+
t3 = [imageToEdit];
|
|
55
|
+
$[1] = imageToEdit;
|
|
56
|
+
$[2] = t2;
|
|
57
|
+
$[3] = t3;
|
|
58
|
+
} else {
|
|
59
|
+
t2 = $[2];
|
|
60
|
+
t3 = $[3];
|
|
61
|
+
}
|
|
62
|
+
useEffect(t2, t3);
|
|
63
|
+
let t4;
|
|
64
|
+
if ($[4] !== onClose) {
|
|
65
|
+
t4 = () => {
|
|
66
|
+
setAlt(undefined);
|
|
67
|
+
setSrc(undefined);
|
|
68
|
+
setNonPublic(undefined);
|
|
69
|
+
fileSelector.current.value = "";
|
|
70
|
+
onClose();
|
|
68
71
|
};
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
72
|
+
$[4] = onClose;
|
|
73
|
+
$[5] = t4;
|
|
74
|
+
} else {
|
|
75
|
+
t4 = $[5];
|
|
76
|
+
}
|
|
77
|
+
const onTryClose = t4;
|
|
78
|
+
let t5;
|
|
79
|
+
if ($[6] !== alt || $[7] !== supportedImageExtensions) {
|
|
80
|
+
t5 = () => {
|
|
81
|
+
fileSelector.current.click();
|
|
82
|
+
fileSelector.current.onchange = function () {
|
|
83
|
+
if (fileSelector.current.files && fileSelector.current.files.length > 0) {
|
|
84
|
+
const file = fileSelector.current.files[0];
|
|
85
|
+
setIsSelectedFileInvalid(!supportedImageExtensions.some(e => file.name.toLocaleLowerCase().endsWith(e)));
|
|
86
|
+
const reader = new FileReader();
|
|
87
|
+
reader.onload = function (e_0) {
|
|
88
|
+
if (e_0.target?.DONE) {
|
|
89
|
+
setSrc(e_0.target.result);
|
|
90
|
+
if (!alt) {
|
|
91
|
+
setAlt(file.name);
|
|
92
|
+
}
|
|
85
93
|
}
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
94
|
+
};
|
|
95
|
+
reader.readAsDataURL(file);
|
|
96
|
+
setNonPublic(false);
|
|
97
|
+
}
|
|
98
|
+
};
|
|
99
|
+
};
|
|
100
|
+
$[6] = alt;
|
|
101
|
+
$[7] = supportedImageExtensions;
|
|
102
|
+
$[8] = t5;
|
|
103
|
+
} else {
|
|
104
|
+
t5 = $[8];
|
|
105
|
+
}
|
|
106
|
+
const onClickImageUpload = t5;
|
|
107
|
+
let t6;
|
|
108
|
+
if ($[9] !== alt || $[10] !== imageToEdit || $[11] !== nonPublic || $[12] !== onTryClose || $[13] !== range || $[14] !== reactQuillRef || $[15] !== src) {
|
|
109
|
+
t6 = () => {
|
|
110
|
+
if (reactQuillRef) {
|
|
111
|
+
const quill = reactQuillRef.getEditor();
|
|
112
|
+
const imageToInsert = {
|
|
113
|
+
src,
|
|
114
|
+
alt,
|
|
115
|
+
nonPublic
|
|
116
|
+
};
|
|
117
|
+
if (imageToEdit) {
|
|
118
|
+
imageToInsert.height = imageToEdit.height;
|
|
119
|
+
imageToInsert.width = imageToEdit.width;
|
|
89
120
|
}
|
|
90
|
-
|
|
121
|
+
const index = range ? range.index : 0;
|
|
122
|
+
const diff = new Delta();
|
|
123
|
+
diff.retain(index);
|
|
124
|
+
if (imageToEdit) {
|
|
125
|
+
diff.delete(1);
|
|
126
|
+
}
|
|
127
|
+
diff.insert({
|
|
128
|
+
image: imageToInsert
|
|
129
|
+
});
|
|
130
|
+
quill.updateContents(diff, "user");
|
|
131
|
+
}
|
|
132
|
+
onTryClose();
|
|
133
|
+
};
|
|
134
|
+
$[9] = alt;
|
|
135
|
+
$[10] = imageToEdit;
|
|
136
|
+
$[11] = nonPublic;
|
|
137
|
+
$[12] = onTryClose;
|
|
138
|
+
$[13] = range;
|
|
139
|
+
$[14] = reactQuillRef;
|
|
140
|
+
$[15] = src;
|
|
141
|
+
$[16] = t6;
|
|
142
|
+
} else {
|
|
143
|
+
t6 = $[16];
|
|
144
|
+
}
|
|
145
|
+
const insertImage = t6;
|
|
146
|
+
const t7 = imageToEdit ? "Edit Image" : "Image Upload";
|
|
147
|
+
let t8;
|
|
148
|
+
if ($[17] !== t7) {
|
|
149
|
+
t8 = /*#__PURE__*/_jsx(Modal.Header, {
|
|
150
|
+
closeButton: true,
|
|
151
|
+
children: /*#__PURE__*/_jsx(Modal.Title, {
|
|
152
|
+
className: "f4",
|
|
153
|
+
children: t7
|
|
154
|
+
})
|
|
155
|
+
});
|
|
156
|
+
$[17] = t7;
|
|
157
|
+
$[18] = t8;
|
|
158
|
+
} else {
|
|
159
|
+
t8 = $[18];
|
|
160
|
+
}
|
|
161
|
+
let t9;
|
|
162
|
+
if ($[19] === Symbol.for("react.memo_cache_sentinel")) {
|
|
163
|
+
t9 = /*#__PURE__*/_jsx("p", {
|
|
164
|
+
className: "mb2 f7",
|
|
165
|
+
children: "* Indicates required field"
|
|
166
|
+
});
|
|
167
|
+
$[19] = t9;
|
|
168
|
+
} else {
|
|
169
|
+
t9 = $[19];
|
|
170
|
+
}
|
|
171
|
+
let t10;
|
|
172
|
+
if ($[20] !== alt || $[21] !== isSelectedFileInvalid || $[22] !== src) {
|
|
173
|
+
t10 = src && !isSelectedFileInvalid && /*#__PURE__*/_jsx(Row, {
|
|
174
|
+
children: /*#__PURE__*/_jsx("img", {
|
|
175
|
+
className: "mb2 h5",
|
|
176
|
+
src: src,
|
|
177
|
+
alt: alt
|
|
178
|
+
})
|
|
179
|
+
});
|
|
180
|
+
$[20] = alt;
|
|
181
|
+
$[21] = isSelectedFileInvalid;
|
|
182
|
+
$[22] = src;
|
|
183
|
+
$[23] = t10;
|
|
184
|
+
} else {
|
|
185
|
+
t10 = $[23];
|
|
186
|
+
}
|
|
187
|
+
let t11;
|
|
188
|
+
if ($[24] !== isSelectedFileInvalid) {
|
|
189
|
+
t11 = isSelectedFileInvalid && /*#__PURE__*/_jsx(ErrorMessage, {
|
|
190
|
+
message: "The chosen file type is not supported. Please use one of the image formats listed below."
|
|
191
|
+
});
|
|
192
|
+
$[24] = isSelectedFileInvalid;
|
|
193
|
+
$[25] = t11;
|
|
194
|
+
} else {
|
|
195
|
+
t11 = $[25];
|
|
196
|
+
}
|
|
197
|
+
let t12;
|
|
198
|
+
if ($[26] !== t11) {
|
|
199
|
+
t12 = /*#__PURE__*/_jsx("div", {
|
|
200
|
+
"aria-live": "polite",
|
|
201
|
+
className: "f7 mb2",
|
|
202
|
+
children: t11
|
|
203
|
+
});
|
|
204
|
+
$[26] = t11;
|
|
205
|
+
$[27] = t12;
|
|
206
|
+
} else {
|
|
207
|
+
t12 = $[27];
|
|
208
|
+
}
|
|
209
|
+
let t13;
|
|
210
|
+
if ($[28] !== alt || $[29] !== imageToEdit) {
|
|
211
|
+
t13 = imageToEdit && !imageToEdit.alt && !alt && /*#__PURE__*/_jsx(ImageWarning, {
|
|
212
|
+
text: "This image is missing alt text. Please provide it below."
|
|
213
|
+
});
|
|
214
|
+
$[28] = alt;
|
|
215
|
+
$[29] = imageToEdit;
|
|
216
|
+
$[30] = t13;
|
|
217
|
+
} else {
|
|
218
|
+
t13 = $[30];
|
|
219
|
+
}
|
|
220
|
+
let t14;
|
|
221
|
+
if ($[31] !== imageToEdit?.nonPublic || $[32] !== nonPublic) {
|
|
222
|
+
t14 = imageToEdit?.nonPublic && nonPublic && /*#__PURE__*/_jsx(ImageWarning, {
|
|
223
|
+
isError: true,
|
|
224
|
+
text: /*#__PURE__*/_jsxs(_Fragment, {
|
|
225
|
+
children: [/*#__PURE__*/_jsx("span", {
|
|
226
|
+
children: "This image is not publicly available"
|
|
227
|
+
}), /*#__PURE__*/_jsx("div", {
|
|
228
|
+
className: "mv2",
|
|
229
|
+
children: "Due to browser security issues, you'll need to upload this from your computer instead of linking from its original source. To fix this:"
|
|
230
|
+
}), /*#__PURE__*/_jsxs("ol", {
|
|
231
|
+
className: "mb1",
|
|
232
|
+
children: [/*#__PURE__*/_jsx("li", {
|
|
233
|
+
children: "Right click on the image and save to your computer."
|
|
234
|
+
}), /*#__PURE__*/_jsx("li", {
|
|
235
|
+
children: "Then use the 'Change Image' button below to upload the saved file."
|
|
236
|
+
})]
|
|
237
|
+
})]
|
|
238
|
+
})
|
|
239
|
+
});
|
|
240
|
+
$[31] = imageToEdit?.nonPublic;
|
|
241
|
+
$[32] = nonPublic;
|
|
242
|
+
$[33] = t14;
|
|
243
|
+
} else {
|
|
244
|
+
t14 = $[33];
|
|
245
|
+
}
|
|
246
|
+
let t15;
|
|
247
|
+
if ($[34] !== imageToEdit || $[35] !== nonPublic || $[36] !== onClickImageUpload || $[37] !== src) {
|
|
248
|
+
t15 = (!imageToEdit || imageToEdit.nonPublic && nonPublic) && /*#__PURE__*/_jsxs(_Fragment, {
|
|
249
|
+
children: [/*#__PURE__*/_jsxs(Button, {
|
|
250
|
+
className: "w-100-lt-xs pa2 mv1 btn-primary",
|
|
251
|
+
onClick: onClickImageUpload,
|
|
252
|
+
children: [src ? /*#__PURE__*/_jsx(IconSwap, {}) : IconUpload, /*#__PURE__*/_jsxs("span", {
|
|
253
|
+
className: "ml1",
|
|
254
|
+
children: [src ? "Change" : "Upload", " Image"]
|
|
255
|
+
})]
|
|
256
|
+
}), /*#__PURE__*/_jsx("p", {
|
|
257
|
+
className: "f7 mb3",
|
|
258
|
+
children: "Supported formats: .jpg, .png, .gif, .bmp"
|
|
259
|
+
})]
|
|
260
|
+
});
|
|
261
|
+
$[34] = imageToEdit;
|
|
262
|
+
$[35] = nonPublic;
|
|
263
|
+
$[36] = onClickImageUpload;
|
|
264
|
+
$[37] = src;
|
|
265
|
+
$[38] = t15;
|
|
266
|
+
} else {
|
|
267
|
+
t15 = $[38];
|
|
268
|
+
}
|
|
269
|
+
let t16;
|
|
270
|
+
if ($[39] === Symbol.for("react.memo_cache_sentinel")) {
|
|
271
|
+
t16 = ["hover", "focus"];
|
|
272
|
+
$[39] = t16;
|
|
273
|
+
} else {
|
|
274
|
+
t16 = $[39];
|
|
275
|
+
}
|
|
276
|
+
let t17;
|
|
277
|
+
if ($[40] === Symbol.for("react.memo_cache_sentinel")) {
|
|
278
|
+
t17 = /*#__PURE__*/_jsx(Popover, {
|
|
279
|
+
id: "alt-text-explanation",
|
|
280
|
+
children: /*#__PURE__*/_jsx("p", {
|
|
281
|
+
className: "mb0",
|
|
282
|
+
children: "Used by screen readers to describe the content of an image."
|
|
283
|
+
})
|
|
284
|
+
});
|
|
285
|
+
$[40] = t17;
|
|
286
|
+
} else {
|
|
287
|
+
t17 = $[40];
|
|
288
|
+
}
|
|
289
|
+
let t18;
|
|
290
|
+
if ($[41] === Symbol.for("react.memo_cache_sentinel")) {
|
|
291
|
+
t18 = /*#__PURE__*/_jsx(Row, {
|
|
292
|
+
className: "mb2",
|
|
293
|
+
children: /*#__PURE__*/_jsx("h3", {
|
|
294
|
+
className: "mv0",
|
|
295
|
+
children: /*#__PURE__*/_jsxs(FormLabel, {
|
|
296
|
+
htmlFor: "img-alt-text",
|
|
297
|
+
className: "mb0",
|
|
298
|
+
children: ["Alt Text *", /*#__PURE__*/_jsx(OverlayTrigger, {
|
|
299
|
+
placement: "top",
|
|
300
|
+
trigger: t16,
|
|
301
|
+
overlay: t17,
|
|
302
|
+
children: /*#__PURE__*/_jsx("button", {
|
|
303
|
+
type: "button",
|
|
304
|
+
className: "dib help-button bg-transparent",
|
|
305
|
+
children: /*#__PURE__*/_jsx(IconHelp, {
|
|
306
|
+
color: "primary",
|
|
307
|
+
titleAccess: "Alt text explanation"
|
|
308
|
+
})
|
|
309
|
+
})
|
|
310
|
+
})]
|
|
311
|
+
})
|
|
312
|
+
})
|
|
313
|
+
});
|
|
314
|
+
$[41] = t18;
|
|
315
|
+
} else {
|
|
316
|
+
t18 = $[41];
|
|
317
|
+
}
|
|
318
|
+
let t19;
|
|
319
|
+
if ($[42] === Symbol.for("react.memo_cache_sentinel")) {
|
|
320
|
+
t19 = event => {
|
|
321
|
+
setAlt(event.target.value);
|
|
91
322
|
};
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
323
|
+
$[42] = t19;
|
|
324
|
+
} else {
|
|
325
|
+
t19 = $[42];
|
|
326
|
+
}
|
|
327
|
+
let t20;
|
|
328
|
+
if ($[43] !== alt) {
|
|
329
|
+
t20 = /*#__PURE__*/_jsxs(FormGroup, {
|
|
330
|
+
children: [t18, /*#__PURE__*/_jsx(FormControl, {
|
|
331
|
+
id: "img-alt-text",
|
|
332
|
+
"aria-label": "Image Alt Text",
|
|
333
|
+
as: "textarea",
|
|
334
|
+
onChange: t19,
|
|
335
|
+
value: alt,
|
|
336
|
+
spellCheck: false,
|
|
337
|
+
autoComplete: "off",
|
|
338
|
+
autoCorrect: "off"
|
|
339
|
+
})]
|
|
340
|
+
});
|
|
341
|
+
$[43] = alt;
|
|
342
|
+
$[44] = t20;
|
|
343
|
+
} else {
|
|
344
|
+
t20 = $[44];
|
|
345
|
+
}
|
|
346
|
+
let t21;
|
|
347
|
+
if ($[45] !== t10 || $[46] !== t12 || $[47] !== t13 || $[48] !== t14 || $[49] !== t15 || $[50] !== t20) {
|
|
348
|
+
t21 = /*#__PURE__*/_jsxs(Modal.Body, {
|
|
349
|
+
children: [t9, t10, t12, t13, t14, t15, t20]
|
|
350
|
+
});
|
|
351
|
+
$[45] = t10;
|
|
352
|
+
$[46] = t12;
|
|
353
|
+
$[47] = t13;
|
|
354
|
+
$[48] = t14;
|
|
355
|
+
$[49] = t15;
|
|
356
|
+
$[50] = t20;
|
|
357
|
+
$[51] = t21;
|
|
358
|
+
} else {
|
|
359
|
+
t21 = $[51];
|
|
360
|
+
}
|
|
361
|
+
let t22;
|
|
362
|
+
if ($[52] !== onTryClose) {
|
|
363
|
+
t22 = /*#__PURE__*/_jsx(Button, {
|
|
364
|
+
className: "mr1 btn-text color-primary",
|
|
365
|
+
onClick: onTryClose,
|
|
366
|
+
children: "Cancel"
|
|
367
|
+
});
|
|
368
|
+
$[52] = onTryClose;
|
|
369
|
+
$[53] = t22;
|
|
370
|
+
} else {
|
|
371
|
+
t22 = $[53];
|
|
372
|
+
}
|
|
373
|
+
let t23;
|
|
374
|
+
if ($[54] !== alt || $[55] !== isSelectedFileInvalid || $[56] !== src) {
|
|
375
|
+
t23 = isEmpty(alt?.trim()) || isEmpty(src) || isSelectedFileInvalid;
|
|
376
|
+
$[54] = alt;
|
|
377
|
+
$[55] = isSelectedFileInvalid;
|
|
378
|
+
$[56] = src;
|
|
379
|
+
$[57] = t23;
|
|
380
|
+
} else {
|
|
381
|
+
t23 = $[57];
|
|
382
|
+
}
|
|
383
|
+
let t24;
|
|
384
|
+
if ($[58] !== insertImage || $[59] !== t23) {
|
|
385
|
+
t24 = /*#__PURE__*/_jsx(Button, {
|
|
386
|
+
className: "btn-primary mb1",
|
|
387
|
+
id: "save-image-button",
|
|
388
|
+
onClick: insertImage,
|
|
389
|
+
disabled: t23,
|
|
390
|
+
children: "Save"
|
|
391
|
+
});
|
|
392
|
+
$[58] = insertImage;
|
|
393
|
+
$[59] = t23;
|
|
394
|
+
$[60] = t24;
|
|
395
|
+
} else {
|
|
396
|
+
t24 = $[60];
|
|
397
|
+
}
|
|
398
|
+
let t25;
|
|
399
|
+
if ($[61] !== t22 || $[62] !== t24) {
|
|
400
|
+
t25 = /*#__PURE__*/_jsxs(Modal.Footer, {
|
|
401
|
+
children: [t22, t24]
|
|
402
|
+
});
|
|
403
|
+
$[61] = t22;
|
|
404
|
+
$[62] = t24;
|
|
405
|
+
$[63] = t25;
|
|
406
|
+
} else {
|
|
407
|
+
t25 = $[63];
|
|
408
|
+
}
|
|
409
|
+
let t26;
|
|
410
|
+
if ($[64] !== isOpen || $[65] !== onTryClose || $[66] !== t21 || $[67] !== t25 || $[68] !== t8) {
|
|
411
|
+
t26 = /*#__PURE__*/_jsxs(ConnectedModal, {
|
|
412
|
+
show: isOpen,
|
|
413
|
+
onHide: onTryClose,
|
|
414
|
+
children: [t8, t21, t25]
|
|
415
|
+
});
|
|
416
|
+
$[64] = isOpen;
|
|
417
|
+
$[65] = onTryClose;
|
|
418
|
+
$[66] = t21;
|
|
419
|
+
$[67] = t25;
|
|
420
|
+
$[68] = t8;
|
|
421
|
+
$[69] = t26;
|
|
422
|
+
} else {
|
|
423
|
+
t26 = $[69];
|
|
424
|
+
}
|
|
425
|
+
return t26;
|
|
95
426
|
};
|
|
96
|
-
exports.ImageWithAltTextModal = ImageWithAltTextModal;
|
|
427
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["Button","SvgIcon","IconHelp","IconSwap","isEmpty","useEffect","useRef","useState","FormControl","FormGroup","FormLabel","Modal","OverlayTrigger","Popover","Row","Quill","ConnectedModal","ErrorMessage","ImageWarning","buildFileSelector","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","Delta","import","mdiUpload","IconUpload","role","children","d","ImageWithAltTextModal","t0","$","_c","isOpen","onClose","imageToEdit","supportedImageExtensions","reactQuillRef","range","t1","Symbol","for","fileSelector","alt","setAlt","src","setSrc","nonPublic","setNonPublic","isSelectedFileInvalid","setIsSelectedFileInvalid","t2","t3","t4","undefined","current","value","onTryClose","t5","click","onchange","files","length","file","some","e","name","toLocaleLowerCase","endsWith","reader","FileReader","onload","e_0","target","DONE","result","readAsDataURL","onClickImageUpload","t6","quill","getEditor","imageToInsert","height","width","index","diff","retain","delete","insert","image","updateContents","insertImage","t7","t8","Header","closeButton","Title","className","t9","t10","t11","message","t12","t13","text","t14","isError","t15","t16","t17","id","t18","htmlFor","placement","trigger","overlay","type","color","titleAccess","t19","event","t20","as","onChange","spellCheck","autoComplete","autoCorrect","t21","Body","t22","t23","trim","t24","disabled","t25","Footer","t26"],"sources":["../../../src/components/Quill/ImageWithAltTextModal.tsx"],"sourcesContent":["import { Button, SvgIcon } from '@material-ui/core'\nimport IconHelp from '@material-ui/icons/Help'\nimport IconSwap from '@material-ui/icons/SwapVert'\nimport { isEmpty } from 'lodash'\nimport { DeltaStatic, RangeStatic } from 'quill'\nimport { FunctionComponent, useEffect, useRef, useState } from 'react'\nimport { FormControl, FormGroup, FormLabel, Modal, OverlayTrigger, Popover, Row } from 'react-bootstrap'\nimport ReactQuill, { Quill } from 'react-quill'\nimport ConnectedModal from '../ConnectedModal'\nimport { ErrorMessage } from '../ErrorMessage'\nimport { ImageValue } from './Formats/Image'\nimport { ImageWarning } from './ImageWarning'\nimport { buildFileSelector } from './index'\n\nconst Delta = Quill.import('delta')\n\nconst mdiUpload = 'M9,16V10H5L12,3L19,10H15V16H9M5,20V18H19V20H5Z'\nconst IconUpload = (\n\t<SvgIcon role=\"presentation\">\n\t\t<path d={mdiUpload} />\n\t</SvgIcon>\n)\n\ninterface ImageWithAltTextProps {\n\tisOpen: boolean\n\timageToEdit?: ImageValue\n\tsupportedImageExtensions: string[]\n\tonClose: () => void\n\treactQuillRef: ReactQuill | null\n\trange: RangeStatic | undefined\n}\n\nexport const ImageWithAltTextModal: FunctionComponent<ImageWithAltTextProps> = ({\n\tisOpen,\n\tonClose,\n\timageToEdit,\n\tsupportedImageExtensions,\n\treactQuillRef,\n\trange\n}) => {\n\tconst fileSelector = useRef(buildFileSelector())\n\t// setup state that is editable in the modal, based on the targeted image, if any\n\tconst [alt, setAlt] = useState<string | undefined>(imageToEdit?.alt)\n\tconst [src, setSrc] = useState<string | undefined>(imageToEdit?.src)\n\tconst [nonPublic, setNonPublic] = useState<boolean | undefined>(imageToEdit?.nonPublic)\n\tconst [isSelectedFileInvalid, setIsSelectedFileInvalid] = useState<boolean>(false)\n\n\t// update local state based on the targeted image, if any\n\tuseEffect(() => {\n\t\tif (imageToEdit) {\n\t\t\tsetAlt(imageToEdit.alt)\n\t\t\tsetSrc(imageToEdit.src)\n\t\t\tsetNonPublic(imageToEdit.nonPublic)\n\t\t}\n\t}, [imageToEdit])\n\n\tconst onTryClose = () => {\n\t\tsetAlt(undefined)\n\t\tsetSrc(undefined)\n\t\tsetNonPublic(undefined)\n\t\t// programmatically reset file selector\n\t\tfileSelector.current.value = ''\n\t\tonClose()\n\t}\n\n\t/** Use file selector to get an image */\n\tconst onClickImageUpload = () => {\n\t\t// programmatically click to open the file upload dialog\n\t\tfileSelector.current.click()\n\t\t// when a file is selected\n\t\tfileSelector.current.onchange = function () {\n\t\t\tif (fileSelector.current.files && fileSelector.current.files.length > 0) {\n\t\t\t\tconst file = fileSelector.current.files[0]\n\t\t\t\t// convert filename to lowercase to make file extension check not case sensitive\n\t\t\t\tsetIsSelectedFileInvalid(!supportedImageExtensions.some(e => file.name.toLocaleLowerCase().endsWith(e)))\n\t\t\t\tconst reader = new FileReader()\n\t\t\t\treader.onload = function (e) {\n\t\t\t\t\tif (e.target?.DONE) {\n\t\t\t\t\t\t// result is image in base64\n\t\t\t\t\t\tsetSrc(e.target.result as string)\n\t\t\t\t\t\tif (!alt) setAlt(file.name)\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t// get the file as a dataURI in base64\n\t\t\t\treader.readAsDataURL(file)\n\t\t\t\tsetNonPublic(false)\n\t\t\t}\n\t\t}\n\t}\n\n\t/** insert Image into quill */\n\tconst insertImage = () => {\n\t\tif (reactQuillRef) {\n\t\t\tconst quill = reactQuillRef.getEditor()\n\t\t\tconst imageToInsert = { src, alt, nonPublic } as Partial<ImageValue>\n\t\t\tif (imageToEdit) {\n\t\t\t\timageToInsert.height = imageToEdit.height\n\t\t\t\timageToInsert.width = imageToEdit.width\n\t\t\t}\n\n\t\t\tconst index = range ? range.index : 0\n\t\t\tconst diff: DeltaStatic = new Delta()\n\t\t\t// retain up until the selected range\n\t\t\tdiff.retain(index)\n\t\t\t// remove the existing image, if any\n\t\t\tif (imageToEdit) {\n\t\t\t\tdiff.delete(1)\n\t\t\t}\n\t\t\t// insert the new image\n\t\t\tdiff.insert({ image: imageToInsert })\n\t\t\tquill.updateContents(diff, 'user')\n\t\t}\n\t\tonTryClose()\n\t}\n\n\treturn (\n\t\t<ConnectedModal show={isOpen} onHide={onTryClose}>\n\t\t\t<Modal.Header closeButton>\n\t\t\t\t<Modal.Title className=\"f4\">{imageToEdit ? `Edit Image` : `Image Upload`}</Modal.Title>\n\t\t\t</Modal.Header>\n\t\t\t<Modal.Body>\n\t\t\t\t<p className=\"mb2 f7\">* Indicates required field</p>\n\t\t\t\t{src && !isSelectedFileInvalid && (\n\t\t\t\t\t<Row>\n\t\t\t\t\t\t<img className=\"mb2 h5\" src={src} alt={alt} />\n\t\t\t\t\t</Row>\n\t\t\t\t)}\n\t\t\t\t<div aria-live=\"polite\" className=\"f7 mb2\">\n\t\t\t\t\t{isSelectedFileInvalid && (\n\t\t\t\t\t\t<ErrorMessage message=\"The chosen file type is not supported. Please use one of the image formats listed below.\" />\n\t\t\t\t\t)}\n\t\t\t\t</div>\n\t\t\t\t{imageToEdit && !imageToEdit.alt && !alt && (\n\t\t\t\t\t<ImageWarning text=\"This image is missing alt text. Please provide it below.\" />\n\t\t\t\t)}\n\t\t\t\t{imageToEdit?.nonPublic && nonPublic && (\n\t\t\t\t\t<ImageWarning\n\t\t\t\t\t\tisError\n\t\t\t\t\t\ttext={\n\t\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t\t<span>This image is not publicly available</span>\n\t\t\t\t\t\t\t\t<div className=\"mv2\">\n\t\t\t\t\t\t\t\t\tDue to browser security issues, you'll need to upload this from your computer\n\t\t\t\t\t\t\t\t\tinstead of linking from its original source. To fix this:\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t<ol className=\"mb1\">\n\t\t\t\t\t\t\t\t\t<li>Right click on the image and save to your computer.</li>\n\t\t\t\t\t\t\t\t\t<li>Then use the 'Change Image' button below to upload the saved file.</li>\n\t\t\t\t\t\t\t\t</ol>\n\t\t\t\t\t\t\t</>\n\t\t\t\t\t\t}\n\t\t\t\t\t/>\n\t\t\t\t)}\n\t\t\t\t{(!imageToEdit || (imageToEdit.nonPublic && nonPublic)) && (\n\t\t\t\t\t<>\n\t\t\t\t\t\t<Button className=\"w-100-lt-xs pa2 mv1 btn-primary\" onClick={onClickImageUpload}>\n\t\t\t\t\t\t\t{src ? <IconSwap /> : IconUpload}\n\t\t\t\t\t\t\t<span className=\"ml1\">{src ? 'Change' : 'Upload'} Image</span>\n\t\t\t\t\t\t</Button>\n\t\t\t\t\t\t<p className=\"f7 mb3\">Supported formats: .jpg, .png, .gif, .bmp</p>\n\t\t\t\t\t</>\n\t\t\t\t)}\n\t\t\t\t<FormGroup>\n\t\t\t\t\t<Row className=\"mb2\">\n\t\t\t\t\t\t<h3 className=\"mv0\">\n\t\t\t\t\t\t\t<FormLabel htmlFor=\"img-alt-text\" className=\"mb0\">\n\t\t\t\t\t\t\t\tAlt Text *\n\t\t\t\t\t\t\t\t<OverlayTrigger\n\t\t\t\t\t\t\t\t\tplacement=\"top\"\n\t\t\t\t\t\t\t\t\ttrigger={['hover', 'focus']}\n\t\t\t\t\t\t\t\t\toverlay={\n\t\t\t\t\t\t\t\t\t\t<Popover id=\"alt-text-explanation\">\n\t\t\t\t\t\t\t\t\t\t\t<p className=\"mb0\">\n\t\t\t\t\t\t\t\t\t\t\t\tUsed by screen readers to describe the content of an image.\n\t\t\t\t\t\t\t\t\t\t\t</p>\n\t\t\t\t\t\t\t\t\t\t</Popover>\n\t\t\t\t\t\t\t\t\t}>\n\t\t\t\t\t\t\t\t\t<button type=\"button\" className=\"dib help-button bg-transparent\">\n\t\t\t\t\t\t\t\t\t\t<IconHelp color=\"primary\" titleAccess=\"Alt text explanation\" />\n\t\t\t\t\t\t\t\t\t</button>\n\t\t\t\t\t\t\t\t</OverlayTrigger>\n\t\t\t\t\t\t\t</FormLabel>\n\t\t\t\t\t\t</h3>\n\t\t\t\t\t</Row>\n\t\t\t\t\t<FormControl\n\t\t\t\t\t\tid=\"img-alt-text\"\n\t\t\t\t\t\taria-label=\"Image Alt Text\"\n\t\t\t\t\t\tas=\"textarea\"\n\t\t\t\t\t\tonChange={(event: any) => {\n\t\t\t\t\t\t\tsetAlt(event.target.value)\n\t\t\t\t\t\t}}\n\t\t\t\t\t\tvalue={alt}\n\t\t\t\t\t\tspellCheck={false}\n\t\t\t\t\t\tautoComplete=\"off\"\n\t\t\t\t\t\tautoCorrect=\"off\"\n\t\t\t\t\t/>\n\t\t\t\t</FormGroup>\n\t\t\t</Modal.Body>\n\t\t\t<Modal.Footer>\n\t\t\t\t<Button className=\"mr1 btn-text color-primary\" onClick={onTryClose}>\n\t\t\t\t\tCancel\n\t\t\t\t</Button>\n\t\t\t\t<Button\n\t\t\t\t\tclassName=\"btn-primary mb1\"\n\t\t\t\t\tid=\"save-image-button\"\n\t\t\t\t\tonClick={insertImage}\n\t\t\t\t\tdisabled={isEmpty(alt?.trim()) || isEmpty(src) || isSelectedFileInvalid}>\n\t\t\t\t\tSave\n\t\t\t\t</Button>\n\t\t\t</Modal.Footer>\n\t\t</ConnectedModal>\n\t)\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const quill_blot_formatter_1 = require("quill-blot-formatter");
|
|
1
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
2
|
+
import { DeleteAction, ImageSpec, ResizeAction } from 'quill-blot-formatter';
|
|
3
|
+
|
|
5
4
|
/**
|
|
6
5
|
* This is a custom Spec for the Blot Formatter.
|
|
7
6
|
* https://github.com/Fandom-OSS/quill-blot-formatter
|
|
@@ -9,31 +8,33 @@ const quill_blot_formatter_1 = require("quill-blot-formatter");
|
|
|
9
8
|
* Additionally, the overlay is repositioned correctly after scroll or resize events.
|
|
10
9
|
* Unfortunately the alignment formatting is not supported by quill/react quill.
|
|
11
10
|
*/
|
|
12
|
-
class CustomImageSpec extends
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
11
|
+
export class CustomImageSpec extends ImageSpec {
|
|
12
|
+
constructor() {
|
|
13
|
+
super(...arguments);
|
|
14
|
+
_defineProperty(this, "onRightClick", e => {
|
|
15
|
+
e.preventDefault();
|
|
16
|
+
if (this.img) {
|
|
17
|
+
this.img.dispatchEvent(new CustomEvent('contextmenu'));
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
_defineProperty(this, "reposition", () => {
|
|
21
|
+
if (this.img) {
|
|
22
|
+
this.formatter.repositionOverlay();
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
init() {
|
|
27
|
+
super.init();
|
|
28
|
+
|
|
29
|
+
// listen for scroll and resize, to reposition the overlay
|
|
30
|
+
this.formatter.quill.root.addEventListener('scroll', this.reposition);
|
|
31
|
+
window.addEventListener('resize', this.reposition);
|
|
32
|
+
|
|
33
|
+
// listen for right-click of the overlay, to pass through to the img
|
|
34
|
+
this.formatter.overlay.addEventListener('contextmenu', this.onRightClick);
|
|
35
|
+
}
|
|
36
|
+
getActions() {
|
|
37
|
+
return [ResizeAction, DeleteAction];
|
|
38
|
+
}
|
|
38
39
|
}
|
|
39
|
-
|
|
40
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJEZWxldGVBY3Rpb24iLCJJbWFnZVNwZWMiLCJSZXNpemVBY3Rpb24iLCJDdXN0b21JbWFnZVNwZWMiLCJjb25zdHJ1Y3RvciIsImFyZ3VtZW50cyIsIl9kZWZpbmVQcm9wZXJ0eSIsImUiLCJwcmV2ZW50RGVmYXVsdCIsImltZyIsImRpc3BhdGNoRXZlbnQiLCJDdXN0b21FdmVudCIsImZvcm1hdHRlciIsInJlcG9zaXRpb25PdmVybGF5IiwiaW5pdCIsInF1aWxsIiwicm9vdCIsImFkZEV2ZW50TGlzdGVuZXIiLCJyZXBvc2l0aW9uIiwid2luZG93Iiwib3ZlcmxheSIsIm9uUmlnaHRDbGljayIsImdldEFjdGlvbnMiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9RdWlsbC9TcGVjcy9DdXN0b21JbWFnZVNwZWMudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVsZXRlQWN0aW9uLCBJbWFnZVNwZWMsIFJlc2l6ZUFjdGlvbiB9IGZyb20gJ3F1aWxsLWJsb3QtZm9ybWF0dGVyJ1xuXG4vKipcbiAqIFRoaXMgaXMgYSBjdXN0b20gU3BlYyBmb3IgdGhlIEJsb3QgRm9ybWF0dGVyLlxuICogaHR0cHM6Ly9naXRodWIuY29tL0ZhbmRvbS1PU1MvcXVpbGwtYmxvdC1mb3JtYXR0ZXJcbiAqIFVzZXMgdGhlIGRlZmF1bHQgYWN0aW9ucywgYWxpZ24sIHJlc2l6ZSwgYW5kIGRlbGV0ZVxuICogQWRkaXRpb25hbGx5LCB0aGUgb3ZlcmxheSBpcyByZXBvc2l0aW9uZWQgY29ycmVjdGx5IGFmdGVyIHNjcm9sbCBvciByZXNpemUgZXZlbnRzLlxuICogVW5mb3J0dW5hdGVseSB0aGUgYWxpZ25tZW50IGZvcm1hdHRpbmcgaXMgbm90IHN1cHBvcnRlZCBieSBxdWlsbC9yZWFjdCBxdWlsbC5cbiAqL1xuZXhwb3J0IGNsYXNzIEN1c3RvbUltYWdlU3BlYyBleHRlbmRzIEltYWdlU3BlYyB7XG5cdGluaXQoKSB7XG5cdFx0c3VwZXIuaW5pdCgpXG5cblx0XHQvLyBsaXN0ZW4gZm9yIHNjcm9sbCBhbmQgcmVzaXplLCB0byByZXBvc2l0aW9uIHRoZSBvdmVybGF5XG5cdFx0dGhpcy5mb3JtYXR0ZXIucXVpbGwucm9vdC5hZGRFdmVudExpc3RlbmVyKCdzY3JvbGwnLCB0aGlzLnJlcG9zaXRpb24pXG5cdFx0d2luZG93LmFkZEV2ZW50TGlzdGVuZXIoJ3Jlc2l6ZScsIHRoaXMucmVwb3NpdGlvbilcblxuXHRcdC8vIGxpc3RlbiBmb3IgcmlnaHQtY2xpY2sgb2YgdGhlIG92ZXJsYXksIHRvIHBhc3MgdGhyb3VnaCB0byB0aGUgaW1nXG5cdFx0dGhpcy5mb3JtYXR0ZXIub3ZlcmxheS5hZGRFdmVudExpc3RlbmVyKCdjb250ZXh0bWVudScsIHRoaXMub25SaWdodENsaWNrKVxuXHR9XG5cblx0Z2V0QWN0aW9ucygpIHtcblx0XHRyZXR1cm4gW1Jlc2l6ZUFjdGlvbiwgRGVsZXRlQWN0aW9uXVxuXHR9XG5cblx0b25SaWdodENsaWNrID0gKGU6IEV2ZW50KSA9PiB7XG5cdFx0ZS5wcmV2ZW50RGVmYXVsdCgpXG5cdFx0aWYgKHRoaXMuaW1nKSB7XG5cdFx0XHR0aGlzLmltZy5kaXNwYXRjaEV2ZW50KG5ldyBDdXN0b21FdmVudCgnY29udGV4dG1lbnUnKSlcblx0XHR9XG5cdH1cblxuXHRyZXBvc2l0aW9uID0gKCkgPT4ge1xuXHRcdGlmICh0aGlzLmltZykge1xuXHRcdFx0dGhpcy5mb3JtYXR0ZXIucmVwb3NpdGlvbk92ZXJsYXkoKVxuXHRcdH1cblx0fVxufVxuIl0sIm1hcHBpbmdzIjoiO0FBQUEsU0FBU0EsWUFBWSxFQUFFQyxTQUFTLEVBQUVDLFlBQVksUUFBUSxzQkFBc0I7O0FBRTVFO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsT0FBTyxNQUFNQyxlQUFlLFNBQVNGLFNBQVMsQ0FBQztFQUFBRyxZQUFBO0lBQUEsU0FBQUMsU0FBQTtJQUFBQyxlQUFBLHVCQWdCOUJDLENBQVEsSUFBSztNQUM1QkEsQ0FBQyxDQUFDQyxjQUFjLENBQUMsQ0FBQztNQUNsQixJQUFJLElBQUksQ0FBQ0MsR0FBRyxFQUFFO1FBQ2IsSUFBSSxDQUFDQSxHQUFHLENBQUNDLGFBQWEsQ0FBQyxJQUFJQyxXQUFXLENBQUMsYUFBYSxDQUFDLENBQUM7TUFDdkQ7SUFDRCxDQUFDO0lBQUFMLGVBQUEscUJBRVksTUFBTTtNQUNsQixJQUFJLElBQUksQ0FBQ0csR0FBRyxFQUFFO1FBQ2IsSUFBSSxDQUFDRyxTQUFTLENBQUNDLGlCQUFpQixDQUFDLENBQUM7TUFDbkM7SUFDRCxDQUFDO0VBQUE7RUExQkRDLElBQUlBLENBQUEsRUFBRztJQUNOLEtBQUssQ0FBQ0EsSUFBSSxDQUFDLENBQUM7O0lBRVo7SUFDQSxJQUFJLENBQUNGLFNBQVMsQ0FBQ0csS0FBSyxDQUFDQyxJQUFJLENBQUNDLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUNDLFVBQVUsQ0FBQztJQUNyRUMsTUFBTSxDQUFDRixnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDQyxVQUFVLENBQUM7O0lBRWxEO0lBQ0EsSUFBSSxDQUFDTixTQUFTLENBQUNRLE9BQU8sQ0FBQ0gsZ0JBQWdCLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQ0ksWUFBWSxDQUFDO0VBQzFFO0VBRUFDLFVBQVVBLENBQUEsRUFBRztJQUNaLE9BQU8sQ0FBQ3BCLFlBQVksRUFBRUYsWUFBWSxDQUFDO0VBQ3BDO0FBY0QiLCJpZ25vcmVMaXN0IjpbXX0=
|