@topconsultnpm/sdkui-react 6.19.0-test.1 → 6.19.0
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/assets/IconsS4t/add.svg +12 -12
- package/lib/assets/IconsS4t/aggiorna.svg +18 -18
- package/lib/assets/IconsS4t/bookmark.svg +42 -42
- package/lib/assets/IconsS4t/cancella.svg +15 -15
- package/lib/assets/IconsS4t/check-box.svg +19 -19
- package/lib/assets/IconsS4t/down-arrow-signBook.svg +40 -40
- package/lib/assets/IconsS4t/down.svg +28 -28
- package/lib/assets/IconsS4t/edit-file.svg +19 -19
- package/lib/assets/IconsS4t/edita.svg +32 -32
- package/lib/assets/IconsS4t/firma.svg +19 -19
- package/lib/assets/IconsS4t/icona_download.svg +16 -16
- package/lib/assets/IconsS4t/info.svg +51 -51
- package/lib/assets/IconsS4t/left.svg +20 -20
- package/lib/assets/IconsS4t/line.svg +40 -40
- package/lib/assets/IconsS4t/more.svg +19 -19
- package/lib/assets/IconsS4t/plus.svg +23 -23
- package/lib/assets/IconsS4t/printer.svg +49 -49
- package/lib/assets/IconsS4t/radio-on-button.svg +25 -25
- package/lib/assets/IconsS4t/rectangle.svg +41 -41
- package/lib/assets/IconsS4t/redo.svg +19 -19
- package/lib/assets/IconsS4t/right-arrow-signBook-finish.svg +40 -40
- package/lib/assets/IconsS4t/right-arrow-signBook.svg +40 -40
- package/lib/assets/IconsS4t/right.svg +22 -22
- package/lib/assets/IconsS4t/searchbar.svg +21 -21
- package/lib/assets/IconsS4t/text-box.svg +36 -36
- package/lib/assets/IconsS4t/tick.svg +8 -8
- package/lib/assets/IconsS4t/trash-white.svg +10 -10
- package/lib/assets/IconsS4t/undo.svg +19 -19
- package/lib/assets/IconsS4t/up.svg +32 -32
- package/lib/assets/IconsS4t/video-streaming.svg +2 -2
- package/lib/assets/IconsS4t/zoom-in.svg +58 -58
- package/lib/assets/IconsS4t/zoom-out.svg +56 -56
- package/lib/assets/icomoon.svg +96 -96
- package/lib/assets/italy.svg +16 -16
- package/lib/assets/six.svg +3 -3
- package/lib/assets/thumbnails/index.ts +39 -39
- package/lib/assets/topmedia-six.svg +65 -65
- package/lib/assets/topmeida-six-bianco.svg +65 -65
- package/lib/components/base/Styled.js +302 -302
- package/lib/components/base/TMAccordion.js +43 -43
- package/lib/components/base/TMAccordionNew.d.ts +28 -0
- package/lib/components/base/TMAccordionNew.js +326 -0
- package/lib/components/base/TMAreaManager.js +23 -23
- package/lib/components/base/TMButton.d.ts +1 -0
- package/lib/components/base/TMButton.js +136 -136
- package/lib/components/base/TMClosableList.js +46 -46
- package/lib/components/base/TMConfirm.js +20 -20
- package/lib/components/base/TMContextMenu.js +4 -4
- package/lib/components/base/TMContextMenuOLD.js +25 -25
- package/lib/components/base/TMCounterBar.js +32 -32
- package/lib/components/base/TMCounterContainer.js +30 -30
- package/lib/components/base/TMCustomButton.d.ts +1 -1
- package/lib/components/base/TMCustomButton.js +90 -35
- package/lib/components/base/TMDataGridExportForm.d.ts +1 -1
- package/lib/components/base/TMDataGridExportForm.js +9 -3
- package/lib/components/base/TMDropDownMenu.js +24 -24
- package/lib/components/base/TMFileManager.js +12 -3
- package/lib/components/base/TMFileManagerDataGridView.d.ts +2 -0
- package/lib/components/base/TMFileManagerDataGridView.js +12 -3
- package/lib/components/base/TMFileManagerThumbnailItems.d.ts +2 -0
- package/lib/components/base/TMFileManagerThumbnailItems.js +12 -2
- package/lib/components/base/TMFileManagerThumbnailsView.d.ts +2 -0
- package/lib/components/base/TMFileManagerThumbnailsView.js +2 -2
- package/lib/components/base/TMFileManagerUtils.js +19 -19
- package/lib/components/base/TMFloatingToolbar.js +34 -34
- package/lib/components/base/TMLayout.js +44 -44
- package/lib/components/base/TMList.js +34 -34
- package/lib/components/base/TMModal.d.ts +2 -0
- package/lib/components/base/TMModal.js +79 -34
- package/lib/components/base/TMPanel.js +57 -57
- package/lib/components/base/TMPopUp.js +186 -117
- package/lib/components/base/TMProgressBar.js +20 -20
- package/lib/components/base/TMResizableMenu.js +28 -28
- package/lib/components/base/TMRightSidebar.js +40 -40
- package/lib/components/base/TMSpinner.js +121 -121
- package/lib/components/base/TMTab.js +11 -11
- package/lib/components/base/TMToggleButton.js +36 -36
- package/lib/components/base/TMToolbarCard.js +35 -35
- package/lib/components/base/TMTooltip.d.ts +1 -1
- package/lib/components/base/TMTooltip.js +1 -1
- package/lib/components/base/TMTreeView.js +16 -16
- package/lib/components/base/TMUserAvatar.js +7 -7
- package/lib/components/base/TMWaitPanel.js +30 -24
- package/lib/components/choosers/TMCultureIDPicker.js +35 -35
- package/lib/components/choosers/TMDataListItemChooser.js +1 -1
- package/lib/components/choosers/TMDataListItemPicker.js +54 -54
- package/lib/components/choosers/TMDcmtTypeChooser.js +2 -2
- package/lib/components/choosers/TMDynDataListItemChooser.js +5 -4
- package/lib/components/choosers/TMMetadataChooser.d.ts +4 -1
- package/lib/components/choosers/TMMetadataChooser.js +31 -8
- package/lib/components/choosers/TMUserChooser.d.ts +4 -0
- package/lib/components/choosers/TMUserChooser.js +21 -5
- package/lib/components/editors/TMCheckBox.js +24 -24
- package/lib/components/editors/TMDateBox.d.ts +1 -1
- package/lib/components/editors/TMDropDown.js +43 -43
- package/lib/components/editors/TMEditorStyled.js +71 -71
- package/lib/components/editors/TMHtmlContentDisplay.js +16 -16
- package/lib/components/editors/TMLocalizedTextBox.js +31 -31
- package/lib/components/editors/TMMetadataValues.js +71 -22
- package/lib/components/editors/TMRadioButton.js +39 -39
- package/lib/components/editors/TMSummary.js +39 -39
- package/lib/components/editors/TMTextArea.d.ts +1 -0
- package/lib/components/editors/TMTextArea.js +56 -22
- package/lib/components/editors/TMTextBox.js +53 -23
- package/lib/components/editors/TMTextExpression.js +36 -28
- package/lib/components/features/assistant/ToppyDraggableHelpCenter.d.ts +30 -0
- package/lib/components/features/assistant/ToppyDraggableHelpCenter.js +482 -0
- package/lib/components/features/assistant/ToppySpeechBubble.d.ts +9 -0
- package/lib/components/features/assistant/ToppySpeechBubble.js +117 -0
- package/lib/components/features/blog/TMBlogCommentForm.d.ts +2 -0
- package/lib/components/features/blog/TMBlogCommentForm.js +21 -9
- package/lib/components/features/documents/TMDcmtBlog.js +1 -1
- package/lib/components/features/documents/TMDcmtForm.d.ts +1 -0
- package/lib/components/features/documents/TMDcmtForm.js +331 -65
- package/lib/components/features/documents/TMDcmtIcon.js +17 -12
- package/lib/components/features/documents/TMDcmtPreview.js +75 -38
- package/lib/components/features/documents/TMFileUploader.js +21 -21
- package/lib/components/features/documents/TMRelationViewer.js +56 -23
- package/lib/components/features/search/TMSavedQuerySelector.js +53 -53
- package/lib/components/features/search/TMSearch.js +2 -2
- package/lib/components/features/search/TMSearchQueryEditor.js +14 -14
- package/lib/components/features/search/TMSearchQueryPanel.js +41 -59
- package/lib/components/features/search/TMSearchResult.js +256 -51
- package/lib/components/features/search/TMSearchResultCheckoutInfoForm.d.ts +8 -0
- package/lib/components/features/search/TMSearchResultCheckoutInfoForm.js +134 -0
- package/lib/components/features/search/TMSearchResultsMenuItems.d.ts +3 -2
- package/lib/components/features/search/TMSearchResultsMenuItems.js +94 -59
- package/lib/components/features/search/TMSignSettingsForm.d.ts +9 -0
- package/lib/components/features/search/TMSignSettingsForm.js +621 -0
- package/lib/components/features/search/TMTreeSelector.js +67 -67
- package/lib/components/features/search/TMViewHistoryDcmtForm.d.ts +18 -0
- package/lib/components/features/search/TMViewHistoryDcmtForm.js +215 -0
- package/lib/components/features/tasks/TMTaskForm.js +42 -36
- package/lib/components/features/tasks/TMTasksAgenda.js +4 -4
- package/lib/components/features/tasks/TMTasksCalendar.js +2 -2
- package/lib/components/features/tasks/TMTasksHeader.js +1 -1
- package/lib/components/features/tasks/TMTasksUtils.d.ts +2 -1
- package/lib/components/features/tasks/TMTasksUtils.js +18 -3
- package/lib/components/features/tasks/TMTasksUtilsView.js +26 -4
- package/lib/components/features/tasks/TMTasksView.js +12 -6
- package/lib/components/features/wg/TMWGsCopyMoveForm.js +9 -9
- package/lib/components/features/workflow/TMWorkflowPopup.js +44 -44
- package/lib/components/features/workflow/diagram/ConnectionComponent.js +29 -29
- package/lib/components/features/workflow/diagram/ConnectionForm.js +10 -10
- package/lib/components/features/workflow/diagram/DiagramItemComponent.js +57 -57
- package/lib/components/features/workflow/diagram/DiagramItemForm.js +40 -35
- package/lib/components/features/workflow/diagram/DiagramItemSvgContent.js +12 -12
- package/lib/components/features/workflow/diagram/RecipientList.js +39 -39
- package/lib/components/features/workflow/diagram/WFDiagram.js +317 -285
- package/lib/components/features/workflow/diagram/WorkitemRecipientsEditor.js +4 -4
- package/lib/components/forms/Login/Chooser.js +35 -35
- package/lib/components/forms/Login/Menu.js +22 -22
- package/lib/components/forms/Login/SelectBox.js +46 -46
- package/lib/components/forms/Login/TMLoginForm.js +14 -14
- package/lib/components/forms/Login/TextBox.js +57 -57
- package/lib/components/forms/TMResultDialog.js +8 -2
- package/lib/components/forms/TMSaveForm.js +3 -11
- package/lib/components/grids/TMBlogAttachments.d.ts +0 -14
- package/lib/components/grids/TMBlogAttachments.js +10 -5
- package/lib/components/grids/TMBlogsPost.d.ts +8 -3
- package/lib/components/grids/TMBlogsPost.js +100 -39
- package/lib/components/grids/TMBlogsPostUtils.d.ts +1 -0
- package/lib/components/grids/TMBlogsPostUtils.js +32 -11
- package/lib/components/grids/TMRecentsManager.js +52 -52
- package/lib/components/grids/TMValidationItemsList.js +48 -48
- package/lib/components/index.d.ts +2 -1
- package/lib/components/index.js +2 -1
- package/lib/components/layout/panelManager/TMPanelManagerContainer.d.ts +1 -0
- package/lib/components/layout/panelManager/TMPanelManagerContainer.js +14 -14
- package/lib/components/layout/panelManager/TMPanelManagerContext.js +0 -1
- package/lib/components/layout/panelManager/TMPanelManagerToolbar.js +36 -35
- package/lib/components/layout/panelManager/types.d.ts +1 -0
- package/lib/components/pages/TMPage.js +1 -1
- package/lib/components/query/TMQueryEditor.js +17 -17
- package/lib/components/query/TMQuerySummary.d.ts +1 -0
- package/lib/components/query/TMQuerySummary.js +15 -15
- package/lib/components/settings/SettingsAppearance.js +9 -1
- package/lib/components/sidebar/TMCommandsPanel.js +10 -10
- package/lib/components/sidebar/TMHeader.js +307 -307
- package/lib/components/sidebar/TMSidebar.js +24 -24
- package/lib/components/sidebar/TMSidebarItem.js +21 -21
- package/lib/components/viewers/TMDataListItemViewer.d.ts +1 -1
- package/lib/components/viewers/TMMidViewer.d.ts +1 -1
- package/lib/components/viewers/TMTidViewer.d.ts +1 -1
- package/lib/components/wizard/TMStepIndicator.js +102 -102
- package/lib/components/wizard/TMWizard.js +29 -29
- package/lib/helper/GlobalStyles.d.ts +2 -0
- package/lib/helper/GlobalStyles.js +10 -0
- package/lib/helper/Globalization.d.ts +1 -0
- package/lib/helper/Globalization.js +30 -0
- package/lib/helper/SDKUI_Globals.d.ts +9 -0
- package/lib/helper/SDKUI_Globals.js +10 -1
- package/lib/helper/SDKUI_Localizator.d.ts +59 -2
- package/lib/helper/SDKUI_Localizator.js +617 -22
- package/lib/helper/TMCustomSearchBar.js +1 -1
- package/lib/helper/TMIcons.d.ts +6 -1
- package/lib/helper/TMIcons.js +22 -2
- package/lib/helper/TMToppyMessage.d.ts +1 -0
- package/lib/helper/TMToppyMessage.js +33 -32
- package/lib/helper/TMUtils.d.ts +42 -4
- package/lib/helper/TMUtils.js +227 -60
- package/lib/helper/cicoHelper.d.ts +31 -0
- package/lib/helper/cicoHelper.js +155 -0
- package/lib/helper/dcmtsHelper.d.ts +2 -1
- package/lib/helper/dcmtsHelper.js +56 -17
- package/lib/helper/helpers.d.ts +8 -1
- package/lib/helper/helpers.js +43 -21
- package/lib/helper/index.d.ts +1 -0
- package/lib/helper/index.js +1 -0
- package/lib/hooks/useDcmtOperations.d.ts +1 -1
- package/lib/hooks/useDcmtOperations.js +10 -6
- package/lib/hooks/useRelatedDocuments.js +35 -26
- package/lib/ts/types.d.ts +3 -1
- package/package.json +54 -54
- package/lib/components/features/assistant/ToppyHelpCenter.d.ts +0 -12
- package/lib/components/features/assistant/ToppyHelpCenter.js +0 -173
|
@@ -4,11 +4,12 @@ import TMDcmtPreview from './TMDcmtPreview';
|
|
|
4
4
|
import { AccessLevels, ArchiveConstraints, ArchiveEngineByID, DcmtTypeListCacheService, LayoutCacheService, LayoutModes, MetadataDataTypes, ObjectClasses, ResultTypes, SDK_Globals, SDK_Localizator, SystemMIDsAsNumber, SystemTIDs, Task_States, TemplateTIDs, TID_DID, UpdateEngineByID, ValidationItem, WorkflowCacheService, WorkItemMetadataNames } from '@topconsultnpm/sdk-ts';
|
|
5
5
|
import { ContextMenu } from 'devextreme-react';
|
|
6
6
|
import { WorkFlowApproveRejectPopUp, WorkFlowMoreInfoPopUp, WorkFlowOperationButtons, WorkFlowReAssignPopUp } from '../workflow/TMWorkflowPopup';
|
|
7
|
-
import { DownloadTypes, FormModes } from '../../../ts';
|
|
7
|
+
import { DownloadTypes, FormModes, DcmtOperationTypes } from '../../../ts';
|
|
8
8
|
import { DeviceType, useDeviceType } from '../../base/TMDeviceProvider';
|
|
9
9
|
import { useDcmtOperations } from '../../../hooks/useDcmtOperations';
|
|
10
|
+
import { useRelatedDocuments } from '../../../hooks/useRelatedDocuments';
|
|
10
11
|
import { getWorkItemSetIDAsync, handleArchiveVisibility, searchResultToMetadataValues } from '../../../helper/queryHelper';
|
|
11
|
-
import { genUniqueId, IconShow, SDKUI_Localizator, updateMruTids, IconBoard, IconDcmtTypeSys, IconDetailDcmts, svgToString, IconDownload, calcIsModified, IconMenuVertical, Globalization, getListMaxItems, getSystemMetadata, IconBoxArchiveIn, IconClear, IconUndo, SDKUI_Globals, IconPreview, isTaskMoreInfo, IconWorkflow, IconSearch, deepCompare, IconCheck, IconActivity } from '../../../helper';
|
|
12
|
+
import { genUniqueId, IconShow, SDKUI_Localizator, updateMruTids, IconBoard, IconDcmtTypeSys, IconDetailDcmts, svgToString, IconDownload, calcIsModified, IconMenuVertical, Globalization, getListMaxItems, getSystemMetadata, IconBoxArchiveIn, IconClear, IconUndo, SDKUI_Globals, IconPreview, isTaskMoreInfo, IconWorkflow, IconSearch, deepCompare, IconCheck, IconActivity, TMImageLibrary, IconStar, IconRelation, IconInfo, IconArchiveDoc, IconDelete, IconPair, IconUnpair, IconArchiveMaster, IconArchiveDetail } from '../../../helper';
|
|
12
13
|
import { hasDetailRelations, hasMasterRelations, isXMLFileExt } from '../../../helper/dcmtsHelper';
|
|
13
14
|
import { Gutters, TMColors } from '../../../utils/theme';
|
|
14
15
|
import { StyledFormButtonsContainer, StyledLoadingContainer, StyledModalContainer, StyledReferenceButton, StyledSpinner, StyledToolbarCardContainer } from '../../base/Styled';
|
|
@@ -27,11 +28,12 @@ import TMMasterDetailDcmts from './TMMasterDetailDcmts';
|
|
|
27
28
|
import TMDcmtBlog from './TMDcmtBlog';
|
|
28
29
|
import { useInputAttachmentsDialog } from '../../../hooks/useInputDialog';
|
|
29
30
|
import TMModal from '../../base/TMModal';
|
|
31
|
+
import TMChooserForm from '../../forms/TMChooserForm';
|
|
32
|
+
import TMSearchResult from '../search/TMSearchResult';
|
|
30
33
|
import { useTMPanelManagerContext } from '../../layout/panelManager/TMPanelManagerContext';
|
|
31
34
|
import TMPanelManagerContainer from '../../layout/panelManager/TMPanelManagerContainer';
|
|
32
35
|
import { TMPanelManagerWithPersistenceProvider } from '../../layout/panelManager/TMPanelManagerWithPersistenceProvider';
|
|
33
36
|
import { useWorkflowApprove } from '../../../hooks/useWorkflowApprove';
|
|
34
|
-
import ToppyHelpCenter from '../assistant/ToppyHelpCenter';
|
|
35
37
|
import TMBlogCommentForm from '../blog/TMBlogCommentForm';
|
|
36
38
|
import WFDiagram from '../workflow/diagram/WFDiagram';
|
|
37
39
|
import TMTooltip from '../../base/TMTooltip';
|
|
@@ -39,9 +41,10 @@ import TMDcmtTasks from './TMDcmtTasks';
|
|
|
39
41
|
import TMToppyMessage from '../../../helper/TMToppyMessage';
|
|
40
42
|
import { getTaskAssignedToMe } from '../tasks/TMTasksUtils';
|
|
41
43
|
import TMCustomButton from '../../base/TMCustomButton';
|
|
44
|
+
import ToppyDraggableHelpCenter from '../assistant/ToppyDraggableHelpCenter';
|
|
42
45
|
let abortControllerLocal = new AbortController();
|
|
43
46
|
//#endregion
|
|
44
|
-
const TMDcmtForm = ({ allTasks = [], getAllTasks, deleteTaskByIdsCallback, addTaskCallback, editTaskCallback, handleNavigateToWGs, handleNavigateToDossiers, showHeader = true, onSaveRecents, layoutMode = LayoutModes.Update, showBackButton = true, onClose, onSavedAsyncCallback, TID, DID, formMode = FormModes.Update, canNext, canPrev, count, itemIndex, onNext, onPrev, allowNavigation = true, allowRelations = true, isClosable = false, isExpertMode = SDKUI_Globals.userSettings.advancedSettings.expertMode === 1, showDcmtFormSidebar = true, invokedByTodo = false, titleModal, isModal = false, widthModal = "100%", heightModal = "100%", groupId, onWFOperationCompleted, onTaskCompleted, inputFile = null, taskFormDialogComponent, taskMoreInfo, connectorFileSave = undefined, inputMids = [], onOpenS4TViewerRequest, s4TViewerDialogComponent, enableDragDropOverlay = false, passToSearch, isSharedDcmt = false, sharedSourceTID, sharedSourceDID, allowButtonsRefs = false, onReferenceClick, }) => {
|
|
47
|
+
const TMDcmtForm = ({ allTasks = [], getAllTasks, deleteTaskByIdsCallback, addTaskCallback, editTaskCallback, handleNavigateToWGs, handleNavigateToDossiers, showHeader = true, onSaveRecents, layoutMode = LayoutModes.Update, showBackButton = true, onClose, onSavedAsyncCallback, TID, DID, formMode = FormModes.Update, canNext, canPrev, count, itemIndex, onNext, onPrev, allowNavigation = true, allowRelations = true, isClosable = false, isExpertMode = SDKUI_Globals.userSettings.advancedSettings.expertMode === 1, showDcmtFormSidebar = true, invokedByTodo = false, titleModal, isModal = false, widthModal = "100%", heightModal = "100%", groupId, onWFOperationCompleted, onTaskCompleted, onTaskCreateRequest, inputFile = null, taskFormDialogComponent, taskMoreInfo, connectorFileSave = undefined, inputMids = [], openS4TViewer = false, onOpenS4TViewerRequest, s4TViewerDialogComponent, enableDragDropOverlay = false, passToSearch, isSharedDcmt = false, sharedSourceTID, sharedSourceDID, allowButtonsRefs = false, onReferenceClick, }) => {
|
|
45
48
|
const [id, setID] = useState('');
|
|
46
49
|
const [showWaitPanelLocal, setShowWaitPanelLocal] = useState(false);
|
|
47
50
|
const [waitPanelTitleLocal, setWaitPanelTitleLocal] = useState('');
|
|
@@ -102,10 +105,44 @@ const TMDcmtForm = ({ allTasks = [], getAllTasks, deleteTaskByIdsCallback, addTa
|
|
|
102
105
|
setDcmtReferences(undefined);
|
|
103
106
|
}, [allowButtonsRefs]);
|
|
104
107
|
const { openConfirmAttachmentsDialog, ConfirmAttachmentsDialog } = useInputAttachmentsDialog();
|
|
105
|
-
const { abortController, showWaitPanel, waitPanelTitle, showPrimary, waitPanelTextPrimary, waitPanelValuePrimary, waitPanelMaxValuePrimary, showSecondary, waitPanelTextSecondary, waitPanelValueSecondary, waitPanelMaxValueSecondary, downloadDcmtsAsync } = useDcmtOperations();
|
|
106
|
-
// Custom hook to manage workflow approval data
|
|
108
|
+
const { abortController, showWaitPanel, waitPanelTitle, showPrimary, waitPanelTextPrimary, waitPanelValuePrimary, waitPanelMaxValuePrimary, showSecondary, waitPanelTextSecondary, waitPanelValueSecondary, waitPanelMaxValueSecondary, downloadDcmtsAsync, runOperationAsync } = useDcmtOperations();
|
|
107
109
|
const { workflowApproveData } = useWorkflowApprove();
|
|
110
|
+
const currentSearchResults = useMemo(() => {
|
|
111
|
+
if (!formData || formData.length === 0 || !TID || !DID)
|
|
112
|
+
return [];
|
|
113
|
+
const selectMIDs = [];
|
|
114
|
+
const rowValues = [];
|
|
115
|
+
formData.forEach(md => {
|
|
116
|
+
if (md.mid !== undefined) {
|
|
117
|
+
selectMIDs.push(md.mid);
|
|
118
|
+
rowValues.push(md.value);
|
|
119
|
+
}
|
|
120
|
+
});
|
|
121
|
+
const searchResult = {
|
|
122
|
+
fromTID: TID,
|
|
123
|
+
selectMIDs: selectMIDs,
|
|
124
|
+
dtdResult: {
|
|
125
|
+
rows: [rowValues],
|
|
126
|
+
columns: selectMIDs.map(mid => ({ name: `MID_${mid}` }))
|
|
127
|
+
},
|
|
128
|
+
dcmtsFound: 1,
|
|
129
|
+
dcmtsReturned: 1
|
|
130
|
+
};
|
|
131
|
+
return [searchResult];
|
|
132
|
+
}, [formData, TID, DID]);
|
|
133
|
+
const relatedDocuments = useRelatedDocuments({
|
|
134
|
+
selectedSearchResult: TID ? { fromTID: Number(TID) } : undefined,
|
|
135
|
+
focusedItem: currentDcmt ? { TID: currentDcmt.tid, DID: currentDcmt.did, rowIndex: 0 } : undefined,
|
|
136
|
+
currentSearchResults: currentSearchResults
|
|
137
|
+
});
|
|
138
|
+
const { relatedDcmts, showRelatedDcmtsChooser, archiveType, isOpenArchiveRelationForm, archiveRelatedDcmtFormTID, archiveRelatedDcmtFormMids, relatedDcmtsChooserDataSource, showManyToManyChooser, manyToManyChooserDataSource, manyToManyRelations, isPairingManyToMany, showPairDcmtsModal, pairedSearchResults, pairFloatingActionConfig, hasManyToManyRelation, canArchiveMasterRelation, canArchiveDetailRelation, pairManyToMany, archiveMasterDocuments, archiveDetailDocuments, checkRelatedDcmtsArchiveCapability, checkManyToManyCapability, setShowRelatedDcmtsChooser, setShowManyToManyChooser, setShowPairDcmtsModal, setIsOpenArchiveRelationForm, setArchiveType, setArchiveRelatedDcmtFormTID, setArchiveRelatedDcmtFormMids, archiveRelatedDcmtHandler, executeManyToManyPairing } = relatedDocuments;
|
|
108
139
|
const fetchErrorShownRef = useRef(false);
|
|
140
|
+
useEffect(() => {
|
|
141
|
+
if (!TID)
|
|
142
|
+
return;
|
|
143
|
+
checkRelatedDcmtsArchiveCapability();
|
|
144
|
+
checkManyToManyCapability();
|
|
145
|
+
}, [TID, checkRelatedDcmtsArchiveCapability, checkManyToManyCapability]);
|
|
109
146
|
const deviceType = useDeviceType();
|
|
110
147
|
const getDcmts = useCallback(() => {
|
|
111
148
|
return [{ TID: currentDcmt?.tid, DID: currentDcmt?.did, FILEEXT: currentDcmt?.fileExt }];
|
|
@@ -200,7 +237,8 @@ const TMDcmtForm = ({ allTasks = [], getAllTasks, deleteTaskByIdsCallback, addTa
|
|
|
200
237
|
// Imposta il layout e customButtonsLayout immediatamente
|
|
201
238
|
setLayout(resLayout);
|
|
202
239
|
if (layoutMode === LayoutModes.Update && customButtonsLayoutResult) {
|
|
203
|
-
|
|
240
|
+
//disabilitato per ora
|
|
241
|
+
//setCustomButtonsLayout(customButtonsLayoutResult);
|
|
204
242
|
}
|
|
205
243
|
// Carica DTD e metadata
|
|
206
244
|
let dtd = await DcmtTypeListCacheService.GetWithNotGrantedAsync(TID, DID, getMetadataResult);
|
|
@@ -331,8 +369,8 @@ const TMDcmtForm = ({ allTasks = [], getAllTasks, deleteTaskByIdsCallback, addTa
|
|
|
331
369
|
return;
|
|
332
370
|
if (!formDataOrig || formDataOrig.length === 0)
|
|
333
371
|
return;
|
|
334
|
-
|
|
335
|
-
if (!
|
|
372
|
+
const hasUserMetadata = formData.some(md => md.mid && md.mid > 99);
|
|
373
|
+
if (!hasUserMetadata)
|
|
336
374
|
return;
|
|
337
375
|
if (appliedInputMidsRef.current && deepCompare(appliedInputMidsRef.current, inputMids))
|
|
338
376
|
return;
|
|
@@ -370,9 +408,11 @@ const TMDcmtForm = ({ allTasks = [], getAllTasks, deleteTaskByIdsCallback, addTa
|
|
|
370
408
|
}, [inputMids, layoutMode, formData, formDataOrig]);
|
|
371
409
|
// Memoizza solo il valore WI_SetID per evitare re-render quando altri metadata cambiano
|
|
372
410
|
const workItemSetIDValue = useMemo(() => formData.find(o => o.md?.name === WorkItemMetadataNames.WI_SetID)?.value, [formData]);
|
|
411
|
+
// Valore derivato: true se formData ha elementi validi
|
|
412
|
+
const hasFormData = useMemo(() => formData.length > 0 && formData.some(md => md.mid && md.mid > 99), [formData]);
|
|
373
413
|
useEffect(() => {
|
|
374
414
|
const loadAllWfData = async () => {
|
|
375
|
-
if (layoutMode !== LayoutModes.Update || !DID) {
|
|
415
|
+
if (layoutMode !== LayoutModes.Update || !DID || fromDTD?.templateTID !== TemplateTIDs.WF_WIApprView) {
|
|
376
416
|
setWorkItems([]);
|
|
377
417
|
setWorkflows([]);
|
|
378
418
|
return;
|
|
@@ -422,7 +462,7 @@ const TMDcmtForm = ({ allTasks = [], getAllTasks, deleteTaskByIdsCallback, addTa
|
|
|
422
462
|
setWorkflows(validWorkflows);
|
|
423
463
|
}
|
|
424
464
|
catch (error) {
|
|
425
|
-
|
|
465
|
+
TMExceptionBoxManager.show({ exception: error });
|
|
426
466
|
setWorkItems([]);
|
|
427
467
|
setWorkflows([]);
|
|
428
468
|
}
|
|
@@ -430,9 +470,14 @@ const TMDcmtForm = ({ allTasks = [], getAllTasks, deleteTaskByIdsCallback, addTa
|
|
|
430
470
|
setIsWFDataLoading(false);
|
|
431
471
|
}
|
|
432
472
|
};
|
|
473
|
+
// Usa hasFormData invece di formDataRef.current
|
|
474
|
+
if (!hasFormData || !fromDTD?.id) {
|
|
475
|
+
// console.log("formData is empty or fromDTD not loaded, skipping loadAllWfData");
|
|
476
|
+
return;
|
|
477
|
+
}
|
|
433
478
|
if (workItemSetIDValue !== undefined || workflowApproveData.length > 0)
|
|
434
479
|
loadAllWfData();
|
|
435
|
-
}, [workItemSetIDValue, workflowApproveData, DID, layoutMode]);
|
|
480
|
+
}, [hasFormData, workItemSetIDValue, workflowApproveData, DID, layoutMode, fromDTD?.templateTID, fromDTD?.id]);
|
|
436
481
|
const getSelectionDcmtInfo = useCallback(() => {
|
|
437
482
|
let dcmts = [];
|
|
438
483
|
dcmts.push({ TID: TID ?? 0, DID: DID ?? 0 });
|
|
@@ -460,35 +505,215 @@ const TMDcmtForm = ({ allTasks = [], getAllTasks, deleteTaskByIdsCallback, addTa
|
|
|
460
505
|
const isMasterDisabled = useMemo(() => layoutMode !== LayoutModes.Update || !DID, [layoutMode, DID]);
|
|
461
506
|
const isWFDisabled = useMemo(() => layoutMode !== LayoutModes.Update || fetchError || workItems.length <= 0, [layoutMode, fetchError, workItems.length]);
|
|
462
507
|
const showToppyForApprove = useMemo(() => layoutMode === LayoutModes.Update && !fetchError && workItems.length > 0 && !isOpenDetails && !isOpenMaster, [layoutMode, fetchError, workItems.length, isOpenDetails, isOpenMaster]);
|
|
463
|
-
const showToppyForCompleteMoreInfo = useMemo(() => layoutMode === LayoutModes.Update && isTaskMoreInfo(taskMoreInfo?.name) && taskMoreInfo?.state !== Task_States.Completed, [layoutMode, taskMoreInfo?.name, taskMoreInfo?.state]);
|
|
464
|
-
const showToppyForReferences = useMemo(() => allowButtonsRefs && layoutMode === LayoutModes.Update && dcmtReferences && dcmtReferences.length > 0 && !isOpenDetails && !isOpenMaster, [allowButtonsRefs, layoutMode, dcmtReferences, isOpenDetails, isOpenMaster]);
|
|
508
|
+
const showToppyForCompleteMoreInfo = useMemo(() => layoutMode === LayoutModes.Update && !!isTaskMoreInfo(taskMoreInfo?.name) && taskMoreInfo?.state !== Task_States.Completed, [layoutMode, taskMoreInfo?.name, taskMoreInfo?.state]);
|
|
509
|
+
const showToppyForReferences = useMemo(() => allowButtonsRefs && layoutMode === LayoutModes.Update && !!(dcmtReferences && dcmtReferences.length > 0) && !isOpenDetails && !isOpenMaster, [allowButtonsRefs, layoutMode, dcmtReferences, isOpenDetails, isOpenMaster]);
|
|
465
510
|
const isMobile = useMemo(() => deviceType === DeviceType.MOBILE, [deviceType]);
|
|
466
511
|
const isApprView = useMemo(() => fromDTD?.templateTID === TemplateTIDs.WF_WIApprView, [fromDTD?.templateTID]);
|
|
467
512
|
const workitemSetID = useMemo(() => workItems.find(o => o.did === Number(DID))?.setID || formData.find(o => o.md?.name === WorkItemMetadataNames.WI_SetID)?.value, [workItems, DID, formData]);
|
|
468
513
|
const approvalVID = useMemo(() => workItems.length > 0 ? Number(workItems[0].tid) : -1, [workItems]);
|
|
514
|
+
//here
|
|
469
515
|
const commandsMenuItems = useMemo(() => {
|
|
470
|
-
const items = [
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
516
|
+
const items = [];
|
|
517
|
+
const operationsItems = [];
|
|
518
|
+
operationsItems.push({
|
|
519
|
+
icon: svgToString(_jsx(IconDownload, {})),
|
|
520
|
+
operationType: 'singleRow',
|
|
521
|
+
disabled: fromDTD?.perm?.canRetrieveFile !== AccessLevels.Yes,
|
|
522
|
+
text: SDKUI_Localizator.DownloadFile,
|
|
523
|
+
onClick: async () => await downloadDcmtsAsync(getDcmts(), DownloadTypes.Dcmt, "download", undefined, undefined, true)
|
|
524
|
+
}, {
|
|
525
|
+
icon: svgToString(_jsx(IconDownload, {})),
|
|
526
|
+
operationType: 'singleRow',
|
|
527
|
+
disabled: !isXMLFileExt(currentDcmt?.fileExt),
|
|
528
|
+
text: SDKUI_Localizator.DownloadXMLAttachments,
|
|
529
|
+
onClick: async () => await downloadDcmtsAsync(getDcmts(), DownloadTypes.Attachment, "download", undefined, openConfirmAttachmentsDialog, true)
|
|
530
|
+
});
|
|
531
|
+
if (layoutMode === LayoutModes.Update && DID) {
|
|
532
|
+
operationsItems.push({
|
|
533
|
+
icon: svgToString(_jsx(IconStar, {})),
|
|
534
|
+
text: SDKUI_Localizator.AddTo + ' ' + SDKUI_Localizator.Favorites,
|
|
535
|
+
operationType: 'singleRow',
|
|
536
|
+
disabled: false,
|
|
537
|
+
onClick: async () => {
|
|
538
|
+
await runOperationAsync(getDcmts(), DcmtOperationTypes.AddToFavs);
|
|
539
|
+
},
|
|
540
|
+
});
|
|
541
|
+
}
|
|
542
|
+
if (onTaskCreateRequest && layoutMode === LayoutModes.Update && DID) {
|
|
543
|
+
operationsItems.push({
|
|
544
|
+
icon: svgToString(_jsx(IconActivity, {})),
|
|
545
|
+
text: SDKUI_Localizator.CreateContextualTask,
|
|
546
|
+
operationType: 'singleRow',
|
|
547
|
+
disabled: false,
|
|
548
|
+
onClick: () => {
|
|
549
|
+
const dcmt = getDcmts()[0];
|
|
550
|
+
const taskContext = {
|
|
551
|
+
document: {
|
|
552
|
+
tid: dcmt.TID,
|
|
553
|
+
did: dcmt.DID,
|
|
554
|
+
name: fromDTD?.description || ''
|
|
555
|
+
}
|
|
556
|
+
};
|
|
557
|
+
onTaskCreateRequest(taskContext);
|
|
558
|
+
}
|
|
559
|
+
});
|
|
560
|
+
}
|
|
561
|
+
if (operationsItems.length > 0) {
|
|
562
|
+
items.push({
|
|
563
|
+
icon: svgToString(_jsx(IconCheck, {})),
|
|
564
|
+
text: SDKUI_Localizator.DocumentOperations,
|
|
565
|
+
items: operationsItems
|
|
566
|
+
});
|
|
567
|
+
}
|
|
568
|
+
if (allowRelations && layoutMode === LayoutModes.Update && DID) {
|
|
569
|
+
const relationsItems = [
|
|
570
|
+
{
|
|
571
|
+
icon: svgToString(_jsx(IconPair, {})),
|
|
572
|
+
text: SDKUI_Localizator.MatchManyDocumentsManyToMany,
|
|
573
|
+
operationType: 'singleRow',
|
|
574
|
+
disabled: !hasManyToManyRelation,
|
|
575
|
+
onClick: async () => await pairManyToMany?.(true)
|
|
576
|
+
},
|
|
577
|
+
{
|
|
578
|
+
icon: svgToString(_jsx(IconUnpair, {})),
|
|
579
|
+
text: SDKUI_Localizator.UnmatchManyDocumentsManyToMany,
|
|
580
|
+
operationType: 'singleRow',
|
|
581
|
+
disabled: !hasManyToManyRelation,
|
|
582
|
+
onClick: async () => await pairManyToMany?.(false)
|
|
583
|
+
},
|
|
584
|
+
{
|
|
585
|
+
icon: svgToString(_jsx(IconArchiveMaster, {})),
|
|
586
|
+
text: SDKUI_Localizator.ArchiveMasterDocument,
|
|
587
|
+
operationType: 'singleRow',
|
|
588
|
+
beginGroup: true,
|
|
589
|
+
disabled: canArchiveMasterRelation !== true,
|
|
590
|
+
onClick: async () => { if (TID)
|
|
591
|
+
await archiveMasterDocuments?.(TID); }
|
|
592
|
+
},
|
|
593
|
+
{
|
|
594
|
+
icon: svgToString(_jsx(IconArchiveDetail, {})),
|
|
595
|
+
text: SDKUI_Localizator.ArchiveDetailDocument,
|
|
596
|
+
operationType: 'singleRow',
|
|
597
|
+
disabled: canArchiveDetailRelation !== true,
|
|
598
|
+
onClick: async () => { if (TID)
|
|
599
|
+
await archiveDetailDocuments?.(TID); }
|
|
600
|
+
},
|
|
601
|
+
{
|
|
602
|
+
icon: svgToString(_jsx(IconDetailDcmts, { transform: 'scale(-1, 1)' })),
|
|
603
|
+
text: SDKUI_Localizator.DcmtsMaster,
|
|
604
|
+
operationType: 'singleRow',
|
|
605
|
+
visible: true,
|
|
606
|
+
beginGroup: true,
|
|
607
|
+
disabled: !currentTIDHasMasterRelations || isMasterDisabled,
|
|
608
|
+
onClick: () => { if (!isMasterDisabled)
|
|
609
|
+
setIsOpenMaster(!isOpenMaster); }
|
|
610
|
+
},
|
|
611
|
+
{
|
|
612
|
+
icon: svgToString(_jsx(IconDetailDcmts, {})),
|
|
613
|
+
text: SDKUI_Localizator.DcmtsDetail,
|
|
614
|
+
operationType: 'singleRow',
|
|
615
|
+
disabled: !currentTIDHasDetailRelations || isDetailsDisabled,
|
|
616
|
+
visible: true,
|
|
617
|
+
onClick: () => { if (!isDetailsDisabled)
|
|
618
|
+
setIsOpenDetails(!isOpenDetails); }
|
|
619
|
+
}
|
|
620
|
+
];
|
|
621
|
+
items.push({
|
|
622
|
+
icon: svgToString(_jsx(IconRelation, {})),
|
|
623
|
+
text: SDKUI_Localizator.Relations,
|
|
624
|
+
items: relationsItems
|
|
625
|
+
});
|
|
626
|
+
}
|
|
627
|
+
if (layoutMode === LayoutModes.Update && DID) {
|
|
628
|
+
const fullTextItems = [
|
|
629
|
+
{
|
|
630
|
+
icon: svgToString(_jsx(IconInfo, {})),
|
|
631
|
+
text: SDKUI_Localizator.IndexingInformation,
|
|
632
|
+
operationType: 'singleRow',
|
|
633
|
+
disabled: false,
|
|
634
|
+
onClick: async () => {
|
|
635
|
+
try {
|
|
636
|
+
TMSpinner.show({ description: `${SDKUI_Localizator.Loading}...` });
|
|
637
|
+
const dcmts = getDcmts();
|
|
638
|
+
const msg = await SDK_Globals.tmSession?.NewSearchEngine().FreeSearchGetDcmtInfoAsync(dcmts[0].TID, dcmts[0].DID);
|
|
639
|
+
TMMessageBoxManager.show({ buttons: [ButtonNames.OK], message: msg, title: SDKUI_Localizator.IndexingInformation });
|
|
640
|
+
}
|
|
641
|
+
catch (e) {
|
|
642
|
+
TMExceptionBoxManager.show({ exception: e });
|
|
643
|
+
}
|
|
644
|
+
finally {
|
|
645
|
+
TMSpinner.hide();
|
|
646
|
+
}
|
|
647
|
+
}
|
|
648
|
+
},
|
|
649
|
+
{
|
|
650
|
+
icon: svgToString(_jsx(IconArchiveDoc, {})),
|
|
651
|
+
text: SDKUI_Localizator.IndexOrReindex,
|
|
652
|
+
operationType: 'singleRow',
|
|
653
|
+
disabled: false,
|
|
654
|
+
onClick: async () => {
|
|
655
|
+
await runOperationAsync(getDcmts(), DcmtOperationTypes.FreeSearchReindex);
|
|
656
|
+
}
|
|
657
|
+
},
|
|
658
|
+
{
|
|
659
|
+
icon: svgToString(_jsx(IconDelete, {})),
|
|
660
|
+
text: SDKUI_Localizator.IndexingDelete,
|
|
661
|
+
operationType: 'singleRow',
|
|
662
|
+
disabled: false,
|
|
663
|
+
onClick: async () => {
|
|
664
|
+
await runOperationAsync(getDcmts(), DcmtOperationTypes.FreeSearchPurge);
|
|
665
|
+
}
|
|
666
|
+
}
|
|
667
|
+
];
|
|
668
|
+
items.push({
|
|
669
|
+
icon: svgToString(_jsx(IconSearch, {})),
|
|
670
|
+
text: SDKUI_Localizator.FullTextSearch,
|
|
671
|
+
items: fullTextItems
|
|
672
|
+
});
|
|
673
|
+
}
|
|
478
674
|
// Aggiungi submenu "Bottoni personalizzati" se esistono customButtons
|
|
479
675
|
if (customButtonsLayout?.customButtons && Array.isArray(customButtonsLayout.customButtons) && customButtonsLayout.customButtons.length > 0) {
|
|
480
|
-
const customButtonsItems = customButtonsLayout.customButtons
|
|
676
|
+
const customButtonsItems = customButtonsLayout.customButtons
|
|
677
|
+
.filter((customButton) => customButton.isForUpdate && customButton.isForUpdate > 0)
|
|
678
|
+
.map((customButton) => ({
|
|
679
|
+
icon: svgToString(TMImageLibrary({ imageID: customButton.glyphID, showPath: true })),
|
|
481
680
|
text: customButton.title || 'Bottone personalizzato',
|
|
482
681
|
onClick: () => setCustomButton(customButton)
|
|
483
682
|
}));
|
|
683
|
+
//disabilitato per ora
|
|
684
|
+
/*
|
|
484
685
|
items.push({
|
|
485
|
-
icon: svgToString(
|
|
486
|
-
text:
|
|
686
|
+
icon: svgToString(<IconCheck />),
|
|
687
|
+
text: SDKUI_Localizator.CustomButtons,
|
|
487
688
|
items: customButtonsItems
|
|
488
|
-
})
|
|
689
|
+
} as TMDataGridContextMenuItem);*/
|
|
489
690
|
}
|
|
490
691
|
return items;
|
|
491
|
-
}, [
|
|
692
|
+
}, [
|
|
693
|
+
fromDTD?.perm?.canRetrieveFile,
|
|
694
|
+
fromDTD?.description,
|
|
695
|
+
currentDcmt?.fileExt,
|
|
696
|
+
allowRelations,
|
|
697
|
+
currentTIDHasMasterRelations,
|
|
698
|
+
isMasterDisabled,
|
|
699
|
+
currentTIDHasDetailRelations,
|
|
700
|
+
isDetailsDisabled,
|
|
701
|
+
customButtonsLayout,
|
|
702
|
+
layoutMode,
|
|
703
|
+
TID,
|
|
704
|
+
DID,
|
|
705
|
+
onTaskCreateRequest,
|
|
706
|
+
hasManyToManyRelation,
|
|
707
|
+
canArchiveMasterRelation,
|
|
708
|
+
canArchiveDetailRelation,
|
|
709
|
+
pairManyToMany,
|
|
710
|
+
archiveMasterDocuments,
|
|
711
|
+
archiveDetailDocuments,
|
|
712
|
+
getDcmts,
|
|
713
|
+
downloadDcmtsAsync,
|
|
714
|
+
runOperationAsync,
|
|
715
|
+
openConfirmAttachmentsDialog
|
|
716
|
+
]);
|
|
492
717
|
const isModified = useMemo(() => calcIsModified(formData, formDataOrig), [formData, formDataOrig]);
|
|
493
718
|
const formToolbar = useMemo(() => _jsxs("div", { style: { display: 'flex', alignItems: 'center', gap: '10px' }, children: [allowNavigation && canPrev != undefined && _jsx("p", { style: { textAlign: 'center', padding: '1px 4px', display: 'flex' }, children: `${itemIndex}/${count}` }), allowNavigation && canPrev != undefined && _jsx(TMSaveFormButtonPrevious, { btnStyle: 'icon', iconColor: 'white', isModified: isModified, formMode: formMode, canPrev: canPrev, onPrev: onPrev }), allowNavigation && canNext != undefined && _jsx(TMSaveFormButtonNext, { btnStyle: 'icon', iconColor: 'white', isModified: isModified, formMode: formMode, canNext: canNext, onNext: onNext }), layoutMode === LayoutModes.Update && _jsx(IconMenuVertical, { id: `commands-detail-${id}`, color: 'white', cursor: 'pointer' }), layoutMode === LayoutModes.Update && _jsx(ContextMenu, { showEvent: 'click', dataSource: commandsMenuItems, target: `#commands-detail-${id}` }), layoutMode === LayoutModes.Ark &&
|
|
494
719
|
_jsx(TMTooltip, { content: SDKUI_Localizator.PassToSearch, position: 'bottom', children: _jsx(IconSearch, { style: { cursor: 'pointer' }, onClick: handlePassToSearch }) })] }), [allowNavigation, canPrev, canNext, itemIndex, count, isModified, formMode, onPrev, onNext, layoutMode, id, commandsMenuItems, handlePassToSearch]);
|
|
@@ -1122,47 +1347,88 @@ const TMDcmtForm = ({ allTasks = [], getAllTasks, deleteTaskByIdsCallback, addTa
|
|
|
1122
1347
|
height: '100%',
|
|
1123
1348
|
position: 'relative',
|
|
1124
1349
|
overflow: 'hidden'
|
|
1125
|
-
}, children: [isNavigating && _jsx(Spinner, { description: SDKUI_Localizator.Loading, flat: false }), (fromDTD) && _jsxs(TMLayoutWaitingContainer, { direction: 'vertical', showWaitPanel: useWaitPanelLocalState ? showWaitPanelLocal : showWaitPanel, showWaitPanelPrimary: useWaitPanelLocalState ? showPrimaryLocal : showPrimary, showWaitPanelSecondary: useWaitPanelLocalState ? showSecondaryLocal : showSecondary, waitPanelTitle: useWaitPanelLocalState ? waitPanelTitleLocal : waitPanelTitle, waitPanelTextPrimary: useWaitPanelLocalState ? waitPanelTextPrimaryLocal : waitPanelTextPrimary, waitPanelValuePrimary: useWaitPanelLocalState ? waitPanelValuePrimaryLocal : waitPanelValuePrimary, waitPanelMaxValuePrimary: useWaitPanelLocalState ? waitPanelMaxValuePrimaryLocal : waitPanelMaxValuePrimary, waitPanelTextSecondary: useWaitPanelLocalState ? waitPanelTextSecondaryLocal : waitPanelTextSecondary, waitPanelValueSecondary: useWaitPanelLocalState ? waitPanelValueSecondaryLocal : waitPanelValueSecondary, waitPanelMaxValueSecondary: useWaitPanelLocalState ? waitPanelMaxValueSecondaryLocal : waitPanelMaxValueSecondary, isCancelable: useWaitPanelLocalState ? dcmtFile ? dcmtFile.size >= 1000000 : false : true, abortController: useWaitPanelLocalState ? abortControllerLocal : abortController, children: [(groupId && groupId.length > 0)
|
|
1126
|
-
|
|
1127
|
-
|
|
1128
|
-
|
|
1129
|
-
|
|
1130
|
-
|
|
1131
|
-
|
|
1132
|
-
|
|
1133
|
-
|
|
1134
|
-
|
|
1135
|
-
|
|
1136
|
-
|
|
1137
|
-
|
|
1138
|
-
|
|
1139
|
-
|
|
1140
|
-
|
|
1141
|
-
|
|
1142
|
-
|
|
1143
|
-
|
|
1144
|
-
|
|
1145
|
-
|
|
1146
|
-
|
|
1147
|
-
|
|
1148
|
-
|
|
1149
|
-
|
|
1150
|
-
|
|
1151
|
-
|
|
1152
|
-
|
|
1153
|
-
|
|
1154
|
-
|
|
1155
|
-
|
|
1156
|
-
|
|
1350
|
+
}, children: [_jsxs("div", { style: { width: '100%', height: '100%', display: isOpenDetails || isOpenMaster ? 'none' : 'flex' }, children: [isNavigating && _jsx(Spinner, { description: SDKUI_Localizator.Loading, flat: false }), (fromDTD) && _jsxs(TMLayoutWaitingContainer, { direction: 'vertical', showWaitPanel: useWaitPanelLocalState ? showWaitPanelLocal : showWaitPanel, showWaitPanelPrimary: useWaitPanelLocalState ? showPrimaryLocal : showPrimary, showWaitPanelSecondary: useWaitPanelLocalState ? showSecondaryLocal : showSecondary, waitPanelTitle: useWaitPanelLocalState ? waitPanelTitleLocal : waitPanelTitle, waitPanelTextPrimary: useWaitPanelLocalState ? waitPanelTextPrimaryLocal : waitPanelTextPrimary, waitPanelValuePrimary: useWaitPanelLocalState ? waitPanelValuePrimaryLocal : waitPanelValuePrimary, waitPanelMaxValuePrimary: useWaitPanelLocalState ? waitPanelMaxValuePrimaryLocal : waitPanelMaxValuePrimary, waitPanelTextSecondary: useWaitPanelLocalState ? waitPanelTextSecondaryLocal : waitPanelTextSecondary, waitPanelValueSecondary: useWaitPanelLocalState ? waitPanelValueSecondaryLocal : waitPanelValueSecondary, waitPanelMaxValueSecondary: useWaitPanelLocalState ? waitPanelMaxValueSecondaryLocal : waitPanelMaxValueSecondary, isCancelable: useWaitPanelLocalState ? dcmtFile ? dcmtFile.size >= 1000000 : false : true, abortController: useWaitPanelLocalState ? abortControllerLocal : abortController, children: [(groupId && groupId.length > 0)
|
|
1351
|
+
? _jsx(TMPanelManagerContainer, { panels: initialPanels, direction: "horizontal", parentId: groupId, showToolbar: showDcmtFormSidebar })
|
|
1352
|
+
: _jsxs(TMPanelManagerWithPersistenceProvider, { panels: initialPanels, initialVisibility: allInitialPanelVisibility, defaultDimensions: defaultPanelDimensions, initialDimensions: defaultPanelDimensions, initialMobilePanelId: 'tmDcmtForm', isPersistenceEnabled: !isMobile ? hasSavedLayout() : false, persistPanelStates: !isMobile ? (state) => persistPanelStates(state) : undefined, persistedPanelStates: getPersistedPanelStates(), children: [_jsx(WfButtonStateHandler, { isWFDisabled: isWFDisabled }), _jsx(TMPanelManagerContainer, { panels: initialPanels, direction: "horizontal", parentId: groupId, showToolbar: showDcmtFormSidebar })] }), isOpenDistinctValues &&
|
|
1353
|
+
_jsx(TMDistinctValues, { tid: TID, mid: focusedMetadataValue?.mid, isModal: true, showHeader: false, layoutMode: layoutMode, onSelectionChanged: (e) => {
|
|
1354
|
+
if (!e)
|
|
1355
|
+
return;
|
|
1356
|
+
setFormData((prevItems) => prevItems.map((item) => item.tid == e.tid && item.mid === e.mid ? { ...item, value: e.newValue } : item));
|
|
1357
|
+
} }), isOpenFormulaEditor &&
|
|
1358
|
+
_jsx(TMFormulaEditor, { isModal: true, formMode: FormModes.Update, inputData: getFormula(), showBack: false, onClose: () => setIsOpenFormulaEditor(false), onApplied: (newFormula) => {
|
|
1359
|
+
setFormData((prevItems) => prevItems.map((item) => item.tid == newFormula.tid && item.mid === newFormula.mid ? { ...item, value: FormulaHelper.addFormulaTag(newFormula.expression), isSelected: true, isEditable: true } : item));
|
|
1360
|
+
setFocusedMetadataValue(prevState => ({
|
|
1361
|
+
...prevState,
|
|
1362
|
+
isSelected: true,
|
|
1363
|
+
isEditable: true,
|
|
1364
|
+
value: FormulaHelper.addFormulaTag(newFormula.expression)
|
|
1365
|
+
}));
|
|
1366
|
+
} }), showApprovePopup && _jsx(WorkFlowApproveRejectPopUp, { deviceType: deviceType, onCompleted: handleWFOperationCompleted, TID: approvalVID, DID: DID, isReject: 0, onClose: () => setShowApprovePopup(false) }), showRejectPopup && _jsx(WorkFlowApproveRejectPopUp, { deviceType: deviceType, onCompleted: handleWFOperationCompleted, TID: approvalVID, DID: DID, isReject: 1, onClose: () => setShowRejectPopup(false) }), showReAssignPopup && _jsx(WorkFlowReAssignPopUp, { deviceType: deviceType, onCompleted: handleWFOperationCompleted, TID: approvalVID, DID: DID, onClose: () => setShowReAssignPopup(false) }), showMoreInfoPopup && _jsx(WorkFlowMoreInfoPopUp, { deviceType: deviceType, onCompleted: handleWFOperationCompleted, TID: approvalVID, DID: DID, onClose: () => setShowMoreInfoPopup(false) }), (isModal && onClose) && _jsx("div", { id: "TMDcmtFormShowConfirmForClose-" + id })] }), _jsx(ToppyDraggableHelpCenter, { initialIsCollapsed: false, deviceType: deviceType, isVisible: (showToppyForApprove || showToppyForCompleteMoreInfo || showToppyForReferences) && !openS4TViewer, content: _jsxs("div", { style: { display: 'flex', flexDirection: 'column', gap: '10px' }, children: [showToppyForApprove && (workItems.length === 1 ?
|
|
1367
|
+
_jsx(WorkFlowOperationButtons, { deviceType: deviceType, onApprove: () => setShowApprovePopup(true), onSignApprove: handleSignApprove, onReject: () => setShowRejectPopup(true), onReAssign: () => setShowReAssignPopup(true), onMoreInfo: () => setShowMoreInfoPopup(true), dtd: fromDTD })
|
|
1368
|
+
:
|
|
1369
|
+
_jsxs("div", { style: { padding: 10, color: 'white', maxWidth: '180px', borderRadius: 10, background: '#1B1464 0% 0% no-repeat padding-box', border: '1px solid #FFFFFF' }, children: [`Devi approvare ${workItems.length} workitem(s) per questo documento.`, `Vai alla sezione di approvazione.`] })), showToppyForCompleteMoreInfo && (_jsxs(_Fragment, { children: [_jsx("div", { style: { padding: 10, color: 'white', maxWidth: '180px', borderRadius: 10, background: '#1B1464 0% 0% no-repeat padding-box', border: '1px solid #FFFFFF' }, children: `${SDKUI_Localizator.MoreInfoCompleteRequestSentBy} ${taskMoreInfo?.fromName}!` }), _jsx(TMButton, { caption: SDKUI_Localizator.CommentAndComplete, color: 'success', showTooltip: false, onClick: () => {
|
|
1370
|
+
setShowCommentForm(true);
|
|
1371
|
+
} })] })), (showToppyForReferences && (dcmtReferences && dcmtReferences.length > 0)) && dcmtReferences
|
|
1372
|
+
.filter(ref => ref.objClass === ObjectClasses.Dossier || ref.objClass === ObjectClasses.WorkingGroup) // keep only known objClass types
|
|
1373
|
+
.map((ref, index, arr) => {
|
|
1374
|
+
const mapEntry = referenceActionMap[String(ref.objClass)];
|
|
1375
|
+
const label = mapEntry?.label ?? 'Vai a riferimento';
|
|
1376
|
+
return (_jsxs(React.Fragment, { children: [index === 0 && (showToppyForApprove || showToppyForCompleteMoreInfo) && (_jsx("div", { style: {
|
|
1377
|
+
height: 1,
|
|
1378
|
+
backgroundColor: 'rgba(255,255,255,0.2)',
|
|
1379
|
+
margin: '6px 0'
|
|
1380
|
+
} })), _jsxs(StyledReferenceButton, { onClick: () => handleNavigateToReference(ref), onDoubleClick: (e) => { e.preventDefault(); e.stopPropagation(); }, children: [_jsx("span", { children: label }), _jsx("span", { children: `"${ref.objName}"` })] }, `ref-${index}-${ref.objID}`)] }, `ref-frag-${index}-${ref.objID}`));
|
|
1381
|
+
})] }) })] }), (showCommentForm && TID && DID) &&
|
|
1157
1382
|
_jsx(TMBlogCommentForm, { context: { engine: 'SearchEngine', object: { tid: TID, did: DID } }, onClose: () => setShowCommentForm(false), refreshCallback: handleCompleteMoreInfo, participants: [], showAttachmentsSection: false, allArchivedDocumentsFileItems: [] }), isOpenDetails &&
|
|
1158
|
-
_jsx(StyledModalContainer, {
|
|
1159
|
-
_jsxs(StyledModalContainer, {
|
|
1160
|
-
return (_jsx(StyledModalContainer, {
|
|
1383
|
+
_jsx(StyledModalContainer, { children: _jsx(TMMasterDetailDcmts, { deviceType: deviceType, isForMaster: false, inputDcmts: getSelectionDcmtInfo(), allowNavigation: allowNavigation, canNext: canNext, canPrev: canPrev, onNext: onNext, onPrev: onPrev, onBack: () => setIsOpenDetails(false), allTasks: allTasks, getAllTasks: getAllTasks, deleteTaskByIdsCallback: deleteTaskByIdsCallback, addTaskCallback: addTaskCallback, editTaskCallback: editTaskCallback, handleNavigateToWGs: handleNavigateToWGs, handleNavigateToDossiers: handleNavigateToDossiers }) }), isOpenMaster &&
|
|
1384
|
+
_jsxs(StyledModalContainer, { children: [_jsx(TMMasterDetailDcmts, { deviceType: deviceType, inputDcmts: getSelectionDcmtInfo(), isForMaster: true, allowNavigation: allowNavigation, canNext: canNext, canPrev: canPrev, onNext: onNext, onPrev: onPrev, onBack: () => setIsOpenMaster(false), appendMasterDcmts: handleAddItem, allTasks: allTasks, getAllTasks: getAllTasks, deleteTaskByIdsCallback: deleteTaskByIdsCallback, addTaskCallback: addTaskCallback, editTaskCallback: editTaskCallback, handleNavigateToWGs: handleNavigateToWGs, handleNavigateToDossiers: handleNavigateToDossiers }), secondaryMasterDcmts.length > 0 && secondaryMasterDcmts.map((dcmt, index) => {
|
|
1385
|
+
return (_jsx(StyledModalContainer, { children: _jsx(TMMasterDetailDcmts, { deviceType: deviceType, inputDcmts: [dcmt], isForMaster: true, allowNavigation: false, onBack: () => handleRemoveItem(dcmt.TID, dcmt.DID), appendMasterDcmts: handleAddItem, allTasks: allTasks, getAllTasks: getAllTasks, deleteTaskByIdsCallback: deleteTaskByIdsCallback, addTaskCallback: addTaskCallback, editTaskCallback: editTaskCallback, handleNavigateToWGs: handleNavigateToWGs, handleNavigateToDossiers: handleNavigateToDossiers }) }, `${index}-${dcmt.DID}`));
|
|
1161
1386
|
})] }), taskFormDialogComponent, s4TViewerDialogComponent] }));
|
|
1162
1387
|
};
|
|
1163
|
-
return (
|
|
1164
|
-
|
|
1165
|
-
|
|
1388
|
+
return (_jsxs(_Fragment, { children: [(isModal && onClose)
|
|
1389
|
+
? _jsx(TMModal, { title: titleModal, onClose: handleClose, width: widthModal ?? '100%', height: heightModal ?? '100%', hidePopup: false, askClosingConfirm: true, children: _jsx("div", { style: { width: "100%", height: "100%", display: 'block', padding: "4px", position: 'relative' }, children: renderDcmtForm() }) })
|
|
1390
|
+
: renderDcmtForm(), showRelatedDcmtsChooser && (_jsx(TMChooserForm, { dataSource: relatedDcmtsChooserDataSource, onChoose: async (selectedRelation) => {
|
|
1391
|
+
try {
|
|
1392
|
+
setShowRelatedDcmtsChooser(false);
|
|
1393
|
+
TMSpinner.show({ description: SDKUI_Localizator.Loading });
|
|
1394
|
+
const relation = relatedDcmts?.find(r => r.id === selectedRelation[0]);
|
|
1395
|
+
if (!relation || !archiveType)
|
|
1396
|
+
return;
|
|
1397
|
+
await archiveRelatedDcmtHandler(relation, archiveType);
|
|
1398
|
+
}
|
|
1399
|
+
catch (error) {
|
|
1400
|
+
TMExceptionBoxManager.show({ exception: error });
|
|
1401
|
+
}
|
|
1402
|
+
finally {
|
|
1403
|
+
TMSpinner.hide();
|
|
1404
|
+
}
|
|
1405
|
+
}, onClose: () => setShowRelatedDcmtsChooser(false), manageUseLocalizedName: false })), showManyToManyChooser && (_jsx(TMChooserForm, { dataSource: manyToManyChooserDataSource, onChoose: async (selectedRelation) => {
|
|
1406
|
+
try {
|
|
1407
|
+
setShowManyToManyChooser(false);
|
|
1408
|
+
TMSpinner.show({ description: SDKUI_Localizator.Loading });
|
|
1409
|
+
const relation = manyToManyRelations?.find(r => r.id === selectedRelation[0]);
|
|
1410
|
+
if (!relation)
|
|
1411
|
+
return;
|
|
1412
|
+
await executeManyToManyPairing(relation, isPairingManyToMany);
|
|
1413
|
+
}
|
|
1414
|
+
catch (error) {
|
|
1415
|
+
TMExceptionBoxManager.show({ exception: error });
|
|
1416
|
+
}
|
|
1417
|
+
finally {
|
|
1418
|
+
TMSpinner.hide();
|
|
1419
|
+
}
|
|
1420
|
+
}, onClose: () => setShowManyToManyChooser(false), manageUseLocalizedName: false })), isOpenArchiveRelationForm && (_jsx(TMDcmtForm, { isModal: true, titleModal: SDKUI_Localizator.Archive + ' - ' + (archiveType === 'detail' ? SDKUI_Localizator.DcmtsDetail : SDKUI_Localizator.DcmtsMaster), TID: archiveRelatedDcmtFormTID, layoutMode: LayoutModes.Ark, inputMids: archiveRelatedDcmtFormMids, showBackButton: false, allowButtonsRefs: false, onClose: () => {
|
|
1421
|
+
setIsOpenArchiveRelationForm(false);
|
|
1422
|
+
setArchiveType(undefined);
|
|
1423
|
+
setArchiveRelatedDcmtFormTID(undefined);
|
|
1424
|
+
setArchiveRelatedDcmtFormMids([]);
|
|
1425
|
+
}, onSavedAsyncCallback: async (tid, did) => {
|
|
1426
|
+
setIsOpenArchiveRelationForm(false);
|
|
1427
|
+
setArchiveType(undefined);
|
|
1428
|
+
setArchiveRelatedDcmtFormTID(undefined);
|
|
1429
|
+
setArchiveRelatedDcmtFormMids([]);
|
|
1430
|
+
await fetchData();
|
|
1431
|
+
}, allTasks: allTasks, getAllTasks: getAllTasks, deleteTaskByIdsCallback: deleteTaskByIdsCallback, addTaskCallback: addTaskCallback, editTaskCallback: editTaskCallback, handleNavigateToWGs: handleNavigateToWGs, handleNavigateToDossiers: handleNavigateToDossiers })), showPairDcmtsModal && (_jsx(TMModal, { title: (isPairingManyToMany ? "Abbina" : "Disabbina") + " documenti", onClose: () => setShowPairDcmtsModal(false), width: isMobile ? '90%' : '50%', height: isMobile ? '90%' : '70%', children: _jsx(TMSearchResult, { searchResults: pairedSearchResults, onRefreshSearchAsync: async () => await fetchData(), onTaskCreateRequest: onTaskCreateRequest, allowFloatingBar: false, floatingActionConfig: pairFloatingActionConfig, showBackButton: false, allTasks: allTasks, getAllTasks: getAllTasks, deleteTaskByIdsCallback: deleteTaskByIdsCallback, addTaskCallback: addTaskCallback, editTaskCallback: editTaskCallback, handleNavigateToWGs: handleNavigateToWGs, handleNavigateToDossiers: handleNavigateToDossiers }) }))] }));
|
|
1166
1432
|
};
|
|
1167
1433
|
export default TMDcmtForm;
|
|
1168
1434
|
/**
|
|
@@ -7,13 +7,13 @@ import { DownloadTypes } from '../../../ts';
|
|
|
7
7
|
import { DeviceType, useDeviceType } from '../../base/TMDeviceProvider';
|
|
8
8
|
import { useDcmtOperations } from '../../../hooks/useDcmtOperations';
|
|
9
9
|
import { TMWaitPanel } from '../../base/TMWaitPanel';
|
|
10
|
-
const StyledCellRenderDcmtIcon = styled.div `
|
|
11
|
-
display: flex;
|
|
12
|
-
flex-direction: row;
|
|
13
|
-
align-items: center;
|
|
14
|
-
justify-content: center;
|
|
15
|
-
overflow: visible;
|
|
16
|
-
position: relative;
|
|
10
|
+
const StyledCellRenderDcmtIcon = styled.div `
|
|
11
|
+
display: flex;
|
|
12
|
+
flex-direction: row;
|
|
13
|
+
align-items: center;
|
|
14
|
+
justify-content: center;
|
|
15
|
+
overflow: visible;
|
|
16
|
+
position: relative;
|
|
17
17
|
`;
|
|
18
18
|
const TMDcmtIcon = ({ fileExtension, fileCount, isLexProt, isSigned, isMail, isShared, tid, did, downloadMode = "none", tooltipContent, openInOffice, onDownloadDcmtsAsync }) => {
|
|
19
19
|
const { downloadDcmtsAsync, showWaitPanel, waitPanelTitle, showSecondary, waitPanelTextSecondary, waitPanelValueSecondary, waitPanelMaxValueSecondary, abortController } = useDcmtOperations();
|
|
@@ -27,19 +27,24 @@ const TMDcmtIcon = ({ fileExtension, fileCount, isLexProt, isSigned, isMail, isS
|
|
|
27
27
|
e.stopPropagation();
|
|
28
28
|
e.preventDefault();
|
|
29
29
|
if (tid && did) {
|
|
30
|
-
|
|
30
|
+
const fileName = fileExtension ? `${did}.${fileExtension}` : undefined;
|
|
31
|
+
let dcmt = [{ TID: tid, DID: did, FILEEXT: fileExtension, fileName: fileName }];
|
|
32
|
+
// Per file con problemi di estensione nelle blob URL (.p7m, .msg), forza la modalità download
|
|
33
|
+
const fileExtLower = fileExtension?.toLowerCase();
|
|
34
|
+
const needsForceDownload = fileExtLower?.includes('p7m') || fileExtLower === 'msg';
|
|
35
|
+
const effectiveDownloadMode = (downloadMode === 'openInNewWindow' && needsForceDownload) ? 'download' : downloadMode;
|
|
31
36
|
// Usa la funzione passata tramite prop se disponibile, altrimenti usa l'hook interno
|
|
32
37
|
if (openInOffice) {
|
|
33
38
|
await openInOffice(dcmt);
|
|
34
39
|
}
|
|
35
40
|
else if (onDownloadDcmtsAsync) {
|
|
36
|
-
await onDownloadDcmtsAsync?.(dcmt, DownloadTypes.Dcmt,
|
|
41
|
+
await onDownloadDcmtsAsync?.(dcmt, DownloadTypes.Dcmt, effectiveDownloadMode);
|
|
37
42
|
}
|
|
38
43
|
else {
|
|
39
|
-
await downloadDcmtsAsync(dcmt, DownloadTypes.Dcmt,
|
|
44
|
+
await downloadDcmtsAsync(dcmt, DownloadTypes.Dcmt, effectiveDownloadMode);
|
|
40
45
|
}
|
|
41
46
|
}
|
|
42
|
-
}, [tid, did, downloadMode, openInOffice, onDownloadDcmtsAsync, downloadDcmtsAsync]);
|
|
47
|
+
}, [tid, did, fileExtension, downloadMode, openInOffice, onDownloadDcmtsAsync, downloadDcmtsAsync]);
|
|
43
48
|
const isDownloadable = downloadMode !== "none" &&
|
|
44
49
|
tid !== undefined &&
|
|
45
50
|
did !== undefined &&
|
|
@@ -56,7 +61,7 @@ const TMDcmtIcon = ({ fileExtension, fileCount, isLexProt, isSigned, isMail, isS
|
|
|
56
61
|
};
|
|
57
62
|
export default TMDcmtIcon;
|
|
58
63
|
function IconLexProtLock(props) {
|
|
59
|
-
return (_jsxs("svg", { viewBox: "0 0 512 512", height: "1em", width: "1em", ...props, children: [_jsx("path", { fill: "#455A64", d: "M256,0c-76.544,0.094-138.573,62.122-138.667,138.667V224c0,5.891,4.776,10.667,10.667,10.667h42.667\n c5.891,0,10.667-4.776,10.667-10.667v-85.333C181.333,97.429,214.763,64,256,64s74.667,33.429,74.667,74.667V224\n c0,5.891,4.776,10.667,10.667,10.667H384c5.891,0,10.667-4.776,10.667-10.667v-85.333C394.573,62.122,332.544,0.094,256,0z" }), _jsx("path", { fill: "#FFC107", d: "M128,213.333h256c29.455,0,53.333,23.878,53.333,53.333v192C437.333,488.122,413.455,512,384,512H128\n c-29.455,0-53.333-23.878-53.333-53.333v-192C74.667,237.211,98.545,213.333,128,213.333z" }), _jsx("path", { fill: "#455A64", d: "M309.333,330.667c0.124-29.455-23.653-53.434-53.108-53.558\n c-29.455-0.124-53.434,23.653-53.558,53.108c-0.086,20.36,11.427,38.992,29.674,48.023l-8.235,57.6\n c-0.825,5.833,3.235,11.23,9.068,12.055c0.494,0.07,0.993,0.105,1.492,0.105h42.667c5.891,0.06,10.715-4.667,10.774-10.558\n c0.005-0.543-0.03-1.086-0.108-1.623l-8.235-57.6C297.788,369.199,309.216,350.82,309.333,330.667z" }), _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " })] })
|
|
64
|
+
return (_jsxs("svg", { viewBox: "0 0 512 512", height: "1em", width: "1em", ...props, children: [_jsx("path", { fill: "#455A64", d: "M256,0c-76.544,0.094-138.573,62.122-138.667,138.667V224c0,5.891,4.776,10.667,10.667,10.667h42.667\r\n c5.891,0,10.667-4.776,10.667-10.667v-85.333C181.333,97.429,214.763,64,256,64s74.667,33.429,74.667,74.667V224\r\n c0,5.891,4.776,10.667,10.667,10.667H384c5.891,0,10.667-4.776,10.667-10.667v-85.333C394.573,62.122,332.544,0.094,256,0z" }), _jsx("path", { fill: "#FFC107", d: "M128,213.333h256c29.455,0,53.333,23.878,53.333,53.333v192C437.333,488.122,413.455,512,384,512H128\r\n c-29.455,0-53.333-23.878-53.333-53.333v-192C74.667,237.211,98.545,213.333,128,213.333z" }), _jsx("path", { fill: "#455A64", d: "M309.333,330.667c0.124-29.455-23.653-53.434-53.108-53.558\r\n c-29.455-0.124-53.434,23.653-53.558,53.108c-0.086,20.36,11.427,38.992,29.674,48.023l-8.235,57.6\r\n c-0.825,5.833,3.235,11.23,9.068,12.055c0.494,0.07,0.993,0.105,1.492,0.105h42.667c5.891,0.06,10.715-4.667,10.774-10.558\r\n c0.005-0.543-0.03-1.086-0.108-1.623l-8.235-57.6C297.788,369.199,309.216,350.82,309.333,330.667z" }), _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " }), " ", _jsx("g", { children: " " })] })
|
|
60
65
|
// <svg
|
|
61
66
|
// viewBox="0 0 24 24"
|
|
62
67
|
// fill="currentColor"
|