61 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
/*
 | 
						|
 * Copyright 2025 coze-dev Authors
 | 
						|
 *
 | 
						|
 * 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 React, { useRef, useCallback } from 'react';
 | 
						|
 | 
						|
import type { OnMount } from '../src/types';
 | 
						|
import { Editor, DiffEditor } from '../src';
 | 
						|
export function DemoComponent(): JSX.Element {
 | 
						|
  const editorRef = useRef({});
 | 
						|
 | 
						|
  const handleEditorDidMount = useCallback<OnMount>(editor => {
 | 
						|
    editorRef.current = editor;
 | 
						|
  }, []);
 | 
						|
  return (
 | 
						|
    <div>
 | 
						|
      Editor:
 | 
						|
      <Editor
 | 
						|
        width="50vw"
 | 
						|
        height="90vh"
 | 
						|
        defaultLanguage="javascript"
 | 
						|
        defaultValue="// some comment"
 | 
						|
        onMount={handleEditorDidMount}
 | 
						|
      />
 | 
						|
      DiffEditor:
 | 
						|
      <DiffEditor
 | 
						|
        width="50vw"
 | 
						|
        height="90vh"
 | 
						|
        language="javascript"
 | 
						|
        original="// the original code"
 | 
						|
        modified="// the modified code"
 | 
						|
      />
 | 
						|
    </div>
 | 
						|
  );
 | 
						|
}
 | 
						|
 | 
						|
export default {
 | 
						|
  title: 'MonacoEditorDemo',
 | 
						|
  component: DemoComponent,
 | 
						|
  parameters: {
 | 
						|
    layout: 'centered',
 | 
						|
  },
 | 
						|
  argTypes: {},
 | 
						|
};
 | 
						|
 | 
						|
export const Base = {
 | 
						|
  args: {},
 | 
						|
};
 |