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


TypeScript katamari.Future類代碼示例

本文整理匯總了TypeScript中@ephox/katamari.Future的典型用法代碼示例。如果您正苦於以下問題:TypeScript Future類的具體用法?TypeScript Future怎麽用?TypeScript Future使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: function

  const check = function (label, initial, destination, amount) {
    return Future.nu(function (callback) {
      let current = initial;
      let values = [ current ];

      const add = function (val, abort) {
        if (val > 100) {
          abort('abort');
        } else {
          current = val;
          values = values.concat([ val ]);
        }
      };

      animator.animate(function () {
        return current;
      }, destination, amount, add, function (s) {
        add(s, Fun.identity);
        callback({
          label,
          info: {
            current,
            values
          }
        });
      }, 2);
    });
  };
開發者ID:aha-app,項目名稱:tinymce-word-paste-filter,代碼行數:28,代碼來源:AsyncSmoothAnimationTest.ts

示例2: function

const moveOnlyScroll = function (element, destination) {
  return Future.nu(function (callback) {
    const getCurrent = Fun.curry(getScrollTop, element);
    Attr.set(element, lastScroll, getCurrent());

    const update = function (newScroll, abort) {
      const previous = DataAttributes.safeParse(element, lastScroll);
      // As soon as we detect a scroll value that we didn't set, assume the user
      // is scrolling, and abort the scrolling.
      if (previous !== element.dom().scrollTop) {
        abort(element.dom().scrollTop);
      } else {
        element.dom().scrollTop = newScroll;
        Attr.set(element, lastScroll, newScroll);
      }
    };

    const finish = function (/* dest */) {
      element.dom().scrollTop = destination;
      Attr.set(element, lastScroll, destination);
      callback(destination);
    };

    // Identify the number of steps based on distance (consistent time)
    const distance = Math.abs(destination - getCurrent());
    const step = Math.ceil(distance / NUM_TOP_ANIMATION_FRAMES);
    animator.animate(getCurrent, destination, step, update, finish, ANIMATION_RATE);
  });
};
開發者ID:abstask,項目名稱:tinymce,代碼行數:29,代碼來源:IosScrolling.ts

示例3: createPartialChoiceMenu

 fetch: (comp) => {
   return Future.nu((callback) => {
     return spec.fetch(callback);
   }).map((items) => {
     return Option.from(createTieredDataFrom(
       Merger.deepMerge(
         createPartialChoiceMenu(
           Id.generate('menu-value'),
           items,
           (value) => {
             spec.onItemAction(comp, value);
           },
           spec.columns,
           spec.presets,
           ItemResponse.CLOSE_ON_EXECUTE,
           // No colour is ever selected on opening
           () => false,
           sharedBackstage.providers
         ),
         {
           movement: deriveMenuMovement(spec.columns, spec.presets)
         }
       )
     ));
   });
 },
開發者ID:tinymce,項目名稱:tinymce,代碼行數:26,代碼來源:PanelButton.ts

示例4: return

 return (comp: AlloyComponent): Future<Option<TieredData>> => {
   return Future.nu((callback) => {
     return spec.fetch(callback);
   }).map((items) => {
     return Option.from(createTieredDataFrom(
       Merger.deepMerge(
         createPartialChoiceMenu(
           Id.generate('menu-value'),
           items,
           (value) => {
             spec.onItemAction(getApi(comp), value);
           },
           spec.columns,
           spec.presets,
           ItemResponse.CLOSE_ON_EXECUTE,
           spec.select.getOr(() => false),
           providersBackstage
         ),
         {
           movement: deriveMenuMovement(spec.columns, spec.presets),
           menuBehaviours: SimpleBehaviours.unnamedEvents(spec.columns !== 'auto' ? [ ] : [
             AlloyEvents.runOnAttached((comp, se) => {
               detectSize(comp, 4, classForPreset(spec.presets)).each(({ numRows, numColumns }) => {
                 Keying.setGridSize(comp, numRows, numColumns);
               });
             })
           ])
         } as TieredMenuTypes.PartialMenuSpec
       )
     ));
   });
 };
