本文整理匯總了TypeScript中@ephox/agar.Step類的典型用法代碼示例。如果您正苦於以下問題:TypeScript Step類的具體用法?TypeScript Step怎麽用?TypeScript Step使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了Step類的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: function
const sSetContent = function (editor, content, args) {
return Step.sync(function () {
SetSelectionContent.setContent(editor, content, args);
});
};
示例2: TestExtras
UnitTest.asynctest('WindowManager:inline-dialog Test', (success, failure) => {
const helpers = TestExtras();
const windowManager = WindowManager.setup(helpers.extras);
const store = TestHelpers.TestStore();
const currentApi = Cell<Types.Dialog.DialogInstanceApi<any>>({ } as any);
const sTestOpen = (params) => Chain.asStep({ }, [
Chain.mapper((_) => {
const dialogSpec: Types.Dialog.DialogApi<{ fred: string }> = {
title: 'Silver Test Inline (Toolbar) Dialog',
body: {
type: 'panel',
items: [
{
type: 'input',
name: 'fred',
label: 'Freds Input'
},
]
},
buttons: [
{
type: 'custom',
name: 'barny',
text: 'Barny Text',
align: 'start',
primary: true
},
],
initialData: {
fred: 'said hello pebbles'
},
onSubmit: store.adder('onSubmit'),
onClose: store.adder('onClose'),
onCancel: store.adder('onCancel'),
onChange: store.adder('onChange'),
onAction: store.adder('onAction')
};
return windowManager.open(dialogSpec, params, store.adder('closeWindow'));
}),
Chain.op((dialogApi) => {
Assertions.assertEq('Initial data', {
fred: 'said hello pebbles'
}, dialogApi.getData());
currentApi.set(dialogApi);
})
]);
const sTestClose = GeneralSteps.sequence([
Mouse.sClickOn(Body.body(), '[aria-label="Close"]'),
UiFinder.sNotExists(Body.body(), '[role="dialog"]')
]);
Pipeline.async({}, [
TestHelpers.GuiSetup.mAddStyles(Element.fromDom(document), [
'.tox-dialog { background: white; border: 2px solid black; padding: 1em; margin: 1em; }'
]),
sTestOpen({ inline: 'magic' }),
FocusTools.sTryOnSelector(
'Focus should start on the input',
Element.fromDom(document),
'input'
),
Step.sync(() => {
currentApi.get().disable('barny');
}),
sTestClose,
Waiter.sTryUntil(
'Waiting for all dialog events when closing',
store.sAssertEq('Checking stuff', [
'onCancel',
'closeWindow',
'onClose'
]),
100,
3000
),
store.sClear,
sTestOpen({ inline: 'toolbar' }),
FocusTools.sTryOnSelector(
'Focus should start on the input',
Element.fromDom(document),
'input'
),
Assertions.sAssertStructure('"tox-dialog__scroll-disable" should not have been added to the body',
ApproxStructure.build((s, str, arr) => {
return s.element('body', {
classes: [ arr.not('tox-dialog__disable-scroll') ]
});
}),
Body.body()
),
Step.sync(() => {
helpers.uiMothership.broadcastOn([ Channels.dismissPopups() ], {
//.........這裏部分代碼省略.........
示例3:
const sAnnotate = (editor: Editor, name: string, uid: string, data: { }) => Step.sync(() => {
editor.annotator.annotate(name, {
uid,
...data
});
});
示例4: function
const sDelete = function (editor) {
return Step.sync(function () {
DeleteCommands.deleteCommand(editor);
});
};
示例5: function
const sWaitForResizeHandles = function (editor) {
return Waiter.sTryUntil('Wait for new width value', Step.sync(function () {
RawAssertions.assertEq('Resize handle should exist', editor.dom.select('#mceResizeHandlenw').length, 1);
}), 1, 3000);
};
示例6: function
const sAssertScrollPosition = function (editor: Editor, x: number, y: number) {
return Step.sync(function () {
Assertions.assertEq('Scroll position X should be expected value', x, Math.round(editor.dom.getViewPort(editor.getWin()).x));
Assertions.assertEq('Scroll position Y should be expected value', y, Math.round(editor.dom.getViewPort(editor.getWin()).y));
});
};
示例7:
const sOpen = (toolbarKey: string) => Step.sync(() => {
editor.fire('contexttoolbar-show', {
toolbarKey
});
});
示例8: function
const sAssertNormalizeCounter = function (expected) {
return Step.sync(function () {
Assertions.assertEq('checking normalization counter', expected, count);
});
};
示例9: function
const sNormalizeBody = function (editor) {
return Step.sync(function () {
editor.getBody().normalize();
});
};
示例10: TinyApis
TinyLoader.setup(function (editor, onSuccess, onFailure) {
const tinyApis = TinyApis(editor);
const tinyActions = TinyActions(editor);
let count;
// hijack editor.selection.normalize() to count how many times it will be invoked
const backupNormalize = editor.selection.normalize;
const normalize = function () {
count = count === undefined ? 1 : count + 1;
backupNormalize.apply(this, arguments);
};
editor.selection.normalize = normalize;
const sResetNormalizeCounter = function () {
return Step.sync(function () {
count = 0;
});
};
const sAssertNormalizeCounter = function (expected) {
return Step.sync(function () {
Assertions.assertEq('checking normalization counter', expected, count);
});
};
const sClickBody = function (editor) {
return Step.sync(function () {
const target = editor.getBody();
editor.fire('mousedown', { target });
editor.fire('mouseup', { target });
editor.fire('click', { target });
});
};
Pipeline.async({}, [
tinyApis.sFocus,
Logger.t('Test normalization for floated images', GeneralSteps.sequence([
tinyApis.sSetContent('<p>a<img src="about:blank" style="float: right"></p>'),
tinyApis.sSetSelection([0], 1, [0], 2),
Step.sync(function () {
const selection = editor.selection.getSel();
Assertions.assertEq('Anchor node should be the paragraph not the text node', 'P', selection.anchorNode.nodeName);
Assertions.assertEq('Anchor offset should be the element index', 1, selection.anchorOffset);
})
])),
Logger.t('Normalize on key events when range is collapsed', GeneralSteps.sequence([
tinyApis.sSetContent('<p>a</p><p>b</p>'),
tinyApis.sSetSelection([], 1, [], 1),
tinyActions.sContentKeystroke(Keys.escape(), {}),
tinyApis.sAssertSelection([1, 0], 0, [1, 0], 0)
])),
Logger.t('Normalize on mouse events when range is expanded', GeneralSteps.sequence([
tinyApis.sSetContent('<p>a</p><p>b</p>'),
tinyApis.sSetSelection([], 0, [], 1),
sClickBody(editor),
tinyApis.sAssertSelection([0, 0], 0, [0, 0], 1)
])),
Logger.t('Normalize on mouse events when range is collapsed', GeneralSteps.sequence([
tinyApis.sSetContent('<p>a</p><p>b</p>'),
tinyApis.sSetSelection([], 1, [], 1),
sClickBody(editor),
tinyApis.sAssertSelection([1, 0], 0, [1, 0], 0)
])),
Logger.t('Normalization during operations with modifier keys, should run only once in the end when user releases modifier key.', GeneralSteps.sequence([
sResetNormalizeCounter(),
tinyApis.sSetContent('<p><b>a</b><i>a</i></p>'),
tinyApis.sSetSelection([0, 0, 0], 0, [0, 0], 0),
Keyboard.sKeyup(Element.fromDom(editor.getDoc()), Keys.left(), { shift: true }),
sAssertNormalizeCounter(0),
Keyboard.sKeyup(Element.fromDom(editor.getDoc()), 17, {}), // single ctrl
sAssertNormalizeCounter(1),
tinyApis.sAssertSelection([0, 0], 0, [0, 0], 0)
]))
], onSuccess, onFailure);
}, {