mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-18 05:36:00 +00:00
54 lines
1.4 KiB
JavaScript
54 lines
1.4 KiB
JavaScript
import React from 'react';
|
|
import _ from 'lodash';
|
|
|
|
import { AppObjectList } from '../appobj/AppObjectList';
|
|
import { useOpenedTabs } from '../utility/globalState';
|
|
import ClosedTabAppObject from '../appobj/ClosedTabAppObject';
|
|
import { WidgetsInnerContainer } from './WidgetStyles';
|
|
import { SavedSqlFileAppObject } from '../appobj/SavedFileAppObject';
|
|
import WidgetColumnBar, { WidgetColumnBarItem } from './WidgetColumnBar';
|
|
import { useFiles } from '../utility/metadataLoaders';
|
|
|
|
function ClosedTabsList() {
|
|
const tabs = useOpenedTabs();
|
|
|
|
return (
|
|
<>
|
|
<WidgetsInnerContainer>
|
|
<AppObjectList
|
|
list={_.sortBy(
|
|
tabs.filter((x) => x.closedTime),
|
|
(x) => -x.closedTime
|
|
)}
|
|
AppObjectComponent={ClosedTabAppObject}
|
|
/>
|
|
</WidgetsInnerContainer>
|
|
</>
|
|
);
|
|
}
|
|
|
|
function SavedSqlFilesList() {
|
|
const files = useFiles({ folder: 'sql' });
|
|
|
|
return (
|
|
<>
|
|
<WidgetsInnerContainer>
|
|
<AppObjectList list={files} AppObjectComponent={SavedSqlFileAppObject} />
|
|
</WidgetsInnerContainer>
|
|
</>
|
|
);
|
|
}
|
|
|
|
export default function FilesWidget() {
|
|
return (
|
|
<WidgetColumnBar>
|
|
<WidgetColumnBarItem title="Recently closed tabs" name="closedTabs" height="50%">
|
|
<ClosedTabsList />
|
|
</WidgetColumnBarItem>
|
|
<WidgetColumnBarItem title="Saved SQL files" name="sqlFiles">
|
|
<SavedSqlFilesList />
|
|
</WidgetColumnBarItem>
|
|
</WidgetColumnBar>
|
|
);
|
|
}
|