當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript GuiFactory.build方法代碼示例

本文整理匯總了TypeScript中@ephox/alloy.GuiFactory.build方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript GuiFactory.build方法的具體用法?TypeScript GuiFactory.build怎麽用?TypeScript GuiFactory.build使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在@ephox/alloy.GuiFactory的用法示例。


在下文中一共展示了GuiFactory.build方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: renderColorInput

 (store, doc, body) => {
   return GuiFactory.build(
     Container.sketch({
       dom: {
         classes: [ 'colorinput-container' ]
       },
       components: [
         renderColorInput({
           type: 'colorinput',
           name: 'alpha',
           label: Option.some('test-color-input'),
         }, helpers.shared, {
           colorPicker: (callback, value) => {},
           hasCustomColors: () => true,
           getColors: () => [
             { type: choiceItem, text: 'Turquoise', value: '#18BC9B' },
             { type: choiceItem, text: 'Green', value: '#2FCC71' },
             { type: choiceItem, text: 'Blue', value: '#3598DB' },
             { type: choiceItem, text: 'Purple', value: '#9B59B6' },
             { type: choiceItem, text: 'Navy Blue', value: '#34495E' }
           ],
           getColorCols: () => 3
         })
       ]
     })
   );
 },
開發者ID:tinymce,項目名稱:tinymce,代碼行數:27,代碼來源:ColorInputTest.ts

示例2:

const makeCell = (row, col, labelId) => {
  const emitCellOver = (c) => AlloyTriggers.emitWith(c, cellOverEvent, {row, col} );
  const emitExecute = (c) => AlloyTriggers.emitWith(c, cellExecuteEvent, {row, col} );

  return GuiFactory.build({
    dom: {
      tag: 'div',
      attributes: {
        role: 'button',
        ['aria-labelledby']: labelId
      }
    },
    behaviours: Behaviour.derive([
      AddEventsBehaviour.config('insert-table-picker-cell', [
        AlloyEvents.run(NativeEvents.mouseover(), Focusing.focus),
        AlloyEvents.run(SystemEvents.execute(), emitExecute),
        AlloyEvents.run(SystemEvents.tapOrClick(), emitExecute)
      ]),
      Toggling.config({
        toggleClass: 'tox-insert-table-picker__selected',
        toggleOnExecute: false
      }),
      Focusing.config({onFocus: emitCellOver})
    ])
  });
};
開發者ID:tinymce,項目名稱:tinymce,代碼行數:26,代碼來源:InsertTableMenuItem.ts

示例3: renderDropZone

 (store, doc, body) => {
   return GuiFactory.build(
     renderDropZone({
       type: 'dropzone',
       name: 'drop1',
       label: Option.some('Dropzone Label'),
     }, TestProviders)
   );
 },
開發者ID:tinymce,項目名稱:tinymce,代碼行數:9,代碼來源:DropzoneTest.ts

示例4: renderHtmlPanel

 (store, doc, body) => {
   return GuiFactory.build(
     renderHtmlPanel({
       type: 'htmlpanel',
       html: '<br /><br /><hr />',
       presets: 'presentation'
     })
   );
 },
開發者ID:tinymce,項目名稱:tinymce,代碼行數:9,代碼來源:HtmlPanelTest.ts

示例5: renderColorPicker

 (store, doc, body) => {
   return GuiFactory.build(
     renderColorPicker({
       type: 'colorpicker',
       label: Option.some('ColorPicker label'),
       name: 'col1'
     })
   );
 },
開發者ID:tinymce,項目名稱:tinymce,代碼行數:9,代碼來源:ColorPickerTest.ts

示例6: getNodeAnchor

