mirror of
https://github.com/tencentmusic/supersonic.git
synced 2025-12-15 06:27:21 +00:00
* [improvement][semantic-fe] Add model alias setting & Add view permission restrictions to the model permission management tab. [improvement][semantic-fe] Add permission control to the action buttons for the main domain; apply high sensitivity filtering to the authorization of metrics/dimensions. [improvement][semantic-fe] Optimize the editing mode in the dimension/metric/datasource components to use the modelId stored in the database for data, instead of relying on the data from the state manager. * [improvement][semantic-fe] Add time granularity setting in the data source configuration. * [improvement][semantic-fe] Dictionary import for dimension values supported in Q&A visibility * [improvement][semantic-fe] Modification of data source creation prompt wording" * [improvement][semantic-fe] metric market experience optimization * [improvement][semantic-fe] enhance the analysis of metric trends * [improvement][semantic-fe] optimize the presentation of metric trend permissions * [improvement][semantic-fe] add metric trend download functionality * [improvement][semantic-fe] fix the dimension initialization issue in metric correlation * [improvement][semantic-fe] Fix the issue of database changes not taking effect when creating based on an SQL data source. * [improvement][semantic-fe] Optimizing pagination logic and some CSS styles * [improvement][semantic-fe] Fixing the API for the indicator list by changing "current" to "pageNum" * [improvement][semantic-fe] Fixing the default value setting for the indicator list * [improvement][semantic-fe] Adding batch operations for indicators/dimensions/models * [improvement][semantic-fe] Replacing the single status update API for indicators/dimensions with a batch update API * [improvement][semantic-fe] Redesigning the indicator homepage to incorporate trend charts and table functionality for indicators
90 lines
2.4 KiB
TypeScript
90 lines
2.4 KiB
TypeScript
import React, { useEffect, useState } from 'react';
|
|
import { Modal, Button, message } from 'antd';
|
|
import DimensionMetricRelationTableTransfer from './DimensionMetricRelationTableTransfer';
|
|
import { ISemantic } from '../data';
|
|
import { updateExprMetric } from '../service';
|
|
import FormItemTitle from '@/components/FormHelper/FormItemTitle';
|
|
|
|
type Props = {
|
|
onCancel: () => void;
|
|
open: boolean;
|
|
metricItem?: ISemantic.IMetricItem;
|
|
relationsInitialValue?: ISemantic.IDrillDownDimensionItem[];
|
|
onSubmit: (relations: ISemantic.IDrillDownDimensionItem[]) => void;
|
|
};
|
|
|
|
const DimensionAndMetricRelationModal: React.FC<Props> = ({
|
|
open,
|
|
metricItem = {},
|
|
relationsInitialValue,
|
|
onCancel,
|
|
onSubmit,
|
|
}) => {
|
|
const [relationList, setRelationList] = useState<ISemantic.IDrillDownDimensionItem[]>([]);
|
|
|
|
const saveMetric = async (relationList: any) => {
|
|
const queryParams = {
|
|
...metricItem,
|
|
relateDimension: {
|
|
...(metricItem?.relateDimension || {}),
|
|
drillDownDimensions: relationList,
|
|
},
|
|
};
|
|
const { code, msg } = await updateExprMetric(queryParams);
|
|
if (code === 200) {
|
|
// message.success('编辑指标成功');
|
|
// onSubmit?.(queryParams);
|
|
return;
|
|
}
|
|
message.error(msg);
|
|
};
|
|
|
|
const renderFooter = () => {
|
|
return (
|
|
<>
|
|
<Button onClick={onCancel}>取消</Button>
|
|
<Button
|
|
type="primary"
|
|
onClick={() => {
|
|
onSubmit(relationList);
|
|
saveMetric(relationList);
|
|
}}
|
|
>
|
|
完成
|
|
</Button>
|
|
</>
|
|
);
|
|
};
|
|
|
|
return (
|
|
<>
|
|
<Modal
|
|
width={1200}
|
|
destroyOnClose
|
|
title={
|
|
<FormItemTitle
|
|
title={'维度关联'}
|
|
subTitle={'注意:完成指标信息更新后,维度关联配置信息才会被保存'}
|
|
/>
|
|
}
|
|
maskClosable={false}
|
|
open={open}
|
|
footer={renderFooter()}
|
|
onCancel={onCancel}
|
|
>
|
|
<div style={{ display: 'flex', justifyContent: 'center' }}>
|
|
<DimensionMetricRelationTableTransfer
|
|
metricItem={metricItem}
|
|
relationsInitialValue={relationsInitialValue}
|
|
onChange={(relations: ISemantic.IDrillDownDimensionItem[]) => {
|
|
setRelationList(relations);
|
|
}}
|
|
/>
|
|
</div>
|
|
</Modal>
|
|
</>
|
|
);
|
|
};
|
|
|
|
export default DimensionAndMetricRelationModal;
|