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


TypeScript lodash.entries函數代碼示例

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


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

示例1: makeBidirectional

/**
 * Populate a graph with inverse operations.
 */
function makeBidirectional(graph: FullGraph) {
  const result: FullGraph = {};
  for (let [source, operations] of _.entries(graph)) {
    for (let [operation, sinks] of _.entries(operations)) {
      for (let sink of sinks) {
        const sinkValue = sink.value;
        if (!sinkValue) {
          continue;
        }
        if (!result[sinkValue]) {
          result[sinkValue] = {};
        }
        const reverseOp = getInverseOperation(operation);
        if (!result[sinkValue][reverseOp]) {
          result[sinkValue][reverseOp] = [];
        }
        if (sinkValue === source) {
          continue;
        }
        const newValue = { ...sink, value: source };
        if (operation === 'gyrate' && sink.direction) {
          newValue.direction = 'back';
        }
        result[sinkValue][reverseOp].push(newValue);
      }
    }
  }
  return graphMerge(result, graph);
}
開發者ID:tessenate,項目名稱:polyhedra-viewer,代碼行數:32,代碼來源:operationGraph.ts

示例2: insertRequisiteTree

export function insertRequisiteTree(modules: Module[], prerequisites: PrereqTreeMap): Module[] {
  // Find modules which this module fulfill the requirements for
  const fulfillModulesMap: { [moduleCode: string]: Set<ModuleCode> } = {};
  for (const module of modules) {
    fulfillModulesMap[module.moduleCode] = new Set();
  }

  for (const [moduleCode, prereqs] of entries(prerequisites)) {
    for (const fulfillsModule of flattenTree(prereqs)) {
      if (fulfillModulesMap[fulfillsModule]) {
        // Since module requires fulfillsModule, that means fulfillsModule
        // fulfills the requirements for module
        fulfillModulesMap[fulfillsModule].add(moduleCode);
      }
    }
  }

  for (const module of modules) {
    const { moduleCode } = module;

    if (prerequisites[moduleCode]) {
      module.prereqTree = prerequisites[moduleCode];
    }

    if (fulfillModulesMap[moduleCode].size > 0) {
      module.fulfillRequirements = Array.from(fulfillModulesMap[moduleCode]);
    }
  }

  return modules;
}
開發者ID:nusmodifications,項目名稱:nusmods,代碼行數:31,代碼來源:index.ts

示例3: nextBreakpoint

function nextBreakpoint(size: Breakpoint): number | null | undefined {
  const breakpointEntries = entries(breakpoints);
  const nextBreakpointIndex =
    breakpointEntries.findIndex(([breakpoint]) => breakpoint === size) + 1;
  if (nextBreakpointIndex >= breakpointEntries.length) return null;
  return breakpointEntries[nextBreakpointIndex][1];
}
開發者ID:nusmodifications,項目名稱:nusmods,代碼行數:7,代碼來源:css.ts

示例4: run

  async run(input: Input) {
    this.logger.info(`Collating venues for ${this.academicYear} semester ${this.semester}`);

    // Insert module code and flatten lessons
    const venueLessons: LessonWithModuleCode[] = flatMap(input, (module) =>
      module.semesterData.timetable.map(
        (lesson: RawLesson): LessonWithModuleCode => ({
          ...lesson,
          moduleCode: module.moduleCode,
        }),
      ),
    );

    const venues = extractVenueAvailability(venueLessons);

    // Get a mapping of module code to module title to help with module aliasing
    const moduleCodeToTitle: { [moduleCode: string]: ModuleTitle } = {};
    input.forEach((module) => {
      moduleCodeToTitle[module.moduleCode] = module.module.title;
    });

    // Merge dual-coded modules and extract the aliases generated for use later
    const allAliases: ModuleAliases = {};
    for (const venue of values(venues)) {
      for (const availability of venue) {
        const { lessons, aliases } = mergeDualCodedModules(availability.classes);
        availability.classes = lessons;

        // Merge the alias mappings
        for (const [moduleCode, alias] of entries(aliases)) {
          // Only add the modules as alias if they have the same title
          const title = moduleCodeToTitle[moduleCode];
          const filteredAliases = Array.from(alias).filter(
            (module) => title === moduleCodeToTitle[module],
          );

          if (filteredAliases.length) {
            allAliases[moduleCode] = union(
              allAliases[moduleCode] || new Set(),
              new Set(filteredAliases),
            );
          }
        }
      }
    }

    // Save the results
    const outputAliases = mapValues(allAliases, (moduleCodes) => Array.from(moduleCodes));
    const venueList = Object.keys(venues);

    await Promise.all([
      this.io.venueInformation(this.semester, venues),
      this.io.venueList(this.semester, venueList),
      this.aliasCache.write(mapValues(outputAliases, (set): string[] => Array.from(set))),
    ]);

    return { venues, aliases: allAliases };
  }
開發者ID:nusmodifications,項目名稱:nusmods,代碼行數:58,代碼來源:CollateVenues.ts

示例5: createStatementForTable

function createStatementForTable(tableName: string, model: SequelizeModel): string {
  const attributeStrings: string[] = []
  for (const [columnName, attribute] of entries((model as any).rawAttributes)) {
    attributeStrings.push(`${columnName}: ${convertAttribute(attribute as ISequelizeAttribute)}`)
  }

  const stringifiedAttributes = `{\n${attributeStrings.join(',\n')}\n}`
  return `queryInterface.createTable('${tableName}', ${stringifiedAttributes})`
}
開發者ID:patrickhulce,項目名稱:klay,代碼行數:9,代碼來源:migration.ts

