Skip to content

Commit

Permalink
fixup! Update useEditor
Browse files Browse the repository at this point in the history
  • Loading branch information
TatianaFomina committed Feb 23, 2024
1 parent 79ed26e commit a56e1d3
Show file tree
Hide file tree
Showing 3 changed files with 31 additions and 34 deletions.
48 changes: 15 additions & 33 deletions src/application/services/useEditor.ts
Original file line number Diff line number Diff line change
@@ -1,20 +1,20 @@
import type { BlockTool } from '@editorjs/editorjs';
import Editor, { type OutputData, type API } from '@editorjs/editorjs';
// @ts-expect-error editor plugins have no types
import Header from '@editorjs/header';
import type { Ref } from 'vue';
import { onBeforeUnmount, onMounted } from 'vue';
import { useAppState } from './useAppState';
import type EditorTool from '@/domain/entities/EditorTool';
import { loadScript } from '@/infrastructure/utils/load-script';

/**
* Editor.js tool
*/
type Tool = any;

/**
* Editorjs params
* UseEditor composable params
*/
interface UseEditorParams {
/** Host element id */
/**
* Host element id
*/
id: string;

/**
Expand All @@ -33,21 +33,6 @@ interface UseEditorParams {
onChange?: (api: API) => void;
}

/**
* Add promise which is rejected after loading is complete
*
* @param src - source path to tool
*/
function loadScript(src: string): Promise<Event> {
return new Promise(function (resolve, reject) {
const script = document.createElement('script');

script.src = src;
script.onload = resolve;
script.onerror = reject;
document.head.appendChild(script);
});
}

/**
* Handles Editor.js instance creation
Expand All @@ -70,32 +55,29 @@ export function useEditor({ id, content, isReadOnly, onChange }: UseEditorParams
*
* @param tool - tool - data
*/
async function downloadTool(tool: EditorTool): Promise<[string, Tool] | undefined> {
async function downloadTool(tool: EditorTool): Promise<Record<string, BlockTool> | undefined> {
if (tool.source.cdn === undefined) {
return;
}

await loadScript(tool.source.cdn);

return [tool.title, window[tool.exportName]];
return { [tool.title]: window[tool.exportName as keyof typeof window] };
}

/**
* Download all the user tools
*
* @param tools - tools data
*/
async function downloadTools(tools: Ref<EditorTool[]>): Promise<Record<string, Tool>> {
async function downloadTools(tools: Ref<EditorTool[]>): Promise<Record<string, BlockTool> | undefined> {
const toolsData = await Promise.all(tools.value.map(downloadTool));

return toolsData.reduce((acc, curr) => {
if (curr === undefined) {
return acc;
}
const name = curr[0];
const obj = curr[1];

acc[name] = obj;
return toolsData.filter(item => item !== undefined).reduce((acc, curr) => {
return {
...acc,
...curr,
};

return acc;
}, {});
Expand Down
15 changes: 15 additions & 0 deletions src/infrastructure/utils/load-script.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
/**
* Loads script by specified url
*
* @param src - script source url
*/
export function loadScript(src: string): Promise<Event> {
return new Promise(function (resolve, reject) {
const script = document.createElement('script');

script.src = src;
script.onload = resolve;
script.onerror = reject;
document.head.appendChild(script);
});
}
2 changes: 1 addition & 1 deletion src/presentation/components/editor/Editor.vue
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
<script setup lang="ts">
import { ref } from 'vue';
import { type OutputData, type API } from '@editorjs/editorjs';
import { useEditor } from '@/application/services/useEditor2';
import { useEditor } from '@/application/services/useEditor';
/**
* Define the props for the component
Expand Down

0 comments on commit a56e1d3

Please sign in to comment.