52637c59e0
* add button to the toolbar to switch palm rejection mode * add a message for that new button to the locales/en * add boolean palmRejection to state of the toolbar * save that boolean also to the session storage, so it is ready to use it in the input handler
126 lines
3.8 KiB
JavaScript
126 lines
3.8 KiB
JavaScript
import { makeCall } from '/imports/ui/services/api';
|
|
import Storage from '/imports/ui/services/storage/session';
|
|
import Users from '/imports/api/users';
|
|
import Auth from '/imports/ui/services/auth';
|
|
import getFromUserSettings from '/imports/ui/services/users-settings';
|
|
|
|
const DRAW_SETTINGS = 'drawSettings';
|
|
const PALM_REJECTION_MODE = 'palmRejectionMode';
|
|
const WHITEBOARD_TOOLBAR = Meteor.settings.public.whiteboard.toolbar;
|
|
|
|
const makeSetter = key => (value) => {
|
|
const drawSettings = Storage.getItem(DRAW_SETTINGS);
|
|
if (drawSettings) {
|
|
drawSettings[key] = value;
|
|
Storage.setItem(DRAW_SETTINGS, drawSettings);
|
|
}
|
|
};
|
|
|
|
const undoAnnotation = (whiteboardId) => {
|
|
makeCall('undoAnnotation', whiteboardId);
|
|
};
|
|
|
|
const clearWhiteboard = (whiteboardId) => {
|
|
makeCall('clearWhiteboard', whiteboardId);
|
|
};
|
|
|
|
const changeWhiteboardMode = (multiUser, whiteboardId) => {
|
|
makeCall('changeWhiteboardAccess', multiUser, whiteboardId);
|
|
};
|
|
|
|
const getCurrentPalmRejectionMode = () => Storage.getItem(PALM_REJECTION_MODE);
|
|
|
|
const setInitialPalmRejectionMode = (palmRejectionMode) => {
|
|
const _palmRejectionMode = Storage.getItem(PALM_REJECTION_MODE);
|
|
if (!_palmRejectionMode) {
|
|
Storage.setItem(PALM_REJECTION_MODE, palmRejectionMode);
|
|
}
|
|
};
|
|
|
|
const setPalmRejectionMode = (palmRejectionMode) => {
|
|
Storage.setItem(PALM_REJECTION_MODE, palmRejectionMode);
|
|
};
|
|
|
|
const setInitialWhiteboardToolbarValues = (tool, thickness, color, fontSize, textShape) => {
|
|
const _drawSettings = Storage.getItem(DRAW_SETTINGS);
|
|
if (!_drawSettings) {
|
|
const drawSettings = {
|
|
whiteboardAnnotationTool: tool,
|
|
whiteboardAnnotationThickness: thickness,
|
|
whiteboardAnnotationColor: color,
|
|
textFontSize: fontSize,
|
|
textShape,
|
|
};
|
|
Storage.setItem(DRAW_SETTINGS, drawSettings);
|
|
}
|
|
};
|
|
|
|
const getCurrentDrawSettings = () => Storage.getItem(DRAW_SETTINGS);
|
|
|
|
const setFontSize = makeSetter('textFontSize');
|
|
|
|
const setTool = makeSetter('whiteboardAnnotationTool');
|
|
|
|
const setThickness = makeSetter('whiteboardAnnotationThickness');
|
|
|
|
const setColor = makeSetter('whiteboardAnnotationColor');
|
|
|
|
const setTextShapeObject = makeSetter('textShape');
|
|
|
|
const getTextShapeActiveId = () => {
|
|
const drawSettings = Storage.getItem(DRAW_SETTINGS);
|
|
return drawSettings ? drawSettings.textShape.textShapeActiveId : '';
|
|
};
|
|
|
|
const isPresenter = () => {
|
|
const currentUser = Users.findOne({ userId: Auth.userID }, { fields: { presenter: 1 } });
|
|
return currentUser ? currentUser.presenter : false;
|
|
};
|
|
|
|
const filterAnnotationList = () => {
|
|
const multiUserPenOnly = getFromUserSettings('bbb_multi_user_pen_only', WHITEBOARD_TOOLBAR.multiUserPenOnly);
|
|
const amIPresenter = isPresenter();
|
|
|
|
let filteredAnnotationList = WHITEBOARD_TOOLBAR.tools;
|
|
|
|
if (!amIPresenter && multiUserPenOnly) {
|
|
filteredAnnotationList = [{
|
|
icon: 'pen_tool',
|
|
value: 'pencil',
|
|
}];
|
|
}
|
|
|
|
const presenterTools = getFromUserSettings('bbb_presenter_tools', WHITEBOARD_TOOLBAR.presenterTools);
|
|
if (amIPresenter && Array.isArray(presenterTools)) {
|
|
filteredAnnotationList = WHITEBOARD_TOOLBAR.tools.filter(el =>
|
|
presenterTools.includes(el.value));
|
|
}
|
|
|
|
const multiUserTools = getFromUserSettings('bbb_multi_user_tools', WHITEBOARD_TOOLBAR.multiUserTools);
|
|
if (!amIPresenter && !multiUserPenOnly && Array.isArray(multiUserTools)) {
|
|
filteredAnnotationList = WHITEBOARD_TOOLBAR.tools.filter(el =>
|
|
multiUserTools.includes(el.value));
|
|
}
|
|
|
|
return filteredAnnotationList;
|
|
};
|
|
|
|
export default {
|
|
undoAnnotation,
|
|
clearWhiteboard,
|
|
changeWhiteboardMode,
|
|
getCurrentPalmRejectionMode,
|
|
setInitialPalmRejectionMode,
|
|
setPalmRejectionMode,
|
|
setInitialWhiteboardToolbarValues,
|
|
getCurrentDrawSettings,
|
|
setFontSize,
|
|
setTool,
|
|
setThickness,
|
|
setColor,
|
|
setTextShapeObject,
|
|
getTextShapeActiveId,
|
|
isPresenter,
|
|
filterAnnotationList,
|
|
};
|