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


TypeScript ramda.assoc函數代碼示例

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


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

示例1: async

    const setKeyValues = async (acc, entries) => {
        if (entries.length) return acc;
        const [[key, value], ...tail] = entries;

        const maybeValue = await formatData(key, value);
        const newAcc = maybeValue.map(assoc(key, __, acc)).getOrElse(acc);

        return await setKeyValues(newAcc, tail);
    };
開發者ID:benjambles,項目名稱:my-own-world,代碼行數:9,代碼來源:formatter.ts

示例2: update

 const noteDragMod$ = noteDrag$.map(({ id, x, y }) => (state: State) => {
   const update = R.compose<State, State, State>(
     R.set(
       R.lensPath(['notes', id, 'pos']),
       { x, y } as Position
     ),
     R.assoc('draggingNoteId', id)
   )
   return update(state)
 })
開發者ID:JamesHageman,項目名稱:xstream-scrumbler,代碼行數:10,代碼來源:index.ts

示例3: catch

export const jsonDecorator = ({
  modelName,
  fields,
}: {
  modelName: string;
  fields: (Fields & WithHidden) | PositionsField;
}): { modelName; fields: (Fields & WithHidden) | PositionsField } => {
  const TAG = '[jsonDecorator]';
  logger.log(TAG, { fields });

  const jsonFields = R.filter(R.pathEq(['options', 'json'], 'str'))(fields);
  if (R.not(R.isEmpty(jsonFields))) {
    logger.debug(TAG, { jsonFields });

    const toJson = value => {
      if (R.is(String, value) && value.length) {
        try {
          return JSON.parse(value);
        } catch (e) {
          logger.warn(TAG, e, { jsonFields });
          return null;
        }
      }
      if (R.is(Object, value)) {
        return value;
      }
      return null;
    };

    const transformValue = R.over(R.lens(R.prop('value'), R.assoc('value')), toJson);
    const transformedFields = R.map(transformValue)(jsonFields);
    const wrappedFields = R.mergeDeepRight(fields, transformedFields);

    logger.log(TAG, 'wrappedFields', { wrappedFields });
    return { modelName, fields: wrappedFields };
  }

  return { modelName, fields };
};
開發者ID:danielwii,項目名稱:asuna-admin,代碼行數:39,代碼來源:index.ts

示例4: assoc

 answer => assoc('id', Math.random().toString(36).substring(2), answer),
開發者ID:goodmind,項目名稱:cycle-telegram,代碼行數:1,代碼來源:sinks.ts

示例5: dispatch

  if (
    attacker.type === CardType.Hero &&
    attacker.weapon &&
    attacker.weapon.durability <= 0
  ) {
    dispatch(destroyWeapon({ id: attacker.id }));
  }

  if (shouldExhaust(attacker)) {
    dispatch(exhaust({ id: attacker.id }));
  }

  dispatch(processDeaths());
  dispatch(checkForEndGame());
};

const exhaustHandler = R.assoc<keyof Character, boolean>('exhausted', true);

export default (state: Character, action: Action<EntityPayload<Object>>) => {
  if (isType(action, exhaust)) {
    return reducerWithoutInitialState<Character>().case(
      exhaust,
      exhaustHandler
    )(state, action);
  }

  return state.type === CardType.Minion
    ? minionReducer(state, action)
    : heroReducer(state, action);
};
開發者ID:zernie,項目名稱:typescript-redux-card-game,代碼行數:30,代碼來源:characterReducer.ts

示例6: assoc

 (updatedItemsById, config) => assoc(String(config.id), config, updatedItemsById),
開發者ID:displague,項目名稱:manager,代碼行數:1,代碼來源:nodeBalancerConfig.reducer.ts

示例7:

 const noteEditStartMod$ = noteEditId$.map(id => (state: State) => {
   if (state.editingNoteId === id) {
     return state
   }
   return R.assoc('editingNoteId', id, state) as State
 })
開發者ID:JamesHageman,項目名稱:xstream-scrumbler,代碼行數:6,代碼來源:index.ts

示例8: path

  // Idx = String | Int
  path(fieldsLevelArr, obj) {
    return R.path(fieldsLevelArr, obj)
  },
  pathOr(defaultVal, fieldsLevelArr, obj) {
    return R.path(defaultVal, fieldsLevelArr, obj)
  },
  // pick :: [k] → {k: v} → {k: v}
  pick(fieldsArr, obj) {
    return R.pick(fieldsArr, obj)
  },

  // assoc/assocPath
  // assoc :: String → a → {k: v} → {k: v}
  assoc(field, val, obj) {
    return R.assoc(field, val, obj)
  },
  // [Idx] → a → {a} → {a}
  // Idx = String | Int
  assocPath(fieldsLevelArr, val, obj) {
    return R.assocPath(fieldsLevelArr, val, obj)
  },

  // dissoc/dissocPath
  // String → {k: v} → {k: v}
  dissoc(field, val, obj) {
    return R.dissoc(field, val, obj)
  },
  // [Idx] → {k: v} → {k: v}
  // Idx = String | Int
  dissocPath(fieldsLevelArr, obj) {
開發者ID:stefaniepei,項目名稱:react-redux-scaffold,代碼行數:31,代碼來源:ramda.ts

示例9:

  GainManaPayload,
  restoreMana,
  spendMana,
  SpendManaPayload,
} from './actions';
import { PlayState } from '../../../enums';

const maximumManaLens = R.lensProp<number, Hero>('maximumMana');
const manaLens = R.lensProp<number, Hero>('mana');

const attackCharacterHandler = R.evolve<Hero>({
  attacksPerformed: R.inc,
  weapon: { durability: R.dec },
});

const destroyWeaponHandler = R.assoc<keyof Hero, null>('weapon', null);

const equipWeaponHandler = (state: Hero, payload: EquipWeaponPayload) =>
  R.merge<Hero, {}>(state, {
    attack: payload.weapon.attack,
    weapon: payload.weapon,
  });

const gainManaHandler = (state: Hero, payload: GainManaPayload) =>
  state.maximumMana < 10
    ? R.over(maximumManaLens, R.add(payload.amount || 1), state)
    : state;

const restoreManaHandler = (state: Hero) =>
  R.set(manaLens, R.view(maximumManaLens, state), state);
開發者ID:zernie,項目名稱:typescript-redux-card-game,代碼行數:30,代碼來源:heroReducer.ts


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