/** * Copyright (c) Microsoft Corporation. * * 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 type { BrowserContextOptions } from '../../..'; import type * as types from '../types'; import type { LanguageGenerator, LanguageGeneratorOptions } from './types'; import type * as actions from '@recorder/actions'; export function generateCode(actions: actions.ActionInContext[], languageGenerator: LanguageGenerator, options: LanguageGeneratorOptions) { const header = languageGenerator.generateHeader(options); const footer = languageGenerator.generateFooter(options.saveStorage); const actionTexts = actions.map(a => languageGenerator.generateAction(a)).filter(Boolean); const text = [header, ...actionTexts, footer].join('\n'); return { header, footer, actionTexts, text }; } export function sanitizeDeviceOptions(device: any, options: BrowserContextOptions): BrowserContextOptions { // Filter out all the properties from the device descriptor. const cleanedOptions: Record = {}; for (const property in options) { if (JSON.stringify(device[property]) !== JSON.stringify((options as any)[property])) cleanedOptions[property] = (options as any)[property]; } return cleanedOptions; } export function toSignalMap(action: actions.Action) { let popup: actions.PopupSignal | undefined; let download: actions.DownloadSignal | undefined; let dialog: actions.DialogSignal | undefined; for (const signal of action.signals) { if (signal.name === 'popup') popup = signal; else if (signal.name === 'download') download = signal; else if (signal.name === 'dialog') dialog = signal; } return { popup, download, dialog, }; } export function toKeyboardModifiers(modifiers: number): types.SmartKeyboardModifier[] { const result: types.SmartKeyboardModifier[] = []; if (modifiers & 1) result.push('Alt'); if (modifiers & 2) result.push('ControlOrMeta'); if (modifiers & 4) result.push('ControlOrMeta'); if (modifiers & 8) result.push('Shift'); return result; } export function fromKeyboardModifiers(modifiers?: types.SmartKeyboardModifier[]): number { let result = 0; if (!modifiers) return result; if (modifiers.includes('Alt')) result |= 1; if (modifiers.includes('Control')) result |= 2; if (modifiers.includes('ControlOrMeta')) result |= 2; if (modifiers.includes('Meta')) result |= 4; if (modifiers.includes('Shift')) result |= 8; return result; } export function toClickOptionsForSourceCode(action: actions.ClickAction): types.MouseClickOptions { const modifiers = toKeyboardModifiers(action.modifiers); const options: types.MouseClickOptions = {}; if (action.button !== 'left') options.button = action.button; if (modifiers.length) options.modifiers = modifiers; // Do not render clickCount === 2 for dblclick. if (action.clickCount > 2) options.clickCount = action.clickCount; if (action.position) options.position = action.position; return options; }