示例6: computeIncrementalMigrations

async function computeIncrementalMigrations(
  models: SequelizeModel[],
  connection: sequelize.Sequelize,
): Promise<IMigrationRequest[]> {
  const tablesResult: any[][] = await connection.query('show tables')
  const tablesInDb = new Set(tablesResult[0].map(row => values(row)[0]))
  const migrations: IMigrationRequest[] = []

  for (const model of models) {
    const tableName = model.getTableName() as string
    if (tablesInDb.has(tableName)) {
      const columnsResult: any[][] = await connection.query(`show columns from ${tableName}`)
      const indexesResult: any[][] = await connection.query(`show indexes from ${tableName}`)
      const columnsInDb = new Set(columnsResult[0].map(row => row.Field))
      const indexesInDb = new Set(indexesResult[0].map(row => row.Key_name))

      // see https://github.com/sequelize/sequelize/blob/b505723927305960003dae2a8b64e1f291a5f927/lib/model.js#L795-L808
      const columnsInKiln = (model as any).rawAttributes
      for (const [columnName, column] of entries(columnsInKiln)) {
        if (!columnsInDb.has(columnName)) {
          migrations.push({
            tableName,
            columnName,
            type: MigrationType.ADD_COLUMN,
            sequelizeData: column as ISequelizeAttribute,
          })
        }
      }

      const indexesInKiln = (model as any).options.indexes as ISequelizeIndex[]
      for (const index of indexesInKiln) {
        if (!indexesInDb.has(index.name)) {
          migrations.push({
            tableName,
            type: MigrationType.ADD_INDEX,
            sequelizeData: index,
          })
        }
      }
    } else {
      migrations.push({
        tableName,
        type: MigrationType.CREATE_TABLE,
        sequelizeData: model,
      })
    }
  }

  return migrations
}
開發者ID:patrickhulce,項目名稱:klay,代碼行數:50,代碼來源:migration.ts

示例7: getIdFromPathMatch

  async getIdFromPathMatch(config: IMultiProjectConfig): Promise<string | undefined> {
    const { ctx } = this.e;

    for (const [ key, value ] of lodash.entries(config.projects)) {
      const id = key;

      if (value && value.root) {
        const projectDir = path.resolve(this.rootDirectory, value.root);

        if (ctx.execPath.startsWith(projectDir)) {
          debug(`Project id from path match: ${strong(id)}`);
          return id;
        }
      }
    }
  }
開發者ID:driftyco,項目名稱:ionic-cli,代碼行數:16,代碼來源:index.ts

示例8: buildPaths

export function buildPaths(router: IRouter, cache?: ISwaggerSchemaCache): IKeyedPaths {
  const paths: IKeyedPaths = {}

  const routeGroups = groupBy(router.routes, 'path')
  for (const [routePath, routeGroup] of entries(routeGroups)) {
    const path: swagger.Path = {}
    for (const route of routeGroup) {
      path[route.method] = buildOperation(route, cache)
    }

    const modifiedRoutePath = routePath.replace(/(.)\/$/, '$1')
    paths[modifiedRoutePath] = path
  }

  return paths
}
開發者ID:patrickhulce,項目名稱:klay,代碼行數:16,代碼來源:paths.ts

示例9: createRouter

export function createRouter(
  routerOptions: IRouterOptions,
  kilnModel?: IKilnModel,
  executor?: IDatabaseExecutor,
): IRouter {
  const router = express.Router()

  const paramHandlers: IRouteParams = {}

  const routes: IRouterRoute[] = map(routerOptions.routes, (typeOrOption, key) => {
    const [method, path] = key.split(' ')
    const routeOptions = typeof typeOrOption === 'string' ? {type: typeOrOption} : typeOrOption
    const route = createRouteOrActionRoute(routeOptions, routerOptions, kilnModel, executor)

    for (const [name, handler] of entries(route.paramHandlers)) {
      const existing = paramHandlers[name] || handler
      modelAssertions.ok(
        isEqual(existing.model.spec, handler.model.spec),
        `incompatible params model for ${name}`,
      )

      paramHandlers[name] = handler
    }

    return {
      path,
      method: method.toLowerCase() as HTTPMethod,
      options: routeOptions,
      kilnModel,
      ...route,
    }
  })

  for (const [name, handler] of entries(paramHandlers)) {
    router.param(name, handler)
  }

  for (const route of routes) {
    router[route.method](route.path, route.middleware)
  }

  return {router, routes}
}
開發者ID:patrickhulce,項目名稱:klay,代碼行數:43,代碼來源:create-router.ts

示例10: printConfig

  printConfig(ctx: ConfigContext, v: any): void {
    const { global, json } = ctx;

    if (json) {
      process.stdout.write(this.jsonStringify(v));
    } else {
      if (global && v && typeof v === 'object') {
        const columns = lodash.entries(v)
          .map(([k, v]) => [k, this.sanitizeEntry(k, v)])
          .map(([k, v]) => [strong(k), util.inspect(v, { colors: chalk.enabled })]);

        columns.sort((a, b) => strcmp(a[0], b[0]));

        this.env.log.rawmsg(columnar(columns, {}));
      } else {
        this.env.log.rawmsg(util.inspect(v, { depth: Infinity, colors: chalk.enabled }));
      }
    }
  }
開發者ID:driftyco,項目名稱:ionic-cli,代碼行數:19,代碼來源:get.ts


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