@finos/legend-application-studio
Version:
Legend Studio application core
110 lines • 8.55 kB
JavaScript
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
/**
* Copyright (c) 2020-present, Goldman Sachs
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { useState, useCallback } from 'react';
import { observer } from 'mobx-react-lite';
import { useDrop } from 'react-dnd';
import { CORE_DND_TYPE, } from '../../../../stores/editor/utils/DnDUtils.js';
import { clsx, CustomSelectorInput, LockIcon, PanelContent, PanelContentLists, PanelDropZone, PanelForm, PanelFormSection, PlusIcon, TimesIcon, } from '@finos/legend-art';
import { StereotypeSelector, StereotypeDragPreviewLayer, } from './StereotypeSelector.js';
import { TaggedValueDragPreviewLayer, TaggedValueEditor, } from './TaggedValueEditor.js';
import { LEGEND_STUDIO_TEST_ID } from '../../../../__lib__/LegendStudioTesting.js';
import { isNonNullable, prettyCONSTName } from '@finos/legend-shared';
import { UML_EDITOR_TAB } from '../../../../stores/editor/editor-state/element-editor-state/UMLEditorState.js';
import { Profile, StereotypeExplicitReference, stub_TaggedValue, stub_Tag, stub_Profile, stub_Stereotype, Property, AggregationKind, } from '@finos/legend-graph';
import { annotatedElement_deleteTaggedValue, annotatedElement_addTaggedValue, annotatedElement_addStereotype, annotatedElement_deleteStereotype, property_setAggregationKind, } from '../../../../stores/graph-modifier/DomainGraphModifierHelper.js';
const buildAggregationKindOption = (val) => ({
label: prettyCONSTName(val),
value: val,
});
export const PropertyEditor = observer((props) => {
const { property, deselectProperty, isReadOnly } = props;
// Tab
const [selectedTab, setSelectedTab] = useState(property instanceof Property
? UML_EDITOR_TAB.PROPERTY_AGGREGATION
: UML_EDITOR_TAB.TAGGED_VALUES);
const tabs = [
property instanceof Property
? UML_EDITOR_TAB.PROPERTY_AGGREGATION
: undefined,
UML_EDITOR_TAB.TAGGED_VALUES,
UML_EDITOR_TAB.STEREOTYPES,
].filter(isNonNullable);
const changeTab = (tab) => () => setSelectedTab(tab);
// Tagged value and Stereotype
let addButtonTitle = '';
switch (selectedTab) {
case UML_EDITOR_TAB.TAGGED_VALUES:
addButtonTitle = 'Add tagged value';
break;
case UML_EDITOR_TAB.STEREOTYPES:
addButtonTitle = 'Add stereotype';
break;
case UML_EDITOR_TAB.PROPERTY_AGGREGATION:
addButtonTitle = 'Configure property aggregation kind';
break;
default:
break;
}
const addValue = () => {
if (!isReadOnly) {
if (selectedTab === UML_EDITOR_TAB.TAGGED_VALUES) {
annotatedElement_addTaggedValue(property, stub_TaggedValue(stub_Tag(stub_Profile())));
}
else if (selectedTab === UML_EDITOR_TAB.STEREOTYPES) {
annotatedElement_addStereotype(property, StereotypeExplicitReference.create(stub_Stereotype(stub_Profile())));
}
}
};
const _deleteStereotype = (val) => () => annotatedElement_deleteStereotype(property, val);
const _deleteTaggedValue = (val) => () => annotatedElement_deleteTaggedValue(property, val);
// Drag and Drop
const handleDropTaggedValue = useCallback((item) => {
if (!isReadOnly && item.data.packageableElement instanceof Profile) {
annotatedElement_addTaggedValue(property, stub_TaggedValue(stub_Tag(item.data.packageableElement)));
}
}, [isReadOnly, property]);
const [{ isTaggedValueDragOver }, taggedValueDropConnector] = useDrop(() => ({
accept: [CORE_DND_TYPE.PROJECT_EXPLORER_PROFILE],
drop: (item) => handleDropTaggedValue(item),
collect: (monitor) => ({
isTaggedValueDragOver: monitor.isOver({ shallow: true }),
}),
}), [handleDropTaggedValue]);
const handleDropStereotype = useCallback((item) => {
if (!isReadOnly && item.data.packageableElement instanceof Profile) {
annotatedElement_addStereotype(property, StereotypeExplicitReference.create(stub_Stereotype(item.data.packageableElement)));
}
}, [isReadOnly, property]);
const [{ isStereotypeDragOver }, stereotypeDropConnector] = useDrop(() => ({
accept: [CORE_DND_TYPE.PROJECT_EXPLORER_PROFILE],
drop: (item) => handleDropStereotype(item),
collect: (monitor) => ({
isStereotypeDragOver: monitor.isOver({ shallow: true }),
}),
}), [handleDropStereotype]);
return (_jsx("div", { className: "uml-element-editor property-editor", children: _jsxs("div", { "data-testid": LEGEND_STUDIO_TEST_ID.PANEL, className: "panel", children: [_jsxs("div", { className: "panel__header", children: [_jsxs("div", { className: "panel__header__title", children: [isReadOnly && (_jsx("div", { className: "uml-element-editor__header__lock", children: _jsx(LockIcon, {}) })), _jsx("div", { className: "panel__header__title__label", children: "property" }), _jsx("div", { className: "panel__header__title__content", children: property.name })] }), _jsx("div", { className: "panel__header__actions", children: _jsx("button", { className: "panel__header__action", onClick: deselectProperty, tabIndex: -1, title: "Close", children: _jsx(TimesIcon, {}) }) })] }), _jsxs("div", { className: "panel__header uml-element-editor__tabs__header", children: [_jsx("div", { className: "uml-element-editor__tabs", children: tabs.map((tab) => (_jsx("div", { onClick: changeTab(tab), className: clsx('uml-element-editor__tab', {
'uml-element-editor__tab--active': tab === selectedTab,
}), children: prettyCONSTName(tab) }, tab))) }), _jsx("div", { className: "panel__header__actions", children: _jsx("button", { className: "panel__header__action", disabled: isReadOnly ||
![
UML_EDITOR_TAB.TAGGED_VALUES,
UML_EDITOR_TAB.STEREOTYPES,
].includes(selectedTab), onClick: addValue, tabIndex: -1, title: addButtonTitle, children: _jsx(PlusIcon, {}) }) })] }), _jsxs(PanelContent, { children: [selectedTab === UML_EDITOR_TAB.PROPERTY_AGGREGATION &&
property instanceof Property && (_jsx(PanelForm, { children: _jsxs(PanelFormSection, { children: [_jsx("div", { className: "panel__content__form__section__header__label", children: "Aggregation Kind" }), _jsx(CustomSelectorInput, { className: "panel__content__form__section__dropdown", options: Object.values(AggregationKind).map(buildAggregationKindOption), onChange: (option) => property_setAggregationKind(property, option?.value), value: property.aggregation
? buildAggregationKindOption(property.aggregation)
: null, escapeClearsValue: true, isClearable: true, disabled: isReadOnly })] }) })), selectedTab === UML_EDITOR_TAB.TAGGED_VALUES && (_jsx(PanelDropZone, { isDragOver: isTaggedValueDragOver && !isReadOnly, dropTargetConnector: taggedValueDropConnector, children: _jsxs(PanelContentLists, { children: [_jsx(TaggedValueDragPreviewLayer, {}), property.taggedValues.map((taggedValue) => (_jsx(TaggedValueEditor, { annotatedElement: property, taggedValue: taggedValue, deleteValue: _deleteTaggedValue(taggedValue), isReadOnly: isReadOnly }, taggedValue._UUID)))] }) })), selectedTab === UML_EDITOR_TAB.STEREOTYPES && (_jsx(PanelDropZone, { isDragOver: isStereotypeDragOver && !isReadOnly, dropTargetConnector: stereotypeDropConnector, children: _jsxs(PanelContentLists, { children: [_jsx(StereotypeDragPreviewLayer, {}), property.stereotypes.map((stereotype) => (_jsx(StereotypeSelector, { annotatedElement: property, stereotype: stereotype, deleteStereotype: _deleteStereotype(stereotype), isReadOnly: isReadOnly }, stereotype.value._UUID)))] }) }))] })] }) }));
});
//# sourceMappingURL=PropertyEditor.js.map