開發者ID:tinymce,項目名稱:tinymce,代碼行數:32,代碼來源:ToolbarButtons.ts

示例5: function

 const loadF = function (url) {
   return Future.nu(function (resolve) {
     load(
       url,
       Fun.compose(resolve, Fun.constant(Result.value(url))),
       Fun.compose(resolve, Fun.constant(Result.error(url)))
     );
   });
 };
開發者ID:tinymce,項目名稱:tinymce,代碼行數:9,代碼來源:StyleSheetLoader.ts

示例6:

          validate: (input) => {
            const inputValue = Representing.getValue(input);
            // Consider empty strings valid colours
            if (inputValue.length === 0) {
              return Future.pure(Result.value(true));
            } else {
              const span = Element.fromTag('span');
              Css.set(span, 'background-color', inputValue);

              const res = Css.getRaw(span, 'background-color').fold(
                // TODO: Work out what we want to do here.
                () => Result.error('blah'),
                (_) => Result.value(inputValue)
              );

              return Future.pure(res);
            }
          }
開發者ID:tinymce,項目名稱:tinymce,代碼行數:18,代碼來源:ColorInput.ts

示例7: completer

const collect = (editor): Future<ImageDialogInfo> => {

  const urlListSanitizer = ListUtils.sanitizer((item) => {
    return editor.convertURL(item.value || item.url, 'src');
  });

  const futureImageList = Future.nu<Option<ListItem[]>>((completer) => {
    Utils.createImageList(editor, (imageList) => {
      completer(
        urlListSanitizer(imageList).map(
          (items) => Arr.flatten([
            [{ text: 'None', value: '' }],
            items
          ])
        )
      );
    });
  });
  const classList = ListUtils.sanitize(Settings.getClassList(editor));
  const hasAdvTab = Settings.hasAdvTab(editor);
  const hasUploadUrl = Settings.hasUploadUrl(editor);
  const hasUploadHandler = Settings.hasUploadHandler(editor);
  const image = readImageDataFromSelection(editor);
  const hasDescription = Settings.hasDescription(editor);
  const hasImageTitle = Settings.hasImageTitle(editor);
  const hasDimensions = Settings.hasDimensions(editor);
  const hasImageCaption = Settings.hasImageCaption(editor);
  const url = Settings.getUploadUrl(editor);
  const basePath = Settings.getUploadBasePath(editor);
  const credentials = Settings.getUploadCredentials(editor);
  const handler = Settings.getUploadHandler(editor);
  const prependURL: Option<string> = Option.some(Settings.getPrependUrl(editor)).filter(
    (preUrl) => Type.isString(preUrl) && preUrl.length > 0);

  return futureImageList.map((imageList): ImageDialogInfo => {
    return {
      image,
      imageList,
      classList,
      hasAdvTab,
      hasUploadUrl,
      hasUploadHandler,
      hasDescription,
      hasImageTitle,
      hasDimensions,
      hasImageCaption,
      url,
      basePath,
      credentials,
      handler,
      prependURL
    };
  });
};
開發者ID:tinymce,項目名稱:tinymce,代碼行數:54,代碼來源:DialogInfo.ts

示例8: resolve

  return Futures.mapM(items, (item: any) => {
    return Future.nu((resolve) => {
      const blob = item.getAsFile ? item.getAsFile() : item;

      const reader = new window.FileReader();
      reader.onload = () => {
        resolve({
          blob,
          uri: reader.result
        });
      };
      reader.readAsDataURL(blob);
    });
  });
開發者ID:mdgbayly,項目名稱:tinymce,代碼行數:14,代碼來源:Clipboard.ts

示例9: makeDialog

const open = function (editor: Editor) {
  const data = collectData(editor);
  data.map((info) => {
    const onSubmit = handleSubmit(editor, info, Settings.assumeExternalTargets(editor.settings));
    return makeDialog(info, onSubmit, editor.settings);
  }).get((spec) => {
    editor.windowManager.open(spec);
  });
};
開發者ID:tinymce,項目名稱:tinymce,代碼行數:9,代碼來源:Dialog.ts


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