export const setup = (editor: Editor, lazySink: () => Result<AlloyComponent, Error>, backstage: UiFactoryBackstage) => {
  const contextmenu = GuiFactory.build(
    InlineView.sketch({
      dom: {
        tag: 'div',
      },
      lazySink,
      onEscape: () => editor.focus(),
      fireDismissalEventInstead: { },
      inlineBehaviours: Behaviour.derive([
        AddEventsBehaviour.config('dismissContextMenu', [
          AlloyEvents.run(SystemEvents.dismissRequested(), (comp, se) => {
            Sandboxing.close(comp);
            editor.focus();
          })
        ])
      ])
    }),
  );

  editor.on('init', () => {
    editor.on('contextmenu', (e) => {
      if (isNativeOverrideKeyEvent(editor, e)) {
        return;
      }

      // Different browsers trigger the context menu from keyboards differently, so need to check both the button and target here
      // Chrome: button = 0 & target = the selection range node
      // Firefox: button = 0 & target = body
      // IE: button = 2 & target = body
      // Safari: N/A (Mac's don't expose a contextmenu keyboard shortcut)
      const isTriggeredByKeyboardEvent = e.button !== 2 || e.target === editor.getBody();
      const anchorSpec = isTriggeredByKeyboardEvent ? getNodeAnchor(editor) : getPointAnchor(editor, e);

      const registry = editor.ui.registry.getAll();
      const menuConfig = Settings.getContextMenu(editor);

      // Use the event target element for mouse clicks, otherwise fallback to the current selection
      const selectedElement = isTriggeredByKeyboardEvent ? editor.selection.getStart(true) : e.target as Element;

      const items = generateContextMenu(registry.contextMenus, menuConfig, selectedElement);

      NestedMenus.build(items, ItemResponse.CLOSE_ON_EXECUTE, backstage).map((menuData) => {
        e.preventDefault();

        // show the context menu, with items set to close on click
        InlineView.showMenuAt(contextmenu, anchorSpec, {
          menu: {
            markers: MenuParts.markers('normal')
          },
          data: menuData
        });
      });
    });
  });
};
開發者ID:tinymce,項目名稱:tinymce,代碼行數:56,代碼來源:SilverContextMenu.ts

示例7:

 memOverflow.getOpt(sink).fold(() => {
   // overflow isn't there yet ... so add it, and return the built thing
   const builtoverFlow = GuiFactory.build(memOverflow.asSpec());
   Attachment.attach(sink, builtoverFlow);
   Positioning.position(sink, toolbarSpec.backstage.shared.anchors.toolbarOverflow(), builtoverFlow);
   SplitAlloyToolbar.refresh(toolbar);
   SplitAlloyToolbar.getMoreButton(toolbar).each(Focusing.focus);
   Keying.focusIn(builtoverFlow);
   // return builtoverFlow;
 }, (builtOverflow) => {
開發者ID:tinymce,項目名稱:tinymce,代碼行數:10,代碼來源:CommonToolbar.ts

示例8: renderSizeInput

 (store, doc, body) => {
   return GuiFactory.build(
     renderSizeInput({
       type: 'sizeinput',
       name: 'dimensions',
       label: Option.some('size'),
       constrain: true
     }, TestProviders)
   );
 },
開發者ID:tinymce,項目名稱:tinymce,代碼行數:10,代碼來源:SizeInputTest.ts

示例9: renderInput

 (store, doc, body) => {
   return GuiFactory.build(
     renderInput({
       name: 'input',
       label: Option.some('LabelA'),
       placeholder: Option.none(),
       validation: Option.none()
     }, TestProviders)
   );
 },
開發者ID:tinymce,項目名稱:tinymce,代碼行數:10,代碼來源:InputTest.ts

示例10: renderIFrame

 (store, doc, body) => {
   return GuiFactory.build(
     renderIFrame({
       type: 'iframe',
       name: 'frame-a',
       label: Option.some('iframe label'),
       sandboxed: true
     }, TestProviders)
   );
 },
開發者ID:tinymce,項目名稱:tinymce,代碼行數:10,代碼來源:IframeTest.ts


注:本文中的@ephox/alloy.GuiFactory.build方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。