@idraw/core
Advanced tools
Comparing version 0.4.0-beta.2 to 0.4.0-beta.3
@@ -7,2 +7,3 @@ import type { Data, PointSize, CoreOptions, BoardMiddleware, ViewSizeInfo, CoreEvent, ViewScaleInfo } from '@idraw/types'; | ||
export { MiddlewareTextEditor, middlewareEventTextEdit } from './middleware/text-editor'; | ||
export { MiddlewareDragger } from './middleware/dragger'; | ||
export declare class Core<E extends CoreEvent = CoreEvent> { | ||
@@ -12,2 +13,3 @@ #private; | ||
use(middleware: BoardMiddleware<any, any>): void; | ||
disuse(middleware: BoardMiddleware<any, any>): void; | ||
setData(data: Data): void; | ||
@@ -14,0 +16,0 @@ getData(): Data | null; |
@@ -14,3 +14,3 @@ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) { | ||
import { Board } from '@idraw/board'; | ||
import { createViewContent, validateElements } from '@idraw/util'; | ||
import { createBoardContent, validateElements } from '@idraw/util'; | ||
import { Cursor } from './lib/cursor'; | ||
@@ -22,2 +22,3 @@ export { MiddlewareSelector, middlewareEventSelect } from './middleware/selector'; | ||
export { MiddlewareTextEditor, middlewareEventTextEdit } from './middleware/text-editor'; | ||
export { MiddlewareDragger } from './middleware/dragger'; | ||
export class Core { | ||
@@ -33,4 +34,4 @@ constructor(container, opts) { | ||
container.appendChild(canvas); | ||
const viewContent = createViewContent(canvas, { width, height, devicePixelRatio, offscreen: true }); | ||
const board = new Board({ viewContent, container }); | ||
const boardContent = createBoardContent(canvas, { width, height, devicePixelRatio, offscreen: true }); | ||
const board = new Board({ boardContent, container }); | ||
const sharer = board.getSharer(); | ||
@@ -54,2 +55,5 @@ sharer.setActiveViewSizeInfo({ | ||
} | ||
disuse(middleware) { | ||
__classPrivateFieldGet(this, _Core_board, "f").disuse(middleware); | ||
} | ||
setData(data) { | ||
@@ -56,0 +60,0 @@ validateElements((data === null || data === void 0 ? void 0 : data.elements) || []); |
export declare const CURSOR = ""; | ||
export declare const CURSOR_RESIZE = ""; | ||
export declare const CURSOR_DRAG_DEFAULT = ""; | ||
export declare const CURSOR_DRAG_ACTIVE = ""; |
export const CURSOR = ''; | ||
export const CURSOR_RESIZE = ''; | ||
export const CURSOR_DRAG_DEFAULT = ``; | ||
export const CURSOR_DRAG_ACTIVE = ``; |
import { limitAngle, loadImage, parseAngleToRadian } from '@idraw/util'; | ||
import { CURSOR, CURSOR_RESIZE } from './cursor-image'; | ||
import { CURSOR, CURSOR_RESIZE, CURSOR_DRAG_DEFAULT, CURSOR_DRAG_ACTIVE } from './cursor-image'; | ||
export class Cursor { | ||
@@ -9,2 +9,4 @@ constructor(container, opts) { | ||
auto: CURSOR, | ||
'drag-default': CURSOR_DRAG_DEFAULT, | ||
'drag-active': CURSOR_DRAG_ACTIVE, | ||
'rotate-0': CURSOR_RESIZE | ||
@@ -28,2 +30,8 @@ }; | ||
} | ||
else if (e.type === 'drag-default') { | ||
this._resetCursor('drag-default'); | ||
} | ||
else if (e.type === 'drag-active') { | ||
this._resetCursor('drag-active'); | ||
} | ||
else { | ||
@@ -30,0 +38,0 @@ this._resetCursor('auto'); |
@@ -5,8 +5,7 @@ import { getViewScaleInfoFromSnapshot, getViewSizeInfoFromSnapshot } from '@idraw/util'; | ||
export const MiddlewareRuler = (opts) => { | ||
const key = 'RULE'; | ||
const { viewContent, viewer, eventHub } = opts; | ||
const { helperContext, underContext } = viewContent; | ||
const { boardContent, viewer, eventHub } = opts; | ||
const { helperContext, underContext } = boardContent; | ||
let show = true; | ||
let showGrid = true; | ||
eventHub.on(middlewareEventRuler, (e) => { | ||
const rulerCallback = (e) => { | ||
if (typeof (e === null || e === void 0 ? void 0 : e.show) === 'boolean') { | ||
@@ -21,6 +20,10 @@ show = e.show; | ||
} | ||
}); | ||
}; | ||
return { | ||
mode: key, | ||
isDefault: true, | ||
use() { | ||
eventHub.on(middlewareEventRuler, rulerCallback); | ||
}, | ||
disuse() { | ||
eventHub.off(middlewareEventRuler, rulerCallback); | ||
}, | ||
beforeDrawFrame: ({ snapshot }) => { | ||
@@ -27,0 +30,0 @@ if (show === true) { |
import { formatNumber } from '@idraw/util'; | ||
export const middlewareEventScale = '@middleware/scale'; | ||
export const MiddlewareScaler = (opts) => { | ||
const key = 'SCALE'; | ||
const { viewer, sharer, eventHub } = opts; | ||
@@ -9,4 +8,2 @@ const maxScale = 50; | ||
return { | ||
mode: key, | ||
isDefault: true, | ||
wheelScale(e) { | ||
@@ -13,0 +10,0 @@ const { deltaY, point } = e; |
import { drawScroller, isPointInScrollThumb } from './util'; | ||
import { key, keyXThumbRect, keyYThumbRect, keyPrevPoint, keyActivePoint, keyActiveThumbType } from './config'; | ||
import { keyXThumbRect, keyYThumbRect, keyPrevPoint, keyActivePoint, keyActiveThumbType } from './config'; | ||
export const MiddlewareScroller = (opts) => { | ||
const { viewer, viewContent, sharer } = opts; | ||
const { helperContext } = viewContent; | ||
const { viewer, boardContent, sharer } = opts; | ||
const { helperContext } = boardContent; | ||
sharer.setSharedStorage(keyXThumbRect, null); | ||
@@ -45,3 +45,2 @@ sharer.setSharedStorage(keyYThumbRect, null); | ||
return { | ||
mode: key, | ||
wheel: (e) => { | ||
@@ -78,3 +77,3 @@ viewer.scroll({ | ||
}, | ||
pointEnd: (e) => { | ||
pointEnd: () => { | ||
const activeThumbType = sharer.getSharedStorage(keyActiveThumbType); | ||
@@ -81,0 +80,0 @@ clear(); |
import { calcElementsViewInfo, calcElementVertexesInGroup, calcElementQueueVertexesQueueInGroup, calcElementSizeController, rotatePointInGroup, getGroupQueueFromList, findElementsFromList, findElementsFromListByPositions } from '@idraw/util'; | ||
import { drawHoverVertexesWrapper, drawArea, drawListArea, drawGroupQueueVertexesWrappers, drawSelectedElementControllersVertexes } from './draw-wrapper'; | ||
import { getPointTarget, resizeElement, getSelectedListArea, calcSelectedElementsArea, isElementInGroup, isPointInViewActiveGroup, calcMoveInGroup } from './util'; | ||
import { key, keyActionType, keyResizeType, keyAreaStart, keyAreaEnd, keyGroupQueue, keyGroupQueueVertexesList, keyHoverElement, keyHoverElementVertexes, keySelectedElementList, keySelectedElementListVertexes, keySelectedElementController } from './config'; | ||
import { keyActionType, keyResizeType, keyAreaStart, keyAreaEnd, keyGroupQueue, keyGroupQueueVertexesList, keyHoverElement, keyHoverElementVertexes, keySelectedElementList, keySelectedElementListVertexes, keySelectedElementController } from './config'; | ||
import { middlewareEventTextEdit } from '../text-editor'; | ||
export const middlewareEventSelect = '@middleware/select'; | ||
export const MiddlewareSelector = (opts) => { | ||
const { viewer, sharer, viewContent, calculator, eventHub } = opts; | ||
const { helperContext } = viewContent; | ||
const { viewer, sharer, boardContent, calculator, eventHub } = opts; | ||
const { helperContext } = boardContent; | ||
let prevPoint = null; | ||
let inBusyMode = null; | ||
eventHub.on(middlewareEventSelect, ({ uuids, positions }) => { | ||
let elements = []; | ||
const actionType = sharer.getSharedStorage(keyActionType); | ||
const data = sharer.getActiveStorage('data'); | ||
if (positions && Array.isArray(positions)) { | ||
elements = findElementsFromListByPositions(positions, (data === null || data === void 0 ? void 0 : data.elements) || []); | ||
} | ||
else { | ||
elements = findElementsFromList(uuids, (data === null || data === void 0 ? void 0 : data.elements) || []); | ||
} | ||
let needRefresh = false; | ||
if (!actionType && elements.length === 1) { | ||
sharer.setSharedStorage(keyActionType, 'select'); | ||
needRefresh = true; | ||
} | ||
else if (actionType === 'select' && elements.length === 1) { | ||
needRefresh = true; | ||
} | ||
if (needRefresh) { | ||
const elem = elements[0]; | ||
const groupQueue = getGroupQueueFromList(elem.uuid, (data === null || data === void 0 ? void 0 : data.elements) || []); | ||
sharer.setSharedStorage(keyGroupQueue, groupQueue); | ||
updateSelectedElementList(elements); | ||
viewer.drawFrame(); | ||
} | ||
}); | ||
sharer.setSharedStorage(keyActionType, null); | ||
@@ -117,4 +91,35 @@ const getActiveElements = () => { | ||
clear(); | ||
const selectCallback = ({ uuids, positions }) => { | ||
let elements = []; | ||
const actionType = sharer.getSharedStorage(keyActionType); | ||
const data = sharer.getActiveStorage('data'); | ||
if (positions && Array.isArray(positions)) { | ||
elements = findElementsFromListByPositions(positions, (data === null || data === void 0 ? void 0 : data.elements) || []); | ||
} | ||
else { | ||
elements = findElementsFromList(uuids, (data === null || data === void 0 ? void 0 : data.elements) || []); | ||
} | ||
let needRefresh = false; | ||
if (!actionType && elements.length === 1) { | ||
sharer.setSharedStorage(keyActionType, 'select'); | ||
needRefresh = true; | ||
} | ||
else if (actionType === 'select' && elements.length === 1) { | ||
needRefresh = true; | ||
} | ||
if (needRefresh) { | ||
const elem = elements[0]; | ||
const groupQueue = getGroupQueueFromList(elem.uuid, (data === null || data === void 0 ? void 0 : data.elements) || []); | ||
sharer.setSharedStorage(keyGroupQueue, groupQueue); | ||
updateSelectedElementList(elements); | ||
viewer.drawFrame(); | ||
} | ||
}; | ||
return { | ||
mode: key, | ||
use() { | ||
eventHub.on(middlewareEventSelect, selectCallback); | ||
}, | ||
disuse() { | ||
eventHub.off(middlewareEventSelect, selectCallback); | ||
}, | ||
hover: (e) => { | ||
@@ -126,3 +131,3 @@ var _a, _b; | ||
const triggerCursor = (target) => { | ||
let cursor = target.type; | ||
const cursor = target.type; | ||
if (inBusyMode === null) { | ||
@@ -129,0 +134,0 @@ eventHub.trigger('cursor', { |
@@ -5,5 +5,4 @@ import { limitAngle, getDefaultElementDetailConfig } from '@idraw/util'; | ||
export const MiddlewareTextEditor = (opts) => { | ||
const key = 'SELECT'; | ||
const { eventHub, viewContent, viewer } = opts; | ||
const canvas = viewContent.boardContext.canvas; | ||
const { eventHub, boardContent, viewer } = opts; | ||
const canvas = boardContent.boardContext.canvas; | ||
const textarea = document.createElement('textarea'); | ||
@@ -133,3 +132,3 @@ const canvasWrapper = document.createElement('div'); | ||
}); | ||
eventHub.on(middlewareEventTextEdit, (e) => { | ||
const textEditCallback = (e) => { | ||
var _a; | ||
@@ -140,7 +139,11 @@ if ((e === null || e === void 0 ? void 0 : e.element) && ((_a = e === null || e === void 0 ? void 0 : e.element) === null || _a === void 0 ? void 0 : _a.type) === 'text') { | ||
showTextArea(e); | ||
}); | ||
}; | ||
return { | ||
mode: key, | ||
isDefault: true | ||
use() { | ||
eventHub.on(middlewareEventTextEdit, textEditCallback); | ||
}, | ||
disuse() { | ||
eventHub.off(middlewareEventTextEdit, textEditCallback); | ||
} | ||
}; | ||
}; |
{ | ||
"name": "@idraw/core", | ||
"version": "0.4.0-beta.2", | ||
"version": "0.4.0-beta.3", | ||
"description": "", | ||
@@ -24,9 +24,9 @@ "main": "dist/esm/index.js", | ||
"devDependencies": { | ||
"@idraw/types": "^0.4.0-beta.2" | ||
"@idraw/types": "^0.4.0-beta.3" | ||
}, | ||
"dependencies": {}, | ||
"peerDependencies": { | ||
"@idraw/board": "^0.4.0-beta.2", | ||
"@idraw/renderer": "^0.4.0-beta.2", | ||
"@idraw/util": "^0.4.0-beta.2" | ||
"@idraw/board": "^0.4.0-beta.3", | ||
"@idraw/renderer": "^0.4.0-beta.3", | ||
"@idraw/util": "^0.4.0-beta.3" | ||
}, | ||
@@ -33,0 +33,0 @@ "publishConfig": { |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is too big to display
481142
36
8267