本文整理匯總了TypeScript中@ephox/alloy.Toolbar.sketch方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript Toolbar.sketch方法的具體用法?TypeScript Toolbar.sketch怎麽用?TypeScript Toolbar.sketch使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類@ephox/alloy.Toolbar
的用法示例。
在下文中一共展示了Toolbar.sketch方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: getToolbarbehaviours
const renderToolbar = (toolbarSpec: ToolbarSpec) => {
const modeName: any = toolbarSpec.cyclicKeying ? 'cyclic' : 'acyclic';
return AlloyToolbar.sketch({
uid: toolbarSpec.uid,
dom: {
tag: 'div',
classes: ['tox-toolbar']
},
components: [
AlloyToolbar.parts().groups({})
],
toolbarBehaviours: getToolbarbehaviours(toolbarSpec, modeName, Option.none())
});
};
示例2: function
export default function () {
const makeGroup = function (gSpec) {
const scrollClass = gSpec.scrollable === true ? '${prefix}-toolbar-scrollable-group' : '';
return {
dom: UiDomFactory.dom('<div aria-label="' + gSpec.label + '" class="${prefix}-toolbar-group ' + scrollClass + '"></div>'),
tgroupBehaviours: Behaviour.derive([
AddEventsBehaviour.config('adhoc-scrollable-toolbar', gSpec.scrollable === true ? [
AlloyEvents.runOnInit(function (component, simulatedEvent) {
Css.set(component.element(), 'overflow-x', 'auto');
Scrollables.markAsHorizontal(component.element());
Scrollable.register(component.element());
})
] : [ ])
]),
components: [
Container.sketch({
components: [
ToolbarGroup.parts().items({ })
]
})
],
markers: {
itemClass: Styles.resolve('toolbar-group-item')
},
items: gSpec.items
};
};
const toolbar = GuiFactory.build(
Toolbar.sketch(
{
dom: UiDomFactory.dom('<div class="${prefix}-toolbar"></div>'),
components: [
Toolbar.parts().groups({ })
],
toolbarBehaviours: Behaviour.derive([
Toggling.config({
toggleClass: Styles.resolve('context-toolbar'),
toggleOnExecute: false,
aria: {
mode: 'none'
}
}),
Keying.config({
mode: 'cyclic'
})
]),
shell: true
}
)
);
const wrapper = GuiFactory.build(
Container.sketch({
dom: {
classes: [ Styles.resolve('toolstrip') ]
},
components: [
GuiFactory.premade(toolbar)
],
containerBehaviours: Behaviour.derive([
Toggling.config({
toggleClass: Styles.resolve('android-selection-context-toolbar'),
toggleOnExecute: false
})
])
})
);
const resetGroups = function () {
Toolbar.setGroups(toolbar, initGroups.get());
Toggling.off(toolbar);
};
const initGroups = Cell([ ]);
const setGroups = function (gs) {
initGroups.set(gs);
resetGroups();
};
const createGroups = function (gs) {
return Arr.map(gs, Fun.compose(ToolbarGroup.sketch, makeGroup));
};
const refresh = function () {
Toolbar.refresh(toolbar);
};
const setContextToolbar = function (gs) {
Toggling.on(toolbar);
Toolbar.setGroups(toolbar, gs);
};
const restoreToolbar = function () {
if (Toggling.isOn(toolbar)) {
resetGroups();
//.........這裏部分代碼省略.........
示例3: renderToolbarGroupCommon
const renderMoreToolbar = (toolbarSpec: ToolbarSpec) => {
const modeName: any = toolbarSpec.cyclicKeying ? 'cyclic' : 'acyclic';
const memOverflow = Memento.record(
AlloyToolbar.sketch({
dom: {
tag: 'div',
classes: ['tox-toolbar__overflow']
},
toolbarBehaviours: Behaviour.derive([
Keying.config({
// THIS IS USED FOR FLOATING AND NOT SLIDING
mode: 'cyclic',
onEscape: () => {
AlloyTriggers.emit(toolbarSpec.moreDrawerData.lazyToolbar(), 'alloy.toolbar.toggle');
Keying.focusIn(toolbarSpec.moreDrawerData.lazyMoreButton());
return Option.some(true);
}
})
])
})
);
const getOverflow = (toolbar) => {
return toolbarSpec.getSink().toOption().bind((sink) => {
return memOverflow.getOpt(sink).bind(
(overflow) => {
return SplitAlloyToolbar.getMoreButton(toolbar).bind((_moreButton) => {
if (overflow.getSystem().isConnected()) {
// you have the build thing, so just return it
Positioning.position(sink, toolbarSpec.backstage.shared.anchors.toolbarOverflow(), overflow);
return Option.some(overflow);
} else {
return Option.none();
}
});
}
);
});
};
const primary = SplitAlloyToolbar.parts().primary({
dom: {
tag: 'div',
classes: ['tox-toolbar__primary']
}
});
const splitToolbarComponents = toolbarSpec.moreDrawerData.floating ? [
primary
] : [
primary,
SplitAlloyToolbar.parts().overflow({
dom: {
tag: 'div',
classes: [ 'tox-toolbar__overflow' ]
}
})
];
return SplitAlloyToolbar.sketch({
uid: toolbarSpec.uid,
dom: {
tag: 'div',
classes: ['tox-toolbar-overlord']
},
floating: toolbarSpec.moreDrawerData.floating,
overflow: getOverflow,
parts: {
// This already knows it is a toolbar group
'overflow-group': renderToolbarGroupCommon({
title: Option.none(),
items: []
}),
'overflow-button': renderIconButtonSpec({
name: 'more',
icon: Option.some('more-drawer'),
disabled: false,
tooltip: Option.some('More...')
}, Option.none(), toolbarSpec.backstage.shared.providers)
},
components: splitToolbarComponents,
markers: {
openClass: 'tox-toolbar__overflow--open',
closedClass: 'tox-toolbar__overflow--closed',
growingClass: 'tox-toolbar__overflow--growing',
shrinkingClass: 'tox-toolbar__overflow--shrinking',
overflowToggledClass: ToolbarButtonClasses.Ticked
},
splitToolbarBehaviours: getToolbarbehaviours(toolbarSpec, modeName, Option.some(memOverflow))
});
};
示例4: function
export default function () {
const makeGroup = function (gSpec) {
const scrollClass = gSpec.scrollable === true ? '${prefix}-toolbar-scrollable-group' : '';
return {
dom: UiDomFactory.dom('<div aria-label="' + gSpec.label + '" class="${prefix}-toolbar-group ' + scrollClass + '"></div>'),
tgroupBehaviours: Behaviour.derive([
AddEventsBehaviour.config('adhoc-scrollable-toolbar', gSpec.scrollable === true ? [
AlloyEvents.runOnInit(function (component, simulatedEvent) {
Css.set(component.element(), 'overflow-x', 'auto');
Scrollables.markAsHorizontal(component.element());
Scrollable.register(component.element());
})
] : [ ])
]),
components: [
Container.sketch({
components: [
ToolbarGroup.parts().items({ })
]
})
],
markers: {
// TODO: Now that alloy isn't marking the items with the old
// itemClass here, this navigation probably doesn't work. But
// it's mobile. However, bluetooth keyboards will need to be fixed
// Essentially, all items put in the toolbar will need to be given
// this class if they are to be part of keyboard navigation
itemSelector: '.' + Styles.resolve('toolbar-group-item')
},
items: gSpec.items
};
};
const toolbar = GuiFactory.build(
Toolbar.sketch(
{
dom: UiDomFactory.dom('<div class="${prefix}-toolbar"></div>'),
components: [
Toolbar.parts().groups({ })
],
toolbarBehaviours: Behaviour.derive([
Toggling.config({
toggleClass: Styles.resolve('context-toolbar'),
toggleOnExecute: false,
aria: {
mode: 'none'
}
}),
Keying.config({
mode: 'cyclic'
})
]),
shell: true
}
)
) as AlloyComponent;
const wrapper = GuiFactory.build(
Container.sketch({
dom: {
classes: [ Styles.resolve('toolstrip') ]
},
components: [
GuiFactory.premade(toolbar)
],
containerBehaviours: Behaviour.derive([
Toggling.config({
toggleClass: Styles.resolve('android-selection-context-toolbar'),
toggleOnExecute: false
})
])
})
) as AlloyComponent;
const resetGroups = function () {
Toolbar.setGroups(toolbar, initGroups.get());
Toggling.off(toolbar);
};
const initGroups = Cell([ ]);
const setGroups = function (gs) {
initGroups.set(gs);
resetGroups();
};
const createGroups = function (gs) {
return Arr.map(gs, Fun.compose(ToolbarGroup.sketch, makeGroup));
};
const refresh = function () {
// Toolbar.refresh is undefined
// Toolbar.refresh(toolbar);
};
const setContextToolbar = function (gs) {
Toggling.on(toolbar);
//.........這裏部分代碼省略.........