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


TypeScript lodash.countBy函數代碼示例

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


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

示例1: collateEntityIds

  private collateEntityIds(entityType: string, nonUniqueEntityIds: string[]): ICollatedIdGroup[] {
    const entityIds = uniq(nonUniqueEntityIds);
    const entityIdCounts = countBy(nonUniqueEntityIds);
    const baseUrlLength = `${SETTINGS.gateUrl}/tags?entityType=${entityType}&entityIds=`.length;
    const maxIdGroupLength = get(SETTINGS, 'entityTags.maxUrlLength', 4000) - baseUrlLength;
    const idGroups: ICollatedIdGroup[] = [];
    const joinedEntityIds = entityIds.join(',');
    const maxGroupSize = 100;

    if (joinedEntityIds.length > maxIdGroupLength) {
      let index = 0,
        currentLength = 0;
      const currentGroup: string[] = [];
      while (index < entityIds.length) {
        if (currentLength + entityIds[index].length + 1 > maxIdGroupLength || currentGroup.length === maxGroupSize) {
          idGroups.push(this.makeIdGroup(currentGroup, entityIdCounts));
          currentGroup.length = 0;
          currentLength = 0;
        }
        currentGroup.push(entityIds[index]);
        currentLength += entityIds[index].length + 1;
        index++;
      }
      if (currentGroup.length) {
        idGroups.push(this.makeIdGroup(currentGroup, entityIdCounts));
      }
    } else {
      idGroups.push(this.makeIdGroup(entityIds, entityIdCounts));
    }

    return idGroups;
  }
開發者ID:jcwest,項目名稱:deck,代碼行數:32,代碼來源:entityTags.read.service.ts

示例2: unmatch

export function unmatch(orbs: Orb[][], match: number[][]): Orb[][] {
    let intersections: number[][] = [];
    // it is a simple match if all of the coords have only 1 rowCoord or 1 colCoord
    let [rowCoords, colCoords] = _.zip(...match);
    let isSimpleMatch = _.uniq(rowCoords).length === 1 || _.uniq(colCoords).length === 1;
    if (isSimpleMatch) {
        // finds the median orb in the match
        let median = Math.floor(match.length / 2);
        let [midRow, midCol] = match[median];

        // Checks for a side-by-side match, which could cause and endless loop.
        // In that case, the skipToRandom argument in _unmatch is triggered.
        let midNeighbors: Orb[];
        if (_.uniq(rowCoords).length === 1) {
            midNeighbors = [orbs[midRow][midCol - 1], orbs[midRow][midCol + 1]];
        } else {
            midNeighbors = [orbs[midRow - 1][midCol], orbs[midRow + 1][midCol]];
        }
        let isSideBySideMatch = _.includes(midNeighbors, orbs[midRow][midCol]);

        orbs = _unmatch(orbs, midRow, midCol, match, isSideBySideMatch);
    } else {
        // collects which rows and columns have matches in them
        let matchRows: number[] = [];
        let matchCols: number[] = [];
        _.each(_.countBy(rowCoords), (v, k) => {
            if (v > 2) {
                matchRows.push(_.toInteger(k));
            };
        });
        _.each(_.countBy(colCoords), (v, k) => {
            if (v > 2) {
                matchCols.push(_.toInteger(k));
            };
        });
        // if a coordinate is in a row match and a column match, it is an intersection
        _.each(match, coords => {
            if (_.includes(matchRows, coords[0]) && _.includes(matchCols, coords[1])) {
                intersections.push(coords);
            };
        });
        // chooses a random intersection to unmatch 
        let [row, col] = _.sample(intersections);
        _unmatch(orbs, row, col, match);
    };    
    return orbs;
};
開發者ID:PlaytestersKitchen,項目名稱:match-three-js,代碼行數:47,代碼來源:orbs.ts

示例3: textForHtml

 textForHtml(boundVariableLists: string[][]) {
   const name = boundVariableLists[this.level][this.index];
   if (_.countBy(_.flattenDeep(boundVariableLists))[name] > 1) { // Disambiguate variables that appear multiple times in scope
     return this.serialize()
   } else {
     return name;
   }
 }
開發者ID:reavowed,項目名稱:prover,代碼行數:8,代碼來源:Expression.ts

示例4: reject

   redisClient.hvals('users', (err, replies) => {
     if (err) {
       console.error(err);
       reject(err);
     }
 
     const counts = countBy(replies);
     resolve(counts);
   });
開發者ID:odetown,項目名稱:golfdraft,代碼行數:9,代碼來源:userAccess.ts

示例5: createApmTelementry

