SAM2.1
SAM2.1 checkpoints + training code + Demo
This commit is contained in:
46
demo/frontend/src/layouts/DemoPageLayout.tsx
Normal file
46
demo/frontend/src/layouts/DemoPageLayout.tsx
Normal file
@@ -0,0 +1,46 @@
|
||||
/**
|
||||
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
||||
*
|
||||
* 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 {spacing} from '@/theme/tokens.stylex';
|
||||
import stylex from '@stylexjs/stylex';
|
||||
import {PropsWithChildren} from 'react';
|
||||
|
||||
type Props = PropsWithChildren;
|
||||
|
||||
const styles = stylex.create({
|
||||
container: {
|
||||
width: '100%',
|
||||
height: '100%',
|
||||
display: 'flex',
|
||||
justifyContent: 'stretch',
|
||||
alignItems: 'stretch',
|
||||
gap: spacing[12],
|
||||
paddingHorizontal: spacing[12],
|
||||
paddingVertical: spacing[4],
|
||||
'@media screen and (max-width: 768px)': {
|
||||
display: 'flex',
|
||||
flexDirection: 'column-reverse',
|
||||
gap: 0,
|
||||
marginTop: spacing[0],
|
||||
marginBottom: spacing[0],
|
||||
paddingHorizontal: spacing[0],
|
||||
paddingBottom: spacing[0],
|
||||
},
|
||||
},
|
||||
});
|
||||
|
||||
export default function DemoPageLayout({children}: Props) {
|
||||
return <div {...stylex.props(styles.container)}>{children}</div>;
|
||||
}
|
91
demo/frontend/src/layouts/RootLayout.tsx
Normal file
91
demo/frontend/src/layouts/RootLayout.tsx
Normal file
@@ -0,0 +1,91 @@
|
||||
/**
|
||||
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
||||
*
|
||||
* 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 LoadingStateScreen from '@/common/loading/LoadingStateScreen';
|
||||
import useSettingsContext from '@/settings/useSettingsContext';
|
||||
import {Cog6ToothIcon} from '@heroicons/react/24/outline';
|
||||
import stylex from '@stylexjs/stylex';
|
||||
import {Suspense} from 'react';
|
||||
import {Button, Indicator} from 'react-daisyui';
|
||||
import {Outlet} from 'react-router-dom';
|
||||
|
||||
const styles = stylex.create({
|
||||
container: {
|
||||
display: 'flex',
|
||||
flexDirection: 'column',
|
||||
height: '100%',
|
||||
maxHeight: '100vh',
|
||||
backgroundColor: '#000',
|
||||
},
|
||||
content: {
|
||||
position: 'relative',
|
||||
flex: '1 1 0%',
|
||||
display: 'flex',
|
||||
flexDirection: 'column',
|
||||
overflowX: 'auto',
|
||||
overflowY: {
|
||||
default: 'auto',
|
||||
'@media screen and (max-width: 768px)': 'auto',
|
||||
},
|
||||
},
|
||||
debugActions: {
|
||||
display: 'flex',
|
||||
flexDirection: 'column',
|
||||
position: 'fixed',
|
||||
top: 100,
|
||||
right: 0,
|
||||
backgroundColor: 'white',
|
||||
borderRadius: 3,
|
||||
},
|
||||
});
|
||||
|
||||
export default function RootLayout() {
|
||||
const {openModal, hasChanged} = useSettingsContext();
|
||||
|
||||
return (
|
||||
<div {...stylex.props(styles.container)}>
|
||||
<div {...stylex.props(styles.content)}>
|
||||
<Suspense
|
||||
fallback={
|
||||
<LoadingStateScreen
|
||||
title="Loading demo..."
|
||||
description="This may take a few moments, you're almost there!"
|
||||
/>
|
||||
}>
|
||||
<Outlet />
|
||||
</Suspense>
|
||||
</div>
|
||||
<div {...stylex.props(styles.debugActions)}>
|
||||
<Indicator>
|
||||
{hasChanged && (
|
||||
<Indicator.Item
|
||||
className="badge badge-primary scale-50"
|
||||
horizontal="start"
|
||||
vertical="top"
|
||||
/>
|
||||
)}
|
||||
<Button
|
||||
color="ghost"
|
||||
onClick={openModal}
|
||||
shape="circle"
|
||||
size="xs"
|
||||
startIcon={<Cog6ToothIcon className="w-4 h-4" />}
|
||||
title="Bugnub"
|
||||
/>
|
||||
</Indicator>
|
||||
</div>
|
||||
</div>
|
||||
);
|
||||
}
|
Reference in New Issue
Block a user