export function createApmTelementry(
  agentNames: string[] = []
): SavedObjectAttributes {
  const validAgentNames = agentNames.filter(isAgentName);
  return {
    has_any_services: validAgentNames.length > 0,
    services_per_agent: countBy(validAgentNames)
  };
}
開發者ID:elastic,項目名稱:kibana,代碼行數:9,代碼來源:apm_telemetry.ts

示例6: makeRoomForPostmaster

export async function makeRoomForPostmaster(
  store: DimStore,
  toaster,
  bucketsService: () => Promise<InventoryBuckets>
): Promise<void> {
  const buckets = await bucketsService();
  const postmasterItems: DimItem[] = _.flatMap(
    buckets.byCategory.Postmaster,
    (bucket: InventoryBucket) => store.buckets[bucket.id]
  );
  const postmasterItemCountsByType = _.countBy(postmasterItems, (i) => i.bucket.id);
  // If any category is full, we'll move enough aside
  const itemsToMove: DimItem[] = [];
  _.each(postmasterItemCountsByType, (count, bucket) => {
    if (count > 0 && store.buckets[bucket].length > 0) {
      const items: DimItem[] = store.buckets[bucket];
      const capacity = store.capacityForItem(items[0]);
      const numNeededToMove = Math.max(0, count + items.length - capacity);
      if (numNeededToMove > 0) {
        // We'll move the lowest-value item to the vault.
        const candidates = _.sortBy(items.filter((i) => !i.equipped && !i.notransfer), (i) => {
          let value: number = {
            Common: 0,
            Uncommon: 1,
            Rare: 2,
            Legendary: 3,
            Exotic: 4
          }[i.tier];
          // And low-stat
          if (i.primStat) {
            value += i.primStat.value / 1000;
          }
          return value;
        });
        itemsToMove.push(..._.take(candidates, numNeededToMove));
      }
    }
  });
  // TODO: it'd be nice if this were a loadout option
  try {
    await moveItemsToVault(store.getStoresService(), store, itemsToMove, dimItemService);
    toaster.pop(
      'success',
      t('Loadouts.MakeRoom'),
      t('Loadouts.MakeRoomDone', {
        count: postmasterItems.length,
        movedNum: itemsToMove.length,
        store: store.name,
        context: store.gender
      })
    );
  } catch (e) {
    toaster.pop('error', t('Loadouts.MakeRoom'), t('Loadouts.MakeRoomError', { error: e.message }));
    throw e;
  }
}
開發者ID:w1cked,項目名稱:DIM,代碼行數:56,代碼來源:postmaster.ts

示例7: return

 _.filter(polyhedron.faces, face => {
   const faceCounts = _.countBy(
     face.vertexAdjacentFaces().filter(f => !f.equals(face)),
     'numSides',
   );
   return (
     _.isEqual(faceCounts, { '4': face.numSides }) ||
     _.isEqual(faceCounts, { '3': 2 * face.numSides })
   );
 }),
開發者ID:tessenate,項目名稱:polyhedra-viewer,代碼行數:10,代碼來源:prismUtils.ts

示例8: createApmTelementry

export function createApmTelementry(
  agentNames: AgentName[] = []
): ApmTelemetry {
  const validAgentNames = agentNames.filter(agentName =>
    Object.values(AgentName).includes(agentName)
  );
  return {
    has_any_services: validAgentNames.length > 0,
    services_per_agent: countBy(validAgentNames)
  };
}
開發者ID:gingerwizard,項目名稱:kibana,代碼行數:11,代碼來源:apm_telemetry.ts

示例9: mapValues

  return mapValues(visTypes, curr => {
    const total = curr.length;
    const spacesBreakdown = countBy(curr, 'space');
    const spaceCounts: number[] = _.values(spacesBreakdown);

    return {
      total,
      spaces_min: _.min(spaceCounts),
      spaces_max: _.max(spaceCounts),
      spaces_avg: total / spaceCounts.length,
    };
  });
開發者ID:elastic,項目名稱:kibana,代碼行數:12,代碼來源:task_runner.ts

示例10: it

 it("returns calendar rows: empty", () => {
   const eventData: EventData = {
     start_time: "2017-12-20T01:02:00.000Z",
     end_time: "2019-12-20T01:05:00.000Z",
     repeat: 100,
     time_unit: "yearly"
   };
   const testTime = moment("2017-12-30T01:00:00.000Z");
   const calendar = mapResourcesToCalendar(
     fakeSeqFEResources(eventData).index, testTime);
   const dayOneItems = calendar.getAll()[0].items;
   expect(countBy(dayOneItems, "heading")).toEqual({ "*Empty*": 1 });
 });
開發者ID:RickCarlino,項目名稱:farmbot-web-app,代碼行數:13,代碼來源:map_state_to_props_test.ts


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