From 2716cda387dba975b80ead61ede9c5bdc2419b09 Mon Sep 17 00:00:00 2001 From: ayuki_j <19406594+ayuki-joto@users.noreply.github.com> Date: Tue, 14 May 2024 20:45:18 +0900 Subject: [PATCH 1/7] feat: add open api yaml --- lib/api-gateway-stack.ts | 4 +- lib/calculate-stack.ts | 2 +- lib/dynamodb-stack.ts | 48 +- lib/lambda/actions/food.ts | 496 +++++++------------ lib/lambda/actions/housing.ts | 290 +++++------ lib/lambda/actions/mobility.ts | 467 +++++++++--------- lib/lambda/actions/other.ts | 145 +++--- lib/lambda/calculate-app.ts | 288 +++++------ lib/props.ts | 1 - openapi.yaml | 857 +++++++++++++++++++++++++++++++++ package.json | 4 + yarn.lock | 490 +++++++++++++++++++ 12 files changed, 2128 insertions(+), 964 deletions(-) create mode 100644 openapi.yaml diff --git a/lib/api-gateway-stack.ts b/lib/api-gateway-stack.ts index f76b0d6..9b0deee 100644 --- a/lib/api-gateway-stack.ts +++ b/lib/api-gateway-stack.ts @@ -65,7 +65,9 @@ export class ApiGatewayStack extends Stack { const calculateId = calculate.addResource('{id}') const footprintIntegration = new LambdaIntegration(props.footprintLambda) - const changeImpactIntegration = new LambdaIntegration(props.changeImpactLambda) + const changeImpactIntegration = new LambdaIntegration( + props.changeImpactLambda + ) const calculateIntegration = new LambdaIntegration(props.calculateLambda) footprintType.addMethod('GET', footprintIntegration) diff --git a/lib/calculate-stack.ts b/lib/calculate-stack.ts index c81fc73..ae92a66 100644 --- a/lib/calculate-stack.ts +++ b/lib/calculate-stack.ts @@ -27,7 +27,7 @@ export class CalculateStack extends Stack { environment: { FOOTPRINT_TABLE_NAME: props.footprintTable.tableName, PARAMETER_TABLE_NAME: props.parameterTable.tableName, - PROFILE_TABLE_NAME: props.profileTable.tableName, + PROFILE_TABLE_NAME: props.profileTable.tableName }, tracing: Tracing.ACTIVE, timeout: Duration.seconds(10) diff --git a/lib/dynamodb-stack.ts b/lib/dynamodb-stack.ts index 96a8305..3f7588c 100644 --- a/lib/dynamodb-stack.ts +++ b/lib/dynamodb-stack.ts @@ -1,4 +1,3 @@ - import { aws_dynamodb, RemovalPolicy, Stack } from 'aws-cdk-lib' import { Attribute, AttributeType, Table } from 'aws-cdk-lib/aws-dynamodb' import { Construct } from 'constructs' @@ -67,7 +66,7 @@ export class DynamodbStack extends Stack { name: 'Id', type: AttributeType.STRING } - }, + } } for (const [key, tableObject] of Object.entries(tableObjects)) { @@ -85,33 +84,28 @@ export class DynamodbStack extends Stack { ) } - - this.localFootprintTable.addGlobalSecondaryIndex( - { - indexName: 'CityName-Domain-index', - partitionKey: { - name: 'CityName', - type: AttributeType.STRING - }, - sortKey: { - name: 'Domain', - type: AttributeType.STRING - } + this.localFootprintTable.addGlobalSecondaryIndex({ + indexName: 'CityName-Domain-index', + partitionKey: { + name: 'CityName', + type: AttributeType.STRING + }, + sortKey: { + name: 'Domain', + type: AttributeType.STRING } - ) + }) - this.changeImpactTable.addGlobalSecondaryIndex( - { - indexName: 'CityName-Domain-index', - partitionKey: { - name: 'CityName', - type: AttributeType.STRING - }, - sortKey: { - name: 'Domain', - type: AttributeType.STRING - } + this.changeImpactTable.addGlobalSecondaryIndex({ + indexName: 'CityName-Domain-index', + partitionKey: { + name: 'CityName', + type: AttributeType.STRING + }, + sortKey: { + name: 'Domain', + type: AttributeType.STRING } - ) + }) } } diff --git a/lib/lambda/actions/food.ts b/lib/lambda/actions/food.ts index 1aefbb2..619ec7c 100644 --- a/lib/lambda/actions/food.ts +++ b/lib/lambda/actions/food.ts @@ -1,58 +1,49 @@ -import { toBaseline, findBaseline, toEstimation } from './util' +import {findBaseline, toBaseline, toEstimation} from './util'; +import {DynamoDBDocumentClient, GetCommand, QueryCommand} from "@aws-sdk/lib-dynamodb"; const estimateFood = async ( - dynamodb: { get: (arg0: { TableName: any; Key: { category: any; key: any } }) => { (): any; new(): any; promise: { (): any; new(): any } }; query: (arg0: { TableName: any; KeyConditions: { dir_domain: { ComparisonOperator: string; AttributeValueList: string[] } } | { category: { ComparisonOperator: string; AttributeValueList: string[] } } }) => { (): any; new(): any; promise: { (): any; new(): any } } }, - foodAnswer: { foodIntakeFactorKey: any; foodDirectWasteFactorKey: any; foodLeftoverFactorKey: any; dairyFoodFactorKey: any; dishBeefFactorKey: any; dishPorkFactorKey: any; dishChickenFactorKey: any; dishSeafoodFactorKey: any; alcoholFactorKey: any; softDrinkSnackFactorKey: any; eatOutFactorKey: any }, - footprintTableName: string, - parameterTableName: string + dynamodb: DynamoDBDocumentClient, + foodAnswer: { foodIntakeFactorKey: any; foodDirectWasteFactorKey: any; foodLeftoverFactorKey: any; dairyFoodFactorKey: any; dishBeefFactorKey: any; dishPorkFactorKey: any; dishChickenFactorKey: any; dishSeafoodFactorKey: any; alcoholFactorKey: any; softDrinkSnackFactorKey: any; eatOutFactorKey: any }, + footprintTableName: string, + parameterTableName: string ) => { - const getData = async (category: string, key: any) => - await dynamodb - .get({ - TableName: parameterTableName, - Key: { - category: category, - key: key - } - }) - .promise() + const getData = async (category: string, key: any) => { + const params = { + TableName: parameterTableName, + Key: { + category: category, + key: key + } + }; + return await dynamodb.send(new GetCommand(params)); + }; // foodのベースラインの取得 - const createAmount = (baselines: any, item: string) => - toEstimation(findBaseline(baselines, 'food', item, 'amount')) - const createIntensity = (item: string) => - toEstimation(findBaseline(baselines, 'food', item, 'intensity')) - const getCategoryBaseTotal = (item: string) => - findBaseline(baselines, 'food', item, 'amount').value * - findBaseline(baselines, 'food', item, 'intensity').value - const getCategoryCustomTotal = (item: string, value: number) => - value * findBaseline(baselines, 'food', item, 'intensity').value - - const estimations: { domain: any; item: any; type: any; value: any; subdomain: any; unit: any; }[] = [] + const createAmount = (baselines: any, item: string) => toEstimation(findBaseline(baselines, 'food', item, 'amount')); + const createIntensity = (baselines: any, item: string) => toEstimation(findBaseline(baselines, 'food', item, 'intensity')); + const getCategoryBaseTotal = (baselines: any, item: string) => findBaseline(baselines, 'food', item, 'amount').value * findBaseline(baselines, 'food', item, 'intensity').value; + const getCategoryCustomTotal = (baselines: any, item: string, value: number) => value * findBaseline(baselines, 'food', item, 'intensity').value; + + const estimations: { domain: any; item: any; type: any; value: any; subdomain: any; unit: any; }[] = []; // ベースラインのフットプリントを取得 const params = { TableName: footprintTableName, - KeyConditions: { - dir_domain: { - ComparisonOperator: 'EQ', - AttributeValueList: ['baseline_food'] - } + KeyConditionExpression: 'dir_domain = :dir_domain', + ExpressionAttributeValues: { + ':dir_domain': 'baseline_food' } - } + }; - const data = await dynamodb.query(params).promise() - const baselines = data.Items.map((item: any) => toBaseline(item)) + const data = await dynamodb.send(new QueryCommand(params)); + const baselines = data.Items?.map((item: any) => toBaseline(item)); // 回答がない場合はベースラインのみ返す if (!foodAnswer) { - return { baselines, estimations } + return { baselines, estimations }; } - const foodIntakeFactor = await getData( - 'food-intake-factor', - foodAnswer?.foodIntakeFactorKey || 'unknown' - ) + const foodIntakeFactor = await getData('food-intake-factor', foodAnswer?.foodIntakeFactorKey || 'unknown'); const estimationAmount = { rice: createAmount(baselines, 'rice'), @@ -82,109 +73,60 @@ const estimateFood = async ( 'cold-drink': createAmount(baselines, 'cold-drink'), restaurant: createAmount(baselines, 'restaurant'), 'bar-cafe': createAmount(baselines, 'bar-cafe') - } + }; + + if (foodAnswer?.foodDirectWasteFactorKey && foodAnswer?.foodLeftoverFactorKey) { + const foodDirectWasteFactor = await getData('food-direct-waste-factor', foodAnswer.foodDirectWasteFactorKey); + const foodLeftoverFactor = await getData('food-leftover-factor', foodAnswer.foodLeftoverFactorKey); - if ( - foodAnswer?.foodDirectWasteFactorKey && - foodAnswer?.foodLeftoverFactorKey - ) { - const foodDirectWasteFactor = await getData( - 'food-direct-waste-factor', - foodAnswer.foodDirectWasteFactorKey - ) - - const foodLeftoverFactor = await getData( - 'food-leftover-factor', - foodAnswer.foodLeftoverFactorKey - ) - - const foodWastRatio = await dynamodb - .query({ - TableName: parameterTableName, - KeyConditions: { - category: { - ComparisonOperator: 'EQ', - AttributeValueList: ['food-waste-share'] - } - } - }) - .promise() - - const leftoverRatio = foodWastRatio.Items.find( - (item: { key: string; }) => item.key === 'leftover-per-food-waste' - ) - const directWasteRatio = foodWastRatio.Items.find( - (item: { key: string; }) => item.key === 'direct-waste-per-food-waste' - ) - const foodWasteRatio = foodWastRatio.Items.find( - (item: { key: string; }) => item.key === 'food-waste-per-food' - ) + const foodWasteRatioData = await dynamodb.send(new QueryCommand({ + TableName: parameterTableName, + KeyConditionExpression: 'category = :category', + ExpressionAttributeValues: { + ':category': 'food-waste-share' + } + })); + + // @ts-ignore + const leftoverRatio = foodWasteRatioData.Items.find((item: { key: string; }) => item.key === 'leftover-per-food-waste'); + // @ts-ignore + const directWasteRatio = foodWasteRatioData?.Items.find((item: { key: string; }) => item.key === 'direct-waste-per-food-waste'); + // @ts-ignore + const foodWasteRatio = foodWasteRatioData?.Items.find((item: { key: string; }) => item.key === 'food-waste-per-food'); const foodLossAverageRatio = - foodDirectWasteFactor.Item?.value * directWasteRatio.value + - foodLeftoverFactor.Item?.value * leftoverRatio.value + foodDirectWasteFactor.Item?.value * directWasteRatio?.value + + foodLeftoverFactor.Item?.value * leftoverRatio?.value; // 全体に影響する割合 // 食品ロスを考慮した食材購入量の平均に対する比率 const foodPurchaseAmountConsideringFoodLossRatio = - (1 + foodLossAverageRatio * foodWasteRatio.value) / - (1 + foodWasteRatio.value) - - estimationAmount.rice.value = - estimationAmount.rice.value * - foodIntakeFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount['bread-flour'].value = - estimationAmount['bread-flour'].value * - foodIntakeFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount.noodle.value = - estimationAmount.noodle.value * - foodIntakeFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount.potatoes.value = - estimationAmount.potatoes.value * - foodIntakeFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount.vegetables.value = - estimationAmount.vegetables.value * - foodIntakeFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount['processed-vegetables'].value = - estimationAmount['processed-vegetables'].value * - foodIntakeFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount.beans.value = - estimationAmount.beans.value * - foodIntakeFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount.fruits.value = - estimationAmount.fruits.value * - foodIntakeFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount.oil.value = - estimationAmount.oil.value * - foodIntakeFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount.seasoning.value = - estimationAmount.seasoning.value * - foodIntakeFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount['ready-meal'].value = - estimationAmount['ready-meal'].value * - foodIntakeFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimations.push(estimationAmount.rice) - estimations.push(estimationAmount['bread-flour']) - estimations.push(estimationAmount.noodle) - estimations.push(estimationAmount.potatoes) - estimations.push(estimationAmount.vegetables) - estimations.push(estimationAmount['processed-vegetables']) - estimations.push(estimationAmount.beans) - estimations.push(estimationAmount.fruits) - estimations.push(estimationAmount.oil) - estimations.push(estimationAmount.seasoning) - estimations.push(estimationAmount['ready-meal']) + (1 + foodLossAverageRatio * foodWasteRatio?.value) / + (1 + foodWasteRatio?.value); + + estimationAmount.rice.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount['bread-flour'].value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount.noodle.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount.potatoes.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount.vegetables.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount['processed-vegetables'].value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount.beans.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount.fruits.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount.oil.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount.seasoning.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount['ready-meal'].value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + + estimations.push(estimationAmount.rice); + estimations.push(estimationAmount['bread-flour']); + estimations.push(estimationAmount.noodle); + estimations.push(estimationAmount.potatoes); + estimations.push(estimationAmount.vegetables); + estimations.push(estimationAmount['processed-vegetables']); + estimations.push(estimationAmount.beans); + estimations.push(estimationAmount.fruits); + estimations.push(estimationAmount.oil); + estimations.push(estimationAmount.seasoning); + estimations.push(estimationAmount['ready-meal']); // // 答えに従ってestimationを計算 @@ -192,148 +134,88 @@ const estimateFood = async ( // 乳製品補正 if (foodAnswer?.dairyFoodFactorKey) { - const dairyFoodFactor = await getData( - 'dairy-food-factor', - foodAnswer.dairyFoodFactorKey - ) - - estimationAmount.milk.value = - estimationAmount.milk.value * - dairyFoodFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount['other-dairy'].value = - estimationAmount['other-dairy'].value * - dairyFoodFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount.eggs.value = - estimationAmount.eggs.value * - dairyFoodFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimations.push(estimationAmount.milk) - estimations.push(estimationAmount['other-dairy']) - estimations.push(estimationAmount.eggs) + const dairyFoodFactor = await getData('dairy-food-factor', foodAnswer.dairyFoodFactorKey); + + estimationAmount.milk.value *= dairyFoodFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount['other-dairy'].value *= dairyFoodFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount.eggs.value *= dairyFoodFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimations.push(estimationAmount.milk); + estimations.push(estimationAmount['other-dairy']); + estimations.push(estimationAmount.eggs); } // 牛肉補正 - let dishBeefFactor = null + let dishBeefFactor = null; if (foodAnswer?.dishBeefFactorKey) { - dishBeefFactor = await getData( - 'dish-beef-factor', - foodAnswer.dishBeefFactorKey - ) - - estimationAmount.beef.value = - estimationAmount.beef.value * - dishBeefFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimations.push(estimationAmount.beef) + dishBeefFactor = await getData('dish-beef-factor', foodAnswer.dishBeefFactorKey); + + estimationAmount.beef.value *= dishBeefFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimations.push(estimationAmount.beef); } // 豚肉補正 - let dishPorkFactor = null + let dishPorkFactor = null; if (foodAnswer?.dishPorkFactorKey) { - dishPorkFactor = await getData( - 'dish-pork-factor', - foodAnswer.dishPorkFactorKey - ) - - estimationAmount.pork.value = - estimationAmount.pork.value * - dishPorkFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount['other-meat'].value = - estimationAmount['other-meat'].value * - dishPorkFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimations.push(estimationAmount.pork) - estimations.push(estimationAmount['other-meat']) + dishPorkFactor = await getData('dish-pork-factor', foodAnswer.dishPorkFactorKey); + + estimationAmount.pork.value *= dishPorkFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount['other-meat'].value *= dishPorkFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimations.push(estimationAmount.pork); + estimations.push(estimationAmount['other-meat']); } // 鶏肉補正 - let dishChickenFactor = null + let dishChickenFactor = null; if (foodAnswer?.dishChickenFactorKey) { - dishChickenFactor = await getData( - 'dish-chicken-factor', - foodAnswer.dishChickenFactorKey - ) - - estimationAmount.chicken.value = - estimationAmount.chicken.value * - dishChickenFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimations.push(estimationAmount.chicken) + dishChickenFactor = await getData('dish-chicken-factor', foodAnswer.dishChickenFactorKey); + + estimationAmount.chicken.value *= dishChickenFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimations.push(estimationAmount.chicken); } // 加工肉補正 if (dishBeefFactor && dishPorkFactor && dishChickenFactor) { estimationAmount['processed-meat'].value = - (estimationAmount['processed-meat'].value * - (estimationAmount.beef.value + - estimationAmount.pork.value + - estimationAmount['other-meat'].value + - estimationAmount.chicken.value)) / - (createAmount(baselines, 'beef').value + - createAmount(baselines, 'pork').value + - createAmount(baselines, 'other-meat').value + - createAmount(baselines, 'chicken').value) - estimations.push(estimationAmount['processed-meat']) + (estimationAmount['processed-meat'].value * + (estimationAmount.beef.value + + estimationAmount.pork.value + + estimationAmount['other-meat'].value + + estimationAmount.chicken.value)) / + (createAmount(baselines, 'beef').value + + createAmount(baselines, 'pork').value + + createAmount(baselines, 'other-meat').value + + createAmount(baselines, 'chicken').value); + estimations.push(estimationAmount['processed-meat']); } // 魚補正 if (foodAnswer?.dishSeafoodFactorKey) { - const dishSeafoodFactor = await getData( - 'dish-seafood-factor', - foodAnswer.dishSeafoodFactorKey - ) - - estimationAmount.fish.value = - estimationAmount.fish.value * - dishSeafoodFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount['processed-fish'].value = - estimationAmount['processed-fish'].value * - dishSeafoodFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimations.push(estimationAmount.fish) - estimations.push(estimationAmount['processed-fish']) + const dishSeafoodFactor = await getData('dish-seafood-factor', foodAnswer.dishSeafoodFactorKey); + + estimationAmount.fish.value *= dishSeafoodFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount['processed-fish'].value *= dishSeafoodFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimations.push(estimationAmount.fish); + estimations.push(estimationAmount['processed-fish']); } // アルコール補正 if (foodAnswer?.alcoholFactorKey) { - const alcoholFactor = await getData( - 'alcohol-factor', - foodAnswer.alcoholFactorKey - ) - - estimationAmount.alcohol.value = - estimationAmount.alcohol.value * - alcoholFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimations.push(estimationAmount.alcohol) + const alcoholFactor = await getData('alcohol-factor', foodAnswer.alcoholFactorKey); + + estimationAmount.alcohol.value *= alcoholFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimations.push(estimationAmount.alcohol); } // 菓子など補正 if (foodAnswer?.softDrinkSnackFactorKey) { - const softDrinkSnackFactor = await getData( - 'soft-drink-snack-factor', - foodAnswer.softDrinkSnackFactorKey - ) - - estimationAmount['sweets-snack'].value = - estimationAmount['sweets-snack'].value * - softDrinkSnackFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount['coffee-tea'].value = - estimationAmount['coffee-tea'].value * - softDrinkSnackFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimationAmount['cold-drink'].value = - estimationAmount['cold-drink'].value * - softDrinkSnackFactor.Item?.value * - foodPurchaseAmountConsideringFoodLossRatio - estimations.push(estimationAmount['sweets-snack']) - estimations.push(estimationAmount['coffee-tea']) - estimations.push(estimationAmount['cold-drink']) + const softDrinkSnackFactor = await getData('soft-drink-snack-factor', foodAnswer.softDrinkSnackFactorKey); + + estimationAmount['sweets-snack'].value *= softDrinkSnackFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount['coffee-tea'].value *= softDrinkSnackFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimationAmount['cold-drink'].value *= softDrinkSnackFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; + estimations.push(estimationAmount['sweets-snack']); + estimations.push(estimationAmount['coffee-tea']); + estimations.push(estimationAmount['cold-drink']); } // //ready-meal intensity @@ -359,46 +241,41 @@ const estimateFood = async ( 'oil', 'seasoning', 'sweets-snack' - ] + ]; - const readyMealIntensity = createIntensity('ready-meal') + const readyMealIntensity = createIntensity(baselines,'ready-meal'); let currentTotalAmount = beforeReadyMealKeyArray.reduce( - // @ts-ignore - (res, key) => res + estimationAmount[key].value, - 0 - ) + // @ts-ignore + (res, key) => res + estimationAmount[key].value, + 0 + ); let baseTotalAmount = beforeReadyMealKeyArray.reduce( - (res, key) => res + findBaseline(baselines, 'food', key, 'amount').value, - 0 - ) + // @ts-ignore + (res, key) => res + findBaseline(baselines, 'food', key, 'amount').value, + 0 + ); readyMealIntensity.value = - (readyMealIntensity.value * + (readyMealIntensity.value * + (beforeReadyMealKeyArray.reduce( + // @ts-ignore + (res, key) => res + getCategoryCustomTotal(baselines, key, estimationAmount[key].value), + 0 + ) / + currentTotalAmount)) / (beforeReadyMealKeyArray.reduce( - (res, key) => - // @ts-ignore - res + getCategoryCustomTotal(key, estimationAmount[key].value), - 0 - ) / - currentTotalAmount)) / - (beforeReadyMealKeyArray.reduce( - (res, key) => res + getCategoryBaseTotal(key), - 0 - ) / - baseTotalAmount) - estimations.push(readyMealIntensity) + (res, key) => res + getCategoryBaseTotal(baselines, key), + 0 + ) / + baseTotalAmount); + estimations.push(readyMealIntensity); // 外食部分の計算 if (foodAnswer?.eatOutFactorKey) { - const eatOutFactor = await getData( - 'eat-out-factor', - foodAnswer.eatOutFactorKey - ) - estimationAmount.restaurant.value = - estimationAmount.restaurant.value * eatOutFactor.Item?.value - estimationAmount['bar-cafe'].value = - estimationAmount['bar-cafe'].value * eatOutFactor.Item?.value - estimations.push(estimationAmount.restaurant) - estimations.push(estimationAmount['bar-cafe']) + const eatOutFactor = await getData('eat-out-factor', foodAnswer.eatOutFactorKey); + estimationAmount.restaurant.value *= eatOutFactor.Item?.value; + estimationAmount['bar-cafe'].value *= eatOutFactor.Item?.value; + estimations.push(estimationAmount.restaurant); + estimations.push(estimationAmount['bar-cafe']); //eatOut intensity const EatOutArray = [ @@ -427,43 +304,38 @@ const estimateFood = async ( 'alcohol', 'coffee-tea', 'cold-drink' - ] + ]; currentTotalAmount = EatOutArray.reduce( - // @ts-ignore - (res, key) => res + estimationAmount[key].value, - 0 - ) + // @ts-ignore + (res, key) => res + estimationAmount[key].value, + 0 + ); baseTotalAmount = EatOutArray.reduce( - (res, key) => - res + findBaseline(baselines, 'food', key, 'amount').value, - 0 - ) + // @ts-ignore + (res, key) => res + findBaseline(baselines, 'food', key, 'amount').value, + 0 + ); const eatOutIntensityResult = - EatOutArray.reduce((res, key) => { - if (key !== 'ready-meal') { - return ( + EatOutArray.reduce((res, key) => { + if (key !== 'ready-meal') { // @ts-ignore - res + getCategoryCustomTotal(key, estimationAmount[key].value) - ) - } else { - return res + estimationAmount[key].value * readyMealIntensity.value - } - }, 0) / - currentTotalAmount / - (EatOutArray.reduce((res, key) => res + getCategoryBaseTotal(key), 0) / - baseTotalAmount) - const restaurantIntensity = createIntensity('restaurant') - const barCafeIntensity = createIntensity('bar-cafe') - restaurantIntensity.value = - restaurantIntensity.value * eatOutIntensityResult - barCafeIntensity.value = barCafeIntensity.value * eatOutIntensityResult - estimations.push(restaurantIntensity) - estimations.push(barCafeIntensity) + return res + getCategoryCustomTotal(baselines, key, estimationAmount[key].value); + } else { + return res + estimationAmount[key].value * readyMealIntensity.value; + } + }, 0) / + currentTotalAmount / + (EatOutArray.reduce((res, key) => res + getCategoryBaseTotal(baselines,key), 0) / baseTotalAmount); + const restaurantIntensity = createIntensity(baselines,'restaurant'); + const barCafeIntensity = createIntensity(baselines,'bar-cafe'); + restaurantIntensity.value *= eatOutIntensityResult; + barCafeIntensity.value *= eatOutIntensityResult; + estimations.push(restaurantIntensity); + estimations.push(barCafeIntensity); } } - // console.log(JSON.stringify(estimations)) - return { baselines, estimations } -} + return { baselines, estimations }; +}; -export { estimateFood } +export { estimateFood }; diff --git a/lib/lambda/actions/housing.ts b/lib/lambda/actions/housing.ts index 9e60338..b2c7e9c 100644 --- a/lib/lambda/actions/housing.ts +++ b/lib/lambda/actions/housing.ts @@ -1,67 +1,68 @@ -import { toBaseline, findBaseline, toEstimation } from './util' +import {findBaseline, toBaseline, toEstimation} from './util'; +import {DynamoDBDocumentClient, GetCommand, QueryCommand} from "@aws-sdk/lib-dynamodb"; const estimateHousing = async ( - dynamodb: any, - housingAnswer: any, - mobilityAnswer: any, - footprintTableName: any, - parameterTableName: any + dynamodb: DynamoDBDocumentClient, + housingAnswer: any, + mobilityAnswer: any, + footprintTableName: string, + parameterTableName: string ) => { - const getData = async (category: any, key: any) => - await dynamodb - .get({ - TableName: parameterTableName, - Key: { - category: category, - key: key - } - }) - .promise() + const getData = async (category: any, key: any) => { + const params = { + TableName: parameterTableName, + Key: { + category: category, + key: key + } + }; + + return await dynamodb.send(new GetCommand(params)); + }; - /* eslint-disable no-unused-vars */ const pushOrUpdateEstimate = (item: any, type: any, estimation: any) => { const estimate = estimations.find( - (estimation) => estimation.item === item && estimation.type === type - ) + (estimation) => estimation.item === item && estimation.type === type + ); if (estimate) { - estimate.value = estimation.value + estimate.value = estimation.value; } else { - estimations.push(estimation) + estimations.push(estimation); } - } - /* eslint-disable no-unused-vars */ + }; - const estimations: { domain: any; item: any; type: any; value: any; subdomain: any; unit: any }[] = [] + const estimations: { domain: any; item: any; type: any; value: any; subdomain: any; unit: any }[] = []; // ベースラインのフットプリントを取得 const params = { TableName: footprintTableName, - KeyConditions: { - dir_domain: { - ComparisonOperator: 'EQ', - AttributeValueList: ['baseline_housing'] - } + KeyConditionExpression: 'dir_domain = :dir_domain', + ExpressionAttributeValues: { + ':dir_domain': 'baseline_housing' } - } + }; - const data = await dynamodb.query(params).promise() - const baselines = data.Items.map((item: any) => toBaseline(item)) + const data = await dynamodb.send(new QueryCommand(params)); + const baselines = data.Items?.map((item: any) => toBaseline(item)); + if(baselines == undefined) { + return {} + } const findAmount = (item: string) => - findBaseline(baselines, 'housing', item, 'amount') + findBaseline(baselines, 'housing', item, 'amount'); const createAmount = (item: string) => - toEstimation(findBaseline(baselines, 'housing', item, 'amount')) + toEstimation(findBaseline(baselines, 'housing', item, 'amount')); const createIntensity = (item: string) => - toEstimation(findBaseline(baselines, 'housing', item, 'intensity')) + toEstimation(findBaseline(baselines, 'housing', item, 'intensity')); // 回答がない場合はベースラインのみ返す if (!housingAnswer) { - return { baselines, estimations } + return { baselines, estimations }; } - const residentCount = housingAnswer.residentCount + const residentCount = housingAnswer.residentCount; // 住居人数が0以下の場合はベースラインのみ返す if (residentCount <= 0) { - return { baselines, estimations } + return { baselines, estimations }; } // 下記部分でパラメータ名から一致を取る必要があるため、ケバブのまま変数化 @@ -73,7 +74,7 @@ const estimateHousing = async ( 'urban-gas': createAmount('urban-gas'), lpg: createAmount('lpg'), kerosene: createAmount('kerosene') - } + }; // // # お住まいの地域(地方)はどちらですか? @@ -83,34 +84,33 @@ const estimateHousing = async ( // housingAmountByRegion: String # northeast|middle|southwest|unknown // if (housingAnswer.housingAmountByRegionFirstKey) { - const housingAmountByRegion = - housingAnswer.housingAmountByRegionFirstKey + '_' + const housingAmountByRegion = housingAnswer.housingAmountByRegionFirstKey + '_'; const params = { TableName: parameterTableName, - KeyConditions: { - category: { - ComparisonOperator: 'EQ', - AttributeValueList: ['housing-amount-by-region'] - }, - key: { - ComparisonOperator: 'BEGINS_WITH', - AttributeValueList: [housingAmountByRegion] - } + KeyConditionExpression: 'category = :category and begins_with(#key, :key)', + ExpressionAttributeNames: { + '#key': 'key' + }, + ExpressionAttributeValues: { + ':category': 'housing-amount-by-region', + ':key': housingAmountByRegion } - } - const amountByRegion = await dynamodb.query(params).promise() + }; + const amountByRegion = await dynamodb.send(new QueryCommand(params)); // estimationAmountに項目があるものだけ、amountByRegionの値を上書き for (const key of Object.keys(estimationAmount)) { + // @ts-ignore const rec = amountByRegion.Items.find( - (a: { key: string }) => a.key === housingAmountByRegion + key + '-amount' - ) + // @ts-ignore + (a: { key: string }) => a.key === housingAmountByRegion + key + '-amount' + ); if (rec) { // @ts-ignore - estimationAmount[key].value = rec.value + estimationAmount[key].value = rec.value; } // @ts-ignore - estimations.push(estimationAmount[key]) + estimations.push(estimationAmount[key]); } } @@ -123,164 +123,132 @@ const estimateHousing = async ( // water if (housingAnswer.housingSizeKey) { - const housingSize = await getData( - 'housing-size', - housingAnswer.housingSizeKey - ) + const housingSize = await getData('housing-size', housingAnswer.housingSizeKey); const housingSizePerResident = - housingAnswer.housingSizeKey === 'unknown' - ? housingSize.Item?.value - : housingSize.Item?.value / residentCount + housingAnswer.housingSizeKey === 'unknown' + ? housingSize.Item?.value + : housingSize.Item?.value / residentCount; - const imputedRentValue = findAmount('imputed-rent').value - const rentValue = findAmount('rent').value + const imputedRentValue = findAmount('imputed-rent').value; + const rentValue = findAmount('rent').value; estimationAmount['imputed-rent'].value = - (housingSizePerResident / (imputedRentValue + rentValue)) * - imputedRentValue + (housingSizePerResident / (imputedRentValue + rentValue)) * + imputedRentValue; estimationAmount.rent.value = - (housingSizePerResident / (imputedRentValue + rentValue)) * rentValue + (housingSizePerResident / (imputedRentValue + rentValue)) * rentValue; estimationAmount['housing-maintenance'].value = - (findAmount('housing-maintenance').value / - (imputedRentValue + rentValue)) * - (estimationAmount['imputed-rent'].value + estimationAmount.rent.value) - pushOrUpdateEstimate( - 'imputed-rent', - 'amount', - estimationAmount['imputed-rent'] - ) - pushOrUpdateEstimate('rent', 'amount', estimationAmount.rent) - pushOrUpdateEstimate( - 'housing-maintenance', - 'amount', - estimationAmount['housing-maintenance'] - ) + (findAmount('housing-maintenance').value / + (imputedRentValue + rentValue)) * + (estimationAmount['imputed-rent'].value + estimationAmount.rent.value); + pushOrUpdateEstimate('imputed-rent', 'amount', estimationAmount['imputed-rent']); + pushOrUpdateEstimate('rent', 'amount', estimationAmount.rent); + pushOrUpdateEstimate('housing-maintenance', 'amount', estimationAmount['housing-maintenance']); } // 再生可能エネルギー if (housingAnswer.electricityIntensityKey) { - const electricityParam = await getData( - 'electricity-intensity', - housingAnswer.electricityIntensityKey - ) - const electricityIntensity = createIntensity('electricity') - electricityIntensity.value = electricityParam.Item?.value - estimations.push(electricityIntensity) + const electricityParam = await getData('electricity-intensity', housingAnswer.electricityIntensityKey); + const electricityIntensity = createIntensity('electricity'); + electricityIntensity.value = electricityParam.Item?.value; + estimations.push(electricityIntensity); } // 電力使用量 if ( - housingAnswer.electricityMonthlyConsumption != undefined && - housingAnswer.electricityMonthlyConsumption != null && - housingAnswer.electricitySeasonFactorKey - ) { - const electricitySeason = await getData( - 'electricity-season-factor', + housingAnswer.electricityMonthlyConsumption != undefined && + housingAnswer.electricityMonthlyConsumption != null && housingAnswer.electricitySeasonFactorKey - ) + ) { + const electricitySeason = await getData('electricity-season-factor', housingAnswer.electricitySeasonFactorKey); - let mobilityElectricityAmount = 0 + let mobilityElectricityAmount = 0; // PHV, EVの補正 if ( - mobilityAnswer?.hasPrivateCar && - (mobilityAnswer?.carIntensityFactorFirstKey === 'phv' || - mobilityAnswer?.carIntensityFactorFirstKey === 'ev') && - mobilityAnswer?.privateCarAnnualMileage && - mobilityAnswer?.carChargingKey + mobilityAnswer?.hasPrivateCar && + (mobilityAnswer?.carIntensityFactorFirstKey === 'phv' || + mobilityAnswer?.carIntensityFactorFirstKey === 'ev') && + mobilityAnswer?.privateCarAnnualMileage && + mobilityAnswer?.carChargingKey ) { const electricityData = await getData( - 'car-intensity-factor', - mobilityAnswer.carIntensityFactorFirstKey + '_electricity-intensity' - ) - const mobilityElectricity = electricityData?.Item?.value || 1 - - const chargingData = await getData( - 'car-charging', - mobilityAnswer.carChargingKey - ) + 'car-intensity-factor', + mobilityAnswer.carIntensityFactorFirstKey + '_electricity-intensity' + ); + const mobilityElectricity = electricityData?.Item?.value || 1; - const mobilityCharging = chargingData?.Item?.value || 1 + const chargingData = await getData('car-charging', mobilityAnswer.carChargingKey); + const mobilityCharging = chargingData?.Item?.value || 1; mobilityElectricityAmount = - mobilityAnswer.privateCarAnnualMileage * - mobilityElectricity * - mobilityCharging + mobilityAnswer.privateCarAnnualMileage * + mobilityElectricity * + mobilityCharging; } estimationAmount.electricity.value = - (housingAnswer.electricityMonthlyConsumption * - electricitySeason.Item?.value) / - residentCount - - mobilityElectricityAmount - pushOrUpdateEstimate('electricity', 'amount', estimationAmount.electricity) + (housingAnswer.electricityMonthlyConsumption * electricitySeason.Item?.value) / + residentCount - + mobilityElectricityAmount; + pushOrUpdateEstimate('electricity', 'amount', estimationAmount.electricity); } // ガスの使用の有無 if (housingAnswer.useGas) { - let gasParam = null + let gasParam = null; if ( - housingAnswer.gasMonthlyConsumption != undefined && - housingAnswer.gasMonthlyConsumption != null && - housingAnswer.gasSeasonFactorKey - ) { - const gasSeason = await getData( - 'gas-season-factor', + housingAnswer.gasMonthlyConsumption != undefined && + housingAnswer.gasMonthlyConsumption != null && housingAnswer.gasSeasonFactorKey - ) - const gasFactor = await getData( - 'energy-heat-intensity', - housingAnswer.energyHeatIntensityKey - ) + ) { + const gasSeason = await getData('gas-season-factor', housingAnswer.gasSeasonFactorKey); + const gasFactor = await getData('energy-heat-intensity', housingAnswer.energyHeatIntensityKey); gasParam = - (housingAnswer.gasMonthlyConsumption * - (gasSeason.Item?.value || 1) * - (gasFactor.Item?.value || 1)) / - residentCount + (housingAnswer.gasMonthlyConsumption * (gasSeason.Item?.value || 1) * (gasFactor.Item?.value || 1)) / + residentCount; } if (housingAnswer.energyHeatIntensityKey === 'lpg') { if (gasParam != null) { - estimationAmount.lpg.value = gasParam + estimationAmount.lpg.value = gasParam; } - estimationAmount['urban-gas'].value = 0 + estimationAmount['urban-gas'].value = 0; } else if (housingAnswer.energyHeatIntensityKey === 'urban-gas') { if (gasParam != null) { - estimationAmount['urban-gas'].value = gasParam + estimationAmount['urban-gas'].value = gasParam; } - estimationAmount.lpg.value = 0 + estimationAmount.lpg.value = 0; } - pushOrUpdateEstimate('urban-gas', 'amount', estimationAmount['urban-gas']) - pushOrUpdateEstimate('lpg', 'amount', estimationAmount.lpg) + pushOrUpdateEstimate('urban-gas', 'amount', estimationAmount['urban-gas']); + pushOrUpdateEstimate('lpg', 'amount', estimationAmount.lpg); } else if (housingAnswer.useGas === false) { - estimationAmount['urban-gas'].value = 0 - estimationAmount.lpg.value = 0 - pushOrUpdateEstimate('urban-gas', 'amount', estimationAmount['urban-gas']) - pushOrUpdateEstimate('lpg', 'amount', estimationAmount.lpg) + estimationAmount['urban-gas'].value = 0; + estimationAmount.lpg.value = 0; + pushOrUpdateEstimate('urban-gas', 'amount', estimationAmount['urban-gas']); + pushOrUpdateEstimate('lpg', 'amount', estimationAmount.lpg); } // 灯油の使用の有無 if (housingAnswer.useKerosene) { if ( - housingAnswer.keroseneMonthlyConsumption != undefined && - housingAnswer.keroseneMonthlyConsumption != null && - housingAnswer.keroseneMonthCount != undefined && - housingAnswer.keroseneMonthCount != null + housingAnswer.keroseneMonthlyConsumption != undefined && + housingAnswer.keroseneMonthlyConsumption != null && + housingAnswer.keroseneMonthCount != undefined && + housingAnswer.keroseneMonthCount != null ) { - const keroseneData = await getData('energy-heat-intensity', 'kerosene') + const keroseneData = await getData('energy-heat-intensity', 'kerosene'); estimationAmount.kerosene.value = - ((keroseneData?.Item?.value || 1) * - (housingAnswer.keroseneMonthlyConsumption * - housingAnswer.keroseneMonthCount)) / - residentCount + ((keroseneData?.Item?.value || 1) * (housingAnswer.keroseneMonthlyConsumption * housingAnswer.keroseneMonthCount)) / + residentCount; } - pushOrUpdateEstimate('kerosene', 'amount', estimationAmount.kerosene) + pushOrUpdateEstimate('kerosene', 'amount', estimationAmount.kerosene); } else if (housingAnswer.useKerosene === false) { - estimationAmount.kerosene.value = 0 - pushOrUpdateEstimate('kerosene', 'amount', estimationAmount.kerosene) + estimationAmount.kerosene.value = 0; + pushOrUpdateEstimate('kerosene', 'amount', estimationAmount.kerosene); } - return { baselines, estimations } -} + return { baselines, estimations }; +}; -export { estimateHousing } +export { estimateHousing }; diff --git a/lib/lambda/actions/mobility.ts b/lib/lambda/actions/mobility.ts index 6e16f0a..a9a0172 100644 --- a/lib/lambda/actions/mobility.ts +++ b/lib/lambda/actions/mobility.ts @@ -1,80 +1,93 @@ -import { toBaseline, findBaseline, toEstimation } from './util' +import {findBaseline, toBaseline, toEstimation} from './util'; +import {DynamoDBDocumentClient, GetCommand, QueryCommand} from "@aws-sdk/lib-dynamodb"; const estimateMobility = async ( - dynamodb: { get: (arg0: { TableName: any; Key: { category: any; key: any } }) => { (): any; new(): any; promise: { (): any; new(): any } }; query: (arg0: { TableName: any; KeyConditions: { dir_domain: { ComparisonOperator: string; AttributeValueList: string[] } } | { category: { ComparisonOperator: string; AttributeValueList: string[] } } | { category: { ComparisonOperator: string; AttributeValueList: string[] }; key: { ComparisonOperator: string; AttributeValueList: string[] } } }) => { (): any; new(): any; promise: { (): any; new(): any } } }, - housingAnswer: { electricityIntensityKey: any }, - mobilityAnswer: { carChargingKey: any; hasPrivateCar: any; carIntensityFactorFirstKey: string; carPassengersFirstKey: string; privateCarAnnualMileage: number; hasTravelingTime: any; trainWeeklyTravelingTime: any; busWeeklyTravelingTime: any; motorbikeWeeklyTravelingTime: any; otherCarWeeklyTravelingTime: any; otherCarAnnualTravelingTime: any; trainAnnualTravelingTime: any; busAnnualTravelingTime: any; motorbikeAnnualTravelingTime: any; airplaneAnnualTravelingTime: any; ferryAnnualTravelingTime: any; mileageByAreaFirstKey: string }, - footprintTableName: any, - parameterTableName: any + dynamodb: DynamoDBDocumentClient, + housingAnswer: { electricityIntensityKey: any }, + mobilityAnswer: { + carChargingKey: any; + hasPrivateCar: any; + carIntensityFactorFirstKey: string; + carPassengersFirstKey: string; + privateCarAnnualMileage: number; + hasTravelingTime: any; + trainWeeklyTravelingTime: any; + busWeeklyTravelingTime: any; + motorbikeWeeklyTravelingTime: any; + otherCarWeeklyTravelingTime: any; + otherCarAnnualTravelingTime: any; + trainAnnualTravelingTime: any; + busAnnualTravelingTime: any; + motorbikeAnnualTravelingTime: any; + airplaneAnnualTravelingTime: any; + ferryAnnualTravelingTime: any; + mileageByAreaFirstKey: string; + }, + footprintTableName: any, + parameterTableName: any ) => { // mobilityのベースラインの取得 const createAmount = (baselines: any, item: string) => - toEstimation(findBaseline(baselines, 'mobility', item, 'amount')) + toEstimation(findBaseline(baselines, 'mobility', item, 'amount')); const createIntensity = (baselines: any, item: string) => - toEstimation(findBaseline(baselines, 'mobility', item, 'intensity')) - - const getData = async (category: string, key: string) => - await dynamodb - .get({ - TableName: parameterTableName, - Key: { - category: category, - key: key - } - }) - .promise() - - const estimations: { domain: any; item: any; type: any; value: any; subdomain: any; unit: any; }[] = [] + toEstimation(findBaseline(baselines, 'mobility', item, 'intensity')); - const pushOrUpdateEstimate = (item: any, type: any, estimation: { domain?: any; item?: any; type?: any; value: any; subdomain?: any; unit?: any; }) => { - const estimate = estimations.find( - (estimation) => estimation.item === item && estimation.type === type - ) + const getData = async (category: string, key: string) => { + const params = { + TableName: parameterTableName, + Key: { + category: category, + key: key + } + }; + return await dynamodb.send(new GetCommand(params)); + }; + + const estimations: { domain: any; item: any; type: any; value: any; subdomain: any; unit: any }[] = []; + + const pushOrUpdateEstimate = ( + item: any, + type: any, + estimation: { domain?: any; item?: any; type?: any; value: any; subdomain?: any; unit?: any } + ) => { + const estimate = estimations.find((estimation) => estimation.item === item && estimation.type === type); if (estimate) { - estimate.value = estimation.value + estimate.value = estimation.value; } else { // @ts-ignore - estimations.push(estimation) + estimations.push(estimation); } - } + }; // ベースラインのフットプリントを取得 let params = { TableName: footprintTableName, - KeyConditions: { - dir_domain: { - ComparisonOperator: 'EQ', - AttributeValueList: ['baseline_mobility'] - } + KeyConditionExpression: 'dir_domain = :dir_domain', + ExpressionAttributeValues: { + ':dir_domain': 'baseline_mobility' } - } + }; - let data = await dynamodb.query(params).promise() - const baselines = data.Items.map((item: any) => toBaseline(item)) + let data = await dynamodb.send(new QueryCommand(params)); + const baselines = data.Items?.map((item: any) => toBaseline(item)); // 回答がない場合はベースラインのみ返す if (!mobilityAnswer) { - return { baselines, estimations } + return { baselines, estimations }; } - let electricityIntensityFactor = 0 + let electricityIntensityFactor = 0; // PHV, EVの場合は自宅での充電割合と再生エネルギー電力の割合で補正 if (housingAnswer?.electricityIntensityKey) { - const electricityData = await getData( - 'electricity-intensity-factor', - housingAnswer.electricityIntensityKey - ) + const electricityData = await getData('electricity-intensity-factor', housingAnswer.electricityIntensityKey); if (electricityData?.Item) { - electricityIntensityFactor = electricityData.Item.value + electricityIntensityFactor = electricityData.Item.value; } - const carChargingData = await getData( - 'car-charging', - mobilityAnswer?.carChargingKey || 'unknown' - ) + const carChargingData = await getData('car-charging', mobilityAnswer?.carChargingKey || 'unknown'); if (carChargingData?.Item) { - electricityIntensityFactor *= carChargingData.Item.value + electricityIntensityFactor *= carChargingData.Item.value; } } @@ -85,157 +98,127 @@ const estimateMobility = async ( // 自家用車をお持ちですか?がYesの場合 if (mobilityAnswer.hasPrivateCar) { if (mobilityAnswer?.carIntensityFactorFirstKey) { - const drivingIntensity = createIntensity(baselines, 'private-car-driving') + const drivingIntensity = createIntensity(baselines, 'private-car-driving'); // 自家用車の場合は、自動車種類に応じて運転時GHG原単位を取得 - let ghgIntensityRatio = 1 + let ghgIntensityRatio = 1; let data = await getData( - 'car-intensity-factor', - mobilityAnswer.carIntensityFactorFirstKey + '_driving-factor' - ) + 'car-intensity-factor', + mobilityAnswer.carIntensityFactorFirstKey + '_driving-factor' + ); if (data?.Item) { - ghgIntensityRatio *= data.Item.value + ghgIntensityRatio *= data.Item.value; } // PHV, EVの補正 - if ( - mobilityAnswer.carIntensityFactorFirstKey === 'phv' || - mobilityAnswer.carIntensityFactorFirstKey === 'ev' - ) { + if (mobilityAnswer.carIntensityFactorFirstKey === 'phv' || mobilityAnswer.carIntensityFactorFirstKey === 'ev') { const data = await getData( - 'renewable-car-intensity-factor', - mobilityAnswer.carIntensityFactorFirstKey + '_driving-factor' - ) + 'renewable-car-intensity-factor', + mobilityAnswer.carIntensityFactorFirstKey + '_driving-factor' + ); if (data?.Item) { ghgIntensityRatio = - ghgIntensityRatio * (1 - electricityIntensityFactor) + - data.Item.value * electricityIntensityFactor + ghgIntensityRatio * (1 - electricityIntensityFactor) + data.Item.value * electricityIntensityFactor; } } // 人数補正値 - data = await getData( - 'car-passengers', - (mobilityAnswer.carPassengersFirstKey || 'unknown') + - '_private-car-factor' - ) - let passengerIntensityRatio = data?.Item?.value || 1 + data = await getData('car-passengers', (mobilityAnswer.carPassengersFirstKey || 'unknown') + '_private-car-factor'); + let passengerIntensityRatio = data?.Item?.value || 1; - const purchaseIntensity = createIntensity( - baselines, - 'private-car-purchase' - ) + const purchaseIntensity = createIntensity(baselines, 'private-car-purchase'); // 自家用車の場合は、自動車種類に応じて運転時GHG原単位を取得 const purchaseData = await getData( - 'car-intensity-factor', - (mobilityAnswer.carIntensityFactorFirstKey || 'unknown') + - '_manufacturing-factor' - ) + 'car-intensity-factor', + (mobilityAnswer.carIntensityFactorFirstKey || 'unknown') + '_manufacturing-factor' + ); if (purchaseData?.Item) { - purchaseIntensity.value *= purchaseData.Item.value + purchaseIntensity.value *= purchaseData.Item.value; } - estimations.push(purchaseIntensity) + estimations.push(purchaseIntensity); - drivingIntensity.value *= ghgIntensityRatio * passengerIntensityRatio - estimations.push(drivingIntensity) + drivingIntensity.value *= ghgIntensityRatio * passengerIntensityRatio; + estimations.push(drivingIntensity); // 自家用車の移動距離を取得 - const amount = createAmount(baselines, 'private-car-driving') - const baselineAmount = amount.value - amount.value = mobilityAnswer.privateCarAnnualMileage || 0 - estimations.push(amount) - const mileageRatio = amount.value / baselineAmount - - const privateCarPurchase = createAmount(baselines, 'private-car-purchase') - const privateCarMaintenance = createAmount( - baselines, - 'private-car-maintenance' - ) + const amount = createAmount(baselines, 'private-car-driving'); + const baselineAmount = amount.value; + amount.value = mobilityAnswer.privateCarAnnualMileage || 0; + estimations.push(amount); + const mileageRatio = amount.value / baselineAmount; + + const privateCarPurchase = createAmount(baselines, 'private-car-purchase'); + const privateCarMaintenance = createAmount(baselines, 'private-car-maintenance'); // 自家用車の購入・メンテナンスを移動距離比で補正 - privateCarPurchase.value *= mileageRatio - privateCarMaintenance.value *= mileageRatio - estimations.push(privateCarPurchase) - estimations.push(privateCarMaintenance) + privateCarPurchase.value *= mileageRatio; + privateCarMaintenance.value *= mileageRatio; + estimations.push(privateCarPurchase); + estimations.push(privateCarMaintenance); } } else { - const amount = createAmount(baselines, 'private-car-driving') - amount.value = 0 - estimations.push(amount) - const privateCarPurchase = createAmount(baselines, 'private-car-purchase') - privateCarPurchase.value = 0 - estimations.push(privateCarPurchase) - const privateCarMaintenance = createAmount( - baselines, - 'private-car-maintenance' - ) - privateCarMaintenance.value = 0 - estimations.push(privateCarMaintenance) + const amount = createAmount(baselines, 'private-car-driving'); + amount.value = 0; + estimations.push(amount); + const privateCarPurchase = createAmount(baselines, 'private-car-purchase'); + privateCarPurchase.value = 0; + estimations.push(privateCarPurchase); + const privateCarMaintenance = createAmount(baselines, 'private-car-maintenance'); + privateCarMaintenance.value = 0; + estimations.push(privateCarMaintenance); } // taxiのintensity補正。本来はtaxiの乗車人数を確認する必要があるがcarPassengersFirstKeyを代用 if (mobilityAnswer.carPassengersFirstKey) { - const intensity = createIntensity(baselines, 'taxi') + const intensity = createIntensity(baselines, 'taxi'); // 人数補正値 - const data = await getData( - 'car-passengers', - mobilityAnswer.carPassengersFirstKey + '_taxi-factor' - ) - const ratio = data?.Item?.value || 1 - intensity.value *= ratio - estimations.push(intensity) + const data = await getData('car-passengers', mobilityAnswer.carPassengersFirstKey + '_taxi-factor'); + const ratio = data?.Item?.value || 1; + intensity.value *= ratio; + estimations.push(intensity); } // カーシェアの補正。本来はcar-sharingの乗車人数を確認する必要があるがcarPassengersFirstKeyを代用 - if ( - mobilityAnswer.carPassengersFirstKey && - mobilityAnswer.carIntensityFactorFirstKey - ) { + if (mobilityAnswer.carPassengersFirstKey && mobilityAnswer.carIntensityFactorFirstKey) { // car-sharing-drivingのintensity補正 // 人数補正値 const passengers = await getData( - 'car-passengers', - mobilityAnswer.carPassengersFirstKey + '_private-car-factor' - ) - const passengerIntensityRatio = passengers?.Item?.value || 1 + 'car-passengers', + mobilityAnswer.carPassengersFirstKey + '_private-car-factor' + ); + const passengerIntensityRatio = passengers?.Item?.value || 1; const driving = await getData( - 'car-intensity-factor', - (mobilityAnswer.carIntensityFactorFirstKey || 'unknown') + - '_driving-factor' - ) - let ghgIntensityRatio = driving?.Item?.value || 1 + 'car-intensity-factor', + (mobilityAnswer.carIntensityFactorFirstKey || 'unknown') + '_driving-factor' + ); + let ghgIntensityRatio = driving?.Item?.value || 1; // PHV, EVの補正 - if ( - mobilityAnswer?.carIntensityFactorFirstKey === 'phv' || - mobilityAnswer?.carIntensityFactorFirstKey === 'ev' - ) { + if (mobilityAnswer?.carIntensityFactorFirstKey === 'phv' || mobilityAnswer?.carIntensityFactorFirstKey === 'ev') { const data = await getData( - 'renewable-car-intensity-factor', - mobilityAnswer.carIntensityFactorFirstKey + '_driving-factor' - ) + 'renewable-car-intensity-factor', + mobilityAnswer.carIntensityFactorFirstKey + '_driving-factor' + ); if (data?.Item) { ghgIntensityRatio = - ghgIntensityRatio * (1 - electricityIntensityFactor) + - data.Item.value * electricityIntensityFactor + ghgIntensityRatio * (1 - electricityIntensityFactor) + data.Item.value * electricityIntensityFactor; } } - const intensity = createIntensity(baselines, 'car-sharing-driving') - intensity.value *= ghgIntensityRatio * passengerIntensityRatio - estimations.push(intensity) + const intensity = createIntensity(baselines, 'car-sharing-driving'); + intensity.value *= ghgIntensityRatio * passengerIntensityRatio; + estimations.push(intensity); // car-sharing-rentalのintensity補正 const rental = await getData( - 'car-intensity-factor', - (mobilityAnswer.carIntensityFactorFirstKey || 'unknown') + - '_manufacturing-factor' - ) + 'car-intensity-factor', + (mobilityAnswer.carIntensityFactorFirstKey || 'unknown') + '_manufacturing-factor' + ); if (rental?.Item) { - const intensity = createIntensity(baselines, 'car-sharing-rental') - intensity.value *= rental.Item.value - estimations.push(intensity) + const intensity = createIntensity(baselines, 'car-sharing-rental'); + intensity.value *= rental.Item.value; + estimations.push(intensity); } } @@ -256,7 +239,7 @@ const estimateMobility = async ( motorbikePurchase: createAmount(baselines, 'motorbike-purchase'), carSharingRental: createAmount(baselines, 'car-sharing-rental'), motorbikeMaintenance: createAmount(baselines, 'motorbike-maintenance') - } + }; const mileage = { airplane: 0, @@ -266,7 +249,7 @@ const estimateMobility = async ( taxi: 0, carSharing: 0, motorbike: 0 - } + }; //=IF('2_CF推定質問'!$F$169='2_CF推定質問'!$W$169,'2_CF推定質問'!U204,Y83/Y78*AW78) // @@ -279,7 +262,7 @@ const estimateMobility = async ( bus: mobilityAnswer.busWeeklyTravelingTime || 0, motorbike: mobilityAnswer.motorbikeWeeklyTravelingTime || 0, otherCar: mobilityAnswer.otherCarWeeklyTravelingTime || 0 - } + }; // // 昨年1年間で、旅行などで利用した移動手段を教えてください @@ -291,157 +274,149 @@ const estimateMobility = async ( motorbike: mobilityAnswer.motorbikeAnnualTravelingTime || 0, airplane: mobilityAnswer.airplaneAnnualTravelingTime || 0, ferry: mobilityAnswer.ferryAnnualTravelingTime || 0 - } + }; // 年間週数の取得 - data = await getData('misc', 'weeks-per-year-excluding-long-vacations') - let weekCount = 49 + let data = await getData('misc', 'weeks-per-year-excluding-long-vacations'); + let weekCount = 49; if (data?.Item) { - weekCount = data.Item.value + weekCount = data.Item.value; } // 時速の取得 const paramsTransportation = { TableName: parameterTableName, - KeyConditions: { - category: { - ComparisonOperator: 'EQ', - AttributeValueList: ['transportation-speed'] - } + KeyConditionExpression: 'category = :category', + ExpressionAttributeValues: { + ':category': 'transportation-speed' } - } - data = await dynamodb.query(paramsTransportation).promise() - const speed = data.Items.reduce((a: { [x: string]: any; }, x: { key: string | number; value: any; }) => { - a[x.key] = x.value - return a - }, {}) + }; + data = await dynamodb.send(new QueryCommand(paramsTransportation)); + // @ts-ignore + const speed = data.Items?.reduce((a: { [x: string]: any }, x: { key: string | number; value: any }) => { + a[x.key] = x.value; + return a; + }, {}); // 飛行機の移動距離の積算 - mileage.airplane += annualTravelingTime.airplane * speed['airplane-speed'] + // @ts-ignore + mileage.airplane += annualTravelingTime.airplane * speed['airplane-speed']; // フェリーの移動距離の積算 - mileage.ferry += annualTravelingTime.ferry * speed['ferry-speed'] + // @ts-ignore + mileage.ferry += annualTravelingTime.ferry * speed['ferry-speed']; // 電車の移動距離の積算 mileage.train += - weeklyTravelingTime.train * weekCount * speed['train-speed'] + - annualTravelingTime.train * speed['long-distance-train-speed'] + // @ts-ignore + weeklyTravelingTime.train * weekCount * speed['train-speed'] + + // @ts-ignore + annualTravelingTime.train * speed['long-distance-train-speed']; // バスの移動距離の積算 mileage.bus += - weeklyTravelingTime.bus * weekCount * speed['bus-speed'] + - annualTravelingTime.bus * speed['express-bus-speed'] + // @ts-ignore + weeklyTravelingTime.bus * weekCount * speed['bus-speed'] + + // @ts-ignore + annualTravelingTime.bus * speed['express-bus-speed']; // バイクの移動距離の積算 mileage.motorbike += - weeklyTravelingTime.motorbike * weekCount * speed['motorbike-speed'] + - annualTravelingTime.motorbike * speed['long-distance-motorbike-speed'] + // @ts-ignore + weeklyTravelingTime.motorbike * weekCount * speed['motorbike-speed'] + + // @ts-ignore + annualTravelingTime.motorbike * speed['long-distance-motorbike-speed']; const taxiRatio = - estimationAmount.taxi.value / - (estimationAmount.taxi.value + estimationAmount.carSharing.value) + estimationAmount.taxi.value / + (estimationAmount.taxi.value + estimationAmount.carSharing.value); // タクシー他、その他の移動の算出 const otherCarMileage = - weeklyTravelingTime.otherCar * weekCount * speed['car-speed'] + - annualTravelingTime.otherCar * speed['long-distance-car-speed'] + // @ts-ignore + weeklyTravelingTime.otherCar * weekCount * speed['car-speed'] + + // @ts-ignore + annualTravelingTime.otherCar * speed['long-distance-car-speed']; - mileage.taxi += otherCarMileage * taxiRatio // タクシーの移動距離の積算 - mileage.carSharing += otherCarMileage * (1 - taxiRatio) // カーシェアリングの移動距離の積算 + mileage.taxi += otherCarMileage * taxiRatio; // タクシーの移動距離の積算 + mileage.carSharing += otherCarMileage * (1 - taxiRatio); // カーシェアリングの移動距離の積算 // motorbike, carSharingベースライン値のバックアップ - const baselineMotorbikeAmount = estimationAmount.motorbike.value - const baselineCarSharingAmount = estimationAmount.carSharing.value + const baselineMotorbikeAmount = estimationAmount.motorbike.value; + const baselineCarSharingAmount = estimationAmount.carSharing.value; // ベースラインの値を書き換えてEstimationを生成 for (let item of Object.keys(mileage)) { // @ts-ignore - estimationAmount[item].value = mileage[item] + estimationAmount[item].value = mileage[item]; // @ts-ignore - estimations.push(estimationAmount[item]) + estimations.push(estimationAmount[item]); } // バイクの購入・メンテナンス、カーシェアの回数はベースラインとの比率で変更 - const motorbikeDrivingRatio = - estimationAmount.motorbike.value / baselineMotorbikeAmount - const carSharingDrivingRatio = - estimationAmount.carSharing.value / baselineCarSharingAmount - - estimationAmount.motorbikePurchase.value *= motorbikeDrivingRatio - estimationAmount.carSharingRental.value *= carSharingDrivingRatio - estimationAmount.motorbikeMaintenance.value *= motorbikeDrivingRatio - - estimations.push(estimationAmount.motorbikePurchase) - estimations.push(estimationAmount.carSharingRental) - estimations.push(estimationAmount.motorbikeMaintenance) + const motorbikeDrivingRatio = estimationAmount.motorbike.value / baselineMotorbikeAmount; + const carSharingDrivingRatio = estimationAmount.carSharing.value / baselineCarSharingAmount; + + estimationAmount.motorbikePurchase.value *= motorbikeDrivingRatio; + estimationAmount.carSharingRental.value *= carSharingDrivingRatio; + estimationAmount.motorbikeMaintenance.value *= motorbikeDrivingRatio; + + estimations.push(estimationAmount.motorbikePurchase); + estimations.push(estimationAmount.carSharingRental); + estimations.push(estimationAmount.motorbikeMaintenance); } else { // // お住まいの地域の規模はどのくらいですか? // - const mileageByAreaFirstKey = - mobilityAnswer.mileageByAreaFirstKey || 'unknown' + const mileageByAreaFirstKey = mobilityAnswer.mileageByAreaFirstKey || 'unknown'; const params = { TableName: parameterTableName, - KeyConditions: { - category: { - ComparisonOperator: 'EQ', - AttributeValueList: ['mileage-by-area'] - }, - key: { - ComparisonOperator: 'BEGINS_WITH', - AttributeValueList: [mileageByAreaFirstKey + '_'] - } + KeyConditionExpression: 'category = :category and begins_with(#key, :key)', + ExpressionAttributeNames: { + '#key': 'key' + }, + ExpressionAttributeValues: { + ':category': 'mileage-by-area', + ':key': mileageByAreaFirstKey + '_' } - } - const data = await dynamodb.query(params).promise() - const consumptionByArea = data.Items.reduce((a: { [x: string]: any; }, x: { key: string | number; value: any; }) => { - a[x.key] = x.value - return a - }, {}) - - estimationAmount.airplane.value = - consumptionByArea[mileageByAreaFirstKey + '_airplane'] - estimationAmount.train.value = - consumptionByArea[mileageByAreaFirstKey + '_train'] - estimationAmount.bus.value = - consumptionByArea[mileageByAreaFirstKey + '_bus'] - estimationAmount.motorbike.value = - consumptionByArea[mileageByAreaFirstKey + '_motorbike-driving'] - estimationAmount.taxi.value = - consumptionByArea[mileageByAreaFirstKey + '_taxi'] - estimationAmount.carSharing.value = - consumptionByArea[mileageByAreaFirstKey + '_car-sharing-driving'] - estimationAmount.ferry.value = - consumptionByArea[mileageByAreaFirstKey + '_ferry'] - estimationAmount.motorbikePurchase.value = - consumptionByArea[mileageByAreaFirstKey + '_motorbike-purchase'] - estimationAmount.carSharingRental.value = - consumptionByArea[mileageByAreaFirstKey + '_car-sharing-rental'] - estimationAmount.motorbikeMaintenance.value = - consumptionByArea[mileageByAreaFirstKey + '_motorbike-maintenance'] + }; + const data = await dynamodb.send(new QueryCommand(params)); + // @ts-ignore + const consumptionByArea = data.Items.reduce((a: { [x: string]: any }, x: { key: string | number; value: any }) => { + a[x.key] = x.value; + return a; + }, {}); + + estimationAmount.airplane.value = consumptionByArea[mileageByAreaFirstKey + '_airplane']; + estimationAmount.train.value = consumptionByArea[mileageByAreaFirstKey + '_train']; + estimationAmount.bus.value = consumptionByArea[mileageByAreaFirstKey + '_bus']; + estimationAmount.motorbike.value = consumptionByArea[mileageByAreaFirstKey + '_motorbike-driving']; + estimationAmount.taxi.value = consumptionByArea[mileageByAreaFirstKey + '_taxi']; + estimationAmount.carSharing.value = consumptionByArea[mileageByAreaFirstKey + '_car-sharing-driving']; + estimationAmount.ferry.value = consumptionByArea[mileageByAreaFirstKey + '_ferry']; + estimationAmount.motorbikePurchase.value = consumptionByArea[mileageByAreaFirstKey + '_motorbike-purchase']; + estimationAmount.carSharingRental.value = consumptionByArea[mileageByAreaFirstKey + '_car-sharing-rental']; + estimationAmount.motorbikeMaintenance.value = consumptionByArea[mileageByAreaFirstKey + '_motorbike-maintenance']; const additionalAmount = { bicycleDriving: createAmount(baselines, 'bicycle-driving'), walking: createAmount(baselines, 'walking'), bicycleMaintenance: createAmount(baselines, 'bicycle-maintenance') - } + }; - additionalAmount.walking.value = - consumptionByArea[mileageByAreaFirstKey + '_walking'] - additionalAmount.bicycleDriving.value = - consumptionByArea[mileageByAreaFirstKey + '_bicycle-driving'] - additionalAmount.bicycleMaintenance.value = - consumptionByArea[mileageByAreaFirstKey + '_bicycle-maintenance'] + additionalAmount.walking.value = consumptionByArea[mileageByAreaFirstKey + '_walking']; + additionalAmount.bicycleDriving.value = consumptionByArea[mileageByAreaFirstKey + '_bicycle-driving']; + additionalAmount.bicycleMaintenance.value = consumptionByArea[mileageByAreaFirstKey + '_bicycle-maintenance']; // ベースラインの値を書き換えてEstimationを生成 for (let amount of Object.values(estimationAmount)) { - pushOrUpdateEstimate(amount.item, amount.type, amount) + pushOrUpdateEstimate(amount.item, amount.type, amount); } for (let amount of Object.values(additionalAmount)) { - pushOrUpdateEstimate(amount.item, amount.type, amount) + pushOrUpdateEstimate(amount.item, amount.type, amount); } } - return { baselines, estimations } -} + return { baselines, estimations }; +}; -export { estimateMobility } +export { estimateMobility }; diff --git a/lib/lambda/actions/other.ts b/lib/lambda/actions/other.ts index 42c372f..0f851db 100644 --- a/lib/lambda/actions/other.ts +++ b/lib/lambda/actions/other.ts @@ -1,62 +1,65 @@ -import { toBaseline, findBaseline, toEstimation } from './util' +import {findBaseline, toBaseline, toEstimation} from './util'; +import {DynamoDBDocumentClient, GetCommand, QueryCommand} from "@aws-sdk/lib-dynamodb"; const estimateOther = async ( - dynamodb: { get: (arg0: { TableName: any; Key: { category: any; key: any } }) => { (): any; new(): any; promise: { (): any; new(): any } }; query: (arg0: { TableName: any; KeyConditions: { dir_domain: { ComparisonOperator: string; AttributeValueList: string[] } } }) => { (): any; new(): any; promise: { (): any; new(): any } } }, - housingAnswer: { residentCount: number | null | undefined }, - otherAnswer: { dailyGoodsAmountKey: any; communicationAmountKey: any; applianceFurnitureAmountKey: any; serviceFactorKey: any; hobbyGoodsFactorKey: any; clothesBeautyFactorKey: any; leisureSportsFactorKey: any; travelFactorKey: any }, - footprintTableName: string, - parameterTableName: string + dynamodb: DynamoDBDocumentClient, + housingAnswer: { residentCount: number | null | undefined }, + otherAnswer: { + dailyGoodsAmountKey: any; + communicationAmountKey: any; + applianceFurnitureAmountKey: any; + serviceFactorKey: any; + hobbyGoodsFactorKey: any; + clothesBeautyFactorKey: any; + leisureSportsFactorKey: any; + travelFactorKey: any; + }, + footprintTableName: string, + parameterTableName: string ) => { // foodのEstimationの取得 - const createAmount = (baselines: any, item: string) => - toEstimation(findBaseline(baselines, 'other', item, 'amount')) + const createAmount = (baselines: any, item: string) => toEstimation(findBaseline(baselines, 'other', item, 'amount')); // parameterの取得 - const getData = async (category: string, key: string) => - await dynamodb - .get({ - TableName: parameterTableName, - Key: { - category: category, - key: key - } - }) - .promise() + const getData = async (category: string, key: string) => { + const params = { + TableName: parameterTableName, + Key: { + category: category, + key: key + } + }; + return await dynamodb.send(new GetCommand(params)); + }; - const estimations: { domain: any; item: any; type: any; value: any; subdomain: any; unit: any; }[] = [] + const estimations: { domain: any; item: any; type: any; value: any; subdomain: any; unit: any }[] = []; // ベースラインのフットプリントを取得 const params = { TableName: footprintTableName, - KeyConditions: { - dir_domain: { - ComparisonOperator: 'EQ', - AttributeValueList: ['baseline_other'] - } + KeyConditionExpression: 'dir_domain = :dir_domain', + ExpressionAttributeValues: { + ':dir_domain': 'baseline_other' } - } + }; - const data = await dynamodb.query(params).promise() - const baselines = data.Items.map((item: any) => toBaseline(item)) + const data = await dynamodb.send(new QueryCommand(params)); + const baselines = data.Items?.map((item: any) => toBaseline(item)); // 回答がない場合はベースラインのみ返す if (!otherAnswer) { - return { baselines, estimations } + return { baselines, estimations }; } // 平均の居住人数を取得 - let residentCount = 1 - const familySize = await getData('family-size', 'unknown') + let residentCount = 1; + const familySize = await getData('family-size', 'unknown'); if (familySize?.Item?.value) { - residentCount = familySize.Item.value + residentCount = familySize.Item.value; } - if ( - housingAnswer && - housingAnswer.residentCount !== undefined && - housingAnswer.residentCount !== null - ) { - residentCount = housingAnswer.residentCount + if (housingAnswer && housingAnswer.residentCount !== undefined && housingAnswer.residentCount !== null) { + residentCount = housingAnswer.residentCount; } const answers = [ @@ -154,12 +157,7 @@ const estimateOther = async ( { category: 'leisure-sports-factor', key: otherAnswer.leisureSportsFactorKey, - items: [ - 'culture-leisure', - 'entertainment-leisure', - 'sports-leisure', - 'bath-spa' - ] + items: ['culture-leisure', 'entertainment-leisure', 'sports-leisure', 'bath-spa'] }, // 過去1年間の宿泊を伴う旅行にかかった費用はいくらくらいですか? @@ -169,33 +167,33 @@ const estimateOther = async ( key: otherAnswer.travelFactorKey, items: ['hotel', 'travel'] } - ] + ]; for (let ans of answers) { if (ans.key) { - const data = await getData(ans.category, ans.key) - let denominator: number | undefined = 1 + const data = await getData(ans.category, ans.key); + let denominator: number | undefined = 1; if (ans.base) { if (ans.key === 'unknown') { // 国平均の支出額(average-per-capita)が指定されていて、わからない、の回答の場合は // 国平均に対する比率は1倍。denominatorをundefinedにして計算に使わないようにする。 - denominator = undefined + denominator = undefined; } else { - const base = await getData(ans.category, ans.base) + const base = await getData(ans.category, ans.base); if (base?.Item?.value) { // 分母は国平均の支出額(average-per-capita) * 居住人数 - denominator = base.Item.value * residentCount + denominator = base.Item.value * residentCount; } } } if (data?.Item?.value) { - const coefficient = denominator ? data.Item.value / denominator : 1 + const coefficient = denominator ? data.Item.value / denominator : 1; for (let item of ans.items) { - const estimation = createAmount(baselines, item) - estimation.value *= coefficient - estimations.push(estimation) + const estimation = createAmount(baselines, item); + estimation.value *= coefficient; + estimations.push(estimation); } } } @@ -223,39 +221,36 @@ const estimateOther = async ( 'kitchen-goods', 'paper-stationery', 'books-magazines' - ]) + ]); - const isTarget = (t: { domain: any; item: any; type: any; value?: any; subdomain?: any; unit?: any; }) => - t.domain === 'other' && wasteSet.has(t.item) && t.type === 'amount' + const isTarget = (t: { domain: any; item: any; type: any; value?: any; subdomain?: any; unit?: any }) => + t.domain === 'other' && wasteSet.has(t.item) && t.type === 'amount'; - const targets = baselines.filter((b: { domain: any; item: any; type: any; value?: any; subdomain?: any; unit?: any; }) => isTarget(b)) - const results = new Map() + // @ts-ignore + const targets = baselines.filter((b: { domain: any; item: any; type: any; value?: any; subdomain?: any; unit?: any }) => isTarget(b)); + const results = new Map(); - let baselineSum = 0 + let baselineSum = 0; for (const baseline of targets) { - const key = baseline.domain + '_' + baseline.item + '_' + baseline.type - results.set(key, toEstimation(baseline)) - baselineSum += baseline.value + const key = baseline.domain + '_' + baseline.item + '_' + baseline.type; + results.set(key, toEstimation(baseline)); + baselineSum += baseline.value; } for (const estimation of estimations.filter((e) => isTarget(e))) { - const key = - estimation.domain + '_' + estimation.item + '_' + estimation.type - results.set(key, estimation) + const key = estimation.domain + '_' + estimation.item + '_' + estimation.type; + results.set(key, estimation); } - const estimationSum = Array.from(results.values()).reduce( - (sum, res) => sum + res.value, - 0 - ) + const estimationSum = Array.from(results.values()).reduce((sum, res) => sum + res.value, 0); - const wasteEstimation = createAmount(baselines, 'waste') + const wasteEstimation = createAmount(baselines, 'waste'); if (baselineSum !== 0) { - wasteEstimation.value *= estimationSum / baselineSum + wasteEstimation.value *= estimationSum / baselineSum; } - estimations.push(toEstimation(wasteEstimation)) + estimations.push(toEstimation(wasteEstimation)); - return { baselines, estimations } -} + return { baselines, estimations }; +}; -export { estimateOther } +export { estimateOther }; diff --git a/lib/lambda/calculate-app.ts b/lib/lambda/calculate-app.ts index 531d4ef..26c5eb6 100644 --- a/lib/lambda/calculate-app.ts +++ b/lib/lambda/calculate-app.ts @@ -1,46 +1,42 @@ -import { validate } from './actions/validate' -import { estimateMobility } from './actions/mobility' -import { estimateHousing } from './actions/housing' -import { estimateFood } from './actions/food' -import { estimateOther } from './actions/other' - -const { DynamoDBDocument } = require('@aws-sdk/lib-dynamodb'); -const { DynamoDB } = require('@aws-sdk/client-dynamodb'); - -const awsServerlessExpressMiddleware = require('aws-serverless-express/middleware') -const bodyParser = require('body-parser') -const { v4: uuid } = require('uuid') -import express from 'express' -import {EmissionCalculator} from "../../utils/emission"; - -const FOOTPRINT_TABLE_NAME = process.env.FOOTPRINT_TABLE_NAME || '' -const PARAMETER_TABLE_NAME = process.env.PARAMETER_TABLE_NAME || '' -const PROFILE_TABLE_NAME = process.env.PROFILE_TABLE_NAME || '' +import { validate } from './actions/validate'; +import { estimateMobility } from './actions/mobility'; +import { estimateHousing } from './actions/housing'; +import { estimateFood } from './actions/food'; +import { estimateOther } from './actions/other'; +import { DynamoDBClient } from '@aws-sdk/client-dynamodb'; +import { DynamoDBDocumentClient, GetCommand, PutCommand } from '@aws-sdk/lib-dynamodb'; + +const awsServerlessExpressMiddleware = require('aws-serverless-express/middleware'); +const bodyParser = require('body-parser'); +const { v4: uuid } = require('uuid'); +import express from 'express'; +import { EmissionCalculator } from '../../utils/emission'; + +const FOOTPRINT_TABLE_NAME = process.env.FOOTPRINT_TABLE_NAME || ''; +const PARAMETER_TABLE_NAME = process.env.PARAMETER_TABLE_NAME || ''; +const PROFILE_TABLE_NAME = process.env.PROFILE_TABLE_NAME || ''; let dynamoParam = {} let footprintTableName = FOOTPRINT_TABLE_NAME let parameterTableName = PARAMETER_TABLE_NAME let profileTableName = PROFILE_TABLE_NAME -const dynamodb = DynamoDBDocument.from(new DynamoDB(dynamoParam)) +const dynamodbClient = new DynamoDBClient(dynamoParam); +const dynamodb = DynamoDBDocumentClient.from(dynamodbClient); -const path = '/calculates' +const path = '/calculates'; // declare a new express app -const app: express.Express = express() -app.use(bodyParser.json()) -app.use(awsServerlessExpressMiddleware.eventContext()) +const app: express.Express = express(); +app.use(bodyParser.json()); +app.use(awsServerlessExpressMiddleware.eventContext()); // Enable CORS for all methods -app.use(function ( - req: express.Request, - res: express.Response, - next: express.NextFunction -) { - res.header('Access-Control-Allow-Origin', '*') - res.header('Access-Control-Allow-Headers', '*') - next() -}) +app.use(function (req: express.Request, res: express.Response, next: express.NextFunction) { + res.header('Access-Control-Allow-Origin', '*'); + res.header('Access-Control-Allow-Headers', '*'); + next(); +}); const toResponse = (profile: any, estimate: any) => { const common = { @@ -50,10 +46,10 @@ const toResponse = (profile: any, estimate: any) => { housingAnswer: profile.housingAnswer, foodAnswer: profile.foodAnswer, otherAnswer: profile.otherAnswer - } + }; return estimate - ? { + ? { ...common, baselines: profile.baselines, estimations: profile.estimations, @@ -62,163 +58,175 @@ const toResponse = (profile: any, estimate: any) => { housingScore: profile.housing, otherScore: profile.other, } - : common -} + : common; +}; /***************************************** * HTTP Get method for get single object * *****************************************/ app.get(path + '/:id', async (req: express.Request, res: express.Response) => { try { - const data = await dynamodb - .get({ - TableName: profileTableName, - Key: { id: req.params.id } - }) + const data = await dynamodb.send(new GetCommand({ + TableName: profileTableName, + Key: { id: req.params.id } + })); + + const profile = data.Item; - const profile = data.Item + if (profile == undefined) { + res.statusCode = 404; + res.json({ error: 'Could not load item: ' + req.params.id }); + return + } // 計算がされていない場合は遅延初期化 if (!profile.estimated) { - await updateProfile(dynamodb, profile) - profile.estimated = true - profile.updatedAt = new Date().toISOString() - await dynamodb - .put({ - TableName: profileTableName, - Item: profile - }) + await updateProfile(dynamodb, profile); + profile.estimated = true; + profile.updatedAt = new Date().toISOString(); + await dynamodb.send(new PutCommand({ + TableName: PROFILE_TABLE_NAME, + Item: profile + })); } - await addScore(profile) + await addScore(profile); - res.json(toResponse(profile, true)) + res.json(toResponse(profile, true)); } catch (err) { - res.statusCode = 500 - res.json({ error: 'Could not load item: ' + err }) + res.statusCode = 500; + res.json({ error: 'Could not load item: ' + err }); } -}) +}); const addScore = async (profile: any) => { const emissionCalculator = new EmissionCalculator(profile); - profile.mobility = emissionCalculator.mobility - profile.food = emissionCalculator.food - profile.housing = emissionCalculator.housing - profile.other = emissionCalculator.other -} + profile.mobility = emissionCalculator.mobility; + profile.food = emissionCalculator.food; + profile.housing = emissionCalculator.housing; + profile.other = emissionCalculator.other; +}; -const updateProfile = async (dynamodb: any, profile: any) => { - profile.baselines = [] - profile.estimations = [] +const updateProfile = async (dynamodb: DynamoDBDocumentClient, profile: any) => { + profile.baselines = []; + profile.estimations = []; if (profile.housingAnswer) { const { baselines, estimations } = await estimateHousing( - dynamodb, - profile.housingAnswer, - profile.mobilityAnswer, - footprintTableName, - parameterTableName - ) - profile.baselines = profile.baselines.concat(baselines) - profile.estimations = profile.estimations.concat(estimations) + dynamodb, + profile.housingAnswer, + profile.mobilityAnswer, + footprintTableName, + parameterTableName + ); + profile.baselines = profile.baselines.concat(baselines); + profile.estimations = profile.estimations.concat(estimations); } if (profile.mobilityAnswer) { const { baselines, estimations } = await estimateMobility( - dynamodb, - profile.housingAnswer, - profile.mobilityAnswer, - footprintTableName, - parameterTableName - ) - profile.baselines = profile.baselines.concat(baselines) - profile.estimations = profile.estimations.concat(estimations) + dynamodb, + profile.housingAnswer, + profile.mobilityAnswer, + footprintTableName, + parameterTableName + ); + profile.baselines = profile.baselines.concat(baselines); + profile.estimations = profile.estimations.concat(estimations); } if (profile.foodAnswer) { const { baselines, estimations } = await estimateFood( - dynamodb, - profile.foodAnswer, - footprintTableName, - parameterTableName - ) - profile.baselines = profile.baselines.concat(baselines) - profile.estimations = profile.estimations.concat(estimations) + dynamodb, + profile.foodAnswer, + footprintTableName, + parameterTableName + ); + profile.baselines = profile.baselines.concat(baselines); + profile.estimations = profile.estimations.concat(estimations); } if (profile.otherAnswer) { const { baselines, estimations } = await estimateOther( - dynamodb, - profile.housingAnswer, - profile.otherAnswer, - footprintTableName, - parameterTableName - ) - profile.baselines = profile.baselines.concat(baselines) - profile.estimations = profile.estimations.concat(estimations) + dynamodb, + profile.housingAnswer, + profile.otherAnswer, + footprintTableName, + parameterTableName + ); + profile.baselines = profile.baselines.concat(baselines); + profile.estimations = profile.estimations.concat(estimations); } -} +}; /************************************ * HTTP put method for insert object * *************************************/ app.put(path + '/:id', async (req: express.Request, res: express.Response) => { - const id = req.params.id - const estimate = req.body.estimate - const body: any = req.body + const id = req.params.id; + const estimate = req.body.estimate; + const body: any = req.body; if (validate(req.body)) { try { - const data = await dynamodb - .get({ - TableName: profileTableName, - Key: { id } - }) - const profile = data.Item + const data = await dynamodb.send(new GetCommand({ + TableName: PROFILE_TABLE_NAME, + Key: { id } + })); + const profile = data.Item; + + if (profile == undefined) { + res.statusCode = 404; + res.json({ error: 'Could not load item: ' + req.params.id }); + return + } if (body.mobilityAnswer) { - profile.mobilityAnswer = body.mobilityAnswer + profile.mobilityAnswer = body.mobilityAnswer; } if (body.housingAnswer) { - profile.housingAnswer = body.housingAnswer + profile.housingAnswer = body.housingAnswer; } if (body.foodAnswer) { - profile.foodAnswer = body.foodAnswer + profile.foodAnswer = body.foodAnswer; } if (body.otherAnswer) { - profile.otherAnswer = body.otherAnswer + profile.otherAnswer = body.otherAnswer; } - profile.estimated = false + profile.estimated = false; if (estimate) { - await updateProfile(dynamodb, profile) - profile.updatedAt = new Date().toISOString() - profile.estimated = true + await updateProfile(dynamodb, profile); + profile.updatedAt = new Date().toISOString(); + profile.estimated = true; } - await dynamodb - .put({ - TableName: profileTableName, - Item: profile - }) + await dynamodb.send(new PutCommand({ + TableName: profileTableName, + Item: profile + })); - await addScore(profile) + await addScore(profile); res.json({ success: 'put call succeed!', url: req.url, data: toResponse(profile, estimate) - }) - } catch (err) { - res.statusCode = 500 - res.json({ error: 'Could not load items: ' + err }) + }); + } catch (err: any) { + res.statusCode = 500; + res.json({ + error: 'Could not load items', + message: err.message, + stack: err.stack + }); } } else { - res.statusCode = 400 - res.json({ error: validate.errors }) + res.statusCode = 400; + res.json({ error: validate.errors }); } -}) +}); /************************************ * HTTP post method for insert object * @@ -227,8 +235,8 @@ app.put(path + '/:id', async (req: express.Request, res: express.Response) => { app.post(path, async (req: express.Request, res: express.Response) => { if (validate(req.body)) { try { - const body: any = req.body - const estimate = body.estimate + const body: any = req.body; + const estimate = body.estimate; const profile = { estimated: false, @@ -243,35 +251,35 @@ app.post(path, async (req: express.Request, res: express.Response) => { createdAt: new Date().toISOString(), updatedAt: new Date().toISOString() - } + }; if (estimate) { - await updateProfile(dynamodb, profile) - profile.estimated = true + await updateProfile(dynamodb, profile); + profile.estimated = true; } const params = { TableName: profileTableName, Item: profile - } - await dynamodb.put(params) - await addScore(profile) + }; + await dynamodb.send(new PutCommand(params)); + await addScore(profile); res.json({ success: 'post call succeed!', url: req.url, data: toResponse(profile, estimate) - }) + }); } catch (err) { - res.statusCode = 500 - res.json({ error: err, url: req.url, body: req.body }) + res.statusCode = 500; + res.json({ error: err, url: req.url, body: req.body }); } } else { - res.statusCode = 400 - res.json({ error: validate.errors }) + res.statusCode = 400; + res.json({ error: validate.errors }); } -}) +}); // Export the app object. When executing the application local this does nothing. However, // to port it to AWS Lambda we will create a wrapper around that will load the app from // this file -export default app +export default app; diff --git a/lib/props.ts b/lib/props.ts index 96f1c76..c6023d7 100644 --- a/lib/props.ts +++ b/lib/props.ts @@ -1,4 +1,3 @@ - import { StackProps } from 'aws-cdk-lib' export interface BaseStackProps extends StackProps { diff --git a/openapi.yaml b/openapi.yaml new file mode 100644 index 0000000..bbe05b2 --- /dev/null +++ b/openapi.yaml @@ -0,0 +1,857 @@ +openapi: "3.0.1" +info: + title: "JibungotoPlanet-Api" + version: "2024-03-11" +servers: + - url: "https://public-api.jibungoto-planet.jp/" + description: Production server + - url: "https://dev-api.jibungoto-planet.jp/" + description: development server +paths: + /footprints/{type}: + get: + summary: Get a list of carbon footprint data for a specified type. + description: > + Retrieves a list of carbon footprint entries based on the specified type. + Each entry includes detailed data about the carbon footprints in different cities and domains. + parameters: + - name: type + in: path + required: true + description: The type of data to retrieve, such as City or Region. + schema: + $ref: '#/components/schemas/Type' + responses: + "200": + description: A successful response containing an array of carbon footprint data entries. + headers: + Access-Control-Allow-Origin: + schema: + type: "string" + Access-Control-Allow-Methods: + schema: + type: "string" + Access-Control-Allow-Headers: + schema: + type: "string" + content: + application/json: + schema: + type: array + items: + anyOf: + - $ref: '#/components/schemas/CarbonFootprintData' + - $ref: '#/components/schemas/Source' + /footprints/{type}/{city_name}: + get: + summary: Get carbon footprint data for a specified city within a given type. + description: > + Retrieves detailed carbon footprint data for a specific city within the given type. + This can include multiple entries depending on the city's available data. + parameters: + - name: "type" + in: "path" + required: true + description: The type of the data, usually 'City'. + schema: + $ref: '#/components/schemas/Type' + - name: "city_name" + in: "path" + required: true + schema: + $ref: '#/components/schemas/CityNames' + responses: + "200": + description: "200 response" + headers: + Access-Control-Allow-Origin: + schema: + type: "string" + Access-Control-Allow-Methods: + schema: + type: "string" + Access-Control-Allow-Headers: + schema: + type: "string" + content: + application/json: + schema: + type: array + items: + anyOf: + - $ref: '#/components/schemas/CarbonFootprintData' + - $ref: '#/components/schemas/Source' + /footprints/{type}/{city_name}/{domain}: + get: + summary: Get carbon footprint data for a specific city and domain. + description: Retrieves the carbon footprint data for a specific component in a city, based on type, city name, and domain. + parameters: + - name: "type" + in: "path" + required: true + description: The type of the data, usually 'City'. + schema: + $ref: '#/components/schemas/Type' + - name: "city_name" + in: "path" + required: true + schema: + $ref: '#/components/schemas/CityNames' + - name: "domain" + in: "path" + required: true + schema: + $ref: '#/components/schemas/Domains' + responses: + "200": + description: "200 response" + headers: + Access-Control-Allow-Origin: + schema: + type: "string" + Access-Control-Allow-Methods: + schema: + type: "string" + Access-Control-Allow-Headers: + schema: + type: "string" + content: + application/json: + schema: + type: array + items: + anyOf: + - $ref: '#/components/schemas/CarbonFootprintData' + - $ref: '#/components/schemas/Source' + '500': + description: Internal server error. + /footprints/{type}/{city_name}/{domain}/{component}: + get: + summary: Get specific carbon footprint data for a city, domain, and component. + description: > + Retrieves detailed carbon footprint data for a specific city within the given type, domain, and component. + This endpoint allows for highly specific data queries. + parameters: + - name: "type" + in: "path" + required: true + description: The type of the data, usually 'City'. + schema: + $ref: '#/components/schemas/Type' + - name: "city_name" + in: "path" + required: true + schema: + $ref: '#/components/schemas/CityNames' + - name: "domain" + in: "path" + required: true + schema: + $ref: '#/components/schemas/Domains' + - name: "component" + in: "path" + required: true + schema: + type: "string" + responses: + "200": + description: "200 response" + headers: + Access-Control-Allow-Origin: + schema: + type: "string" + Access-Control-Allow-Methods: + schema: + type: "string" + Access-Control-Allow-Headers: + schema: + type: "string" + content: + application/json: + schema: + type: array + items: + anyOf: + - $ref: '#/components/schemas/CarbonFootprintData' + - $ref: '#/components/schemas/Source' + /changeImpacts/{type}: + get: + summary: Retrieve data based on type + description: Retrieves lifestyle change data based on the specified type. + parameters: + - name: "type" + in: "path" + required: true + description: The type of the data, usually 'City'. + schema: + $ref: '#/components/schemas/Type' + responses: + "200": + description: "200 response" + headers: + Access-Control-Allow-Origin: + schema: + type: "string" + Access-Control-Allow-Methods: + schema: + type: "string" + Access-Control-Allow-Headers: + schema: + type: "string" + content: + application/json: + schema: + type: array + items: + anyOf: + - $ref: '#/components/schemas/ChangeImpactEntry' + - $ref: '#/components/schemas/Source' + /changeImpacts/{type}/{city_name}: + get: + summary: Retrieve data for a specified type and city + description: Retrieves lifestyle change data based on the specified type and city. + parameters: + - name: "type" + in: "path" + required: true + description: The type of the data, usually 'City'. + schema: + $ref: '#/components/schemas/Type' + - name: "city_name" + in: "path" + required: true + schema: + $ref: '#/components/schemas/CityNames' + responses: + "200": + description: "200 response" + headers: + Access-Control-Allow-Origin: + schema: + type: "string" + Access-Control-Allow-Methods: + schema: + type: "string" + Access-Control-Allow-Headers: + schema: + type: "string" + content: + application/json: + schema: + type: array + items: + anyOf: + - $ref: '#/components/schemas/ChangeImpactEntry' + - $ref: '#/components/schemas/Source' + /changeImpacts/{type}/{city_name}/{domain}: + get: + summary: Retrieve data based on type, city, and domain + description: Retrieves lifestyle change data based on the specified type, city, and domain. + parameters: + - name: "type" + in: "path" + required: true + description: The type of the data, usually 'City'. + schema: + $ref: '#/components/schemas/Type' + - name: "city_name" + in: "path" + required: true + schema: + $ref: '#/components/schemas/CityNames' + - name: "domain" + in: "path" + required: true + schema: + $ref: '#/components/schemas/ChangeImpactDomains' + responses: + "200": + description: "200 response" + headers: + Access-Control-Allow-Origin: + schema: + type: "string" + Access-Control-Allow-Methods: + schema: + type: "string" + Access-Control-Allow-Headers: + schema: + type: "string" + content: + application/json: + schema: + type: array + items: + anyOf: + - $ref: '#/components/schemas/ChangeImpactEntry' + - $ref: '#/components/schemas/Source' + /changeImpacts/{type}/{city_name}/{domain}/{group}: + get: + summary: Retrieve data based on type, city, domain, and group + description: Retrieves lifestyle change data based on the specified type, city, domain, and group. + parameters: + - name: "type" + in: "path" + required: true + description: The type of the data, usually 'City'. + schema: + $ref: '#/components/schemas/Type' + - name: "city_name" + in: "path" + required: true + schema: + $ref: '#/components/schemas/CityNames' + - name: "domain" + in: "path" + required: true + schema: + $ref: '#/components/schemas/ChangeImpactDomains' + - name: "group" + in: "path" + required: true + schema: + $ref: '#/components/schemas/ChangeImpactGroup' + responses: + "200": + description: "200 response" + headers: + Access-Control-Allow-Origin: + schema: + type: "string" + Access-Control-Allow-Methods: + schema: + type: "string" + Access-Control-Allow-Headers: + schema: + type: "string" + content: + application/json: + schema: + type: array + items: + anyOf: + - $ref: '#/components/schemas/ChangeImpactEntry' + - $ref: '#/components/schemas/Source' + /changeImpacts/{type}/{city_name}/{domain}/{group}/{options}: + get: + summary: Get potential impacts of lifestyle changes. + description: > + Retrieves detailed data on the potential impacts of various lifestyle change options for a specified city, domain, and group. + parameters: + - name: "type" + in: "path" + required: true + description: The type of the data, usually 'City'. + schema: + $ref: '#/components/schemas/Type' + - name: "city_name" + in: "path" + required: true + schema: + $ref: '#/components/schemas/CityNames' + - name: "domain" + in: "path" + required: true + schema: + $ref: '#/components/schemas/ChangeImpactDomains' + - name: "group" + in: "path" + required: true + schema: + $ref: '#/components/schemas/ChangeImpactGroup' + - name: "options" + in: "path" + required: true + schema: + type: "string" + responses: + "200": + description: A successful response containing the potential impact data. + headers: + Access-Control-Allow-Origin: + schema: + type: "string" + Access-Control-Allow-Methods: + schema: + type: "string" + Access-Control-Allow-Headers: + schema: + type: "string" + content: + application/json: + schema: + type: array + items: + anyOf: + - $ref: '#/components/schemas/ChangeImpactEntry' + - $ref: '#/components/schemas/Source' + /calculates/{id}: + get: + summary: Get profile data by ID + description: Retrieve profile data including estimated carbon footprints. + parameters: + - name: "id" + in: "path" + required: true + description: Profile ID + schema: + type: "string" + responses: + "200": + description: "200 response" + headers: + Access-Control-Allow-Origin: + schema: + type: "string" + Access-Control-Allow-Methods: + schema: + type: "string" + Access-Control-Allow-Headers: + schema: + type: "string" + content: { } + put: + summary: Update profile data by ID + description: Update profile data and optionally recalculate carbon footprints. + parameters: + - name: "id" + in: "path" + required: true + description: Profile ID + schema: + type: "string" + requestBody: + required: true + content: + application/json: + schema: + $ref: '#/components/schemas/ProfileRequest' + responses: + "200": + description: "200 response" + headers: + Access-Control-Allow-Origin: + schema: + type: "string" + Access-Control-Allow-Methods: + schema: + type: "string" + Access-Control-Allow-Headers: + schema: + type: "string" + content: + application/json: + schema: + $ref: '#/components/schemas/ProfileResponse' + /calculates: + post: + requestBody: + required: true + content: + application/json: + schema: + $ref: '#/components/schemas/CreateProfileRequest' + summary: Create new profile data + description: Create new profile data and optionally calculate carbon footprints. + responses: + "200": + description: "200 response" + headers: + Access-Control-Allow-Origin: + schema: + type: "string" + Access-Control-Allow-Methods: + schema: + type: "string" + Access-Control-Allow-Headers: + schema: + type: "string" + content: + application/json: + schema: + $ref: '#/components/schemas/CreateProfileResponse' +components: + schemas: + Type: + type: string + enum: [ City, Region, Metropolitan, Class, Country ] + CityNames: + type: string + enum: [ Akita, Aomori, Chiba, ChugokuReg., ChukyoMetro., Cities50000+pop., Fukui, Fukuoka, Fukushima, Gifu, Hamamatsu, Hiroshima, HokkaidoReg., HokurikuReg., Japan, Kagoshima, Kanazawa, KantoMetro., KantoReg., Kawasaki, KinkiMetro., KinkiReg., Kitakyushu, Kitakyushu/FukuokaMetro., Kobe, Kochi, Kofu, Kumamoto, Kyoto, KyushuReg., LargeCities, Maebashi, Matsue, Matsuyama, MiddleCities, Mito, Miyazaki, Morioka, Nagano, Nagasaki, Nagoya, Naha, Nara, Niigata, Oita, Okayama, OkinawaReg., Osaka, Otsu, Saga, Sagamihara, Saitama, Sakae, Sapporo, Sendai, ShikokuReg., Shizuoka, SmallB/Towns/Villages, SmallCitiesA, Takamatsu, TohokuReg., TokaiReg., Tokushima, Tokyo, Tottori, Toyama, Tsu, Utsunomiya, Wakayama, Yamagata, Yamaguchi, Yokohama ] + Domains: + type: string + enum: [ Housing, Mobility, Food, Goods, Leisure, Services ] + ChangeImpactDomains: + type: string + enum: [ Housing, Mobility, Food, Other ] + ChangeImpactGroup: + type: string + enum: [ Material Sufficiency, Durability and Repair, Decarbonized Leisure and Service, Seasonal and Local Food, Food Loss, Protein Shift, Dietary Shift, Energy Behavior, Appliances, Housing Sufficiency, Renewable Energy, Eco House, Compact City, Micro Leisure, Demand Reduction, Modal Shift, Vehicle Efficiency, Vehicle Sharing ] + Options: + type: string + enum: [ 'E-Books', 'Consumables Saving', 'Furniture Longer Use', 'Accessory Longer Use', 'Electronics Longer Use', 'Hobby Products Longer Use', 'Clothes Longer Use', 'Healthy Lifestyles', 'Eco Tourism', 'Community Recreation', 'Local Food', 'Seasonal Food', 'Food Loss Reduction', 'Pollotarian Diet', 'Pescatarian Diet', 'Alternative Meat', 'Food Guide Snacks/Drinks', 'Food Guide Meal', 'Vegetarian Diet', 'Vegan Diet', 'Energy Saving by Nudging', 'Warm/Cool Clothes', 'LED Lighting', 'Air Conditioner', 'Water Heat Pump', 'Compact House', 'Solar Water Heater', 'Renewable Grid Electricity', 'Rooftop Solar PV', 'Rooftop Solar PV (IH)', 'Window Insulation', 'Insulation Renovation', 'Nearly Zero Energy House', 'Zero Energy House', 'Life Cycle Carbon Minus House', 'Living Close to Services', 'Living Close to Workplace', 'Local Weekend', 'Domestic Vacation', 'Local Vacation', 'Less Frequent Shopping', 'Online Homecoming Visit', 'Teleworking', 'Taxi Trips', 'Domestic Flights', 'Long Distance Trips', 'Commuting Trips', 'In-city Private Trips', 'Eco Driving', 'Light Vehicle', 'Non-plug-in Hybrid Vehicle', 'Electric Vehicle', 'Plug-in Hybrid Vehicle', 'Plug-in Hybrid Vehicle (RE)', 'Electric Vehicle (RE)', 'Carsharing', 'Ridesharing' ] + CarbonFootprintData: + type: object + properties: + city_name: + type: string + CarbonFootprints: + type: number + format: float + No: + type: integer + format: int32 + Domain: + type: string + Component: + type: string + English: + type: string + Japanese: + type: string + Type: + type: string + ChangeImpactEntry: + type: object + properties: + CityName: + type: string + Potential: + type: number + format: float + Domain: + type: string + Group: + type: string + Options: + type: string + Type: + type: string + Japanese: + type: string + Source: + type: object + properties: + source: + type: string + format: uri + CreateProfileRequest: + type: object + properties: + estimate: + type: boolean + required: + - estimate + CreateProfileResponse: + type: object + properties: + success: + type: string + example: "post call succeed!" + url: + type: string + example: "/calculates" + data: + type: object + properties: + id: + type: string + example: "237220a7-0c0e-42ea-9879-243398f0222b" + baselines: + type: array + items: + type: object + estimations: + type: array + items: + type: object + mobilityScore: + type: array + items: + type: object + properties: + key: + type: string + value: + type: number + foodScore: + type: array + items: + type: object + properties: + key: + type: string + value: + type: number + housingScore: + type: array + items: + type: object + properties: + key: + type: string + value: + type: number + otherScore: + type: array + items: + type: object + properties: + key: + type: string + value: + type: number + ProfileRequest: + type: object + properties: + estimate: + type: boolean + mobilityAnswer: + type: object + properties: + carIntensityFactorFirstKey: + type: string + pattern: '^gasoline$|^light$|^hv$|^phv$|^ev$|^unknown$' + carChargingKey: + type: string + pattern: '^charge-almost-at-home$|^use-charging-spots-occasionally$|^use-charging-spots-sometimes$|^use-charging-spots-usually$|^unknown$' + carPassengersFirstKey: + type: string + pattern: '^1$|^1-2$|^2$|^2-3$|^3$|^3-4$|^4-more$|^unknown$' + mileageByAreaFirstKey: + type: string + pattern: '^major-city-or-metropolitan-area$|^city-150k-more$|^city-50k-150k$|^area-less-than-50k$|^unknown$' + hasPrivateCar: + type: boolean + privateCarAnnualMileage: + type: number + minimum: 0 + trainWeeklyTravelingTime: + type: number + minimum: 0 + busWeeklyTravelingTime: + type: number + minimum: 0 + motorbikeWeeklyTravelingTime: + type: number + minimum: 0 + otherCarWeeklyTravelingTime: + type: number + minimum: 0 + hasTravelingTime: + type: boolean + otherCarAnnualTravelingTime: + type: number + minimum: 0 + trainAnnualTravelingTime: + type: number + minimum: 0 + busAnnualTravelingTime: + type: number + minimum: 0 + motorbikeAnnualTravelingTime: + type: number + minimum: 0 + airplaneAnnualTravelingTime: + type: number + minimum: 0 + ferryAnnualTravelingTime: + type: number + minimum: 0 + housingAnswer: + type: object + properties: + residentCount: + type: number + minimum: 1 + electricityMonthlyConsumption: + type: number + minimum: 0 + useGas: + type: boolean + gasMonthlyConsumption: + type: number + minimum: 0 + useKerosene: + type: boolean + keroseneMonthlyConsumption: + type: number + minimum: 0 + keroseneMonthCount: + type: number + minimum: 0 + housingSizeKey: + type: string + pattern: '^1-room$|^2-room$|^3-room$|^4-room$|^5-6-room$|^7-more-room$|^unknown$' + housingInsulationFirstKey: + type: string + pattern: '^no-insulation$|^2-level$|^3-level$|^4-level$|^unknown$' + electricityIntensityKey: + type: string + pattern: '^conventional$|^30-renewable$|^50-renewable$|^100-renewable$|^solar-panel$|^unknown$' + electricitySeasonFactorKey: + type: string + pattern: '^january$|^february$|^march$|^april$|^may$|^june$|^july$|^august$|^september$|^october$|^november$|^december$' + energyHeatIntensityKey: + type: string + pattern: '^urban-gas$|^lpg$|^unknown$' + gasSeasonFactorKey: + type: string + pattern: '^january$|^february$|^march$|^april$|^may$|^june$|^july$|^august$|^september$|^october$|^november$|^december$' + housingAmountByRegionFirstKey: + type: string + pattern: '^northeast$|^middle$|^southwest$|^unknown$' + foodAnswer: + type: object + properties: + foodIntakeFactorKey: + type: string + pattern: '^very-little$|^somewhat-little$|^moderate$|^somewhat-much$|^very-much$|^unknown$' + foodDirectWasteFactorKey: + type: string + pattern: '^seldom$|^1-per-week$|^2-3-per-week$|^4-7-per-week$|^8-more-per-week$|^unknown$' + foodLeftoverFactorKey: + type: string + pattern: '^seldom$|^1-per-week$|^2-3-per-week$|^4-7-per-week$|^8-more-per-week$|^unknown$' + dishBeefFactorKey: + type: string + pattern: '^everyday$|^4-5-per-week$|^2-3-per-week$|^1-per-week$|^2-3-per-month$|^1-less-per-month$|^never$|^unknown$' + dishPorkFactorKey: + type: string + pattern: '^everyday$|^4-5-per-week$|^2-3-per-week$|^1-per-week$|^2-3-per-month$|^1-less-per-month$|^never$|^unknown$' + dishChickenFactorKey: + type: string + pattern: '^everyday$|^4-5-per-week$|^2-3-per-week$|^1-per-week$|^2-3-per-month$|^1-less-per-month$|^never$|^unknown$' + dishSeafoodFactorKey: + type: string + pattern: '^everyday$|^4-5-per-week$|^2-3-per-week$|^1-per-week$|^2-3-per-month$|^1-less-per-month$|^never$|^unknown$' + dairyFoodFactorKey: + type: string + pattern: '^3-more-per-day$|^2-per-day$|^1-per-day$|^half-of-week$|^1-2-less-per-week$|^never$|^unknown$' + alcoholFactorKey: + type: string + pattern: '^everyday$|^4-5-per-week$|^2-3-per-week$|^1-per-week$|^2-3-less-per-month$|^never$|^unknown$' + softDrinkSnackFactorKey: + type: string + pattern: '^3k-less$|^3k-5k$|^5k-10k$|^10k-15k$|^15k-more$|^unknown$' + eatOutFactorKey: + type: string + pattern: '^5k-less$|^5k-10k$|^10k-20k$|^20k-50k$|^50k-more$|^unknown$' + otherAnswer: + type: object + properties: + dailyGoodsAmountKey: + type: string + pattern: '^5k-less$|^5k-10k$|^10k-20k$|^20k-30k$|^30k-more$|^unknown$|^average-per-capita$' + communicationAmountKey: + type: string + pattern: '^5k-less$|^5k-10k$|^10k-20k$|^20k-30k$|^30k-more$|^unknown$|^average-per-capita$' + applianceFurnitureAmountKey: + type: string + pattern: '^50k-less$|^50k-100k$|^100k-200k$|^200k-300k$|^$|^300k-400k$|^400k-more$|^unknown$|^average-per-capita$' + serviceFactorKey: + type: string + pattern: '^5k-less$|^5k-10k$|^10k-20k$|^20k-50k$|^50k-more$|^unknown$' + hobbyGoodsFactorKey: + type: string + pattern: '^5k-less$|^5k-10k$|^10k-20k$|^20k-50k$|^50k-more$|^unknown$' + clothesBeautyFactorKey: + type: string + pattern: '^5k-less$|^5k-10k$|^10k-20k$|^20k-50k$|^50k-more$|^unknown$' + leisureSportsFactorKey: + type: string + pattern: '^5k-less$|^5k-10k$|^10k-20k$|^20k-50k$|^50k-more$|^unknown$' + travelFactorKey: + type: string + pattern: '^10k-less$|^10k-30k$|^30k-50k$|^50k-100k$|^100k-200k$|^200k-more$|^unknown$' + additionalProperties: false + ProfileResponse: + type: object + properties: + id: + type: string + mobilityAnswer: + type: object + housingAnswer: + type: object + foodAnswer: + type: object + otherAnswer: + type: object + baselines: + type: array + items: + type: object + properties: + domain: + type: string + item: + type: string + type: + type: string + value: + type: number + subdomain: + type: string + unit: + type: string + estimations: + type: array + items: + type: object + properties: + domain: + type: string + item: + type: string + type: + type: string + value: + type: number + subdomain: + type: string + unit: + type: string + mobilityScore: + type: array + items: + type: object + properties: + key: + type: string + value: + type: number + foodScore: + type: array + items: + type: object + properties: + key: + type: string + value: + type: number + housingScore: + type: array + items: + type: object + properties: + key: + type: string + value: + type: number + otherScore: + type: array + items: + type: object + properties: + key: + type: string + value: + type: number + createdAt: + type: string + format: date-time + updatedAt: + type: string + format: date-time + diff --git a/package.json b/package.json index 58beb6b..2ea4e8b 100644 --- a/package.json +++ b/package.json @@ -21,7 +21,11 @@ "typescript": "~5.4.5" }, "dependencies": { + "@aws-sdk/client-dynamodb": "^3.575.0", + "@aws-sdk/lib-dynamodb": "^3.575.0", "@types/supertest": "^6.0.2", + "@typescript-eslint/eslint-plugin": "^7.9.0", + "@typescript-eslint/parser": "^7.9.0", "ajv": "^8.13.0", "aws-cdk-lib": "2.141.0", "aws-sdk": "^2.1618.0", diff --git a/yarn.lock b/yarn.lock index f93638e..1660d6e 100644 --- a/yarn.lock +++ b/yarn.lock @@ -25,6 +25,496 @@ resolved "https://registry.npmjs.org/@aws-cdk/asset-node-proxy-agent-v6/-/asset-node-proxy-agent-v6-2.0.3.tgz" integrity sha512-twhuEG+JPOYCYPx/xy5uH2+VUsIEhPTzDY0F1KuB+ocjWWB/KEDiOVL19nHvbPCB6fhWnkykXEMJ4HHcKvjtvg== +"@aws-crypto/ie11-detection@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@aws-crypto/ie11-detection/-/ie11-detection-3.0.0.tgz#640ae66b4ec3395cee6a8e94ebcd9f80c24cd688" + integrity sha512-341lBBkiY1DfDNKai/wXM3aujNBkXR7tq1URPQDL9wi3AUbI80NR74uF1TXHMm7po1AcnFk8iu2S2IeU/+/A+Q== + dependencies: + tslib "^1.11.1" + +"@aws-crypto/sha256-browser@3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@aws-crypto/sha256-browser/-/sha256-browser-3.0.0.tgz#05f160138ab893f1c6ba5be57cfd108f05827766" + integrity sha512-8VLmW2B+gjFbU5uMeqtQM6Nj0/F1bro80xQXCW6CQBWgosFWXTx77aeOF5CAIAmbOK64SdMBJdNr6J41yP5mvQ== + dependencies: + "@aws-crypto/ie11-detection" "^3.0.0" + "@aws-crypto/sha256-js" "^3.0.0" + "@aws-crypto/supports-web-crypto" "^3.0.0" + "@aws-crypto/util" "^3.0.0" + "@aws-sdk/types" "^3.222.0" + "@aws-sdk/util-locate-window" "^3.0.0" + "@aws-sdk/util-utf8-browser" "^3.0.0" + tslib "^1.11.1" + +"@aws-crypto/sha256-js@3.0.0", "@aws-crypto/sha256-js@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@aws-crypto/sha256-js/-/sha256-js-3.0.0.tgz#f06b84d550d25521e60d2a0e2a90139341e007c2" + integrity sha512-PnNN7os0+yd1XvXAy23CFOmTbMaDxgxXtTKHybrJ39Y8kGzBATgBFibWJKH6BhytLI/Zyszs87xCOBNyBig6vQ== + dependencies: + "@aws-crypto/util" "^3.0.0" + "@aws-sdk/types" "^3.222.0" + tslib "^1.11.1" + +"@aws-crypto/supports-web-crypto@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@aws-crypto/supports-web-crypto/-/supports-web-crypto-3.0.0.tgz#5d1bf825afa8072af2717c3e455f35cda0103ec2" + integrity sha512-06hBdMwUAb2WFTuGG73LSC0wfPu93xWwo5vL2et9eymgmu3Id5vFAHBbajVWiGhPO37qcsdCap/FqXvJGJWPIg== + dependencies: + tslib "^1.11.1" + +"@aws-crypto/util@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@aws-crypto/util/-/util-3.0.0.tgz#1c7ca90c29293f0883468ad48117937f0fe5bfb0" + integrity sha512-2OJlpeJpCR48CC8r+uKVChzs9Iungj9wkZrl8Z041DWEWvyIHILYKCPNzJghKsivj+S3mLo6BVc7mBNzdxA46w== + dependencies: + "@aws-sdk/types" "^3.222.0" + "@aws-sdk/util-utf8-browser" "^3.0.0" + tslib "^1.11.1" + +"@aws-sdk/client-dynamodb@^3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/client-dynamodb/-/client-dynamodb-3.575.0.tgz#5be07d3279eba5ef56ff70e25f26a4042802d026" + integrity sha512-9qS95Ym+P/DqcvL+UtqWVnnN+G8W1TOCLOde+y4EYeg8HLOy0AfCK24s3cbhgokb6NsAQnyAPrAT8F4bZhUlQw== + dependencies: + "@aws-crypto/sha256-browser" "3.0.0" + "@aws-crypto/sha256-js" "3.0.0" + "@aws-sdk/client-sso-oidc" "3.575.0" + "@aws-sdk/client-sts" "3.575.0" + "@aws-sdk/core" "3.575.0" + "@aws-sdk/credential-provider-node" "3.575.0" + "@aws-sdk/middleware-endpoint-discovery" "3.575.0" + "@aws-sdk/middleware-host-header" "3.575.0" + "@aws-sdk/middleware-logger" "3.575.0" + "@aws-sdk/middleware-recursion-detection" "3.575.0" + "@aws-sdk/middleware-user-agent" "3.575.0" + "@aws-sdk/region-config-resolver" "3.575.0" + "@aws-sdk/types" "3.575.0" + "@aws-sdk/util-endpoints" "3.575.0" + "@aws-sdk/util-user-agent-browser" "3.575.0" + "@aws-sdk/util-user-agent-node" "3.575.0" + "@smithy/config-resolver" "^3.0.0" + "@smithy/core" "^2.0.0" + "@smithy/fetch-http-handler" "^3.0.0" + "@smithy/hash-node" "^3.0.0" + "@smithy/invalid-dependency" "^3.0.0" + "@smithy/middleware-content-length" "^3.0.0" + "@smithy/middleware-endpoint" "^3.0.0" + "@smithy/middleware-retry" "^3.0.0" + "@smithy/middleware-serde" "^3.0.0" + "@smithy/middleware-stack" "^3.0.0" + "@smithy/node-config-provider" "^3.0.0" + "@smithy/node-http-handler" "^3.0.0" + "@smithy/protocol-http" "^4.0.0" + "@smithy/smithy-client" "^3.0.0" + "@smithy/types" "^3.0.0" + "@smithy/url-parser" "^3.0.0" + "@smithy/util-base64" "^3.0.0" + "@smithy/util-body-length-browser" "^3.0.0" + "@smithy/util-body-length-node" "^3.0.0" + "@smithy/util-defaults-mode-browser" "^3.0.0" + "@smithy/util-defaults-mode-node" "^3.0.0" + "@smithy/util-endpoints" "^2.0.0" + "@smithy/util-middleware" "^3.0.0" + "@smithy/util-retry" "^3.0.0" + "@smithy/util-utf8" "^3.0.0" + "@smithy/util-waiter" "^3.0.0" + tslib "^2.6.2" + uuid "^9.0.1" + +"@aws-sdk/client-sso-oidc@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/client-sso-oidc/-/client-sso-oidc-3.575.0.tgz#640a38d9fa63ec837b02c4463d84f6828c8662ed" + integrity sha512-YCstVaW5tAvXs+v4LR9gNAO+VRhIObjk1/knCdVQ5QQRTevtVQtdJWeNrDZYo4ATo0OHGyqGCj5Z09TWMv+e1Q== + dependencies: + "@aws-crypto/sha256-browser" "3.0.0" + "@aws-crypto/sha256-js" "3.0.0" + "@aws-sdk/client-sts" "3.575.0" + "@aws-sdk/core" "3.575.0" + "@aws-sdk/credential-provider-node" "3.575.0" + "@aws-sdk/middleware-host-header" "3.575.0" + "@aws-sdk/middleware-logger" "3.575.0" + "@aws-sdk/middleware-recursion-detection" "3.575.0" + "@aws-sdk/middleware-user-agent" "3.575.0" + "@aws-sdk/region-config-resolver" "3.575.0" + "@aws-sdk/types" "3.575.0" + "@aws-sdk/util-endpoints" "3.575.0" + "@aws-sdk/util-user-agent-browser" "3.575.0" + "@aws-sdk/util-user-agent-node" "3.575.0" + "@smithy/config-resolver" "^3.0.0" + "@smithy/core" "^2.0.0" + "@smithy/fetch-http-handler" "^3.0.0" + "@smithy/hash-node" "^3.0.0" + "@smithy/invalid-dependency" "^3.0.0" + "@smithy/middleware-content-length" "^3.0.0" + "@smithy/middleware-endpoint" "^3.0.0" + "@smithy/middleware-retry" "^3.0.0" + "@smithy/middleware-serde" "^3.0.0" + "@smithy/middleware-stack" "^3.0.0" + "@smithy/node-config-provider" "^3.0.0" + "@smithy/node-http-handler" "^3.0.0" + "@smithy/protocol-http" "^4.0.0" + "@smithy/smithy-client" "^3.0.0" + "@smithy/types" "^3.0.0" + "@smithy/url-parser" "^3.0.0" + "@smithy/util-base64" "^3.0.0" + "@smithy/util-body-length-browser" "^3.0.0" + "@smithy/util-body-length-node" "^3.0.0" + "@smithy/util-defaults-mode-browser" "^3.0.0" + "@smithy/util-defaults-mode-node" "^3.0.0" + "@smithy/util-endpoints" "^2.0.0" + "@smithy/util-middleware" "^3.0.0" + "@smithy/util-retry" "^3.0.0" + "@smithy/util-utf8" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/client-sso@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/client-sso/-/client-sso-3.575.0.tgz#473e1315e4601319f11b50bd2c5d28992aa0e820" + integrity sha512-elFWpAtktD3XBy47etG80GKXK9Lh3sNCMXLjcSs0NS0fdRIQJS2zKxC8qK22UQmdFKpXxthND5FKk7fNEqrR+g== + dependencies: + "@aws-crypto/sha256-browser" "3.0.0" + "@aws-crypto/sha256-js" "3.0.0" + "@aws-sdk/core" "3.575.0" + "@aws-sdk/middleware-host-header" "3.575.0" + "@aws-sdk/middleware-logger" "3.575.0" + "@aws-sdk/middleware-recursion-detection" "3.575.0" + "@aws-sdk/middleware-user-agent" "3.575.0" + "@aws-sdk/region-config-resolver" "3.575.0" + "@aws-sdk/types" "3.575.0" + "@aws-sdk/util-endpoints" "3.575.0" + "@aws-sdk/util-user-agent-browser" "3.575.0" + "@aws-sdk/util-user-agent-node" "3.575.0" + "@smithy/config-resolver" "^3.0.0" + "@smithy/core" "^2.0.0" + "@smithy/fetch-http-handler" "^3.0.0" + "@smithy/hash-node" "^3.0.0" + "@smithy/invalid-dependency" "^3.0.0" + "@smithy/middleware-content-length" "^3.0.0" + "@smithy/middleware-endpoint" "^3.0.0" + "@smithy/middleware-retry" "^3.0.0" + "@smithy/middleware-serde" "^3.0.0" + "@smithy/middleware-stack" "^3.0.0" + "@smithy/node-config-provider" "^3.0.0" + "@smithy/node-http-handler" "^3.0.0" + "@smithy/protocol-http" "^4.0.0" + "@smithy/smithy-client" "^3.0.0" + "@smithy/types" "^3.0.0" + "@smithy/url-parser" "^3.0.0" + "@smithy/util-base64" "^3.0.0" + "@smithy/util-body-length-browser" "^3.0.0" + "@smithy/util-body-length-node" "^3.0.0" + "@smithy/util-defaults-mode-browser" "^3.0.0" + "@smithy/util-defaults-mode-node" "^3.0.0" + "@smithy/util-endpoints" "^2.0.0" + "@smithy/util-middleware" "^3.0.0" + "@smithy/util-retry" "^3.0.0" + "@smithy/util-utf8" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/client-sts@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/client-sts/-/client-sts-3.575.0.tgz#9e24a85588ff8db537c7d9c558a19fd54dfd7ab3" + integrity sha512-8MrT4J2dRiskf0JFMGL5VNBqPvc6igNa218LGBJzHXmLsm1WfGCGnce84R7U2USr8oPOenu0XzSCLvMQyZbGWQ== + dependencies: + "@aws-crypto/sha256-browser" "3.0.0" + "@aws-crypto/sha256-js" "3.0.0" + "@aws-sdk/client-sso-oidc" "3.575.0" + "@aws-sdk/core" "3.575.0" + "@aws-sdk/credential-provider-node" "3.575.0" + "@aws-sdk/middleware-host-header" "3.575.0" + "@aws-sdk/middleware-logger" "3.575.0" + "@aws-sdk/middleware-recursion-detection" "3.575.0" + "@aws-sdk/middleware-user-agent" "3.575.0" + "@aws-sdk/region-config-resolver" "3.575.0" + "@aws-sdk/types" "3.575.0" + "@aws-sdk/util-endpoints" "3.575.0" + "@aws-sdk/util-user-agent-browser" "3.575.0" + "@aws-sdk/util-user-agent-node" "3.575.0" + "@smithy/config-resolver" "^3.0.0" + "@smithy/core" "^2.0.0" + "@smithy/fetch-http-handler" "^3.0.0" + "@smithy/hash-node" "^3.0.0" + "@smithy/invalid-dependency" "^3.0.0" + "@smithy/middleware-content-length" "^3.0.0" + "@smithy/middleware-endpoint" "^3.0.0" + "@smithy/middleware-retry" "^3.0.0" + "@smithy/middleware-serde" "^3.0.0" + "@smithy/middleware-stack" "^3.0.0" + "@smithy/node-config-provider" "^3.0.0" + "@smithy/node-http-handler" "^3.0.0" + "@smithy/protocol-http" "^4.0.0" + "@smithy/smithy-client" "^3.0.0" + "@smithy/types" "^3.0.0" + "@smithy/url-parser" "^3.0.0" + "@smithy/util-base64" "^3.0.0" + "@smithy/util-body-length-browser" "^3.0.0" + "@smithy/util-body-length-node" "^3.0.0" + "@smithy/util-defaults-mode-browser" "^3.0.0" + "@smithy/util-defaults-mode-node" "^3.0.0" + "@smithy/util-endpoints" "^2.0.0" + "@smithy/util-middleware" "^3.0.0" + "@smithy/util-retry" "^3.0.0" + "@smithy/util-utf8" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/core@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/core/-/core-3.575.0.tgz#c336796db71faac1140aa1b4e4d5f50932964fba" + integrity sha512-117U+kQki2XoKcYQfepmlRcNxn6rELGlOFOBQ8Z2JTBXEYHblW2ke067a0CLmxFwp/zCWuc7IGjd3in3x4Q3rg== + dependencies: + "@smithy/core" "^2.0.0" + "@smithy/protocol-http" "^4.0.0" + "@smithy/signature-v4" "^3.0.0" + "@smithy/smithy-client" "^3.0.0" + "@smithy/types" "^3.0.0" + fast-xml-parser "4.2.5" + tslib "^2.6.2" + +"@aws-sdk/credential-provider-env@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-env/-/credential-provider-env-3.575.0.tgz#2f0238719b383e37265e736575e9a9823a562982" + integrity sha512-YTgpq3rvYBXzW6OTDB00cE79evQtss/lz2GlJXgqqVXD0m7i77hGA8zb44VevP/WxtDaiSW7SSjuu8VCBGsg4g== + dependencies: + "@aws-sdk/types" "3.575.0" + "@smithy/property-provider" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/credential-provider-http@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-http/-/credential-provider-http-3.575.0.tgz#d410dba2ae89ea6c42bf30d319b98e410da14d1b" + integrity sha512-xQfVmYI+9KqRvhWY8fyElnpcVUBBUgi/Hoji3oU6WLrUjrX98k93He7gKDQSyHf7ykMLUAJYWwsV4AjQ2j6njA== + dependencies: + "@aws-sdk/types" "3.575.0" + "@smithy/fetch-http-handler" "^3.0.0" + "@smithy/node-http-handler" "^3.0.0" + "@smithy/property-provider" "^3.0.0" + "@smithy/protocol-http" "^4.0.0" + "@smithy/smithy-client" "^3.0.0" + "@smithy/types" "^3.0.0" + "@smithy/util-stream" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/credential-provider-ini@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-ini/-/credential-provider-ini-3.575.0.tgz#787faee394686d9af83ea482ea44168b5fe8b61d" + integrity sha512-BdM6a/5VUuNge3c6yRuxvO+4srLoSfqHfkQGfUDfhTdTJpljlpfnc9h3z2Ni1+aueOHPZMNFWIktHDcX5wUGBg== + dependencies: + "@aws-sdk/credential-provider-env" "3.575.0" + "@aws-sdk/credential-provider-process" "3.575.0" + "@aws-sdk/credential-provider-sso" "3.575.0" + "@aws-sdk/credential-provider-web-identity" "3.575.0" + "@aws-sdk/types" "3.575.0" + "@smithy/credential-provider-imds" "^3.0.0" + "@smithy/property-provider" "^3.0.0" + "@smithy/shared-ini-file-loader" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/credential-provider-node@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-node/-/credential-provider-node-3.575.0.tgz#eb0a69b229ea8a4f7240fa36968a8a4b661879e1" + integrity sha512-rEdNpqW2jEc5kwbf/s9XQywMLQlIkMjuCK6mw9sF2OVRGHGVnh+6eh/1JFx8Kj+eU51ctifQ7KaHe8dGco8HYQ== + dependencies: + "@aws-sdk/credential-provider-env" "3.575.0" + "@aws-sdk/credential-provider-http" "3.575.0" + "@aws-sdk/credential-provider-ini" "3.575.0" + "@aws-sdk/credential-provider-process" "3.575.0" + "@aws-sdk/credential-provider-sso" "3.575.0" + "@aws-sdk/credential-provider-web-identity" "3.575.0" + "@aws-sdk/types" "3.575.0" + "@smithy/credential-provider-imds" "^3.0.0" + "@smithy/property-provider" "^3.0.0" + "@smithy/shared-ini-file-loader" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/credential-provider-process@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-process/-/credential-provider-process-3.575.0.tgz#b1b409af833ccbce18e2806991434aa30f61ceb3" + integrity sha512-2/5NJV7MZysKglqJSQ/O8OELNcwLcH3xknabL9NagtzB7RNB2p1AUXR0UlTey9sSDLL4oCmNa/+unYuglW/Ahg== + dependencies: + "@aws-sdk/types" "3.575.0" + "@smithy/property-provider" "^3.0.0" + "@smithy/shared-ini-file-loader" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/credential-provider-sso@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-sso/-/credential-provider-sso-3.575.0.tgz#f39bbde97fe4dc2ecc2908cebfe79961a824fb58" + integrity sha512-NtXA9OPIKsqavs2F7hhLT/t2ZDjwJsvQevj31ov1NpmTNYMc7OWFWDptOG7rppsWMsk5KKmfiL2qViQJnezXNA== + dependencies: + "@aws-sdk/client-sso" "3.575.0" + "@aws-sdk/token-providers" "3.575.0" + "@aws-sdk/types" "3.575.0" + "@smithy/property-provider" "^3.0.0" + "@smithy/shared-ini-file-loader" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/credential-provider-web-identity@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-web-identity/-/credential-provider-web-identity-3.575.0.tgz#524ff9f944986c99486be5fa374db4d5895f63ff" + integrity sha512-QcvVH7wpvpFRXGAGgCBfQeiF/ptD0NJ+Hrc8dDYfPGhFeZ0EoVQBYNphLi25xe7JZ+XbaqCKrURHZtr4fAEOJw== + dependencies: + "@aws-sdk/types" "3.575.0" + "@smithy/property-provider" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/endpoint-cache@3.572.0": + version "3.572.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/endpoint-cache/-/endpoint-cache-3.572.0.tgz#414970b764db207eba4d93228363d61af33ea03b" + integrity sha512-CzuRWMj/xtN9p9eP915nlPmlyniTzke732Ow/M60++gGgB3W+RtZyFftw3TEx+NzNhd1tH54dEcGiWdiNaBz3Q== + dependencies: + mnemonist "0.38.3" + tslib "^2.6.2" + +"@aws-sdk/lib-dynamodb@^3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/lib-dynamodb/-/lib-dynamodb-3.575.0.tgz#503fb32fc63f8fa08a7785410594cbeb574b0fb6" + integrity sha512-pmWweAeztuU47yQqfd/fcSerI0syGLTLC7amnCAZCvd8y8BbSmpDuLctDGNQQTjiI3YbsGft0YO+An4SrMcsXQ== + dependencies: + "@aws-sdk/util-dynamodb" "3.575.0" + "@smithy/smithy-client" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/middleware-endpoint-discovery@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-endpoint-discovery/-/middleware-endpoint-discovery-3.575.0.tgz#bd9c714d65c0b8dd99f8c259f5317e7788fee876" + integrity sha512-IcswRas8vfUvvOCISAN5u1sVx0ioTqMZU6QYm3eVUwUDuZDvIDnrqLSGWPIS4c+Utc7RZcENgEYtbgb1aLSPVw== + dependencies: + "@aws-sdk/endpoint-cache" "3.572.0" + "@aws-sdk/types" "3.575.0" + "@smithy/node-config-provider" "^3.0.0" + "@smithy/protocol-http" "^4.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/middleware-host-header@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-host-header/-/middleware-host-header-3.575.0.tgz#5bf24080d6a6c466cdeaff49879c77559f74a2fd" + integrity sha512-V2WoLBiXNCc4rIWZt6FUcP4TN0Vk02A9PPCBWkTfyOooiqfq+WZmZjRRBpwl1+5UsvARslrKWF0VzheMRXPJLQ== + dependencies: + "@aws-sdk/types" "3.575.0" + "@smithy/protocol-http" "^4.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/middleware-logger@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-logger/-/middleware-logger-3.575.0.tgz#981c939cb3c10c1e3ecfa458c64f7be8c5a71307" + integrity sha512-7DEKx9Z11Maaye7FfhYtC8rjbM/PcFcMO2N4QEAfypcgWCj+w4gseE2OGdfAH9OFDoFc6YvLp53v16vbPjzQSg== + dependencies: + "@aws-sdk/types" "3.575.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/middleware-recursion-detection@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-recursion-detection/-/middleware-recursion-detection-3.575.0.tgz#924a4b7ca864600a202d82621bed3ddfd7819e06" + integrity sha512-ri89ldRFos6KZDGaknWPS2XPO9qr+gZ7+mPaoU8YkSM1W4uKqtnUSONyc+O3CFGJrqReuGHhRq0l2Sld0bjwOw== + dependencies: + "@aws-sdk/types" "3.575.0" + "@smithy/protocol-http" "^4.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/middleware-user-agent@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-user-agent/-/middleware-user-agent-3.575.0.tgz#1969f8b8972ee0c02753584575dde3e3b0b204b8" + integrity sha512-fWlr4RfrUNS2R3PgP+WsoMYORAgv/47Lp0J0fb3dXO1YvdczNWddRbFSUX2MQxM/y9XFfQPLpLgzluhoL3Cjeg== + dependencies: + "@aws-sdk/types" "3.575.0" + "@aws-sdk/util-endpoints" "3.575.0" + "@smithy/protocol-http" "^4.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/region-config-resolver@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/region-config-resolver/-/region-config-resolver-3.575.0.tgz#8be6a9411ec8b5da3f3d0cac44beaa5b9eb6341f" + integrity sha512-sBJKwTWKCWu9y8FzXIijYGwkKr3tDkPXM7BylToe6W+tGkp4OirV4iXrWA9zReNwTTepoxHufofqjGK9BtcI8g== + dependencies: + "@aws-sdk/types" "3.575.0" + "@smithy/node-config-provider" "^3.0.0" + "@smithy/types" "^3.0.0" + "@smithy/util-config-provider" "^3.0.0" + "@smithy/util-middleware" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/token-providers@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/token-providers/-/token-providers-3.575.0.tgz#0d5ded8434b49cafd7303a139d09c97155138d3b" + integrity sha512-EPNDPQoQkjKqn4D2t70qVzbfdtlaAy9KBdG58qD1yNWVxq8Rh/lXdwmB+aE2PSahtyfVikZdCRoZiFzxDh5IUA== + dependencies: + "@aws-sdk/types" "3.575.0" + "@smithy/property-provider" "^3.0.0" + "@smithy/shared-ini-file-loader" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/types@3.575.0", "@aws-sdk/types@^3.222.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/types/-/types-3.575.0.tgz#ed8f33e15c7ea22b5244018330475983d0558556" + integrity sha512-XrnolQGs0wXxdgNudirR14OgNOarH7WUif38+2Pd4onZH+L7XoILem0EgA1tRpgFpw2pFHlZCNaAHDNSBEal7g== + dependencies: + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/util-dynamodb@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-dynamodb/-/util-dynamodb-3.575.0.tgz#87f71b5a1066e23c2c9490ba7d206089551b5861" + integrity sha512-zdGZKhNM7QTez6MhSdm85rvTEiLMu+ol7G2RhqNweGcjemi7zBJvKrEanCg0Lf8sGMZYIwFC0KlOSy7XHQyQYg== + dependencies: + tslib "^2.6.2" + +"@aws-sdk/util-endpoints@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-endpoints/-/util-endpoints-3.575.0.tgz#370ad9b1ce7df227d44447ab2135c5e110aa72d2" + integrity sha512-wC5x+V6w3kRlR6X6XVINsAPDYG+Tzs3Wthlw+YLtjuPODUNZIQAqsABHahxnekFyAvse+1929Hwo+CaL+BHZGA== + dependencies: + "@aws-sdk/types" "3.575.0" + "@smithy/types" "^3.0.0" + "@smithy/util-endpoints" "^2.0.0" + tslib "^2.6.2" + +"@aws-sdk/util-locate-window@^3.0.0": + version "3.568.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-locate-window/-/util-locate-window-3.568.0.tgz#2acc4b2236af0d7494f7e517401ba6b3c4af11ff" + integrity sha512-3nh4TINkXYr+H41QaPelCceEB2FXP3fxp93YZXB/kqJvX0U9j0N0Uk45gvsjmEPzG8XxkPEeLIfT2I1M7A6Lig== + dependencies: + tslib "^2.6.2" + +"@aws-sdk/util-user-agent-browser@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-user-agent-browser/-/util-user-agent-browser-3.575.0.tgz#3054cc42e0b386a34f7b0d4e8e9609e016c72eed" + integrity sha512-iADonXyaXgwvC4T0qRuDWCdKInz82GX2cyezq/oqVlL8bPY7HD8jwZZruuJdq5tkaJi1EhbO4+f1ksZqOiZKvQ== + dependencies: + "@aws-sdk/types" "3.575.0" + "@smithy/types" "^3.0.0" + bowser "^2.11.0" + tslib "^2.6.2" + +"@aws-sdk/util-user-agent-node@3.575.0": + version "3.575.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-user-agent-node/-/util-user-agent-node-3.575.0.tgz#49a6ecc5f56297e1477de90f30f102c470d3dc78" + integrity sha512-kwzvBfA0LoILDOFS6BV8uOkksBHrYulP6kNXegB5eZnDSNia5DbBsXqxQ/HknNF5a429SWQw2aaQJEgQvZB1VA== + dependencies: + "@aws-sdk/types" "3.575.0" + "@smithy/node-config-provider" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@aws-sdk/util-utf8-browser@^3.0.0": + version "3.259.0" + resolved "https://registry.yarnpkg.com/@aws-sdk/util-utf8-browser/-/util-utf8-browser-3.259.0.tgz#3275a6f5eb334f96ca76635b961d3c50259fd9ff" + integrity sha512-UvFa/vR+e19XookZF8RzFZBrw2EUkQWxiBW0yYQAhvk3C+QVGl0H3ouca8LDBlBfQKXwmW3huo/59H8rwb1wJw== + dependencies: + tslib "^2.3.1" + "@babel/code-frame@^7.0.0", "@babel/code-frame@^7.12.13", "@babel/code-frame@^7.23.5": version "7.23.5" resolved "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.23.5.tgz" From ac3e6da781423f1b048d8892dca24a2003920a73 Mon Sep 17 00:00:00 2001 From: ayuki_j <19406594+ayuki-joto@users.noreply.github.com> Date: Tue, 14 May 2024 20:45:27 +0900 Subject: [PATCH 2/7] feat: add eslint --- .eslintrc.json | 18 + .prettierrc | 8 + package.json | 10 +- yarn.lock | 1010 +++++++++++++++++++++++++++++++++++++++++++++++- 4 files changed, 1036 insertions(+), 10 deletions(-) create mode 100644 .eslintrc.json create mode 100644 .prettierrc diff --git a/.eslintrc.json b/.eslintrc.json new file mode 100644 index 0000000..1f8998c --- /dev/null +++ b/.eslintrc.json @@ -0,0 +1,18 @@ +{ + "env": { + "browser": true, + "es2021": true, + "node": true + }, + "extends": ["eslint:recommended", "plugin:jest/recommended", "prettier"], + "parser": "@typescript-eslint/parser", + "parserOptions": { + "ecmaVersion": "latest", + "sourceType": "module" + }, + "plugins": ["@typescript-eslint", "jest"], + "root": true, + "rules": { + "no-unused-vars": "off" + } +} diff --git a/.prettierrc b/.prettierrc new file mode 100644 index 0000000..cfdd6e9 --- /dev/null +++ b/.prettierrc @@ -0,0 +1,8 @@ +{ + "printWidth": 80, + "trailingComma": "none", + "tabWidth": 2, + "semi": false, + "singleQuote": true, + "endOfLine": "lf" +} diff --git a/package.json b/package.json index 2ea4e8b..cbcbc88 100644 --- a/package.json +++ b/package.json @@ -8,13 +8,17 @@ "build": "tsc", "watch": "tsc -w", "test": "jest", - "cdk": "cdk" + "cdk": "cdk", + "lint": "npx eslint 'lib/**/*.ts'", + "lint:fix": "npx prettier --write 'lib/*.ts' && eslint --fix lib/*.ts" }, "devDependencies": { + "@eslint/eslintrc": "^3.0.2", "@types/express": "^4.17.21", "@types/jest": "^29.5.12", "@types/node": "^20.12.11", "aws-cdk": "2.141.0", + "eslint-config-prettier": "^9.1.0", "jest": "^29.7.0", "ts-jest": "^29.1.2", "ts-node": "^10.9.2", @@ -31,9 +35,13 @@ "aws-sdk": "^2.1618.0", "aws-serverless-express": "^3.4.0", "constructs": "^10.3.0", + "eslint": "^9.2.0", + "eslint-plugin-jest": "^28.5.0", "express": "^4.19.2", + "prettier": "^3.2.5", "source-map-support": "^0.5.21", "supertest": "^6.3.4", + "typescript-eslint": "^7.9.0", "uuid": "^9.0.1", "xlsx": "^0.18.5" } diff --git a/yarn.lock b/yarn.lock index 1660d6e..b29991c 100644 --- a/yarn.lock +++ b/yarn.lock @@ -822,6 +822,62 @@ dependencies: "@jridgewell/trace-mapping" "0.3.9" +"@eslint-community/eslint-utils@^4.2.0", "@eslint-community/eslint-utils@^4.4.0": + version "4.4.0" + resolved "https://registry.yarnpkg.com/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz#a23514e8fb9af1269d5f7788aa556798d61c6b59" + integrity sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA== + dependencies: + eslint-visitor-keys "^3.3.0" + +"@eslint-community/regexpp@^4.10.0", "@eslint-community/regexpp@^4.6.1": + version "4.10.0" + resolved "https://registry.yarnpkg.com/@eslint-community/regexpp/-/regexpp-4.10.0.tgz#548f6de556857c8bb73bbee70c35dc82a2e74d63" + integrity sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA== + +"@eslint/eslintrc@^3.0.2": + version "3.0.2" + resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-3.0.2.tgz#36180f8e85bf34d2fe3ccc2261e8e204a411ab4e" + integrity sha512-wV19ZEGEMAC1eHgrS7UQPqsdEiCIbTKTasEfcXAigzoXICcqZSjBZEHlZwNVvKg6UBCjSlos84XiLqsRJnIcIg== + dependencies: + ajv "^6.12.4" + debug "^4.3.2" + espree "^10.0.1" + globals "^14.0.0" + ignore "^5.2.0" + import-fresh "^3.2.1" + js-yaml "^4.1.0" + minimatch "^3.1.2" + strip-json-comments "^3.1.1" + +"@eslint/js@9.2.0": + version "9.2.0" + resolved "https://registry.yarnpkg.com/@eslint/js/-/js-9.2.0.tgz#b0a9123e8e91a3d9a2eed3a04a6ed44fdab639aa" + integrity sha512-ESiIudvhoYni+MdsI8oD7skpprZ89qKocwRM2KEvhhBJ9nl5MRh7BXU5GTod7Mdygq+AUl+QzId6iWJKR/wABA== + +"@humanwhocodes/config-array@^0.13.0": + version "0.13.0" + resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.13.0.tgz#fb907624df3256d04b9aa2df50d7aa97ec648748" + integrity sha512-DZLEEqFWQFiyK6h5YIeynKx7JlvCYWL0cImfSRXZ9l4Sg2efkFGTuFf6vzXjK1cq6IYkU+Eg/JizXw+TD2vRNw== + dependencies: + "@humanwhocodes/object-schema" "^2.0.3" + debug "^4.3.1" + minimatch "^3.0.5" + +"@humanwhocodes/module-importer@^1.0.1": + version "1.0.1" + resolved "https://registry.yarnpkg.com/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz#af5b2691a22b44be847b0ca81641c5fb6ad0172c" + integrity sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA== + +"@humanwhocodes/object-schema@^2.0.3": + version "2.0.3" + resolved "https://registry.yarnpkg.com/@humanwhocodes/object-schema/-/object-schema-2.0.3.tgz#4a2868d75d6d6963e423bcf90b7fd1be343409d3" + integrity sha512-93zYdMES/c1D69yZiKDBj0V24vqNzB/koF26KPaagAfd3P/4gUlh3Dys5ogAK+Exi9QyzlD8x/08Zt7wIKcDcA== + +"@humanwhocodes/retry@^0.2.3": + version "0.2.4" + resolved "https://registry.yarnpkg.com/@humanwhocodes/retry/-/retry-0.2.4.tgz#4f3059423823bd8176132ceea9447dee101dfac1" + integrity sha512-Ttl/jHpxfS3st5sxwICYfk4pOH0WrLI1SpW283GgQL7sCWU7EHIOhX4b4fkIxr3tkfzwg8+FNojtzsIEE7Ecgg== + "@istanbuljs/load-nyc-config@^1.0.0": version "1.1.0" resolved "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz" @@ -1070,6 +1126,27 @@ "@jridgewell/resolve-uri" "^3.1.0" "@jridgewell/sourcemap-codec" "^1.4.14" +"@nodelib/fs.scandir@2.1.5": + version "2.1.5" + resolved "https://registry.yarnpkg.com/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz#7619c2eb21b25483f6d167548b4cfd5a7488c3d5" + integrity sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g== + dependencies: + "@nodelib/fs.stat" "2.0.5" + run-parallel "^1.1.9" + +"@nodelib/fs.stat@2.0.5", "@nodelib/fs.stat@^2.0.2": + version "2.0.5" + resolved "https://registry.yarnpkg.com/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz#5bd262af94e9d25bd1e71b05deed44876a222e8b" + integrity sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A== + +"@nodelib/fs.walk@^1.2.3", "@nodelib/fs.walk@^1.2.8": + version "1.2.8" + resolved "https://registry.yarnpkg.com/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz#e95737e8bb6746ddedf69c556953494f196fe69a" + integrity sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg== + dependencies: + "@nodelib/fs.scandir" "2.1.5" + fastq "^1.6.0" + "@sinclair/typebox@^0.27.8": version "0.27.8" resolved "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.27.8.tgz" @@ -1089,6 +1166,382 @@ dependencies: "@sinonjs/commons" "^3.0.0" +"@smithy/abort-controller@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/abort-controller/-/abort-controller-3.0.0.tgz#5815f5d4618e14bf8d031bb98a99adabbb831168" + integrity sha512-p6GlFGBt9K4MYLu72YuJ523NVR4A8oHlC5M2JO6OmQqN8kAc/uh1JqLE+FizTokrSJGg0CSvC+BrsmGzKtsZKA== + dependencies: + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/config-resolver@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/config-resolver/-/config-resolver-3.0.0.tgz#d37b31e3202c5ce54d9bd2406dcde7c7b5073cbd" + integrity sha512-2GzOfADwYLQugYkKQhIyZyQlM05K+tMKvRnc6eFfZcpJGRfKoMUMYdPlBKmqHwQFXQKBrGV6cxL9oymWgDzvFw== + dependencies: + "@smithy/node-config-provider" "^3.0.0" + "@smithy/types" "^3.0.0" + "@smithy/util-config-provider" "^3.0.0" + "@smithy/util-middleware" "^3.0.0" + tslib "^2.6.2" + +"@smithy/core@^2.0.0": + version "2.0.0" + resolved "https://registry.yarnpkg.com/@smithy/core/-/core-2.0.0.tgz#221c8407d185bd28d3bd6d8f2fefdfe240fa2ccf" + integrity sha512-y1VuiOpU8nL0KlL0pvYpOddKGK+8xpD4Jvg9NN42Bl6gHWAr46LpAzWi4I78WxcFIMN1vw1+RUVOlcqR/vfs5g== + dependencies: + "@smithy/middleware-endpoint" "^3.0.0" + "@smithy/middleware-retry" "^3.0.0" + "@smithy/middleware-serde" "^3.0.0" + "@smithy/protocol-http" "^4.0.0" + "@smithy/smithy-client" "^3.0.0" + "@smithy/types" "^3.0.0" + "@smithy/util-middleware" "^3.0.0" + tslib "^2.6.2" + +"@smithy/credential-provider-imds@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/credential-provider-imds/-/credential-provider-imds-3.0.0.tgz#a290eb0224ef045742e5c806685cf63d44a084f3" + integrity sha512-lfmBiFQcA3FsDAPxNfY0L7CawcWtbyWsBOHo34nF095728JLkBX4Y9q/VPPE2r7fqMVK+drmDigqE2/SSQeVRA== + dependencies: + "@smithy/node-config-provider" "^3.0.0" + "@smithy/property-provider" "^3.0.0" + "@smithy/types" "^3.0.0" + "@smithy/url-parser" "^3.0.0" + tslib "^2.6.2" + +"@smithy/fetch-http-handler@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/fetch-http-handler/-/fetch-http-handler-3.0.0.tgz#229ac830d9ac7aaab096f2ef126abd8ed1ea1d35" + integrity sha512-gP1MlOpIB/onIbh4g9eSG3XdI/G31cAvd9Lo11192eL4mxks3xpkPaa+RIcZaX2Vmb8I8HzxBddPSXviY1iq0w== + dependencies: + "@smithy/protocol-http" "^4.0.0" + "@smithy/querystring-builder" "^3.0.0" + "@smithy/types" "^3.0.0" + "@smithy/util-base64" "^3.0.0" + tslib "^2.6.2" + +"@smithy/hash-node@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/hash-node/-/hash-node-3.0.0.tgz#f44b5fff193e241c1cdcc957b296b60f186f0e59" + integrity sha512-84qXstNemP3XS5jcof0el6+bDfjzuvhJPQTEfro3lgtbCtKgzPm3MgiS6ehXVPjeQ5+JS0HqmTz8f/RYfzHVxw== + dependencies: + "@smithy/types" "^3.0.0" + "@smithy/util-buffer-from" "^3.0.0" + "@smithy/util-utf8" "^3.0.0" + tslib "^2.6.2" + +"@smithy/invalid-dependency@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/invalid-dependency/-/invalid-dependency-3.0.0.tgz#21cb6b5203ee15321bfcc751f21f7a19536d4ae8" + integrity sha512-F6wBBaEFgJzj0s4KUlliIGPmqXemwP6EavgvDqYwCH40O5Xr2iMHvS8todmGVZtuJCorBkXsYLyTu4PuizVq5g== + dependencies: + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/is-array-buffer@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/is-array-buffer/-/is-array-buffer-3.0.0.tgz#9a95c2d46b8768946a9eec7f935feaddcffa5e7a" + integrity sha512-+Fsu6Q6C4RSJiy81Y8eApjEB5gVtM+oFKTffg+jSuwtvomJJrhUJBu2zS8wjXSgH/g1MKEWrzyChTBe6clb5FQ== + dependencies: + tslib "^2.6.2" + +"@smithy/middleware-content-length@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/middleware-content-length/-/middleware-content-length-3.0.0.tgz#084b3d22248967885d496eb0b105d9090e8ababd" + integrity sha512-3C4s4d/iGobgCtk2tnWW6+zSTOBg1PRAm2vtWZLdriwTroFbbWNSr3lcyzHdrQHnEXYCC5K52EbpfodaIUY8sg== + dependencies: + "@smithy/protocol-http" "^4.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/middleware-endpoint@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/middleware-endpoint/-/middleware-endpoint-3.0.0.tgz#54c9e1bd8f35b7d004c803eaf3702e61e32b8295" + integrity sha512-aXOAWztw/5qAfp0NcA2OWpv6ZI/E+Dh9mByif7i91D/0iyYNUcKvskmXiowKESFkuZ7PIMd3VOR4fTibZDs2OQ== + dependencies: + "@smithy/middleware-serde" "^3.0.0" + "@smithy/node-config-provider" "^3.0.0" + "@smithy/shared-ini-file-loader" "^3.0.0" + "@smithy/types" "^3.0.0" + "@smithy/url-parser" "^3.0.0" + "@smithy/util-middleware" "^3.0.0" + tslib "^2.6.2" + +"@smithy/middleware-retry@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/middleware-retry/-/middleware-retry-3.0.0.tgz#3edf6e73651b81273629bf7a8f10db31c4e90a82" + integrity sha512-kFaBiTa50y0iwhrOjX5UISo1SfiXPrE1EsMtZJAVF7Oci3AUpVzaMzRxzQJFGnxioSyCwSmzqiE9x4X3dW+7VQ== + dependencies: + "@smithy/node-config-provider" "^3.0.0" + "@smithy/protocol-http" "^4.0.0" + "@smithy/service-error-classification" "^3.0.0" + "@smithy/smithy-client" "^3.0.0" + "@smithy/types" "^3.0.0" + "@smithy/util-middleware" "^3.0.0" + "@smithy/util-retry" "^3.0.0" + tslib "^2.6.2" + uuid "^9.0.1" + +"@smithy/middleware-serde@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/middleware-serde/-/middleware-serde-3.0.0.tgz#786da6a6bc0e5e51d669dac834c19965245dd302" + integrity sha512-I1vKG1foI+oPgG9r7IMY1S+xBnmAn1ISqployvqkwHoSb8VPsngHDTOgYGYBonuOKndaWRUGJZrKYYLB+Ane6w== + dependencies: + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/middleware-stack@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/middleware-stack/-/middleware-stack-3.0.0.tgz#00f112bae7af5fc3bd37d4fab95ebce0f17a7774" + integrity sha512-+H0jmyfAyHRFXm6wunskuNAqtj7yfmwFB6Fp37enytp2q047/Od9xetEaUbluyImOlGnGpaVGaVfjwawSr+i6Q== + dependencies: + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/node-config-provider@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/node-config-provider/-/node-config-provider-3.0.0.tgz#4cd5dcf6132c75d6a582fcd6243482dac703865a" + integrity sha512-buqfaSdDh0zo62EPLf8rGDvcpKwGpO5ho4bXS2cdFhlOta7tBkWJt+O5uiaAeICfIOfPclNOndshDNSanX2X9g== + dependencies: + "@smithy/property-provider" "^3.0.0" + "@smithy/shared-ini-file-loader" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/node-http-handler@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/node-http-handler/-/node-http-handler-3.0.0.tgz#e771ea95d03e259f04b7b37e8aece8a4fffc8cdc" + integrity sha512-3trD4r7NOMygwLbUJo4eodyQuypAWr7uvPnebNJ9a70dQhVn+US8j/lCnvoJS6BXfZeF7PkkkI0DemVJw+n+eQ== + dependencies: + "@smithy/abort-controller" "^3.0.0" + "@smithy/protocol-http" "^4.0.0" + "@smithy/querystring-builder" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/property-provider@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/property-provider/-/property-provider-3.0.0.tgz#ef7a26557c855cc1471b9aa0e05529183e99b978" + integrity sha512-LmbPgHBswdXCrkWWuUwBm9w72S2iLWyC/5jet9/Y9cGHtzqxi+GVjfCfahkvNV4KXEwgnH8EMpcrD9RUYe0eLQ== + dependencies: + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/protocol-http@^4.0.0": + version "4.0.0" + resolved "https://registry.yarnpkg.com/@smithy/protocol-http/-/protocol-http-4.0.0.tgz#04df3b5674b540323f678e7c4113e8abd8b26432" + integrity sha512-qOQZOEI2XLWRWBO9AgIYuHuqjZ2csyr8/IlgFDHDNuIgLAMRx2Bl8ck5U5D6Vh9DPdoaVpuzwWMa0xcdL4O/AQ== + dependencies: + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/querystring-builder@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/querystring-builder/-/querystring-builder-3.0.0.tgz#48a9aa7b700e8409368c21bc0adf7564e001daea" + integrity sha512-bW8Fi0NzyfkE0TmQphDXr1AmBDbK01cA4C1Z7ggwMAU5RDz5AAv/KmoRwzQAS0kxXNf/D2ALTEgwK0U2c4LtRg== + dependencies: + "@smithy/types" "^3.0.0" + "@smithy/util-uri-escape" "^3.0.0" + tslib "^2.6.2" + +"@smithy/querystring-parser@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/querystring-parser/-/querystring-parser-3.0.0.tgz#fa1ed0cee408cd4d622070fa874bc50ac1a379b7" + integrity sha512-UzHwthk0UEccV4dHzPySnBy34AWw3V9lIqUTxmozQ+wPDAO9csCWMfOLe7V9A2agNYy7xE+Pb0S6K/J23JSzfQ== + dependencies: + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/service-error-classification@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/service-error-classification/-/service-error-classification-3.0.0.tgz#06a45cb91b15b8b0d5f3b1df2b3743d2ca42f5c4" + integrity sha512-3BsBtOUt2Gsnc3X23ew+r2M71WwtpHfEDGhHYHSDg6q1t8FrWh15jT25DLajFV1H+PpxAJ6gqe9yYeRUsmSdFA== + dependencies: + "@smithy/types" "^3.0.0" + +"@smithy/shared-ini-file-loader@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/shared-ini-file-loader/-/shared-ini-file-loader-3.0.0.tgz#8739b7cd24f55fb4e276a74f00f0c2bb4e3f25d8" + integrity sha512-REVw6XauXk8xE4zo5aGL7Rz4ywA8qNMUn8RtWeTRQsgAlmlvbJ7CEPBcaXU2NDC3AYBgYAXrGyWD8XrN8UGDog== + dependencies: + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/signature-v4@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/signature-v4/-/signature-v4-3.0.0.tgz#f536d0abebfeeca8e9aab846a4042658ca07d3b7" + integrity sha512-kXFOkNX+BQHe2qnLxpMEaCRGap9J6tUGLzc3A9jdn+nD4JdMwCKTJ+zFwQ20GkY+mAXGatyTw3HcoUlR39HwmA== + dependencies: + "@smithy/is-array-buffer" "^3.0.0" + "@smithy/types" "^3.0.0" + "@smithy/util-hex-encoding" "^3.0.0" + "@smithy/util-middleware" "^3.0.0" + "@smithy/util-uri-escape" "^3.0.0" + "@smithy/util-utf8" "^3.0.0" + tslib "^2.6.2" + +"@smithy/smithy-client@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/smithy-client/-/smithy-client-3.0.0.tgz#b9c73b6d162d8f1b3a202d04476c3b588fe666da" + integrity sha512-HTLlEOPOoPxyVCoqzwRGJuRh4hyAAo+eveRcEPi7UpIaq2PCAmdFZM76jabUuzlPPR9ge+OQlKzZre+LT1nXzA== + dependencies: + "@smithy/middleware-endpoint" "^3.0.0" + "@smithy/middleware-stack" "^3.0.0" + "@smithy/protocol-http" "^4.0.0" + "@smithy/types" "^3.0.0" + "@smithy/util-stream" "^3.0.0" + tslib "^2.6.2" + +"@smithy/types@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/types/-/types-3.0.0.tgz#00231052945159c64ffd8b91e8909d8d3006cb7e" + integrity sha512-VvWuQk2RKFuOr98gFhjca7fkBS+xLLURT8bUjk5XQoV0ZLm7WPwWPPY3/AwzTLuUBDeoKDCthfe1AsTUWaSEhw== + dependencies: + tslib "^2.6.2" + +"@smithy/url-parser@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/url-parser/-/url-parser-3.0.0.tgz#5fdc77cd22051c1aac6531be0315bfcba0fa705d" + integrity sha512-2XLazFgUu+YOGHtWihB3FSLAfCUajVfNBXGGYjOaVKjLAuAxx3pSBY3hBgLzIgB17haf59gOG3imKqTy8mcrjw== + dependencies: + "@smithy/querystring-parser" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/util-base64@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-base64/-/util-base64-3.0.0.tgz#f7a9a82adf34e27a72d0719395713edf0e493017" + integrity sha512-Kxvoh5Qtt0CDsfajiZOCpJxgtPHXOKwmM+Zy4waD43UoEMA+qPxxa98aE/7ZhdnBFZFXMOiBR5xbcaMhLtznQQ== + dependencies: + "@smithy/util-buffer-from" "^3.0.0" + "@smithy/util-utf8" "^3.0.0" + tslib "^2.6.2" + +"@smithy/util-body-length-browser@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-body-length-browser/-/util-body-length-browser-3.0.0.tgz#86ec2f6256310b4845a2f064e2f571c1ca164ded" + integrity sha512-cbjJs2A1mLYmqmyVl80uoLTJhAcfzMOyPgjwAYusWKMdLeNtzmMz9YxNl3/jRLoxSS3wkqkf0jwNdtXWtyEBaQ== + dependencies: + tslib "^2.6.2" + +"@smithy/util-body-length-node@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-body-length-node/-/util-body-length-node-3.0.0.tgz#99a291bae40d8932166907fe981d6a1f54298a6d" + integrity sha512-Tj7pZ4bUloNUP6PzwhN7K386tmSmEET9QtQg0TgdNOnxhZvCssHji+oZTUIuzxECRfG8rdm2PMw2WCFs6eIYkA== + dependencies: + tslib "^2.6.2" + +"@smithy/util-buffer-from@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-buffer-from/-/util-buffer-from-3.0.0.tgz#559fc1c86138a89b2edaefc1e6677780c24594e3" + integrity sha512-aEOHCgq5RWFbP+UDPvPot26EJHjOC+bRgse5A8V3FSShqd5E5UN4qc7zkwsvJPPAVsf73QwYcHN1/gt/rtLwQA== + dependencies: + "@smithy/is-array-buffer" "^3.0.0" + tslib "^2.6.2" + +"@smithy/util-config-provider@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-config-provider/-/util-config-provider-3.0.0.tgz#62c6b73b22a430e84888a8f8da4b6029dd5b8efe" + integrity sha512-pbjk4s0fwq3Di/ANL+rCvJMKM5bzAQdE5S/6RL5NXgMExFAi6UgQMPOm5yPaIWPpr+EOXKXRonJ3FoxKf4mCJQ== + dependencies: + tslib "^2.6.2" + +"@smithy/util-defaults-mode-browser@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-defaults-mode-browser/-/util-defaults-mode-browser-3.0.0.tgz#38bf6536fec24059d96459d8480028cf33548695" + integrity sha512-/ChTQXFZVK/92dLR9RLW2fOG03ghgUYZnRfrs9d9T3L7UxtsGx9QitF7Ppu64A8xcUHqA30kV7TUayFRBd7YQw== + dependencies: + "@smithy/property-provider" "^3.0.0" + "@smithy/smithy-client" "^3.0.0" + "@smithy/types" "^3.0.0" + bowser "^2.11.0" + tslib "^2.6.2" + +"@smithy/util-defaults-mode-node@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-defaults-mode-node/-/util-defaults-mode-node-3.0.0.tgz#7b0d7f8964f78b5bcc94ae5d2849a5338c475d38" + integrity sha512-gfABCXswcMgDUcVO+16e4BgTFnouaXNCowp9mVxV8dgaOCpUT9eEWIC+PK3ZoEm26QwlwT7WgfuN1Y22HKX36g== + dependencies: + "@smithy/config-resolver" "^3.0.0" + "@smithy/credential-provider-imds" "^3.0.0" + "@smithy/node-config-provider" "^3.0.0" + "@smithy/property-provider" "^3.0.0" + "@smithy/smithy-client" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/util-endpoints@^2.0.0": + version "2.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-endpoints/-/util-endpoints-2.0.0.tgz#5a16a723c1220f536a9b1b3e01787e69e77b6f12" + integrity sha512-+exaXzEY3DNt2qtA2OtRNSDlVrE4p32j1JSsQkzA5AdP0YtJNjkYbYhJxkFmPYcjI1abuwopOZCwUmv682QkiQ== + dependencies: + "@smithy/node-config-provider" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/util-hex-encoding@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-hex-encoding/-/util-hex-encoding-3.0.0.tgz#32938b33d5bf2a15796cd3f178a55b4155c535e6" + integrity sha512-eFndh1WEK5YMUYvy3lPlVmYY/fZcQE1D8oSf41Id2vCeIkKJXPcYDCZD+4+xViI6b1XSd7tE+s5AmXzz5ilabQ== + dependencies: + tslib "^2.6.2" + +"@smithy/util-middleware@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-middleware/-/util-middleware-3.0.0.tgz#64d775628b99a495ca83ce982f5c83aa45f1e894" + integrity sha512-q5ITdOnV2pXHSVDnKWrwgSNTDBAMHLptFE07ua/5Ty5WJ11bvr0vk2a7agu7qRhrCFRQlno5u3CneU5EELK+DQ== + dependencies: + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/util-retry@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-retry/-/util-retry-3.0.0.tgz#8a0c47496aab74e1dfde4905d462ad636a8824bb" + integrity sha512-nK99bvJiziGv/UOKJlDvFF45F00WgPLKVIGUfAK+mDhzVN2hb/S33uW2Tlhg5PVBoqY7tDVqL0zmu4OxAHgo9g== + dependencies: + "@smithy/service-error-classification" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + +"@smithy/util-stream@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-stream/-/util-stream-3.0.0.tgz#b0fef162385b4daef18601cd3e8e79e19e53a764" + integrity sha512-AYQeeAxBi3yee9SXC0HgrbeIchQeo6EAkpiwwmmCK6Z7uq8GnMGe8AxRZT3O4wyMNRNK2qfjZSvx6+wKfuMajg== + dependencies: + "@smithy/fetch-http-handler" "^3.0.0" + "@smithy/node-http-handler" "^3.0.0" + "@smithy/types" "^3.0.0" + "@smithy/util-base64" "^3.0.0" + "@smithy/util-buffer-from" "^3.0.0" + "@smithy/util-hex-encoding" "^3.0.0" + "@smithy/util-utf8" "^3.0.0" + tslib "^2.6.2" + +"@smithy/util-uri-escape@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-uri-escape/-/util-uri-escape-3.0.0.tgz#e43358a78bf45d50bb736770077f0f09195b6f54" + integrity sha512-LqR7qYLgZTD7nWLBecUi4aqolw8Mhza9ArpNEQ881MJJIU2sE5iHCK6TdyqqzcDLy0OPe10IY4T8ctVdtynubg== + dependencies: + tslib "^2.6.2" + +"@smithy/util-utf8@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-utf8/-/util-utf8-3.0.0.tgz#1a6a823d47cbec1fd6933e5fc87df975286d9d6a" + integrity sha512-rUeT12bxFnplYDe815GXbq/oixEGHfRFFtcTF3YdDi/JaENIM6aSYYLJydG83UNzLXeRI5K8abYd/8Sp/QM0kA== + dependencies: + "@smithy/util-buffer-from" "^3.0.0" + tslib "^2.6.2" + +"@smithy/util-waiter@^3.0.0": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@smithy/util-waiter/-/util-waiter-3.0.0.tgz#26bcc5bbbf1de9360a7aeb3b3919926fc6afa2bc" + integrity sha512-+fEXJxGDLCoqRKVSmo0auGxaqbiCo+8oph+4auefYjaNxjOLKSY2MxVQfRzo65PaZv4fr+5lWg+au7vSuJJ/zw== + dependencies: + "@smithy/abort-controller" "^3.0.0" + "@smithy/types" "^3.0.0" + tslib "^2.6.2" + "@tsconfig/node10@^1.0.7": version "1.0.9" resolved "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.9.tgz" @@ -1304,6 +1757,87 @@ dependencies: "@types/yargs-parser" "*" +"@typescript-eslint/eslint-plugin@7.9.0", "@typescript-eslint/eslint-plugin@^7.9.0": + version "7.9.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/eslint-plugin/-/eslint-plugin-7.9.0.tgz#093b96fc4e342226e65d5f18f9c87081e0b04a31" + integrity sha512-6e+X0X3sFe/G/54aC3jt0txuMTURqLyekmEHViqyA2VnxhLMpvA6nqmcjIy+Cr9tLDHPssA74BP5Mx9HQIxBEA== + dependencies: + "@eslint-community/regexpp" "^4.10.0" + "@typescript-eslint/scope-manager" "7.9.0" + "@typescript-eslint/type-utils" "7.9.0" + "@typescript-eslint/utils" "7.9.0" + "@typescript-eslint/visitor-keys" "7.9.0" + graphemer "^1.4.0" + ignore "^5.3.1" + natural-compare "^1.4.0" + ts-api-utils "^1.3.0" + +"@typescript-eslint/parser@7.9.0", "@typescript-eslint/parser@^7.9.0": + version "7.9.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/parser/-/parser-7.9.0.tgz#fb3ba01b75e0e65cb78037a360961b00301f6c70" + integrity sha512-qHMJfkL5qvgQB2aLvhUSXxbK7OLnDkwPzFalg458pxQgfxKDfT1ZDbHQM/I6mDIf/svlMkj21kzKuQ2ixJlatQ== + dependencies: + "@typescript-eslint/scope-manager" "7.9.0" + "@typescript-eslint/types" "7.9.0" + "@typescript-eslint/typescript-estree" "7.9.0" + "@typescript-eslint/visitor-keys" "7.9.0" + debug "^4.3.4" + +"@typescript-eslint/scope-manager@7.9.0": + version "7.9.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/scope-manager/-/scope-manager-7.9.0.tgz#1dd3e63a4411db356a9d040e75864851b5f2619b" + integrity sha512-ZwPK4DeCDxr3GJltRz5iZejPFAAr4Wk3+2WIBaj1L5PYK5RgxExu/Y68FFVclN0y6GGwH8q+KgKRCvaTmFBbgQ== + dependencies: + "@typescript-eslint/types" "7.9.0" + "@typescript-eslint/visitor-keys" "7.9.0" + +"@typescript-eslint/type-utils@7.9.0": + version "7.9.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/type-utils/-/type-utils-7.9.0.tgz#f523262e1b66ca65540b7a65a1222db52e0a90c9" + integrity sha512-6Qy8dfut0PFrFRAZsGzuLoM4hre4gjzWJB6sUvdunCYZsYemTkzZNwF1rnGea326PHPT3zn5Lmg32M/xfJfByA== + dependencies: + "@typescript-eslint/typescript-estree" "7.9.0" + "@typescript-eslint/utils" "7.9.0" + debug "^4.3.4" + ts-api-utils "^1.3.0" + +"@typescript-eslint/types@7.9.0": + version "7.9.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/types/-/types-7.9.0.tgz#b58e485e4bfba055659c7e683ad4f5f0821ae2ec" + integrity sha512-oZQD9HEWQanl9UfsbGVcZ2cGaR0YT5476xfWE0oE5kQa2sNK2frxOlkeacLOTh9po4AlUT5rtkGyYM5kew0z5w== + +"@typescript-eslint/typescript-estree@7.9.0": + version "7.9.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/typescript-estree/-/typescript-estree-7.9.0.tgz#3395e27656060dc313a6b406c3a298b729685e07" + integrity sha512-zBCMCkrb2YjpKV3LA0ZJubtKCDxLttxfdGmwZvTqqWevUPN0FZvSI26FalGFFUZU/9YQK/A4xcQF9o/VVaCKAg== + dependencies: + "@typescript-eslint/types" "7.9.0" + "@typescript-eslint/visitor-keys" "7.9.0" + debug "^4.3.4" + globby "^11.1.0" + is-glob "^4.0.3" + minimatch "^9.0.4" + semver "^7.6.0" + ts-api-utils "^1.3.0" + +"@typescript-eslint/utils@7.9.0", "@typescript-eslint/utils@^6.0.0 || ^7.0.0": + version "7.9.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/utils/-/utils-7.9.0.tgz#1b96a34eefdca1c820cb1bbc2751d848b4540899" + integrity sha512-5KVRQCzZajmT4Ep+NEgjXCvjuypVvYHUW7RHlXzNPuak2oWpVoD1jf5xCP0dPAuNIchjC7uQyvbdaSTFaLqSdA== + dependencies: + "@eslint-community/eslint-utils" "^4.4.0" + "@typescript-eslint/scope-manager" "7.9.0" + "@typescript-eslint/types" "7.9.0" + "@typescript-eslint/typescript-estree" "7.9.0" + +"@typescript-eslint/visitor-keys@7.9.0": + version "7.9.0" + resolved "https://registry.yarnpkg.com/@typescript-eslint/visitor-keys/-/visitor-keys-7.9.0.tgz#82162656e339c3def02895f5c8546f6888d9b9ea" + integrity sha512-iESPx2TNLDNGQLyjKhUvIKprlP49XNEK+MvIf9nIO7ZZaZdbnfWKHnXAgufpxqfA0YryH8XToi4+CjBgVnFTSQ== + dependencies: + "@typescript-eslint/types" "7.9.0" + eslint-visitor-keys "^3.4.3" + "@vendia/serverless-express@^3.4.0": version "3.4.1" resolved "https://registry.npmjs.org/@vendia/serverless-express/-/serverless-express-3.4.1.tgz" @@ -1321,12 +1855,17 @@ accepts@~1.3.8: mime-types "~2.1.34" negotiator "0.6.3" +acorn-jsx@^5.3.2: + version "5.3.2" + resolved "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.3.2.tgz#7ed5bb55908b3b2f1bc55c6af1653bada7f07937" + integrity sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ== + acorn-walk@^8.1.1: version "8.3.2" resolved "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.2.tgz" integrity sha512-cjkyv4OtNCIeqhHrfS81QWXoCBPExR/J62oyEqepVw8WaQeSqpW2uhuLPh1m9eWhDuOo/jUXVTlifvesOWp/4A== -acorn@^8.4.1: +acorn@^8.11.3, acorn@^8.4.1: version "8.11.3" resolved "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz" integrity sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg== @@ -1336,6 +1875,16 @@ adler-32@~1.3.0: resolved "https://registry.npmjs.org/adler-32/-/adler-32-1.3.1.tgz" integrity sha512-ynZ4w/nUUv5rrsR8UUGoe1VC9hZj6V5hU9Qw1HlMDJGEJw5S7TfTErWTjMys6M7vr0YWcPqs3qAr4ss0nDfP+A== +ajv@^6.12.4: + version "6.12.6" + resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" + integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== + dependencies: + fast-deep-equal "^3.1.1" + fast-json-stable-stringify "^2.0.0" + json-schema-traverse "^0.4.1" + uri-js "^4.2.2" + ajv@^8.0.1, ajv@^8.13.0: version "8.13.0" resolved "https://registry.npmjs.org/ajv/-/ajv-8.13.0.tgz" @@ -1397,11 +1946,21 @@ argparse@^1.0.7: dependencies: sprintf-js "~1.0.2" +argparse@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38" + integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== + array-flatten@1.1.1: version "1.1.1" resolved "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz" integrity sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg== +array-union@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/array-union/-/array-union-2.1.0.tgz#b798420adbeb1de828d84acd8a2e23d3efe85e8d" + integrity sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw== + asap@^2.0.0: version "2.0.6" resolved "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz" @@ -1569,6 +2128,11 @@ body-parser@1.20.2: type-is "~1.6.18" unpipe "1.0.0" +bowser@^2.11.0: + version "2.11.0" + resolved "https://registry.yarnpkg.com/bowser/-/bowser-2.11.0.tgz#5ca3c35757a7aa5771500c70a73a9f91ef420a8f" + integrity sha512-AlcaJBi/pqqJBIQ8U9Mcpc9i8Aqxn88Skv5d+xBX006BY5u8N3mGLHa5Lgppa7L/HfwgwLgZ6NYs+Ag6uUmJRA== + brace-expansion@^1.1.7: version "1.1.11" resolved "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz" @@ -1577,6 +2141,13 @@ brace-expansion@^1.1.7: balanced-match "^1.0.0" concat-map "0.0.1" +brace-expansion@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-2.0.1.tgz#1edc459e0f0c548486ecf9fc99f2221364b9a0ae" + integrity sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA== + dependencies: + balanced-match "^1.0.0" + braces@^3.0.2: version "3.0.2" resolved "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz" @@ -1828,7 +2399,7 @@ create-require@^1.1.0: resolved "https://registry.npmjs.org/create-require/-/create-require-1.1.1.tgz" integrity sha512-dcKFX3jn0MpIaXjisoRvexIJVEKzaq7z2rZKxf+MSr9TkdmHmsU4m2lcLojrj/FHl8mk5VxMmYA+ftRkP/3oKQ== -cross-spawn@^7.0.3: +cross-spawn@^7.0.2, cross-spawn@^7.0.3: version "7.0.3" resolved "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz" integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== @@ -1844,7 +2415,7 @@ debug@2.6.9: dependencies: ms "2.0.0" -debug@^4.1.0, debug@^4.1.1, debug@^4.3.1, debug@^4.3.4: +debug@^4.1.0, debug@^4.1.1, debug@^4.3.1, debug@^4.3.2, debug@^4.3.4: version "4.3.4" resolved "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz" integrity sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ== @@ -1856,6 +2427,11 @@ dedent@^1.0.0: resolved "https://registry.npmjs.org/dedent/-/dedent-1.5.1.tgz" integrity sha512-+LxW+KLWxu3HW3M2w2ympwtqPrqYRzU8fqi6Fhd18fBALe15blJPI/I4+UHveMVG6lJqB4JNd4UG0S5cnVHwIg== +deep-is@^0.1.3: + version "0.1.4" + resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.4.tgz#a6f2dce612fadd2ef1f519b73551f17e85199831" + integrity sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ== + deepmerge@^4.2.2: version "4.3.1" resolved "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz" @@ -1908,6 +2484,13 @@ diff@^4.0.1: resolved "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz" integrity sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A== +dir-glob@^3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/dir-glob/-/dir-glob-3.0.1.tgz#56dbf73d992a4a93ba1584f4534063fd2e41717f" + integrity sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA== + dependencies: + path-type "^4.0.0" + ee-first@1.1.1: version "1.1.1" resolved "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz" @@ -1972,11 +2555,119 @@ escape-string-regexp@^2.0.0: resolved "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz" integrity sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w== +escape-string-regexp@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34" + integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA== + +eslint-config-prettier@^9.1.0: + version "9.1.0" + resolved "https://registry.yarnpkg.com/eslint-config-prettier/-/eslint-config-prettier-9.1.0.tgz#31af3d94578645966c082fcb71a5846d3c94867f" + integrity sha512-NSWl5BFQWEPi1j4TjVNItzYV7dZXZ+wP6I6ZhrBGpChQhZRUaElihE9uRRkcbRnNb76UMKDF3r+WTmNcGPKsqw== + +eslint-plugin-jest@^28.5.0: + version "28.5.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-jest/-/eslint-plugin-jest-28.5.0.tgz#b497b795de37f671eaccd38bd83030186ff5dc8d" + integrity sha512-6np6DGdmNq/eBbA7HOUNV8fkfL86PYwBfwyb8n23FXgJNTR8+ot3smRHjza9LGsBBZRypK3qyF79vMjohIL8eQ== + dependencies: + "@typescript-eslint/utils" "^6.0.0 || ^7.0.0" + +eslint-scope@^8.0.1: + version "8.0.1" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-8.0.1.tgz#a9601e4b81a0b9171657c343fb13111688963cfc" + integrity sha512-pL8XjgP4ZOmmwfFE8mEhSxA7ZY4C+LWyqjQ3o4yWkkmD0qcMT9kkW3zWHOczhWcjTSgqycYAgwSlXvZltv65og== + dependencies: + esrecurse "^4.3.0" + estraverse "^5.2.0" + +eslint-visitor-keys@^3.3.0, eslint-visitor-keys@^3.4.3: + version "3.4.3" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz#0cd72fe8550e3c2eae156a96a4dddcd1c8ac5800" + integrity sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag== + +eslint-visitor-keys@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-4.0.0.tgz#e3adc021aa038a2a8e0b2f8b0ce8f66b9483b1fb" + integrity sha512-OtIRv/2GyiF6o/d8K7MYKKbXrOUBIK6SfkIRM4Z0dY3w+LiQ0vy3F57m0Z71bjbyeiWFiHJ8brqnmE6H6/jEuw== + +eslint@^9.2.0: + version "9.2.0" + resolved "https://registry.yarnpkg.com/eslint/-/eslint-9.2.0.tgz#0700ebc99528753315d78090876911d3cdbf19fe" + integrity sha512-0n/I88vZpCOzO+PQpt0lbsqmn9AsnsJAQseIqhZFI8ibQT0U1AkEKRxA3EVMos0BoHSXDQvCXY25TUjB5tr8Og== + dependencies: + "@eslint-community/eslint-utils" "^4.2.0" + "@eslint-community/regexpp" "^4.6.1" + "@eslint/eslintrc" "^3.0.2" + "@eslint/js" "9.2.0" + "@humanwhocodes/config-array" "^0.13.0" + "@humanwhocodes/module-importer" "^1.0.1" + "@humanwhocodes/retry" "^0.2.3" + "@nodelib/fs.walk" "^1.2.8" + ajv "^6.12.4" + chalk "^4.0.0" + cross-spawn "^7.0.2" + debug "^4.3.2" + escape-string-regexp "^4.0.0" + eslint-scope "^8.0.1" + eslint-visitor-keys "^4.0.0" + espree "^10.0.1" + esquery "^1.4.2" + esutils "^2.0.2" + fast-deep-equal "^3.1.3" + file-entry-cache "^8.0.0" + find-up "^5.0.0" + glob-parent "^6.0.2" + ignore "^5.2.0" + imurmurhash "^0.1.4" + is-glob "^4.0.0" + is-path-inside "^3.0.3" + json-stable-stringify-without-jsonify "^1.0.1" + levn "^0.4.1" + lodash.merge "^4.6.2" + minimatch "^3.1.2" + natural-compare "^1.4.0" + optionator "^0.9.3" + strip-ansi "^6.0.1" + text-table "^0.2.0" + +espree@^10.0.1: + version "10.0.1" + resolved "https://registry.yarnpkg.com/espree/-/espree-10.0.1.tgz#600e60404157412751ba4a6f3a2ee1a42433139f" + integrity sha512-MWkrWZbJsL2UwnjxTX3gG8FneachS/Mwg7tdGXce011sJd5b0JG54vat5KHnfSBODZ3Wvzd2WnjxyzsRoVv+ww== + dependencies: + acorn "^8.11.3" + acorn-jsx "^5.3.2" + eslint-visitor-keys "^4.0.0" + esprima@^4.0.0: version "4.0.1" resolved "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz" integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== +esquery@^1.4.2: + version "1.5.0" + resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.5.0.tgz#6ce17738de8577694edd7361c57182ac8cb0db0b" + integrity sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg== + dependencies: + estraverse "^5.1.0" + +esrecurse@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.3.0.tgz#7ad7964d679abb28bee72cec63758b1c5d2c9921" + integrity sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag== + dependencies: + estraverse "^5.2.0" + +estraverse@^5.1.0, estraverse@^5.2.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123" + integrity sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA== + +esutils@^2.0.2: + version "2.0.3" + resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64" + integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== + etag@~1.8.1: version "1.8.1" resolved "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz" @@ -2055,21 +2746,51 @@ express@^4.19.2: utils-merge "1.0.1" vary "~1.1.2" -fast-deep-equal@^3.1.3: +fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: version "3.1.3" resolved "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz" integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q== -fast-json-stable-stringify@2.x, fast-json-stable-stringify@^2.1.0: +fast-glob@^3.2.9: + version "3.3.2" + resolved "https://registry.yarnpkg.com/fast-glob/-/fast-glob-3.3.2.tgz#a904501e57cfdd2ffcded45e99a54fef55e46129" + integrity sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow== + dependencies: + "@nodelib/fs.stat" "^2.0.2" + "@nodelib/fs.walk" "^1.2.3" + glob-parent "^5.1.2" + merge2 "^1.3.0" + micromatch "^4.0.4" + +fast-json-stable-stringify@2.x, fast-json-stable-stringify@^2.0.0, fast-json-stable-stringify@^2.1.0: version "2.1.0" resolved "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz" integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw== +fast-levenshtein@^2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917" + integrity sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw== + fast-safe-stringify@^2.1.1: version "2.1.1" resolved "https://registry.npmjs.org/fast-safe-stringify/-/fast-safe-stringify-2.1.1.tgz" integrity sha512-W+KJc2dmILlPplD/H4K9l9LcAHAfPtP6BY84uVLXQ6Evcz9Lcg33Y2z1IVblT6xdY54PXYVHEv+0Wpq8Io6zkA== +fast-xml-parser@4.2.5: + version "4.2.5" + resolved "https://registry.yarnpkg.com/fast-xml-parser/-/fast-xml-parser-4.2.5.tgz#a6747a09296a6cb34f2ae634019bf1738f3b421f" + integrity sha512-B9/wizE4WngqQftFPmdaMYlXoJlJOYxGQOanC77fq9k8+Z0v5dDSVh+3glErdIROP//s/jgb7ZuxKfB8nVyo0g== + dependencies: + strnum "^1.0.5" + +fastq@^1.6.0: + version "1.17.1" + resolved "https://registry.yarnpkg.com/fastq/-/fastq-1.17.1.tgz#2a523f07a4e7b1e81a42b91b8bf2254107753b47" + integrity sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w== + dependencies: + reusify "^1.0.4" + fb-watchman@^2.0.0: version "2.0.2" resolved "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.2.tgz" @@ -2077,6 +2798,13 @@ fb-watchman@^2.0.0: dependencies: bser "2.1.1" +file-entry-cache@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-8.0.0.tgz#7787bddcf1131bffb92636c69457bbc0edd6d81f" + integrity sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ== + dependencies: + flat-cache "^4.0.0" + fill-range@^7.0.1: version "7.0.1" resolved "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz" @@ -2105,6 +2833,27 @@ find-up@^4.0.0, find-up@^4.1.0: locate-path "^5.0.0" path-exists "^4.0.0" +find-up@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-5.0.0.tgz#4c92819ecb7083561e4f4a240a86be5198f536fc" + integrity sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng== + dependencies: + locate-path "^6.0.0" + path-exists "^4.0.0" + +flat-cache@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-4.0.1.tgz#0ece39fcb14ee012f4b0410bd33dd9c1f011127c" + integrity sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw== + dependencies: + flatted "^3.2.9" + keyv "^4.5.4" + +flatted@^3.2.9: + version "3.3.1" + resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.3.1.tgz#21db470729a6734d4997002f439cb308987f567a" + integrity sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw== + for-each@^0.3.3: version "0.3.3" resolved "https://registry.npmjs.org/for-each/-/for-each-0.3.3.tgz" @@ -2206,6 +2955,20 @@ get-stream@^6.0.0: resolved "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz" integrity sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg== +glob-parent@^5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.2.tgz#869832c58034fe68a4093c17dc15e8340d8401c4" + integrity sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow== + dependencies: + is-glob "^4.0.1" + +glob-parent@^6.0.2: + version "6.0.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-6.0.2.tgz#6d237d99083950c79290f24c7642a3de9a28f9e3" + integrity sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A== + dependencies: + is-glob "^4.0.3" + glob@^7.1.3, glob@^7.1.4: version "7.2.3" resolved "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz" @@ -2223,6 +2986,23 @@ globals@^11.1.0: resolved "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz" integrity sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA== +globals@^14.0.0: + version "14.0.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-14.0.0.tgz#898d7413c29babcf6bafe56fcadded858ada724e" + integrity sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ== + +globby@^11.1.0: + version "11.1.0" + resolved "https://registry.yarnpkg.com/globby/-/globby-11.1.0.tgz#bd4be98bb042f83d796f7e3811991fbe82a0d34b" + integrity sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g== + dependencies: + array-union "^2.1.0" + dir-glob "^3.0.1" + fast-glob "^3.2.9" + ignore "^5.2.0" + merge2 "^1.4.1" + slash "^3.0.0" + gopd@^1.0.1: version "1.0.1" resolved "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz" @@ -2235,6 +3015,11 @@ graceful-fs@^4.1.6, graceful-fs@^4.2.0, graceful-fs@^4.2.9: resolved "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz" integrity sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ== +graphemer@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/graphemer/-/graphemer-1.4.0.tgz#fb2f1d55e0e3a1849aeffc90c4fa0dd53a0e66c6" + integrity sha512-EtKwoO6kxCL9WO5xipiHTZlSzBm7WLT627TqC/uVRd0HKmq8NXyebnNYxDoBi7wt8eTWrUrKXCOVaFq9x1kgag== + has-flag@^3.0.0: version "3.0.0" resolved "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz" @@ -2319,11 +3104,19 @@ ieee754@^1.1.4: resolved "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz" integrity sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA== -ignore@^5.3.1: +ignore@^5.2.0, ignore@^5.3.1: version "5.3.1" resolved "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz" integrity sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw== +import-fresh@^3.2.1: + version "3.3.0" + resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b" + integrity sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw== + dependencies: + parent-module "^1.0.0" + resolve-from "^4.0.0" + import-local@^3.0.2: version "3.1.0" resolved "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz" @@ -2380,6 +3173,11 @@ is-core-module@^2.13.0: dependencies: hasown "^2.0.0" +is-extglob@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" + integrity sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ== + is-fullwidth-code-point@^3.0.0: version "3.0.0" resolved "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz" @@ -2397,11 +3195,23 @@ is-generator-function@^1.0.7: dependencies: has-tostringtag "^1.0.0" +is-glob@^4.0.0, is-glob@^4.0.1, is-glob@^4.0.3: + version "4.0.3" + resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084" + integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== + dependencies: + is-extglob "^2.1.1" + is-number@^7.0.0: version "7.0.0" resolved "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz" integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== +is-path-inside@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-3.0.3.tgz#d231362e53a07ff2b0e0ea7fed049161ffd16283" + integrity sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ== + is-stream@^2.0.0: version "2.0.1" resolved "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz" @@ -2853,21 +3663,43 @@ js-yaml@^3.13.1: argparse "^1.0.7" esprima "^4.0.0" +js-yaml@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-4.1.0.tgz#c1fb65f8f5017901cdd2c951864ba18458a10602" + integrity sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA== + dependencies: + argparse "^2.0.1" + jsesc@^2.5.1: version "2.5.2" resolved "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz" integrity sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA== +json-buffer@3.0.1: + version "3.0.1" + resolved "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.1.tgz#9338802a30d3b6605fbe0613e094008ca8c05a13" + integrity sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ== + json-parse-even-better-errors@^2.3.0: version "2.3.1" resolved "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz" integrity sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w== +json-schema-traverse@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660" + integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg== + json-schema-traverse@^1.0.0: version "1.0.0" resolved "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz" integrity sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug== +json-stable-stringify-without-jsonify@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651" + integrity sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw== + json5@^2.2.3: version "2.2.3" resolved "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz" @@ -2887,6 +3719,13 @@ jsonschema@^1.4.1: resolved "https://registry.npmjs.org/jsonschema/-/jsonschema-1.4.1.tgz" integrity sha512-S6cATIPVv1z0IlxdN+zUk5EPjkGCdnhN4wVSBlvoUO1tOLJootbo9CquNJmbIh4yikWHiUedhRYrNPn1arpEmQ== +keyv@^4.5.4: + version "4.5.4" + resolved "https://registry.yarnpkg.com/keyv/-/keyv-4.5.4.tgz#a879a99e29452f942439f2a405e3af8b31d4de93" + integrity sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw== + dependencies: + json-buffer "3.0.1" + kleur@^3.0.3: version "3.0.3" resolved "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz" @@ -2897,6 +3736,14 @@ leven@^3.1.0: resolved "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz" integrity sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A== +levn@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/levn/-/levn-0.4.1.tgz#ae4562c007473b932a6200d403268dd2fffc6ade" + integrity sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ== + dependencies: + prelude-ls "^1.2.1" + type-check "~0.4.0" + lines-and-columns@^1.1.6: version "1.2.4" resolved "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz" @@ -2909,11 +3756,23 @@ locate-path@^5.0.0: dependencies: p-locate "^4.1.0" +locate-path@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-6.0.0.tgz#55321eb309febbc59c4801d931a72452a681d286" + integrity sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw== + dependencies: + p-locate "^5.0.0" + lodash.memoize@4.x: version "4.1.2" resolved "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz" integrity sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag== +lodash.merge@^4.6.2: + version "4.6.2" + resolved "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz#558aa53b43b661e1925a0afdfa36a9a1085fe57a" + integrity sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ== + lodash.truncate@^4.4.2: version "4.4.2" resolved "https://registry.npmjs.org/lodash.truncate/-/lodash.truncate-4.4.2.tgz" @@ -2967,6 +3826,11 @@ merge-stream@^2.0.0: resolved "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz" integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== +merge2@^1.3.0, merge2@^1.4.1: + version "1.4.1" + resolved "https://registry.yarnpkg.com/merge2/-/merge2-1.4.1.tgz#4368892f885e907455a6fd7dc55c0c9d404990ae" + integrity sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg== + methods@^1.1.2, methods@~1.1.2: version "1.1.2" resolved "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz" @@ -3007,13 +3871,27 @@ mimic-fn@^2.1.0: resolved "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz" integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== -minimatch@^3.0.4, minimatch@^3.1.1, minimatch@^3.1.2: +minimatch@^3.0.4, minimatch@^3.0.5, minimatch@^3.1.1, minimatch@^3.1.2: version "3.1.2" resolved "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz" integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== dependencies: brace-expansion "^1.1.7" +minimatch@^9.0.4: + version "9.0.4" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-9.0.4.tgz#8e49c731d1749cbec05050ee5145147b32496a51" + integrity sha512-KqWh+VchfxcMNRAJjj2tnsSJdNbHsVgnkBhTNrW7AjVo6OvLtxw8zfT9oLw1JSohlFzJ8jCoTgaoXvJ+kHt6fw== + dependencies: + brace-expansion "^2.0.1" + +mnemonist@0.38.3: + version "0.38.3" + resolved "https://registry.yarnpkg.com/mnemonist/-/mnemonist-0.38.3.tgz#35ec79c1c1f4357cfda2fe264659c2775ccd7d9d" + integrity sha512-2K9QYubXx/NAjv4VLq1d1Ly8pWNC5L3BrixtdkyTegXWJIqY+zLNDhhX/A+ZwWt70tB1S8H4BE8FLYEFyNoOBw== + dependencies: + obliterator "^1.6.1" + ms@2.0.0: version "2.0.0" resolved "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz" @@ -3066,6 +3944,11 @@ object-inspect@^1.13.1: resolved "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz" integrity sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ== +obliterator@^1.6.1: + version "1.6.1" + resolved "https://registry.yarnpkg.com/obliterator/-/obliterator-1.6.1.tgz#dea03e8ab821f6c4d96a299e17aef6a3af994ef3" + integrity sha512-9WXswnqINnnhOG/5SLimUlzuU1hFJUc8zkwyD59Sd+dPOMf05PmnYG/d6Q7HZ+KmgkZJa1PxRso6QdM3sTNHig== + on-finished@2.4.1: version "2.4.1" resolved "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz" @@ -3087,6 +3970,18 @@ onetime@^5.1.2: dependencies: mimic-fn "^2.1.0" +optionator@^0.9.3: + version "0.9.4" + resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.4.tgz#7ea1c1a5d91d764fb282139c88fe11e182a3a734" + integrity sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g== + dependencies: + deep-is "^0.1.3" + fast-levenshtein "^2.0.6" + levn "^0.4.1" + prelude-ls "^1.2.1" + type-check "^0.4.0" + word-wrap "^1.2.5" + p-limit@^2.2.0: version "2.3.0" resolved "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz" @@ -3094,7 +3989,7 @@ p-limit@^2.2.0: dependencies: p-try "^2.0.0" -p-limit@^3.1.0: +p-limit@^3.0.2, p-limit@^3.1.0: version "3.1.0" resolved "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz" integrity sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ== @@ -3108,11 +4003,25 @@ p-locate@^4.1.0: dependencies: p-limit "^2.2.0" +p-locate@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-5.0.0.tgz#83c8315c6785005e3bd021839411c9e110e6d834" + integrity sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw== + dependencies: + p-limit "^3.0.2" + p-try@^2.0.0: version "2.2.0" resolved "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz" integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ== +parent-module@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" + integrity sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g== + dependencies: + callsites "^3.0.0" + parse-json@^5.2.0: version "5.2.0" resolved "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz" @@ -3153,6 +4062,11 @@ path-to-regexp@0.1.7: resolved "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz" integrity sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ== +path-type@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-type/-/path-type-4.0.0.tgz#84ed01c0a7ba380afe09d90a8c180dcd9d03043b" + integrity sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw== + picocolors@^1.0.0: version "1.0.0" resolved "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz" @@ -3180,6 +4094,16 @@ possible-typed-array-names@^1.0.0: resolved "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz" integrity sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q== +prelude-ls@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.2.1.tgz#debc6489d7a6e6b0e7611888cec880337d316396" + integrity sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g== + +prettier@^3.2.5: + version "3.2.5" + resolved "https://registry.yarnpkg.com/prettier/-/prettier-3.2.5.tgz#e52bc3090586e824964a8813b09aba6233b28368" + integrity sha512-3/GWa9aOC0YeD7LUfvOG2NiDyhOWRvt1k+rcKhOuYnMY24iiCphgneUfJDyFXd6rZCAnuLBv6UeAULtrhT/F4A== + pretty-format@^29.0.0, pretty-format@^29.7.0: version "29.7.0" resolved "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz" @@ -3239,6 +4163,11 @@ querystring@0.2.0: resolved "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz" integrity sha512-X/xY82scca2tau62i9mDyU9K+I+djTMUsvwf7xnUX5GLvVzgJybOJf4Y6o9Zx3oJK/LSXg5tTZBjwzqVPaPO2g== +queue-microtask@^1.2.2: + version "1.2.3" + resolved "https://registry.yarnpkg.com/queue-microtask/-/queue-microtask-1.2.3.tgz#4929228bbc724dfac43e0efb058caf7b6cfb6243" + integrity sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A== + range-parser@~1.2.1: version "1.2.1" resolved "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz" @@ -3276,6 +4205,11 @@ resolve-cwd@^3.0.0: dependencies: resolve-from "^5.0.0" +resolve-from@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz#4abcd852ad32dd7baabfe9b40e00a36db5f392e6" + integrity sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g== + resolve-from@^5.0.0: version "5.0.0" resolved "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz" @@ -3295,6 +4229,18 @@ resolve@^1.20.0: path-parse "^1.0.7" supports-preserve-symlinks-flag "^1.0.0" +reusify@^1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/reusify/-/reusify-1.0.4.tgz#90da382b1e126efc02146e90845a88db12925d76" + integrity sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw== + +run-parallel@^1.1.9: + version "1.2.0" + resolved "https://registry.yarnpkg.com/run-parallel/-/run-parallel-1.2.0.tgz#66d1368da7bdf921eb9d95bd1a9229e7f21a43ee" + integrity sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA== + dependencies: + queue-microtask "^1.2.2" + safe-buffer@5.2.1: version "5.2.1" resolved "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz" @@ -3503,6 +4449,11 @@ strip-json-comments@^3.1.1: resolved "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz" integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== +strnum@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/strnum/-/strnum-1.0.5.tgz#5c4e829fe15ad4ff0d20c3db5ac97b73c9b072db" + integrity sha512-J8bbNyKKXl5qYcR36TIO8W3mVGVHrmmxsd5PAItGkmyzwJvybiw2IVq5nqd0i4LSNSkB/sx9VHllbfFdr9k1JA== + superagent@^8.1.2: version "8.1.2" resolved "https://registry.npmjs.org/superagent/-/superagent-8.1.2.tgz" @@ -3573,6 +4524,11 @@ test-exclude@^6.0.0: glob "^7.1.4" minimatch "^3.0.4" +text-table@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" + integrity sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw== + tmpl@1.0.5: version "1.0.5" resolved "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz" @@ -3595,6 +4551,11 @@ toidentifier@1.0.1: resolved "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz" integrity sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA== +ts-api-utils@^1.3.0: + version "1.3.0" + resolved "https://registry.yarnpkg.com/ts-api-utils/-/ts-api-utils-1.3.0.tgz#4b490e27129f1e8e686b45cc4ab63714dc60eea1" + integrity sha512-UQMIo7pb8WRomKR1/+MFVLTroIvDVtMX3K6OUir8ynLyzB8Jeriont2bTAtmNPa1ekAgN7YPDyf6V+ygrdU+eQ== + ts-jest@^29.1.2: version "29.1.2" resolved "https://registry.npmjs.org/ts-jest/-/ts-jest-29.1.2.tgz" @@ -3628,6 +4589,23 @@ ts-node@^10.9.2: v8-compile-cache-lib "^3.0.1" yn "3.1.1" +tslib@^1.11.1: + version "1.14.1" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00" + integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg== + +tslib@^2.3.1, tslib@^2.6.2: + version "2.6.2" + resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.6.2.tgz#703ac29425e7b37cd6fd456e92404d46d1f3e4ae" + integrity sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q== + +type-check@^0.4.0, type-check@~0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.4.0.tgz#07b8203bfa7056c0657050e3ccd2c37730bab8f1" + integrity sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew== + dependencies: + prelude-ls "^1.2.1" + type-detect@4.0.8: version "4.0.8" resolved "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz" @@ -3646,6 +4624,15 @@ type-is@^1.6.16, type-is@~1.6.18: media-typer "0.3.0" mime-types "~2.1.24" +typescript-eslint@^7.9.0: + version "7.9.0" + resolved "https://registry.yarnpkg.com/typescript-eslint/-/typescript-eslint-7.9.0.tgz#353312f356ef4ba20105a4e2e736aa8c68f096a2" + integrity sha512-7iTn9c10teHHCys5Ud/yaJntXZrjt3h2mrx3feJGBOLgQkF3TB1X89Xs3aVQ/GgdXRAXpk2bPTdpRwHP4YkUow== + dependencies: + "@typescript-eslint/eslint-plugin" "7.9.0" + "@typescript-eslint/parser" "7.9.0" + "@typescript-eslint/utils" "7.9.0" + typescript@~5.4.5: version "5.4.5" resolved "https://registry.npmjs.org/typescript/-/typescript-5.4.5.tgz" @@ -3674,7 +4661,7 @@ update-browserslist-db@^1.0.13: escalade "^3.1.1" picocolors "^1.0.0" -uri-js@^4.4.1: +uri-js@^4.2.2, uri-js@^4.4.1: version "4.4.1" resolved "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz" integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg== @@ -3764,6 +4751,11 @@ wmf@~1.0.1: resolved "https://registry.npmjs.org/wmf/-/wmf-1.0.2.tgz" integrity sha512-/p9K7bEh0Dj6WbXg4JG0xvLQmIadrner1bi45VMJTfnbVHsc7yIajZyoSoK60/dtVBs12Fm6WkUI5/3WAVsNMw== +word-wrap@^1.2.5: + version "1.2.5" + resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.5.tgz#d2c45c6dd4fbce621a66f136cbe328afd0410b34" + integrity sha512-BN22B5eaMMI9UMtjrGd5g5eCYPpCPDUy0FJXbYsaT5zYxjFOckS53SQDE3pWkVoWpHXVb3BrYcEN4Twa55B5cA== + word@~0.3.0: version "0.3.0" resolved "https://registry.npmjs.org/word/-/word-0.3.0.tgz" From c8bc39169a5752751649294aa1e36f64f41f0b33 Mon Sep 17 00:00:00 2001 From: ayuki_j <19406594+ayuki-joto@users.noreply.github.com> Date: Tue, 14 May 2024 20:49:22 +0900 Subject: [PATCH 3/7] refactor: lint:fix --- lib/lambda/actions/food.ts | 464 +++++++++++------- lib/lambda/actions/housing.ts | 261 ++++++----- lib/lambda/actions/mobility.ts | 468 +++++++++++-------- lib/lambda/actions/other.ts | 158 ++++--- lib/lambda/actions/util.ts | 24 +- lib/lambda/calculate-app.ts | 309 ++++++------ lib/lambda/citycarbonfootprints-app.ts | 151 +++--- lib/lambda/citylifestylechangeimpacts-app.ts | 224 ++++----- package.json | 2 +- 9 files changed, 1204 insertions(+), 857 deletions(-) diff --git a/lib/lambda/actions/food.ts b/lib/lambda/actions/food.ts index 619ec7c..5e93954 100644 --- a/lib/lambda/actions/food.ts +++ b/lib/lambda/actions/food.ts @@ -1,11 +1,27 @@ -import {findBaseline, toBaseline, toEstimation} from './util'; -import {DynamoDBDocumentClient, GetCommand, QueryCommand} from "@aws-sdk/lib-dynamodb"; +import { findBaseline, toBaseline, toEstimation } from './util' +import { + DynamoDBDocumentClient, + GetCommand, + QueryCommand +} from '@aws-sdk/lib-dynamodb' const estimateFood = async ( - dynamodb: DynamoDBDocumentClient, - foodAnswer: { foodIntakeFactorKey: any; foodDirectWasteFactorKey: any; foodLeftoverFactorKey: any; dairyFoodFactorKey: any; dishBeefFactorKey: any; dishPorkFactorKey: any; dishChickenFactorKey: any; dishSeafoodFactorKey: any; alcoholFactorKey: any; softDrinkSnackFactorKey: any; eatOutFactorKey: any }, - footprintTableName: string, - parameterTableName: string + dynamodb: DynamoDBDocumentClient, + foodAnswer: { + foodIntakeFactorKey: any + foodDirectWasteFactorKey: any + foodLeftoverFactorKey: any + dairyFoodFactorKey: any + dishBeefFactorKey: any + dishPorkFactorKey: any + dishChickenFactorKey: any + dishSeafoodFactorKey: any + alcoholFactorKey: any + softDrinkSnackFactorKey: any + eatOutFactorKey: any + }, + footprintTableName: string, + parameterTableName: string ) => { const getData = async (category: string, key: any) => { const params = { @@ -14,17 +30,32 @@ const estimateFood = async ( category: category, key: key } - }; - return await dynamodb.send(new GetCommand(params)); - }; + } + return await dynamodb.send(new GetCommand(params)) + } // foodのベースラインの取得 - const createAmount = (baselines: any, item: string) => toEstimation(findBaseline(baselines, 'food', item, 'amount')); - const createIntensity = (baselines: any, item: string) => toEstimation(findBaseline(baselines, 'food', item, 'intensity')); - const getCategoryBaseTotal = (baselines: any, item: string) => findBaseline(baselines, 'food', item, 'amount').value * findBaseline(baselines, 'food', item, 'intensity').value; - const getCategoryCustomTotal = (baselines: any, item: string, value: number) => value * findBaseline(baselines, 'food', item, 'intensity').value; - - const estimations: { domain: any; item: any; type: any; value: any; subdomain: any; unit: any; }[] = []; + const createAmount = (baselines: any, item: string) => + toEstimation(findBaseline(baselines, 'food', item, 'amount')) + const createIntensity = (baselines: any, item: string) => + toEstimation(findBaseline(baselines, 'food', item, 'intensity')) + const getCategoryBaseTotal = (baselines: any, item: string) => + findBaseline(baselines, 'food', item, 'amount').value * + findBaseline(baselines, 'food', item, 'intensity').value + const getCategoryCustomTotal = ( + baselines: any, + item: string, + value: number + ) => value * findBaseline(baselines, 'food', item, 'intensity').value + + const estimations: { + domain: any + item: any + type: any + value: any + subdomain: any + unit: any + }[] = [] // ベースラインのフットプリントを取得 const params = { @@ -33,17 +64,20 @@ const estimateFood = async ( ExpressionAttributeValues: { ':dir_domain': 'baseline_food' } - }; + } - const data = await dynamodb.send(new QueryCommand(params)); - const baselines = data.Items?.map((item: any) => toBaseline(item)); + const data = await dynamodb.send(new QueryCommand(params)) + const baselines = data.Items?.map((item: any) => toBaseline(item)) // 回答がない場合はベースラインのみ返す if (!foodAnswer) { - return { baselines, estimations }; + return { baselines, estimations } } - const foodIntakeFactor = await getData('food-intake-factor', foodAnswer?.foodIntakeFactorKey || 'unknown'); + const foodIntakeFactor = await getData( + 'food-intake-factor', + foodAnswer?.foodIntakeFactorKey || 'unknown' + ) const estimationAmount = { rice: createAmount(baselines, 'rice'), @@ -73,60 +107,91 @@ const estimateFood = async ( 'cold-drink': createAmount(baselines, 'cold-drink'), restaurant: createAmount(baselines, 'restaurant'), 'bar-cafe': createAmount(baselines, 'bar-cafe') - }; - - if (foodAnswer?.foodDirectWasteFactorKey && foodAnswer?.foodLeftoverFactorKey) { - const foodDirectWasteFactor = await getData('food-direct-waste-factor', foodAnswer.foodDirectWasteFactorKey); - const foodLeftoverFactor = await getData('food-leftover-factor', foodAnswer.foodLeftoverFactorKey); + } - const foodWasteRatioData = await dynamodb.send(new QueryCommand({ - TableName: parameterTableName, - KeyConditionExpression: 'category = :category', - ExpressionAttributeValues: { - ':category': 'food-waste-share' - } - })); + if ( + foodAnswer?.foodDirectWasteFactorKey && + foodAnswer?.foodLeftoverFactorKey + ) { + const foodDirectWasteFactor = await getData( + 'food-direct-waste-factor', + foodAnswer.foodDirectWasteFactorKey + ) + const foodLeftoverFactor = await getData( + 'food-leftover-factor', + foodAnswer.foodLeftoverFactorKey + ) + + const foodWasteRatioData = await dynamodb.send( + new QueryCommand({ + TableName: parameterTableName, + KeyConditionExpression: 'category = :category', + ExpressionAttributeValues: { + ':category': 'food-waste-share' + } + }) + ) // @ts-ignore - const leftoverRatio = foodWasteRatioData.Items.find((item: { key: string; }) => item.key === 'leftover-per-food-waste'); + const leftoverRatio = foodWasteRatioData.Items.find( + // @ts-ignore + (item: { key: string }) => item.key === 'leftover-per-food-waste' + ) // @ts-ignore - const directWasteRatio = foodWasteRatioData?.Items.find((item: { key: string; }) => item.key === 'direct-waste-per-food-waste'); + const directWasteRatio = foodWasteRatioData?.Items.find( // @ts-ignore - const foodWasteRatio = foodWasteRatioData?.Items.find((item: { key: string; }) => item.key === 'food-waste-per-food'); + (item: { key: string }) => item.key === 'direct-waste-per-food-waste' + ) + // @ts-ignore + const foodWasteRatio = foodWasteRatioData?.Items.find( + // @ts-ignore + (item: { key: string }) => item.key === 'food-waste-per-food' + ) const foodLossAverageRatio = - foodDirectWasteFactor.Item?.value * directWasteRatio?.value + - foodLeftoverFactor.Item?.value * leftoverRatio?.value; + foodDirectWasteFactor.Item?.value * directWasteRatio?.value + + foodLeftoverFactor.Item?.value * leftoverRatio?.value // 全体に影響する割合 // 食品ロスを考慮した食材購入量の平均に対する比率 const foodPurchaseAmountConsideringFoodLossRatio = - (1 + foodLossAverageRatio * foodWasteRatio?.value) / - (1 + foodWasteRatio?.value); - - estimationAmount.rice.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount['bread-flour'].value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount.noodle.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount.potatoes.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount.vegetables.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount['processed-vegetables'].value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount.beans.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount.fruits.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount.oil.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount.seasoning.value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount['ready-meal'].value *= foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - - estimations.push(estimationAmount.rice); - estimations.push(estimationAmount['bread-flour']); - estimations.push(estimationAmount.noodle); - estimations.push(estimationAmount.potatoes); - estimations.push(estimationAmount.vegetables); - estimations.push(estimationAmount['processed-vegetables']); - estimations.push(estimationAmount.beans); - estimations.push(estimationAmount.fruits); - estimations.push(estimationAmount.oil); - estimations.push(estimationAmount.seasoning); - estimations.push(estimationAmount['ready-meal']); + (1 + foodLossAverageRatio * foodWasteRatio?.value) / + (1 + foodWasteRatio?.value) + + estimationAmount.rice.value *= + foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimationAmount['bread-flour'].value *= + foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimationAmount.noodle.value *= + foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimationAmount.potatoes.value *= + foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimationAmount.vegetables.value *= + foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimationAmount['processed-vegetables'].value *= + foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimationAmount.beans.value *= + foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimationAmount.fruits.value *= + foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimationAmount.oil.value *= + foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimationAmount.seasoning.value *= + foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimationAmount['ready-meal'].value *= + foodIntakeFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + + estimations.push(estimationAmount.rice) + estimations.push(estimationAmount['bread-flour']) + estimations.push(estimationAmount.noodle) + estimations.push(estimationAmount.potatoes) + estimations.push(estimationAmount.vegetables) + estimations.push(estimationAmount['processed-vegetables']) + estimations.push(estimationAmount.beans) + estimations.push(estimationAmount.fruits) + estimations.push(estimationAmount.oil) + estimations.push(estimationAmount.seasoning) + estimations.push(estimationAmount['ready-meal']) // // 答えに従ってestimationを計算 @@ -134,88 +199,128 @@ const estimateFood = async ( // 乳製品補正 if (foodAnswer?.dairyFoodFactorKey) { - const dairyFoodFactor = await getData('dairy-food-factor', foodAnswer.dairyFoodFactorKey); - - estimationAmount.milk.value *= dairyFoodFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount['other-dairy'].value *= dairyFoodFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount.eggs.value *= dairyFoodFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimations.push(estimationAmount.milk); - estimations.push(estimationAmount['other-dairy']); - estimations.push(estimationAmount.eggs); + const dairyFoodFactor = await getData( + 'dairy-food-factor', + foodAnswer.dairyFoodFactorKey + ) + + estimationAmount.milk.value *= + dairyFoodFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimationAmount['other-dairy'].value *= + dairyFoodFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimationAmount.eggs.value *= + dairyFoodFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimations.push(estimationAmount.milk) + estimations.push(estimationAmount['other-dairy']) + estimations.push(estimationAmount.eggs) } // 牛肉補正 - let dishBeefFactor = null; + let dishBeefFactor = null if (foodAnswer?.dishBeefFactorKey) { - dishBeefFactor = await getData('dish-beef-factor', foodAnswer.dishBeefFactorKey); - - estimationAmount.beef.value *= dishBeefFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimations.push(estimationAmount.beef); + dishBeefFactor = await getData( + 'dish-beef-factor', + foodAnswer.dishBeefFactorKey + ) + + estimationAmount.beef.value *= + dishBeefFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimations.push(estimationAmount.beef) } // 豚肉補正 - let dishPorkFactor = null; + let dishPorkFactor = null if (foodAnswer?.dishPorkFactorKey) { - dishPorkFactor = await getData('dish-pork-factor', foodAnswer.dishPorkFactorKey); - - estimationAmount.pork.value *= dishPorkFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount['other-meat'].value *= dishPorkFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimations.push(estimationAmount.pork); - estimations.push(estimationAmount['other-meat']); + dishPorkFactor = await getData( + 'dish-pork-factor', + foodAnswer.dishPorkFactorKey + ) + + estimationAmount.pork.value *= + dishPorkFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimationAmount['other-meat'].value *= + dishPorkFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimations.push(estimationAmount.pork) + estimations.push(estimationAmount['other-meat']) } // 鶏肉補正 - let dishChickenFactor = null; + let dishChickenFactor = null if (foodAnswer?.dishChickenFactorKey) { - dishChickenFactor = await getData('dish-chicken-factor', foodAnswer.dishChickenFactorKey); - - estimationAmount.chicken.value *= dishChickenFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimations.push(estimationAmount.chicken); + dishChickenFactor = await getData( + 'dish-chicken-factor', + foodAnswer.dishChickenFactorKey + ) + + estimationAmount.chicken.value *= + dishChickenFactor.Item?.value * + foodPurchaseAmountConsideringFoodLossRatio + estimations.push(estimationAmount.chicken) } // 加工肉補正 if (dishBeefFactor && dishPorkFactor && dishChickenFactor) { estimationAmount['processed-meat'].value = - (estimationAmount['processed-meat'].value * - (estimationAmount.beef.value + - estimationAmount.pork.value + - estimationAmount['other-meat'].value + - estimationAmount.chicken.value)) / - (createAmount(baselines, 'beef').value + - createAmount(baselines, 'pork').value + - createAmount(baselines, 'other-meat').value + - createAmount(baselines, 'chicken').value); - estimations.push(estimationAmount['processed-meat']); + (estimationAmount['processed-meat'].value * + (estimationAmount.beef.value + + estimationAmount.pork.value + + estimationAmount['other-meat'].value + + estimationAmount.chicken.value)) / + (createAmount(baselines, 'beef').value + + createAmount(baselines, 'pork').value + + createAmount(baselines, 'other-meat').value + + createAmount(baselines, 'chicken').value) + estimations.push(estimationAmount['processed-meat']) } // 魚補正 if (foodAnswer?.dishSeafoodFactorKey) { - const dishSeafoodFactor = await getData('dish-seafood-factor', foodAnswer.dishSeafoodFactorKey); - - estimationAmount.fish.value *= dishSeafoodFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount['processed-fish'].value *= dishSeafoodFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimations.push(estimationAmount.fish); - estimations.push(estimationAmount['processed-fish']); + const dishSeafoodFactor = await getData( + 'dish-seafood-factor', + foodAnswer.dishSeafoodFactorKey + ) + + estimationAmount.fish.value *= + dishSeafoodFactor.Item?.value * + foodPurchaseAmountConsideringFoodLossRatio + estimationAmount['processed-fish'].value *= + dishSeafoodFactor.Item?.value * + foodPurchaseAmountConsideringFoodLossRatio + estimations.push(estimationAmount.fish) + estimations.push(estimationAmount['processed-fish']) } // アルコール補正 if (foodAnswer?.alcoholFactorKey) { - const alcoholFactor = await getData('alcohol-factor', foodAnswer.alcoholFactorKey); - - estimationAmount.alcohol.value *= alcoholFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimations.push(estimationAmount.alcohol); + const alcoholFactor = await getData( + 'alcohol-factor', + foodAnswer.alcoholFactorKey + ) + + estimationAmount.alcohol.value *= + alcoholFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio + estimations.push(estimationAmount.alcohol) } // 菓子など補正 if (foodAnswer?.softDrinkSnackFactorKey) { - const softDrinkSnackFactor = await getData('soft-drink-snack-factor', foodAnswer.softDrinkSnackFactorKey); - - estimationAmount['sweets-snack'].value *= softDrinkSnackFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount['coffee-tea'].value *= softDrinkSnackFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimationAmount['cold-drink'].value *= softDrinkSnackFactor.Item?.value * foodPurchaseAmountConsideringFoodLossRatio; - estimations.push(estimationAmount['sweets-snack']); - estimations.push(estimationAmount['coffee-tea']); - estimations.push(estimationAmount['cold-drink']); + const softDrinkSnackFactor = await getData( + 'soft-drink-snack-factor', + foodAnswer.softDrinkSnackFactorKey + ) + + estimationAmount['sweets-snack'].value *= + softDrinkSnackFactor.Item?.value * + foodPurchaseAmountConsideringFoodLossRatio + estimationAmount['coffee-tea'].value *= + softDrinkSnackFactor.Item?.value * + foodPurchaseAmountConsideringFoodLossRatio + estimationAmount['cold-drink'].value *= + softDrinkSnackFactor.Item?.value * + foodPurchaseAmountConsideringFoodLossRatio + estimations.push(estimationAmount['sweets-snack']) + estimations.push(estimationAmount['coffee-tea']) + estimations.push(estimationAmount['cold-drink']) } // //ready-meal intensity @@ -241,41 +346,46 @@ const estimateFood = async ( 'oil', 'seasoning', 'sweets-snack' - ]; + ] - const readyMealIntensity = createIntensity(baselines,'ready-meal'); + const readyMealIntensity = createIntensity(baselines, 'ready-meal') let currentTotalAmount = beforeReadyMealKeyArray.reduce( - // @ts-ignore - (res, key) => res + estimationAmount[key].value, - 0 - ); + // @ts-ignore + (res, key) => res + estimationAmount[key].value, + 0 + ) let baseTotalAmount = beforeReadyMealKeyArray.reduce( - // @ts-ignore - (res, key) => res + findBaseline(baselines, 'food', key, 'amount').value, - 0 - ); + // @ts-ignore + (res, key) => res + findBaseline(baselines, 'food', key, 'amount').value, + 0 + ) readyMealIntensity.value = - (readyMealIntensity.value * - (beforeReadyMealKeyArray.reduce( - // @ts-ignore - (res, key) => res + getCategoryCustomTotal(baselines, key, estimationAmount[key].value), - 0 - ) / - currentTotalAmount)) / + (readyMealIntensity.value * (beforeReadyMealKeyArray.reduce( - (res, key) => res + getCategoryBaseTotal(baselines, key), - 0 - ) / - baseTotalAmount); - estimations.push(readyMealIntensity); + (res, key) => + res + + // @ts-ignore + getCategoryCustomTotal(baselines, key, estimationAmount[key].value), + 0 + ) / + currentTotalAmount)) / + (beforeReadyMealKeyArray.reduce( + (res, key) => res + getCategoryBaseTotal(baselines, key), + 0 + ) / + baseTotalAmount) + estimations.push(readyMealIntensity) // 外食部分の計算 if (foodAnswer?.eatOutFactorKey) { - const eatOutFactor = await getData('eat-out-factor', foodAnswer.eatOutFactorKey); - estimationAmount.restaurant.value *= eatOutFactor.Item?.value; - estimationAmount['bar-cafe'].value *= eatOutFactor.Item?.value; - estimations.push(estimationAmount.restaurant); - estimations.push(estimationAmount['bar-cafe']); + const eatOutFactor = await getData( + 'eat-out-factor', + foodAnswer.eatOutFactorKey + ) + estimationAmount.restaurant.value *= eatOutFactor.Item?.value + estimationAmount['bar-cafe'].value *= eatOutFactor.Item?.value + estimations.push(estimationAmount.restaurant) + estimations.push(estimationAmount['bar-cafe']) //eatOut intensity const EatOutArray = [ @@ -304,38 +414,50 @@ const estimateFood = async ( 'alcohol', 'coffee-tea', 'cold-drink' - ]; + ] currentTotalAmount = EatOutArray.reduce( - // @ts-ignore - (res, key) => res + estimationAmount[key].value, - 0 - ); + // @ts-ignore + (res, key) => res + estimationAmount[key].value, + 0 + ) baseTotalAmount = EatOutArray.reduce( - // @ts-ignore - (res, key) => res + findBaseline(baselines, 'food', key, 'amount').value, - 0 - ); + (res, key) => + // @ts-ignore + res + findBaseline(baselines, 'food', key, 'amount').value, + 0 + ) const eatOutIntensityResult = - EatOutArray.reduce((res, key) => { - if (key !== 'ready-meal') { - // @ts-ignore - return res + getCategoryCustomTotal(baselines, key, estimationAmount[key].value); - } else { - return res + estimationAmount[key].value * readyMealIntensity.value; - } - }, 0) / - currentTotalAmount / - (EatOutArray.reduce((res, key) => res + getCategoryBaseTotal(baselines,key), 0) / baseTotalAmount); - const restaurantIntensity = createIntensity(baselines,'restaurant'); - const barCafeIntensity = createIntensity(baselines,'bar-cafe'); - restaurantIntensity.value *= eatOutIntensityResult; - barCafeIntensity.value *= eatOutIntensityResult; - estimations.push(restaurantIntensity); - estimations.push(barCafeIntensity); + EatOutArray.reduce((res, key) => { + if (key !== 'ready-meal') { + return ( + res + + getCategoryCustomTotal( + baselines, + key, + // @ts-ignore + estimationAmount[key].value + ) + ) + } else { + return res + estimationAmount[key].value * readyMealIntensity.value + } + }, 0) / + currentTotalAmount / + (EatOutArray.reduce( + (res, key) => res + getCategoryBaseTotal(baselines, key), + 0 + ) / + baseTotalAmount) + const restaurantIntensity = createIntensity(baselines, 'restaurant') + const barCafeIntensity = createIntensity(baselines, 'bar-cafe') + restaurantIntensity.value *= eatOutIntensityResult + barCafeIntensity.value *= eatOutIntensityResult + estimations.push(restaurantIntensity) + estimations.push(barCafeIntensity) } } - return { baselines, estimations }; -}; + return { baselines, estimations } +} -export { estimateFood }; +export { estimateFood } diff --git a/lib/lambda/actions/housing.ts b/lib/lambda/actions/housing.ts index b2c7e9c..a0e7dd2 100644 --- a/lib/lambda/actions/housing.ts +++ b/lib/lambda/actions/housing.ts @@ -1,12 +1,16 @@ -import {findBaseline, toBaseline, toEstimation} from './util'; -import {DynamoDBDocumentClient, GetCommand, QueryCommand} from "@aws-sdk/lib-dynamodb"; +import { findBaseline, toBaseline, toEstimation } from './util' +import { + DynamoDBDocumentClient, + GetCommand, + QueryCommand +} from '@aws-sdk/lib-dynamodb' const estimateHousing = async ( - dynamodb: DynamoDBDocumentClient, - housingAnswer: any, - mobilityAnswer: any, - footprintTableName: string, - parameterTableName: string + dynamodb: DynamoDBDocumentClient, + housingAnswer: any, + mobilityAnswer: any, + footprintTableName: string, + parameterTableName: string ) => { const getData = async (category: any, key: any) => { const params = { @@ -15,23 +19,30 @@ const estimateHousing = async ( category: category, key: key } - }; + } - return await dynamodb.send(new GetCommand(params)); - }; + return await dynamodb.send(new GetCommand(params)) + } const pushOrUpdateEstimate = (item: any, type: any, estimation: any) => { const estimate = estimations.find( - (estimation) => estimation.item === item && estimation.type === type - ); + (estimation) => estimation.item === item && estimation.type === type + ) if (estimate) { - estimate.value = estimation.value; + estimate.value = estimation.value } else { - estimations.push(estimation); + estimations.push(estimation) } - }; + } - const estimations: { domain: any; item: any; type: any; value: any; subdomain: any; unit: any }[] = []; + const estimations: { + domain: any + item: any + type: any + value: any + subdomain: any + unit: any + }[] = [] // ベースラインのフットプリントを取得 const params = { @@ -40,29 +51,29 @@ const estimateHousing = async ( ExpressionAttributeValues: { ':dir_domain': 'baseline_housing' } - }; + } - const data = await dynamodb.send(new QueryCommand(params)); - const baselines = data.Items?.map((item: any) => toBaseline(item)); + const data = await dynamodb.send(new QueryCommand(params)) + const baselines = data.Items?.map((item: any) => toBaseline(item)) - if(baselines == undefined) { + if (baselines == undefined) { return {} } const findAmount = (item: string) => - findBaseline(baselines, 'housing', item, 'amount'); + findBaseline(baselines, 'housing', item, 'amount') const createAmount = (item: string) => - toEstimation(findBaseline(baselines, 'housing', item, 'amount')); + toEstimation(findBaseline(baselines, 'housing', item, 'amount')) const createIntensity = (item: string) => - toEstimation(findBaseline(baselines, 'housing', item, 'intensity')); + toEstimation(findBaseline(baselines, 'housing', item, 'intensity')) // 回答がない場合はベースラインのみ返す if (!housingAnswer) { - return { baselines, estimations }; + return { baselines, estimations } } - const residentCount = housingAnswer.residentCount; + const residentCount = housingAnswer.residentCount // 住居人数が0以下の場合はベースラインのみ返す if (residentCount <= 0) { - return { baselines, estimations }; + return { baselines, estimations } } // 下記部分でパラメータ名から一致を取る必要があるため、ケバブのまま変数化 @@ -74,7 +85,7 @@ const estimateHousing = async ( 'urban-gas': createAmount('urban-gas'), lpg: createAmount('lpg'), kerosene: createAmount('kerosene') - }; + } // // # お住まいの地域(地方)はどちらですか? @@ -84,10 +95,12 @@ const estimateHousing = async ( // housingAmountByRegion: String # northeast|middle|southwest|unknown // if (housingAnswer.housingAmountByRegionFirstKey) { - const housingAmountByRegion = housingAnswer.housingAmountByRegionFirstKey + '_'; + const housingAmountByRegion = + housingAnswer.housingAmountByRegionFirstKey + '_' const params = { TableName: parameterTableName, - KeyConditionExpression: 'category = :category and begins_with(#key, :key)', + KeyConditionExpression: + 'category = :category and begins_with(#key, :key)', ExpressionAttributeNames: { '#key': 'key' }, @@ -95,22 +108,23 @@ const estimateHousing = async ( ':category': 'housing-amount-by-region', ':key': housingAmountByRegion } - }; - const amountByRegion = await dynamodb.send(new QueryCommand(params)); + } + const amountByRegion = await dynamodb.send(new QueryCommand(params)) // estimationAmountに項目があるものだけ、amountByRegionの値を上書き for (const key of Object.keys(estimationAmount)) { // @ts-ignore const rec = amountByRegion.Items.find( - // @ts-ignore - (a: { key: string }) => a.key === housingAmountByRegion + key + '-amount' - ); + // @ts-ignore + (a: { key: string }) => + a.key === housingAmountByRegion + key + '-amount' + ) if (rec) { // @ts-ignore - estimationAmount[key].value = rec.value; + estimationAmount[key].value = rec.value } // @ts-ignore - estimations.push(estimationAmount[key]); + estimations.push(estimationAmount[key]) } } @@ -123,132 +137,163 @@ const estimateHousing = async ( // water if (housingAnswer.housingSizeKey) { - const housingSize = await getData('housing-size', housingAnswer.housingSizeKey); + const housingSize = await getData( + 'housing-size', + housingAnswer.housingSizeKey + ) const housingSizePerResident = - housingAnswer.housingSizeKey === 'unknown' - ? housingSize.Item?.value - : housingSize.Item?.value / residentCount; + housingAnswer.housingSizeKey === 'unknown' + ? housingSize.Item?.value + : housingSize.Item?.value / residentCount - const imputedRentValue = findAmount('imputed-rent').value; - const rentValue = findAmount('rent').value; + const imputedRentValue = findAmount('imputed-rent').value + const rentValue = findAmount('rent').value estimationAmount['imputed-rent'].value = - (housingSizePerResident / (imputedRentValue + rentValue)) * - imputedRentValue; + (housingSizePerResident / (imputedRentValue + rentValue)) * + imputedRentValue estimationAmount.rent.value = - (housingSizePerResident / (imputedRentValue + rentValue)) * rentValue; + (housingSizePerResident / (imputedRentValue + rentValue)) * rentValue estimationAmount['housing-maintenance'].value = - (findAmount('housing-maintenance').value / - (imputedRentValue + rentValue)) * - (estimationAmount['imputed-rent'].value + estimationAmount.rent.value); - pushOrUpdateEstimate('imputed-rent', 'amount', estimationAmount['imputed-rent']); - pushOrUpdateEstimate('rent', 'amount', estimationAmount.rent); - pushOrUpdateEstimate('housing-maintenance', 'amount', estimationAmount['housing-maintenance']); + (findAmount('housing-maintenance').value / + (imputedRentValue + rentValue)) * + (estimationAmount['imputed-rent'].value + estimationAmount.rent.value) + pushOrUpdateEstimate( + 'imputed-rent', + 'amount', + estimationAmount['imputed-rent'] + ) + pushOrUpdateEstimate('rent', 'amount', estimationAmount.rent) + pushOrUpdateEstimate( + 'housing-maintenance', + 'amount', + estimationAmount['housing-maintenance'] + ) } // 再生可能エネルギー if (housingAnswer.electricityIntensityKey) { - const electricityParam = await getData('electricity-intensity', housingAnswer.electricityIntensityKey); - const electricityIntensity = createIntensity('electricity'); - electricityIntensity.value = electricityParam.Item?.value; - estimations.push(electricityIntensity); + const electricityParam = await getData( + 'electricity-intensity', + housingAnswer.electricityIntensityKey + ) + const electricityIntensity = createIntensity('electricity') + electricityIntensity.value = electricityParam.Item?.value + estimations.push(electricityIntensity) } // 電力使用量 if ( - housingAnswer.electricityMonthlyConsumption != undefined && - housingAnswer.electricityMonthlyConsumption != null && - housingAnswer.electricitySeasonFactorKey + housingAnswer.electricityMonthlyConsumption != undefined && + housingAnswer.electricityMonthlyConsumption != null && + housingAnswer.electricitySeasonFactorKey ) { - const electricitySeason = await getData('electricity-season-factor', housingAnswer.electricitySeasonFactorKey); + const electricitySeason = await getData( + 'electricity-season-factor', + housingAnswer.electricitySeasonFactorKey + ) - let mobilityElectricityAmount = 0; + let mobilityElectricityAmount = 0 // PHV, EVの補正 if ( - mobilityAnswer?.hasPrivateCar && - (mobilityAnswer?.carIntensityFactorFirstKey === 'phv' || - mobilityAnswer?.carIntensityFactorFirstKey === 'ev') && - mobilityAnswer?.privateCarAnnualMileage && - mobilityAnswer?.carChargingKey + mobilityAnswer?.hasPrivateCar && + (mobilityAnswer?.carIntensityFactorFirstKey === 'phv' || + mobilityAnswer?.carIntensityFactorFirstKey === 'ev') && + mobilityAnswer?.privateCarAnnualMileage && + mobilityAnswer?.carChargingKey ) { const electricityData = await getData( - 'car-intensity-factor', - mobilityAnswer.carIntensityFactorFirstKey + '_electricity-intensity' - ); - const mobilityElectricity = electricityData?.Item?.value || 1; + 'car-intensity-factor', + mobilityAnswer.carIntensityFactorFirstKey + '_electricity-intensity' + ) + const mobilityElectricity = electricityData?.Item?.value || 1 - const chargingData = await getData('car-charging', mobilityAnswer.carChargingKey); - const mobilityCharging = chargingData?.Item?.value || 1; + const chargingData = await getData( + 'car-charging', + mobilityAnswer.carChargingKey + ) + const mobilityCharging = chargingData?.Item?.value || 1 mobilityElectricityAmount = - mobilityAnswer.privateCarAnnualMileage * - mobilityElectricity * - mobilityCharging; + mobilityAnswer.privateCarAnnualMileage * + mobilityElectricity * + mobilityCharging } estimationAmount.electricity.value = - (housingAnswer.electricityMonthlyConsumption * electricitySeason.Item?.value) / + (housingAnswer.electricityMonthlyConsumption * + electricitySeason.Item?.value) / residentCount - - mobilityElectricityAmount; - pushOrUpdateEstimate('electricity', 'amount', estimationAmount.electricity); + mobilityElectricityAmount + pushOrUpdateEstimate('electricity', 'amount', estimationAmount.electricity) } // ガスの使用の有無 if (housingAnswer.useGas) { - let gasParam = null; + let gasParam = null if ( - housingAnswer.gasMonthlyConsumption != undefined && - housingAnswer.gasMonthlyConsumption != null && - housingAnswer.gasSeasonFactorKey + housingAnswer.gasMonthlyConsumption != undefined && + housingAnswer.gasMonthlyConsumption != null && + housingAnswer.gasSeasonFactorKey ) { - const gasSeason = await getData('gas-season-factor', housingAnswer.gasSeasonFactorKey); - const gasFactor = await getData('energy-heat-intensity', housingAnswer.energyHeatIntensityKey); + const gasSeason = await getData( + 'gas-season-factor', + housingAnswer.gasSeasonFactorKey + ) + const gasFactor = await getData( + 'energy-heat-intensity', + housingAnswer.energyHeatIntensityKey + ) gasParam = - (housingAnswer.gasMonthlyConsumption * (gasSeason.Item?.value || 1) * (gasFactor.Item?.value || 1)) / - residentCount; + (housingAnswer.gasMonthlyConsumption * + (gasSeason.Item?.value || 1) * + (gasFactor.Item?.value || 1)) / + residentCount } if (housingAnswer.energyHeatIntensityKey === 'lpg') { if (gasParam != null) { - estimationAmount.lpg.value = gasParam; + estimationAmount.lpg.value = gasParam } - estimationAmount['urban-gas'].value = 0; + estimationAmount['urban-gas'].value = 0 } else if (housingAnswer.energyHeatIntensityKey === 'urban-gas') { if (gasParam != null) { - estimationAmount['urban-gas'].value = gasParam; + estimationAmount['urban-gas'].value = gasParam } - estimationAmount.lpg.value = 0; + estimationAmount.lpg.value = 0 } - pushOrUpdateEstimate('urban-gas', 'amount', estimationAmount['urban-gas']); - pushOrUpdateEstimate('lpg', 'amount', estimationAmount.lpg); + pushOrUpdateEstimate('urban-gas', 'amount', estimationAmount['urban-gas']) + pushOrUpdateEstimate('lpg', 'amount', estimationAmount.lpg) } else if (housingAnswer.useGas === false) { - estimationAmount['urban-gas'].value = 0; - estimationAmount.lpg.value = 0; - pushOrUpdateEstimate('urban-gas', 'amount', estimationAmount['urban-gas']); - pushOrUpdateEstimate('lpg', 'amount', estimationAmount.lpg); + estimationAmount['urban-gas'].value = 0 + estimationAmount.lpg.value = 0 + pushOrUpdateEstimate('urban-gas', 'amount', estimationAmount['urban-gas']) + pushOrUpdateEstimate('lpg', 'amount', estimationAmount.lpg) } // 灯油の使用の有無 if (housingAnswer.useKerosene) { if ( - housingAnswer.keroseneMonthlyConsumption != undefined && - housingAnswer.keroseneMonthlyConsumption != null && - housingAnswer.keroseneMonthCount != undefined && - housingAnswer.keroseneMonthCount != null + housingAnswer.keroseneMonthlyConsumption != undefined && + housingAnswer.keroseneMonthlyConsumption != null && + housingAnswer.keroseneMonthCount != undefined && + housingAnswer.keroseneMonthCount != null ) { - const keroseneData = await getData('energy-heat-intensity', 'kerosene'); + const keroseneData = await getData('energy-heat-intensity', 'kerosene') estimationAmount.kerosene.value = - ((keroseneData?.Item?.value || 1) * (housingAnswer.keroseneMonthlyConsumption * housingAnswer.keroseneMonthCount)) / - residentCount; + ((keroseneData?.Item?.value || 1) * + (housingAnswer.keroseneMonthlyConsumption * + housingAnswer.keroseneMonthCount)) / + residentCount } - pushOrUpdateEstimate('kerosene', 'amount', estimationAmount.kerosene); + pushOrUpdateEstimate('kerosene', 'amount', estimationAmount.kerosene) } else if (housingAnswer.useKerosene === false) { - estimationAmount.kerosene.value = 0; - pushOrUpdateEstimate('kerosene', 'amount', estimationAmount.kerosene); + estimationAmount.kerosene.value = 0 + pushOrUpdateEstimate('kerosene', 'amount', estimationAmount.kerosene) } - return { baselines, estimations }; -}; + return { baselines, estimations } +} -export { estimateHousing }; +export { estimateHousing } diff --git a/lib/lambda/actions/mobility.ts b/lib/lambda/actions/mobility.ts index a9a0172..f0ab44b 100644 --- a/lib/lambda/actions/mobility.ts +++ b/lib/lambda/actions/mobility.ts @@ -1,36 +1,40 @@ -import {findBaseline, toBaseline, toEstimation} from './util'; -import {DynamoDBDocumentClient, GetCommand, QueryCommand} from "@aws-sdk/lib-dynamodb"; +import { findBaseline, toBaseline, toEstimation } from './util' +import { + DynamoDBDocumentClient, + GetCommand, + QueryCommand +} from '@aws-sdk/lib-dynamodb' const estimateMobility = async ( - dynamodb: DynamoDBDocumentClient, - housingAnswer: { electricityIntensityKey: any }, - mobilityAnswer: { - carChargingKey: any; - hasPrivateCar: any; - carIntensityFactorFirstKey: string; - carPassengersFirstKey: string; - privateCarAnnualMileage: number; - hasTravelingTime: any; - trainWeeklyTravelingTime: any; - busWeeklyTravelingTime: any; - motorbikeWeeklyTravelingTime: any; - otherCarWeeklyTravelingTime: any; - otherCarAnnualTravelingTime: any; - trainAnnualTravelingTime: any; - busAnnualTravelingTime: any; - motorbikeAnnualTravelingTime: any; - airplaneAnnualTravelingTime: any; - ferryAnnualTravelingTime: any; - mileageByAreaFirstKey: string; - }, - footprintTableName: any, - parameterTableName: any + dynamodb: DynamoDBDocumentClient, + housingAnswer: { electricityIntensityKey: any }, + mobilityAnswer: { + carChargingKey: any + hasPrivateCar: any + carIntensityFactorFirstKey: string + carPassengersFirstKey: string + privateCarAnnualMileage: number + hasTravelingTime: any + trainWeeklyTravelingTime: any + busWeeklyTravelingTime: any + motorbikeWeeklyTravelingTime: any + otherCarWeeklyTravelingTime: any + otherCarAnnualTravelingTime: any + trainAnnualTravelingTime: any + busAnnualTravelingTime: any + motorbikeAnnualTravelingTime: any + airplaneAnnualTravelingTime: any + ferryAnnualTravelingTime: any + mileageByAreaFirstKey: string + }, + footprintTableName: any, + parameterTableName: any ) => { // mobilityのベースラインの取得 const createAmount = (baselines: any, item: string) => - toEstimation(findBaseline(baselines, 'mobility', item, 'amount')); + toEstimation(findBaseline(baselines, 'mobility', item, 'amount')) const createIntensity = (baselines: any, item: string) => - toEstimation(findBaseline(baselines, 'mobility', item, 'intensity')); + toEstimation(findBaseline(baselines, 'mobility', item, 'intensity')) const getData = async (category: string, key: string) => { const params = { @@ -39,25 +43,41 @@ const estimateMobility = async ( category: category, key: key } - }; - return await dynamodb.send(new GetCommand(params)); - }; + } + return await dynamodb.send(new GetCommand(params)) + } - const estimations: { domain: any; item: any; type: any; value: any; subdomain: any; unit: any }[] = []; + const estimations: { + domain: any + item: any + type: any + value: any + subdomain: any + unit: any + }[] = [] const pushOrUpdateEstimate = ( - item: any, - type: any, - estimation: { domain?: any; item?: any; type?: any; value: any; subdomain?: any; unit?: any } + item: any, + type: any, + estimation: { + domain?: any + item?: any + type?: any + value: any + subdomain?: any + unit?: any + } ) => { - const estimate = estimations.find((estimation) => estimation.item === item && estimation.type === type); + const estimate = estimations.find( + (estimation) => estimation.item === item && estimation.type === type + ) if (estimate) { - estimate.value = estimation.value; + estimate.value = estimation.value } else { // @ts-ignore - estimations.push(estimation); + estimations.push(estimation) } - }; + } // ベースラインのフットプリントを取得 let params = { @@ -66,28 +86,34 @@ const estimateMobility = async ( ExpressionAttributeValues: { ':dir_domain': 'baseline_mobility' } - }; + } - let data = await dynamodb.send(new QueryCommand(params)); - const baselines = data.Items?.map((item: any) => toBaseline(item)); + let data = await dynamodb.send(new QueryCommand(params)) + const baselines = data.Items?.map((item: any) => toBaseline(item)) // 回答がない場合はベースラインのみ返す if (!mobilityAnswer) { - return { baselines, estimations }; + return { baselines, estimations } } - let electricityIntensityFactor = 0; + let electricityIntensityFactor = 0 // PHV, EVの場合は自宅での充電割合と再生エネルギー電力の割合で補正 if (housingAnswer?.electricityIntensityKey) { - const electricityData = await getData('electricity-intensity-factor', housingAnswer.electricityIntensityKey); + const electricityData = await getData( + 'electricity-intensity-factor', + housingAnswer.electricityIntensityKey + ) if (electricityData?.Item) { - electricityIntensityFactor = electricityData.Item.value; + electricityIntensityFactor = electricityData.Item.value } - const carChargingData = await getData('car-charging', mobilityAnswer?.carChargingKey || 'unknown'); + const carChargingData = await getData( + 'car-charging', + mobilityAnswer?.carChargingKey || 'unknown' + ) if (carChargingData?.Item) { - electricityIntensityFactor *= carChargingData.Item.value; + electricityIntensityFactor *= carChargingData.Item.value } } @@ -98,127 +124,157 @@ const estimateMobility = async ( // 自家用車をお持ちですか?がYesの場合 if (mobilityAnswer.hasPrivateCar) { if (mobilityAnswer?.carIntensityFactorFirstKey) { - const drivingIntensity = createIntensity(baselines, 'private-car-driving'); + const drivingIntensity = createIntensity(baselines, 'private-car-driving') // 自家用車の場合は、自動車種類に応じて運転時GHG原単位を取得 - let ghgIntensityRatio = 1; + let ghgIntensityRatio = 1 let data = await getData( - 'car-intensity-factor', - mobilityAnswer.carIntensityFactorFirstKey + '_driving-factor' - ); + 'car-intensity-factor', + mobilityAnswer.carIntensityFactorFirstKey + '_driving-factor' + ) if (data?.Item) { - ghgIntensityRatio *= data.Item.value; + ghgIntensityRatio *= data.Item.value } // PHV, EVの補正 - if (mobilityAnswer.carIntensityFactorFirstKey === 'phv' || mobilityAnswer.carIntensityFactorFirstKey === 'ev') { + if ( + mobilityAnswer.carIntensityFactorFirstKey === 'phv' || + mobilityAnswer.carIntensityFactorFirstKey === 'ev' + ) { const data = await getData( - 'renewable-car-intensity-factor', - mobilityAnswer.carIntensityFactorFirstKey + '_driving-factor' - ); + 'renewable-car-intensity-factor', + mobilityAnswer.carIntensityFactorFirstKey + '_driving-factor' + ) if (data?.Item) { ghgIntensityRatio = - ghgIntensityRatio * (1 - electricityIntensityFactor) + data.Item.value * electricityIntensityFactor; + ghgIntensityRatio * (1 - electricityIntensityFactor) + + data.Item.value * electricityIntensityFactor } } // 人数補正値 - data = await getData('car-passengers', (mobilityAnswer.carPassengersFirstKey || 'unknown') + '_private-car-factor'); - let passengerIntensityRatio = data?.Item?.value || 1; + data = await getData( + 'car-passengers', + (mobilityAnswer.carPassengersFirstKey || 'unknown') + + '_private-car-factor' + ) + let passengerIntensityRatio = data?.Item?.value || 1 - const purchaseIntensity = createIntensity(baselines, 'private-car-purchase'); + const purchaseIntensity = createIntensity( + baselines, + 'private-car-purchase' + ) // 自家用車の場合は、自動車種類に応じて運転時GHG原単位を取得 const purchaseData = await getData( - 'car-intensity-factor', - (mobilityAnswer.carIntensityFactorFirstKey || 'unknown') + '_manufacturing-factor' - ); + 'car-intensity-factor', + (mobilityAnswer.carIntensityFactorFirstKey || 'unknown') + + '_manufacturing-factor' + ) if (purchaseData?.Item) { - purchaseIntensity.value *= purchaseData.Item.value; + purchaseIntensity.value *= purchaseData.Item.value } - estimations.push(purchaseIntensity); + estimations.push(purchaseIntensity) - drivingIntensity.value *= ghgIntensityRatio * passengerIntensityRatio; - estimations.push(drivingIntensity); + drivingIntensity.value *= ghgIntensityRatio * passengerIntensityRatio + estimations.push(drivingIntensity) // 自家用車の移動距離を取得 - const amount = createAmount(baselines, 'private-car-driving'); - const baselineAmount = amount.value; - amount.value = mobilityAnswer.privateCarAnnualMileage || 0; - estimations.push(amount); - const mileageRatio = amount.value / baselineAmount; - - const privateCarPurchase = createAmount(baselines, 'private-car-purchase'); - const privateCarMaintenance = createAmount(baselines, 'private-car-maintenance'); + const amount = createAmount(baselines, 'private-car-driving') + const baselineAmount = amount.value + amount.value = mobilityAnswer.privateCarAnnualMileage || 0 + estimations.push(amount) + const mileageRatio = amount.value / baselineAmount + + const privateCarPurchase = createAmount(baselines, 'private-car-purchase') + const privateCarMaintenance = createAmount( + baselines, + 'private-car-maintenance' + ) // 自家用車の購入・メンテナンスを移動距離比で補正 - privateCarPurchase.value *= mileageRatio; - privateCarMaintenance.value *= mileageRatio; - estimations.push(privateCarPurchase); - estimations.push(privateCarMaintenance); + privateCarPurchase.value *= mileageRatio + privateCarMaintenance.value *= mileageRatio + estimations.push(privateCarPurchase) + estimations.push(privateCarMaintenance) } } else { - const amount = createAmount(baselines, 'private-car-driving'); - amount.value = 0; - estimations.push(amount); - const privateCarPurchase = createAmount(baselines, 'private-car-purchase'); - privateCarPurchase.value = 0; - estimations.push(privateCarPurchase); - const privateCarMaintenance = createAmount(baselines, 'private-car-maintenance'); - privateCarMaintenance.value = 0; - estimations.push(privateCarMaintenance); + const amount = createAmount(baselines, 'private-car-driving') + amount.value = 0 + estimations.push(amount) + const privateCarPurchase = createAmount(baselines, 'private-car-purchase') + privateCarPurchase.value = 0 + estimations.push(privateCarPurchase) + const privateCarMaintenance = createAmount( + baselines, + 'private-car-maintenance' + ) + privateCarMaintenance.value = 0 + estimations.push(privateCarMaintenance) } // taxiのintensity補正。本来はtaxiの乗車人数を確認する必要があるがcarPassengersFirstKeyを代用 if (mobilityAnswer.carPassengersFirstKey) { - const intensity = createIntensity(baselines, 'taxi'); + const intensity = createIntensity(baselines, 'taxi') // 人数補正値 - const data = await getData('car-passengers', mobilityAnswer.carPassengersFirstKey + '_taxi-factor'); - const ratio = data?.Item?.value || 1; - intensity.value *= ratio; - estimations.push(intensity); + const data = await getData( + 'car-passengers', + mobilityAnswer.carPassengersFirstKey + '_taxi-factor' + ) + const ratio = data?.Item?.value || 1 + intensity.value *= ratio + estimations.push(intensity) } // カーシェアの補正。本来はcar-sharingの乗車人数を確認する必要があるがcarPassengersFirstKeyを代用 - if (mobilityAnswer.carPassengersFirstKey && mobilityAnswer.carIntensityFactorFirstKey) { + if ( + mobilityAnswer.carPassengersFirstKey && + mobilityAnswer.carIntensityFactorFirstKey + ) { // car-sharing-drivingのintensity補正 // 人数補正値 const passengers = await getData( - 'car-passengers', - mobilityAnswer.carPassengersFirstKey + '_private-car-factor' - ); - const passengerIntensityRatio = passengers?.Item?.value || 1; + 'car-passengers', + mobilityAnswer.carPassengersFirstKey + '_private-car-factor' + ) + const passengerIntensityRatio = passengers?.Item?.value || 1 const driving = await getData( - 'car-intensity-factor', - (mobilityAnswer.carIntensityFactorFirstKey || 'unknown') + '_driving-factor' - ); - let ghgIntensityRatio = driving?.Item?.value || 1; + 'car-intensity-factor', + (mobilityAnswer.carIntensityFactorFirstKey || 'unknown') + + '_driving-factor' + ) + let ghgIntensityRatio = driving?.Item?.value || 1 // PHV, EVの補正 - if (mobilityAnswer?.carIntensityFactorFirstKey === 'phv' || mobilityAnswer?.carIntensityFactorFirstKey === 'ev') { + if ( + mobilityAnswer?.carIntensityFactorFirstKey === 'phv' || + mobilityAnswer?.carIntensityFactorFirstKey === 'ev' + ) { const data = await getData( - 'renewable-car-intensity-factor', - mobilityAnswer.carIntensityFactorFirstKey + '_driving-factor' - ); + 'renewable-car-intensity-factor', + mobilityAnswer.carIntensityFactorFirstKey + '_driving-factor' + ) if (data?.Item) { ghgIntensityRatio = - ghgIntensityRatio * (1 - electricityIntensityFactor) + data.Item.value * electricityIntensityFactor; + ghgIntensityRatio * (1 - electricityIntensityFactor) + + data.Item.value * electricityIntensityFactor } } - const intensity = createIntensity(baselines, 'car-sharing-driving'); - intensity.value *= ghgIntensityRatio * passengerIntensityRatio; - estimations.push(intensity); + const intensity = createIntensity(baselines, 'car-sharing-driving') + intensity.value *= ghgIntensityRatio * passengerIntensityRatio + estimations.push(intensity) // car-sharing-rentalのintensity補正 const rental = await getData( - 'car-intensity-factor', - (mobilityAnswer.carIntensityFactorFirstKey || 'unknown') + '_manufacturing-factor' - ); + 'car-intensity-factor', + (mobilityAnswer.carIntensityFactorFirstKey || 'unknown') + + '_manufacturing-factor' + ) if (rental?.Item) { - const intensity = createIntensity(baselines, 'car-sharing-rental'); - intensity.value *= rental.Item.value; - estimations.push(intensity); + const intensity = createIntensity(baselines, 'car-sharing-rental') + intensity.value *= rental.Item.value + estimations.push(intensity) } } @@ -239,7 +295,7 @@ const estimateMobility = async ( motorbikePurchase: createAmount(baselines, 'motorbike-purchase'), carSharingRental: createAmount(baselines, 'car-sharing-rental'), motorbikeMaintenance: createAmount(baselines, 'motorbike-maintenance') - }; + } const mileage = { airplane: 0, @@ -249,7 +305,7 @@ const estimateMobility = async ( taxi: 0, carSharing: 0, motorbike: 0 - }; + } //=IF('2_CF推定質問'!$F$169='2_CF推定質問'!$W$169,'2_CF推定質問'!U204,Y83/Y78*AW78) // @@ -262,7 +318,7 @@ const estimateMobility = async ( bus: mobilityAnswer.busWeeklyTravelingTime || 0, motorbike: mobilityAnswer.motorbikeWeeklyTravelingTime || 0, otherCar: mobilityAnswer.otherCarWeeklyTravelingTime || 0 - }; + } // // 昨年1年間で、旅行などで利用した移動手段を教えてください @@ -274,13 +330,13 @@ const estimateMobility = async ( motorbike: mobilityAnswer.motorbikeAnnualTravelingTime || 0, airplane: mobilityAnswer.airplaneAnnualTravelingTime || 0, ferry: mobilityAnswer.ferryAnnualTravelingTime || 0 - }; + } // 年間週数の取得 - let data = await getData('misc', 'weeks-per-year-excluding-long-vacations'); - let weekCount = 49; + let data = await getData('misc', 'weeks-per-year-excluding-long-vacations') + let weekCount = 49 if (data?.Item) { - weekCount = data.Item.value; + weekCount = data.Item.value } // 時速の取得 @@ -290,87 +346,94 @@ const estimateMobility = async ( ExpressionAttributeValues: { ':category': 'transportation-speed' } - }; - data = await dynamodb.send(new QueryCommand(paramsTransportation)); + } + data = await dynamodb.send(new QueryCommand(paramsTransportation)) // @ts-ignore - const speed = data.Items?.reduce((a: { [x: string]: any }, x: { key: string | number; value: any }) => { - a[x.key] = x.value; - return a; - }, {}); + const speed = data.Items?.reduce( + (a: { [x: string]: any }, x: { key: string | number; value: any }) => { + a[x.key] = x.value + return a + }, + {} + ) // 飛行機の移動距離の積算 // @ts-ignore - mileage.airplane += annualTravelingTime.airplane * speed['airplane-speed']; + mileage.airplane += annualTravelingTime.airplane * speed['airplane-speed'] // フェリーの移動距離の積算 // @ts-ignore - mileage.ferry += annualTravelingTime.ferry * speed['ferry-speed']; + mileage.ferry += annualTravelingTime.ferry * speed['ferry-speed'] // 電車の移動距離の積算 mileage.train += - // @ts-ignore - weeklyTravelingTime.train * weekCount * speed['train-speed'] + - // @ts-ignore - annualTravelingTime.train * speed['long-distance-train-speed']; + // @ts-ignore + weeklyTravelingTime.train * weekCount * speed['train-speed'] + + // @ts-ignore + annualTravelingTime.train * speed['long-distance-train-speed'] // バスの移動距離の積算 mileage.bus += - // @ts-ignore - weeklyTravelingTime.bus * weekCount * speed['bus-speed'] + - // @ts-ignore - annualTravelingTime.bus * speed['express-bus-speed']; + // @ts-ignore + weeklyTravelingTime.bus * weekCount * speed['bus-speed'] + + // @ts-ignore + annualTravelingTime.bus * speed['express-bus-speed'] // バイクの移動距離の積算 mileage.motorbike += - // @ts-ignore - weeklyTravelingTime.motorbike * weekCount * speed['motorbike-speed'] + - // @ts-ignore - annualTravelingTime.motorbike * speed['long-distance-motorbike-speed']; + // @ts-ignore + weeklyTravelingTime.motorbike * weekCount * speed['motorbike-speed'] + + // @ts-ignore + annualTravelingTime.motorbike * speed['long-distance-motorbike-speed'] const taxiRatio = - estimationAmount.taxi.value / - (estimationAmount.taxi.value + estimationAmount.carSharing.value); + estimationAmount.taxi.value / + (estimationAmount.taxi.value + estimationAmount.carSharing.value) // タクシー他、その他の移動の算出 const otherCarMileage = - // @ts-ignore - weeklyTravelingTime.otherCar * weekCount * speed['car-speed'] + - // @ts-ignore - annualTravelingTime.otherCar * speed['long-distance-car-speed']; + // @ts-ignore + weeklyTravelingTime.otherCar * weekCount * speed['car-speed'] + + // @ts-ignore + annualTravelingTime.otherCar * speed['long-distance-car-speed'] - mileage.taxi += otherCarMileage * taxiRatio; // タクシーの移動距離の積算 - mileage.carSharing += otherCarMileage * (1 - taxiRatio); // カーシェアリングの移動距離の積算 + mileage.taxi += otherCarMileage * taxiRatio // タクシーの移動距離の積算 + mileage.carSharing += otherCarMileage * (1 - taxiRatio) // カーシェアリングの移動距離の積算 // motorbike, carSharingベースライン値のバックアップ - const baselineMotorbikeAmount = estimationAmount.motorbike.value; - const baselineCarSharingAmount = estimationAmount.carSharing.value; + const baselineMotorbikeAmount = estimationAmount.motorbike.value + const baselineCarSharingAmount = estimationAmount.carSharing.value // ベースラインの値を書き換えてEstimationを生成 for (let item of Object.keys(mileage)) { // @ts-ignore - estimationAmount[item].value = mileage[item]; + estimationAmount[item].value = mileage[item] // @ts-ignore - estimations.push(estimationAmount[item]); + estimations.push(estimationAmount[item]) } // バイクの購入・メンテナンス、カーシェアの回数はベースラインとの比率で変更 - const motorbikeDrivingRatio = estimationAmount.motorbike.value / baselineMotorbikeAmount; - const carSharingDrivingRatio = estimationAmount.carSharing.value / baselineCarSharingAmount; - - estimationAmount.motorbikePurchase.value *= motorbikeDrivingRatio; - estimationAmount.carSharingRental.value *= carSharingDrivingRatio; - estimationAmount.motorbikeMaintenance.value *= motorbikeDrivingRatio; - - estimations.push(estimationAmount.motorbikePurchase); - estimations.push(estimationAmount.carSharingRental); - estimations.push(estimationAmount.motorbikeMaintenance); + const motorbikeDrivingRatio = + estimationAmount.motorbike.value / baselineMotorbikeAmount + const carSharingDrivingRatio = + estimationAmount.carSharing.value / baselineCarSharingAmount + + estimationAmount.motorbikePurchase.value *= motorbikeDrivingRatio + estimationAmount.carSharingRental.value *= carSharingDrivingRatio + estimationAmount.motorbikeMaintenance.value *= motorbikeDrivingRatio + + estimations.push(estimationAmount.motorbikePurchase) + estimations.push(estimationAmount.carSharingRental) + estimations.push(estimationAmount.motorbikeMaintenance) } else { // // お住まいの地域の規模はどのくらいですか? // - const mileageByAreaFirstKey = mobilityAnswer.mileageByAreaFirstKey || 'unknown'; + const mileageByAreaFirstKey = + mobilityAnswer.mileageByAreaFirstKey || 'unknown' const params = { TableName: parameterTableName, - KeyConditionExpression: 'category = :category and begins_with(#key, :key)', + KeyConditionExpression: + 'category = :category and begins_with(#key, :key)', ExpressionAttributeNames: { '#key': 'key' }, @@ -378,45 +441,62 @@ const estimateMobility = async ( ':category': 'mileage-by-area', ':key': mileageByAreaFirstKey + '_' } - }; - const data = await dynamodb.send(new QueryCommand(params)); + } + const data = await dynamodb.send(new QueryCommand(params)) + // @ts-ignore + const consumptionByArea = data.Items.reduce( // @ts-ignore - const consumptionByArea = data.Items.reduce((a: { [x: string]: any }, x: { key: string | number; value: any }) => { - a[x.key] = x.value; - return a; - }, {}); - - estimationAmount.airplane.value = consumptionByArea[mileageByAreaFirstKey + '_airplane']; - estimationAmount.train.value = consumptionByArea[mileageByAreaFirstKey + '_train']; - estimationAmount.bus.value = consumptionByArea[mileageByAreaFirstKey + '_bus']; - estimationAmount.motorbike.value = consumptionByArea[mileageByAreaFirstKey + '_motorbike-driving']; - estimationAmount.taxi.value = consumptionByArea[mileageByAreaFirstKey + '_taxi']; - estimationAmount.carSharing.value = consumptionByArea[mileageByAreaFirstKey + '_car-sharing-driving']; - estimationAmount.ferry.value = consumptionByArea[mileageByAreaFirstKey + '_ferry']; - estimationAmount.motorbikePurchase.value = consumptionByArea[mileageByAreaFirstKey + '_motorbike-purchase']; - estimationAmount.carSharingRental.value = consumptionByArea[mileageByAreaFirstKey + '_car-sharing-rental']; - estimationAmount.motorbikeMaintenance.value = consumptionByArea[mileageByAreaFirstKey + '_motorbike-maintenance']; + (a: { [x: string]: any }, x: { key: string | number; value: any }) => { + a[x.key] = x.value + return a + }, + {} + ) + + estimationAmount.airplane.value = + consumptionByArea[mileageByAreaFirstKey + '_airplane'] + estimationAmount.train.value = + consumptionByArea[mileageByAreaFirstKey + '_train'] + estimationAmount.bus.value = + consumptionByArea[mileageByAreaFirstKey + '_bus'] + estimationAmount.motorbike.value = + consumptionByArea[mileageByAreaFirstKey + '_motorbike-driving'] + estimationAmount.taxi.value = + consumptionByArea[mileageByAreaFirstKey + '_taxi'] + estimationAmount.carSharing.value = + consumptionByArea[mileageByAreaFirstKey + '_car-sharing-driving'] + estimationAmount.ferry.value = + consumptionByArea[mileageByAreaFirstKey + '_ferry'] + estimationAmount.motorbikePurchase.value = + consumptionByArea[mileageByAreaFirstKey + '_motorbike-purchase'] + estimationAmount.carSharingRental.value = + consumptionByArea[mileageByAreaFirstKey + '_car-sharing-rental'] + estimationAmount.motorbikeMaintenance.value = + consumptionByArea[mileageByAreaFirstKey + '_motorbike-maintenance'] const additionalAmount = { bicycleDriving: createAmount(baselines, 'bicycle-driving'), walking: createAmount(baselines, 'walking'), bicycleMaintenance: createAmount(baselines, 'bicycle-maintenance') - }; + } - additionalAmount.walking.value = consumptionByArea[mileageByAreaFirstKey + '_walking']; - additionalAmount.bicycleDriving.value = consumptionByArea[mileageByAreaFirstKey + '_bicycle-driving']; - additionalAmount.bicycleMaintenance.value = consumptionByArea[mileageByAreaFirstKey + '_bicycle-maintenance']; + additionalAmount.walking.value = + consumptionByArea[mileageByAreaFirstKey + '_walking'] + additionalAmount.bicycleDriving.value = + consumptionByArea[mileageByAreaFirstKey + '_bicycle-driving'] + additionalAmount.bicycleMaintenance.value = + consumptionByArea[mileageByAreaFirstKey + '_bicycle-maintenance'] // ベースラインの値を書き換えてEstimationを生成 for (let amount of Object.values(estimationAmount)) { - pushOrUpdateEstimate(amount.item, amount.type, amount); + pushOrUpdateEstimate(amount.item, amount.type, amount) } for (let amount of Object.values(additionalAmount)) { - pushOrUpdateEstimate(amount.item, amount.type, amount); + pushOrUpdateEstimate(amount.item, amount.type, amount) } } - return { baselines, estimations }; -}; + return { baselines, estimations } +} -export { estimateMobility }; +export { estimateMobility } diff --git a/lib/lambda/actions/other.ts b/lib/lambda/actions/other.ts index 0f851db..0e29b8f 100644 --- a/lib/lambda/actions/other.ts +++ b/lib/lambda/actions/other.ts @@ -1,24 +1,29 @@ -import {findBaseline, toBaseline, toEstimation} from './util'; -import {DynamoDBDocumentClient, GetCommand, QueryCommand} from "@aws-sdk/lib-dynamodb"; +import { findBaseline, toBaseline, toEstimation } from './util' +import { + DynamoDBDocumentClient, + GetCommand, + QueryCommand +} from '@aws-sdk/lib-dynamodb' const estimateOther = async ( - dynamodb: DynamoDBDocumentClient, - housingAnswer: { residentCount: number | null | undefined }, - otherAnswer: { - dailyGoodsAmountKey: any; - communicationAmountKey: any; - applianceFurnitureAmountKey: any; - serviceFactorKey: any; - hobbyGoodsFactorKey: any; - clothesBeautyFactorKey: any; - leisureSportsFactorKey: any; - travelFactorKey: any; - }, - footprintTableName: string, - parameterTableName: string + dynamodb: DynamoDBDocumentClient, + housingAnswer: { residentCount: number | null | undefined }, + otherAnswer: { + dailyGoodsAmountKey: any + communicationAmountKey: any + applianceFurnitureAmountKey: any + serviceFactorKey: any + hobbyGoodsFactorKey: any + clothesBeautyFactorKey: any + leisureSportsFactorKey: any + travelFactorKey: any + }, + footprintTableName: string, + parameterTableName: string ) => { // foodのEstimationの取得 - const createAmount = (baselines: any, item: string) => toEstimation(findBaseline(baselines, 'other', item, 'amount')); + const createAmount = (baselines: any, item: string) => + toEstimation(findBaseline(baselines, 'other', item, 'amount')) // parameterの取得 const getData = async (category: string, key: string) => { @@ -28,11 +33,18 @@ const estimateOther = async ( category: category, key: key } - }; - return await dynamodb.send(new GetCommand(params)); - }; + } + return await dynamodb.send(new GetCommand(params)) + } - const estimations: { domain: any; item: any; type: any; value: any; subdomain: any; unit: any }[] = []; + const estimations: { + domain: any + item: any + type: any + value: any + subdomain: any + unit: any + }[] = [] // ベースラインのフットプリントを取得 const params = { @@ -41,25 +53,29 @@ const estimateOther = async ( ExpressionAttributeValues: { ':dir_domain': 'baseline_other' } - }; + } - const data = await dynamodb.send(new QueryCommand(params)); - const baselines = data.Items?.map((item: any) => toBaseline(item)); + const data = await dynamodb.send(new QueryCommand(params)) + const baselines = data.Items?.map((item: any) => toBaseline(item)) // 回答がない場合はベースラインのみ返す if (!otherAnswer) { - return { baselines, estimations }; + return { baselines, estimations } } // 平均の居住人数を取得 - let residentCount = 1; - const familySize = await getData('family-size', 'unknown'); + let residentCount = 1 + const familySize = await getData('family-size', 'unknown') if (familySize?.Item?.value) { - residentCount = familySize.Item.value; + residentCount = familySize.Item.value } - if (housingAnswer && housingAnswer.residentCount !== undefined && housingAnswer.residentCount !== null) { - residentCount = housingAnswer.residentCount; + if ( + housingAnswer && + housingAnswer.residentCount !== undefined && + housingAnswer.residentCount !== null + ) { + residentCount = housingAnswer.residentCount } const answers = [ @@ -157,7 +173,12 @@ const estimateOther = async ( { category: 'leisure-sports-factor', key: otherAnswer.leisureSportsFactorKey, - items: ['culture-leisure', 'entertainment-leisure', 'sports-leisure', 'bath-spa'] + items: [ + 'culture-leisure', + 'entertainment-leisure', + 'sports-leisure', + 'bath-spa' + ] }, // 過去1年間の宿泊を伴う旅行にかかった費用はいくらくらいですか? @@ -167,33 +188,33 @@ const estimateOther = async ( key: otherAnswer.travelFactorKey, items: ['hotel', 'travel'] } - ]; + ] for (let ans of answers) { if (ans.key) { - const data = await getData(ans.category, ans.key); - let denominator: number | undefined = 1; + const data = await getData(ans.category, ans.key) + let denominator: number | undefined = 1 if (ans.base) { if (ans.key === 'unknown') { // 国平均の支出額(average-per-capita)が指定されていて、わからない、の回答の場合は // 国平均に対する比率は1倍。denominatorをundefinedにして計算に使わないようにする。 - denominator = undefined; + denominator = undefined } else { - const base = await getData(ans.category, ans.base); + const base = await getData(ans.category, ans.base) if (base?.Item?.value) { // 分母は国平均の支出額(average-per-capita) * 居住人数 - denominator = base.Item.value * residentCount; + denominator = base.Item.value * residentCount } } } if (data?.Item?.value) { - const coefficient = denominator ? data.Item.value / denominator : 1; + const coefficient = denominator ? data.Item.value / denominator : 1 for (let item of ans.items) { - const estimation = createAmount(baselines, item); - estimation.value *= coefficient; - estimations.push(estimation); + const estimation = createAmount(baselines, item) + estimation.value *= coefficient + estimations.push(estimation) } } } @@ -221,36 +242,55 @@ const estimateOther = async ( 'kitchen-goods', 'paper-stationery', 'books-magazines' - ]); + ]) - const isTarget = (t: { domain: any; item: any; type: any; value?: any; subdomain?: any; unit?: any }) => - t.domain === 'other' && wasteSet.has(t.item) && t.type === 'amount'; + const isTarget = (t: { + domain: any + item: any + type: any + value?: any + subdomain?: any + unit?: any + }) => t.domain === 'other' && wasteSet.has(t.item) && t.type === 'amount' // @ts-ignore - const targets = baselines.filter((b: { domain: any; item: any; type: any; value?: any; subdomain?: any; unit?: any }) => isTarget(b)); - const results = new Map(); + const targets = baselines.filter( + (b: { + domain: any + item: any + type: any + value?: any + subdomain?: any + unit?: any + }) => isTarget(b) + ) + const results = new Map() - let baselineSum = 0; + let baselineSum = 0 for (const baseline of targets) { - const key = baseline.domain + '_' + baseline.item + '_' + baseline.type; - results.set(key, toEstimation(baseline)); - baselineSum += baseline.value; + const key = baseline.domain + '_' + baseline.item + '_' + baseline.type + results.set(key, toEstimation(baseline)) + baselineSum += baseline.value } for (const estimation of estimations.filter((e) => isTarget(e))) { - const key = estimation.domain + '_' + estimation.item + '_' + estimation.type; - results.set(key, estimation); + const key = + estimation.domain + '_' + estimation.item + '_' + estimation.type + results.set(key, estimation) } - const estimationSum = Array.from(results.values()).reduce((sum, res) => sum + res.value, 0); + const estimationSum = Array.from(results.values()).reduce( + (sum, res) => sum + res.value, + 0 + ) - const wasteEstimation = createAmount(baselines, 'waste'); + const wasteEstimation = createAmount(baselines, 'waste') if (baselineSum !== 0) { - wasteEstimation.value *= estimationSum / baselineSum; + wasteEstimation.value *= estimationSum / baselineSum } - estimations.push(toEstimation(wasteEstimation)); + estimations.push(toEstimation(wasteEstimation)) - return { baselines, estimations }; -}; + return { baselines, estimations } +} -export { estimateOther }; +export { estimateOther } diff --git a/lib/lambda/actions/util.ts b/lib/lambda/actions/util.ts index cbc1b81..7eb5634 100644 --- a/lib/lambda/actions/util.ts +++ b/lib/lambda/actions/util.ts @@ -1,10 +1,22 @@ -const findBaseline = (baselines: any[], domain: string, item: string, type: string) => { +const findBaseline = ( + baselines: any[], + domain: string, + item: string, + type: string +) => { return baselines.find( (bl) => bl.domain === domain && bl.item === item && bl.type === type ) } -const toEstimation = (baseline: { domain: any; item: any; type: any; value: any; subdomain: any; unit: any }) => { +const toEstimation = (baseline: { + domain: any + item: any + type: any + value: any + subdomain: any + unit: any +}) => { return { domain: baseline.domain, item: baseline.item, @@ -15,7 +27,13 @@ const toEstimation = (baseline: { domain: any; item: any; type: any; value: any; } } -const toBaseline = (rec: { dir_domain: string; item_type: string; value: any; subdomain: any; unit: any; }) => { +const toBaseline = (rec: { + dir_domain: string + item_type: string + value: any + subdomain: any + unit: any +}) => { const dir_domain = rec.dir_domain.split('_') const item_type = rec.item_type.split('_') return { diff --git a/lib/lambda/calculate-app.ts b/lib/lambda/calculate-app.ts index 26c5eb6..ef3f817 100644 --- a/lib/lambda/calculate-app.ts +++ b/lib/lambda/calculate-app.ts @@ -1,42 +1,50 @@ -import { validate } from './actions/validate'; -import { estimateMobility } from './actions/mobility'; -import { estimateHousing } from './actions/housing'; -import { estimateFood } from './actions/food'; -import { estimateOther } from './actions/other'; -import { DynamoDBClient } from '@aws-sdk/client-dynamodb'; -import { DynamoDBDocumentClient, GetCommand, PutCommand } from '@aws-sdk/lib-dynamodb'; - -const awsServerlessExpressMiddleware = require('aws-serverless-express/middleware'); -const bodyParser = require('body-parser'); -const { v4: uuid } = require('uuid'); -import express from 'express'; -import { EmissionCalculator } from '../../utils/emission'; - -const FOOTPRINT_TABLE_NAME = process.env.FOOTPRINT_TABLE_NAME || ''; -const PARAMETER_TABLE_NAME = process.env.PARAMETER_TABLE_NAME || ''; -const PROFILE_TABLE_NAME = process.env.PROFILE_TABLE_NAME || ''; - -let dynamoParam = {} -let footprintTableName = FOOTPRINT_TABLE_NAME -let parameterTableName = PARAMETER_TABLE_NAME -let profileTableName = PROFILE_TABLE_NAME - -const dynamodbClient = new DynamoDBClient(dynamoParam); -const dynamodb = DynamoDBDocumentClient.from(dynamodbClient); - -const path = '/calculates'; +import { validate } from './actions/validate' +import { estimateMobility } from './actions/mobility' +import { estimateHousing } from './actions/housing' +import { estimateFood } from './actions/food' +import { estimateOther } from './actions/other' +import { DynamoDBClient } from '@aws-sdk/client-dynamodb' +import { + DynamoDBDocumentClient, + GetCommand, + PutCommand +} from '@aws-sdk/lib-dynamodb' + +const awsServerlessExpressMiddleware = require('aws-serverless-express/middleware') +const bodyParser = require('body-parser') +const { v4: uuid } = require('uuid') +import express from 'express' +import { EmissionCalculator } from '../../utils/emission' + +const FOOTPRINT_TABLE_NAME = process.env.FOOTPRINT_TABLE_NAME || '' +const PARAMETER_TABLE_NAME = process.env.PARAMETER_TABLE_NAME || '' +const PROFILE_TABLE_NAME = process.env.PROFILE_TABLE_NAME || '' + +const dynamoParam = {} +const footprintTableName = FOOTPRINT_TABLE_NAME +const parameterTableName = PARAMETER_TABLE_NAME +const profileTableName = PROFILE_TABLE_NAME + +const dynamodbClient = new DynamoDBClient(dynamoParam) +const dynamodb = DynamoDBDocumentClient.from(dynamodbClient) + +const path = '/calculates' // declare a new express app -const app: express.Express = express(); -app.use(bodyParser.json()); -app.use(awsServerlessExpressMiddleware.eventContext()); +const app: express.Express = express() +app.use(bodyParser.json()) +app.use(awsServerlessExpressMiddleware.eventContext()) // Enable CORS for all methods -app.use(function (req: express.Request, res: express.Response, next: express.NextFunction) { - res.header('Access-Control-Allow-Origin', '*'); - res.header('Access-Control-Allow-Headers', '*'); - next(); -}); +app.use(function ( + req: express.Request, + res: express.Response, + next: express.NextFunction +) { + res.header('Access-Control-Allow-Origin', '*') + res.header('Access-Control-Allow-Headers', '*') + next() +}) const toResponse = (profile: any, estimate: any) => { const common = { @@ -46,187 +54,198 @@ const toResponse = (profile: any, estimate: any) => { housingAnswer: profile.housingAnswer, foodAnswer: profile.foodAnswer, otherAnswer: profile.otherAnswer - }; + } return estimate - ? { + ? { ...common, baselines: profile.baselines, estimations: profile.estimations, mobilityScore: profile.mobility, foodScore: profile.food, housingScore: profile.housing, - otherScore: profile.other, + otherScore: profile.other } - : common; -}; + : common +} /***************************************** * HTTP Get method for get single object * *****************************************/ app.get(path + '/:id', async (req: express.Request, res: express.Response) => { try { - const data = await dynamodb.send(new GetCommand({ - TableName: profileTableName, - Key: { id: req.params.id } - })); + const data = await dynamodb.send( + new GetCommand({ + TableName: profileTableName, + Key: { id: req.params.id } + }) + ) - const profile = data.Item; + const profile = data.Item if (profile == undefined) { - res.statusCode = 404; - res.json({ error: 'Could not load item: ' + req.params.id }); + res.statusCode = 404 + res.json({ error: 'Could not load item: ' + req.params.id }) return } // 計算がされていない場合は遅延初期化 if (!profile.estimated) { - await updateProfile(dynamodb, profile); - profile.estimated = true; - profile.updatedAt = new Date().toISOString(); - await dynamodb.send(new PutCommand({ - TableName: PROFILE_TABLE_NAME, - Item: profile - })); + await updateProfile(dynamodb, profile) + profile.estimated = true + profile.updatedAt = new Date().toISOString() + await dynamodb.send( + new PutCommand({ + TableName: PROFILE_TABLE_NAME, + Item: profile + }) + ) } - await addScore(profile); + await addScore(profile) - res.json(toResponse(profile, true)); + res.json(toResponse(profile, true)) } catch (err) { - res.statusCode = 500; - res.json({ error: 'Could not load item: ' + err }); + res.statusCode = 500 + res.json({ error: 'Could not load item: ' + err }) } -}); +}) const addScore = async (profile: any) => { - const emissionCalculator = new EmissionCalculator(profile); - profile.mobility = emissionCalculator.mobility; - profile.food = emissionCalculator.food; - profile.housing = emissionCalculator.housing; - profile.other = emissionCalculator.other; -}; - -const updateProfile = async (dynamodb: DynamoDBDocumentClient, profile: any) => { - profile.baselines = []; - profile.estimations = []; + const emissionCalculator = new EmissionCalculator(profile) + profile.mobility = emissionCalculator.mobility + profile.food = emissionCalculator.food + profile.housing = emissionCalculator.housing + profile.other = emissionCalculator.other +} + +const updateProfile = async ( + dynamodb: DynamoDBDocumentClient, + profile: any +) => { + profile.baselines = [] + profile.estimations = [] if (profile.housingAnswer) { const { baselines, estimations } = await estimateHousing( - dynamodb, - profile.housingAnswer, - profile.mobilityAnswer, - footprintTableName, - parameterTableName - ); - profile.baselines = profile.baselines.concat(baselines); - profile.estimations = profile.estimations.concat(estimations); + dynamodb, + profile.housingAnswer, + profile.mobilityAnswer, + footprintTableName, + parameterTableName + ) + profile.baselines = profile.baselines.concat(baselines) + profile.estimations = profile.estimations.concat(estimations) } if (profile.mobilityAnswer) { const { baselines, estimations } = await estimateMobility( - dynamodb, - profile.housingAnswer, - profile.mobilityAnswer, - footprintTableName, - parameterTableName - ); - profile.baselines = profile.baselines.concat(baselines); - profile.estimations = profile.estimations.concat(estimations); + dynamodb, + profile.housingAnswer, + profile.mobilityAnswer, + footprintTableName, + parameterTableName + ) + profile.baselines = profile.baselines.concat(baselines) + profile.estimations = profile.estimations.concat(estimations) } if (profile.foodAnswer) { const { baselines, estimations } = await estimateFood( - dynamodb, - profile.foodAnswer, - footprintTableName, - parameterTableName - ); - profile.baselines = profile.baselines.concat(baselines); - profile.estimations = profile.estimations.concat(estimations); + dynamodb, + profile.foodAnswer, + footprintTableName, + parameterTableName + ) + profile.baselines = profile.baselines.concat(baselines) + profile.estimations = profile.estimations.concat(estimations) } if (profile.otherAnswer) { const { baselines, estimations } = await estimateOther( - dynamodb, - profile.housingAnswer, - profile.otherAnswer, - footprintTableName, - parameterTableName - ); - profile.baselines = profile.baselines.concat(baselines); - profile.estimations = profile.estimations.concat(estimations); + dynamodb, + profile.housingAnswer, + profile.otherAnswer, + footprintTableName, + parameterTableName + ) + profile.baselines = profile.baselines.concat(baselines) + profile.estimations = profile.estimations.concat(estimations) } -}; +} /************************************ * HTTP put method for insert object * *************************************/ app.put(path + '/:id', async (req: express.Request, res: express.Response) => { - const id = req.params.id; - const estimate = req.body.estimate; - const body: any = req.body; + const id = req.params.id + const estimate = req.body.estimate + const body: any = req.body if (validate(req.body)) { try { - const data = await dynamodb.send(new GetCommand({ - TableName: PROFILE_TABLE_NAME, - Key: { id } - })); - const profile = data.Item; + const data = await dynamodb.send( + new GetCommand({ + TableName: PROFILE_TABLE_NAME, + Key: { id } + }) + ) + const profile = data.Item if (profile == undefined) { - res.statusCode = 404; - res.json({ error: 'Could not load item: ' + req.params.id }); + res.statusCode = 404 + res.json({ error: 'Could not load item: ' + req.params.id }) return } if (body.mobilityAnswer) { - profile.mobilityAnswer = body.mobilityAnswer; + profile.mobilityAnswer = body.mobilityAnswer } if (body.housingAnswer) { - profile.housingAnswer = body.housingAnswer; + profile.housingAnswer = body.housingAnswer } if (body.foodAnswer) { - profile.foodAnswer = body.foodAnswer; + profile.foodAnswer = body.foodAnswer } if (body.otherAnswer) { - profile.otherAnswer = body.otherAnswer; + profile.otherAnswer = body.otherAnswer } - profile.estimated = false; + profile.estimated = false if (estimate) { - await updateProfile(dynamodb, profile); - profile.updatedAt = new Date().toISOString(); - profile.estimated = true; + await updateProfile(dynamodb, profile) + profile.updatedAt = new Date().toISOString() + profile.estimated = true } - await dynamodb.send(new PutCommand({ - TableName: profileTableName, - Item: profile - })); + await dynamodb.send( + new PutCommand({ + TableName: profileTableName, + Item: profile + }) + ) - await addScore(profile); + await addScore(profile) res.json({ success: 'put call succeed!', url: req.url, data: toResponse(profile, estimate) - }); + }) } catch (err: any) { - res.statusCode = 500; + res.statusCode = 500 res.json({ error: 'Could not load items', message: err.message, stack: err.stack - }); + }) } } else { - res.statusCode = 400; - res.json({ error: validate.errors }); + res.statusCode = 400 + res.json({ error: validate.errors }) } -}); +}) /************************************ * HTTP post method for insert object * @@ -235,8 +254,8 @@ app.put(path + '/:id', async (req: express.Request, res: express.Response) => { app.post(path, async (req: express.Request, res: express.Response) => { if (validate(req.body)) { try { - const body: any = req.body; - const estimate = body.estimate; + const body: any = req.body + const estimate = body.estimate const profile = { estimated: false, @@ -251,35 +270,35 @@ app.post(path, async (req: express.Request, res: express.Response) => { createdAt: new Date().toISOString(), updatedAt: new Date().toISOString() - }; + } if (estimate) { - await updateProfile(dynamodb, profile); - profile.estimated = true; + await updateProfile(dynamodb, profile) + profile.estimated = true } const params = { TableName: profileTableName, Item: profile - }; - await dynamodb.send(new PutCommand(params)); - await addScore(profile); + } + await dynamodb.send(new PutCommand(params)) + await addScore(profile) res.json({ success: 'post call succeed!', url: req.url, data: toResponse(profile, estimate) - }); + }) } catch (err) { - res.statusCode = 500; - res.json({ error: err, url: req.url, body: req.body }); + res.statusCode = 500 + res.json({ error: err, url: req.url, body: req.body }) } } else { - res.statusCode = 400; - res.json({ error: validate.errors }); + res.statusCode = 400 + res.json({ error: validate.errors }) } -}); +}) // Export the app object. When executing the application local this does nothing. However, // to port it to AWS Lambda we will create a wrapper around that will load the app from // this file -export default app; +export default app diff --git a/lib/lambda/citycarbonfootprints-app.ts b/lib/lambda/citycarbonfootprints-app.ts index 3214167..f309718 100644 --- a/lib/lambda/citycarbonfootprints-app.ts +++ b/lib/lambda/citycarbonfootprints-app.ts @@ -1,9 +1,9 @@ -const { DynamoDBDocument } = require("@aws-sdk/lib-dynamodb"); -const { DynamoDB } = require("@aws-sdk/client-dynamodb"); +const { DynamoDBDocument } = require('@aws-sdk/lib-dynamodb') +const { DynamoDB } = require('@aws-sdk/client-dynamodb') const awsServerlessExpressMiddleware = require('aws-serverless-express/middleware') const bodyParser = require('body-parser') -import express from "express"; +import express from 'express' const TABLE_NAME = process.env.TABLE_NAME || '' @@ -16,13 +16,12 @@ const toComponent = (item: any) => { Component: item.Component, English: item.English, Japanese: item.Japanese, - Type: item.Type, - }; + Type: item.Type + } } - -let dynamoParam = {} -let tableName = TABLE_NAME +const dynamoParam = {} +const tableName = TABLE_NAME const dynamodb = DynamoDBDocument.from(new DynamoDB(dynamoParam)) @@ -48,42 +47,43 @@ app.use(function ( * HTTP Get method for list objects * ********************************/ -app.get(path + '/:type', async (req: express.Request, res: express.Response) => { - const type = req.params.type - let response: any[] = [{ source: 'https://lifestyle.nies.go.jp' }] - - const params = { - TableName: tableName, - KeyConditionExpression: '#type = :typeValue', - ExpressionAttributeNames: { - '#type': 'Type', - }, - ExpressionAttributeValues: { - ':typeValue': type, +app.get( + path + '/:type', + async (req: express.Request, res: express.Response) => { + const type = req.params.type + let response: any[] = [{ source: 'https://lifestyle.nies.go.jp' }] + + const params = { + TableName: tableName, + KeyConditionExpression: '#type = :typeValue', + ExpressionAttributeNames: { + '#type': 'Type' + }, + ExpressionAttributeValues: { + ':typeValue': type + } } - }; - - try { - const data = await dynamodb.query(params) - response = response.concat( - data.Items.map((item: any) => toComponent(item)) - ) - } catch (err) { - res.statusCode = 500 - res.json({ error: 'Could not load type: ' + err }) - } + try { + const data = await dynamodb.query(params) + response = response.concat( + data.Items.map((item: any) => toComponent(item)) + ) + } catch (err) { + res.statusCode = 500 + res.json({ error: 'Could not load type: ' + err }) + } - if (res.statusCode !== 500) { - res.json(response) + if (res.statusCode !== 500) { + res.json(response) + } } -}) +) /******************************** * HTTP Get method for list objects * ********************************/ - app.get(path + '/:type/:city_name', async (req, res) => { const type = req.params.type const city_name = req.params.city_name @@ -91,22 +91,25 @@ app.get(path + '/:type/:city_name', async (req, res) => { const params = { TableName: tableName, IndexName: 'CityName-Domain-index', - KeyConditionExpression: "#city_name = :city_nameValue", - FilterExpression: "#type = :typeValue", + KeyConditionExpression: '#city_name = :city_nameValue', + FilterExpression: '#type = :typeValue', ExpressionAttributeNames: { - "#city_name": "CityName", - "#type": "Type", + '#city_name': 'CityName', + '#type': 'Type' }, ExpressionAttributeValues: { - ":city_nameValue": city_name, - ":typeValue": type, + ':city_nameValue': city_name, + ':typeValue': type } - }; + } try { const data = await dynamodb.query(params) - res.json(data.Items.map((item: any) => toComponent(item)) - .concat([{ source: 'https://lifestyle.nies.go.jp' }])) + res.json( + data.Items.map((item: any) => toComponent(item)).concat([ + { source: 'https://lifestyle.nies.go.jp' } + ]) + ) } catch (err) { res.statusCode = 500 res.json({ error: 'Could not load city_name ' + err }) @@ -125,32 +128,34 @@ app.get(path + '/:type/:city_name/:domain', async (req, res) => { const params = { TableName: tableName, IndexName: 'CityName-Domain-index', - KeyConditionExpression: "#city_name = :city_nameValue and #domain = :domainValue", - FilterExpression: "#type = :typeValue", + KeyConditionExpression: + '#city_name = :city_nameValue and #domain = :domainValue', + FilterExpression: '#type = :typeValue', ExpressionAttributeNames: { - "#city_name": "CityName", - "#domain": "Domain", - "#type": "Type", + '#city_name': 'CityName', + '#domain': 'Domain', + '#type': 'Type' }, ExpressionAttributeValues: { - ":city_nameValue": city_name, - ":domainValue": domain, - ":typeValue": type, + ':city_nameValue': city_name, + ':domainValue': domain, + ':typeValue': type } - }; - + } try { const data = await dynamodb.query(params) - res.json(data.Items.map((item: any) => toComponent(item)) - .concat([{ source: 'https://lifestyle.nies.go.jp' }])) + res.json( + data.Items.map((item: any) => toComponent(item)).concat([ + { source: 'https://lifestyle.nies.go.jp' } + ]) + ) } catch (err) { res.statusCode = 500 res.json({ error: 'Could not load domain: ' + err }) } }) - /***************************************** * HTTP Get method for get single object * *****************************************/ @@ -164,34 +169,36 @@ app.get(path + '/:type/:city_name/:domain/:component', async (req, res) => { const params = { TableName: tableName, IndexName: 'CityName-Domain-index', - KeyConditionExpression: "#city_name = :city_nameValue and #domain = :domainValue", - FilterExpression: "#type = :typeValue and #component = :componentValue", + KeyConditionExpression: + '#city_name = :city_nameValue and #domain = :domainValue', + FilterExpression: '#type = :typeValue and #component = :componentValue', ExpressionAttributeNames: { - "#city_name": "CityName", - "#domain": "Domain", - "#type": "Type", - "#component": "Component" + '#city_name': 'CityName', + '#domain': 'Domain', + '#type': 'Type', + '#component': 'Component' }, ExpressionAttributeValues: { - ":city_nameValue": city_name, - ":domainValue": domain, - ":typeValue": type, - ":componentValue": component + ':city_nameValue': city_name, + ':domainValue': domain, + ':typeValue': type, + ':componentValue': component } - }; - + } try { const data = await dynamodb.query(params) - res.json(data.Items.map((item: any) => toComponent(item)) - .concat([{ source: 'https://lifestyle.nies.go.jp' }])) + res.json( + data.Items.map((item: any) => toComponent(item)).concat([ + { source: 'https://lifestyle.nies.go.jp' } + ]) + ) } catch (err) { res.statusCode = 500 res.json({ error: 'Could not load component: ' + err }) } }) - // Export the app object. When executing the application local this does nothing. However, // to port it to AWS Lambda we will create a wrapper around that will load the app from // this file diff --git a/lib/lambda/citylifestylechangeimpacts-app.ts b/lib/lambda/citylifestylechangeimpacts-app.ts index 466bc20..bed4fce 100644 --- a/lib/lambda/citylifestylechangeimpacts-app.ts +++ b/lib/lambda/citylifestylechangeimpacts-app.ts @@ -1,5 +1,5 @@ -const { DynamoDBDocument } = require("@aws-sdk/lib-dynamodb"); -const { DynamoDB } = require("@aws-sdk/client-dynamodb"); +const { DynamoDBDocument } = require('@aws-sdk/lib-dynamodb') +const { DynamoDB } = require('@aws-sdk/client-dynamodb') const awsServerlessExpressMiddleware = require('aws-serverless-express/middleware') const bodyParser = require('body-parser') @@ -15,12 +15,12 @@ const toComponent = (item: any) => { Group: item.Group, Options: item.Options, Type: item.Type, - Japanese: item.Japanese, - }; + Japanese: item.Japanese + } } -let dynamoParam = {} -let tableName = TABLE_NAME +const dynamoParam = {} +const tableName = TABLE_NAME const dynamodb = DynamoDBDocument.from(new DynamoDB(dynamoParam)) @@ -46,42 +46,43 @@ app.use(function ( * HTTP Get method for list objects * ********************************/ -app.get(path + '/:type', async (req: express.Request, res: express.Response) => { - const type = req.params.type - let response: any[] = [{ source: 'https://lifestyle.nies.go.jp' }] - - const params = { - TableName: tableName, - KeyConditionExpression: '#type = :typeValue', - ExpressionAttributeNames: { - '#type': 'Type', - }, - ExpressionAttributeValues: { - ':typeValue': type, +app.get( + path + '/:type', + async (req: express.Request, res: express.Response) => { + const type = req.params.type + let response: any[] = [{ source: 'https://lifestyle.nies.go.jp' }] + + const params = { + TableName: tableName, + KeyConditionExpression: '#type = :typeValue', + ExpressionAttributeNames: { + '#type': 'Type' + }, + ExpressionAttributeValues: { + ':typeValue': type + } } - }; - - try { - const data = await dynamodb.query(params) - response = response.concat( - data.Items.map((item: any) => toComponent(item)) - ) - } catch (err) { - res.statusCode = 500 - res.json({ error: 'Could not load type: ' + err }) - } + try { + const data = await dynamodb.query(params) + response = response.concat( + data.Items.map((item: any) => toComponent(item)) + ) + } catch (err) { + res.statusCode = 500 + res.json({ error: 'Could not load type: ' + err }) + } - if (res.statusCode !== 500) { - res.json(response) + if (res.statusCode !== 500) { + res.json(response) + } } -}) +) /******************************** * HTTP Get method for list objects * ********************************/ - app.get(path + '/:type/:city_name', async (req, res) => { const type = req.params.type const city_name = req.params.city_name @@ -89,22 +90,25 @@ app.get(path + '/:type/:city_name', async (req, res) => { const params = { TableName: tableName, IndexName: 'CityName-Domain-index', - KeyConditionExpression: "#city_name = :city_nameValue", - FilterExpression: "#type = :typeValue", + KeyConditionExpression: '#city_name = :city_nameValue', + FilterExpression: '#type = :typeValue', ExpressionAttributeNames: { - "#city_name": "CityName", - "#type": "Type", + '#city_name': 'CityName', + '#type': 'Type' }, ExpressionAttributeValues: { - ":city_nameValue": city_name, - ":typeValue": type, + ':city_nameValue': city_name, + ':typeValue': type } - }; + } try { const data = await dynamodb.query(params) - res.json(data.Items.map((item: any) => toComponent(item)) - .concat([{ source: 'https://lifestyle.nies.go.jp' }])) + res.json( + data.Items.map((item: any) => toComponent(item)).concat([ + { source: 'https://lifestyle.nies.go.jp' } + ]) + ) } catch (err) { res.statusCode = 500 res.json({ error: 'Could not load city_name: ' + err }) @@ -123,25 +127,28 @@ app.get(path + '/:type/:city_name/:domain', async (req, res) => { const params = { TableName: tableName, IndexName: 'CityName-Domain-index', - KeyConditionExpression: "#city_name = :city_nameValue and #domain = :domainValue", - FilterExpression: "#type = :typeValue", + KeyConditionExpression: + '#city_name = :city_nameValue and #domain = :domainValue', + FilterExpression: '#type = :typeValue', ExpressionAttributeNames: { - "#city_name": "CityName", - "#domain": "Domain", - "#type": "Type", + '#city_name': 'CityName', + '#domain': 'Domain', + '#type': 'Type' }, ExpressionAttributeValues: { - ":city_nameValue": city_name, - ":domainValue": domain, - ":typeValue": type, + ':city_nameValue': city_name, + ':domainValue': domain, + ':typeValue': type } - }; - + } try { const data = await dynamodb.query(params) - res.json(data.Items.map((item: any) => toComponent(item)) - .concat([{ source: 'https://lifestyle.nies.go.jp' }])) + res.json( + data.Items.map((item: any) => toComponent(item)).concat([ + { source: 'https://lifestyle.nies.go.jp' } + ]) + ) } catch (err) { res.statusCode = 500 res.json({ error: 'Could not load domain: ' + err }) @@ -161,76 +168,85 @@ app.get(path + '/:type/:city_name/:domain/:group', async (req, res) => { const params = { TableName: tableName, IndexName: 'CityName-Domain-index', - KeyConditionExpression: "#city_name = :city_nameValue and #domain = :domainValue", - FilterExpression: "#type = :typeValue and #group = :groupValue", + KeyConditionExpression: + '#city_name = :city_nameValue and #domain = :domainValue', + FilterExpression: '#type = :typeValue and #group = :groupValue', ExpressionAttributeNames: { - "#city_name": "CityName", - "#domain": "Domain", - "#type": "Type", - "#group": "Group", + '#city_name': 'CityName', + '#domain': 'Domain', + '#type': 'Type', + '#group': 'Group' }, ExpressionAttributeValues: { - ":city_nameValue": city_name, - ":domainValue": domain, - ":typeValue": type, - ":groupValue": group + ':city_nameValue': city_name, + ':domainValue': domain, + ':typeValue': type, + ':groupValue': group } - }; - + } try { const data = await dynamodb.query(params) - res.json(data.Items.map((item: any) => toComponent(item)) - .concat([{ source: 'https://lifestyle.nies.go.jp' }])) + res.json( + data.Items.map((item: any) => toComponent(item)).concat([ + { source: 'https://lifestyle.nies.go.jp' } + ]) + ) } catch (err) { res.statusCode = 500 res.json({ error: 'Could not load group: ' + err }) } }) - /***************************************** * HTTP Get method for get single object * *****************************************/ -app.get(path + '/:type/:city_name/:domain/:group/:options', async (req, res) => { - const type = req.params.type - const city_name = req.params.city_name - const domain = req.params.domain - const group = req.params.group - const options = req.params.options - - const params = { - TableName: tableName, - IndexName: 'CityName-Domain-index', - KeyConditionExpression: "#city_name = :city_nameValue and #domain = :domainValue", - FilterExpression: "#type = :typeValue and #group = :groupValue and #options = :optionsValue", - ExpressionAttributeNames: { - "#city_name": "CityName", - "#domain": "Domain", - "#type": "Type", - "#group": "Group", - "#options": "Options", - }, - ExpressionAttributeValues: { - ":city_nameValue": city_name, - ":domainValue": domain, - ":typeValue": type, - ":groupValue": group, - ":optionsValue": options +app.get( + path + '/:type/:city_name/:domain/:group/:options', + async (req, res) => { + const type = req.params.type + const city_name = req.params.city_name + const domain = req.params.domain + const group = req.params.group + const options = req.params.options + + const params = { + TableName: tableName, + IndexName: 'CityName-Domain-index', + KeyConditionExpression: + '#city_name = :city_nameValue and #domain = :domainValue', + FilterExpression: + '#type = :typeValue and #group = :groupValue and #options = :optionsValue', + ExpressionAttributeNames: { + '#city_name': 'CityName', + '#domain': 'Domain', + '#type': 'Type', + '#group': 'Group', + '#options': 'Options' + }, + ExpressionAttributeValues: { + ':city_nameValue': city_name, + ':domainValue': domain, + ':typeValue': type, + ':groupValue': group, + ':optionsValue': options + } } - }; - - try { - const data = await dynamodb.query(params) - res.json(data.Items.map((item: any) => toComponent(item)) - .concat([{ source: 'https://lifestyle.nies.go.jp' }])) - } catch (err) { - res.statusCode = 500 - res.json({ error: 'Could not load options: ' + err }) + try { + const data = await dynamodb.query(params) + res.json( + data.Items.map((item: any) => toComponent(item)).concat([ + { source: 'https://lifestyle.nies.go.jp' } + ]) + ) + } catch (err) { + res.statusCode = 500 + res.json({ error: 'Could not load options: ' + err }) + } } -}) +) // Export the app object. When executing the application local this does nothing. However, // to port it to AWS Lambda we will create a wrapper around that will load the app from diff --git a/package.json b/package.json index cbcbc88..b065f6e 100644 --- a/package.json +++ b/package.json @@ -10,7 +10,7 @@ "test": "jest", "cdk": "cdk", "lint": "npx eslint 'lib/**/*.ts'", - "lint:fix": "npx prettier --write 'lib/*.ts' && eslint --fix lib/*.ts" + "lint:fix": "npx prettier --write 'lib/**/*.ts' && eslint --fix lib/**/*.ts" }, "devDependencies": { "@eslint/eslintrc": "^3.0.2", From 46b6bb534c44cd0d792b2ae4806bad89549875e1 Mon Sep 17 00:00:00 2001 From: ayuki_j <19406594+ayuki-joto@users.noreply.github.com> Date: Thu, 16 May 2024 15:57:34 +0900 Subject: [PATCH 4/7] refactor: add swagger ui --- eslint.config.mjs | 35 ++++++++++++++++++++++++ lib/lambda/actions/food.ts | 12 ++++---- lib/lambda/actions/mobility.ts | 2 +- swagger/favicon-16x16.png | Bin 0 -> 665 bytes swagger/favicon-32x32.png | Bin 0 -> 628 bytes swagger/index.css | 16 +++++++++++ swagger/index.html | 32 ++++++++++++++++++++++ swagger/swagger-initializer.js | 20 ++++++++++++++ swagger/swagger-ui-bundle.js | 2 ++ swagger/swagger-ui-standalone-preset.js | 2 ++ swagger/swagger-ui.css | 3 ++ 11 files changed, 117 insertions(+), 7 deletions(-) create mode 100644 eslint.config.mjs create mode 100644 swagger/favicon-16x16.png create mode 100644 swagger/favicon-32x32.png create mode 100644 swagger/index.css create mode 100644 swagger/index.html create mode 100644 swagger/swagger-initializer.js create mode 100644 swagger/swagger-ui-bundle.js create mode 100644 swagger/swagger-ui-standalone-preset.js create mode 100644 swagger/swagger-ui.css diff --git a/eslint.config.mjs b/eslint.config.mjs new file mode 100644 index 0000000..0b02c6b --- /dev/null +++ b/eslint.config.mjs @@ -0,0 +1,35 @@ +import { FlatCompat } from '@eslint/eslintrc'; +import js from '@eslint/js'; +import tsParser from '@typescript-eslint/parser'; +import tsPlugin from '@typescript-eslint/eslint-plugin'; +import jestPlugin from 'eslint-plugin-jest'; +import prettierConfig from 'eslint-config-prettier'; + +const compat = new FlatCompat({ + recommendedConfig: js.configs.recommended, + baseDirectory: new URL('.', import.meta.url).pathname, // Adjust the base directory as needed +}); + +export default [ + { + ignores: ['node_modules/**', 'dist/**', 'src/tests/*', '**/*.json'], // Add other paths to ignore as needed + }, + ...compat.extends('eslint:recommended'), + ...compat.extends('plugin:@typescript-eslint/recommended'), + ...compat.extends('plugin:jest/recommended'), + ...compat.extends('prettier'), + { + languageOptions: { + ecmaVersion: 'latest', + sourceType: 'module', + parser: tsParser, + }, + plugins: { + '@typescript-eslint': tsPlugin, + 'jest': jestPlugin, + }, + rules: { + '@typescript-eslint/no-unused-vars': 'off', + }, + }, +]; diff --git a/lib/lambda/actions/food.ts b/lib/lambda/actions/food.ts index 5e93954..01b08ef 100644 --- a/lib/lambda/actions/food.ts +++ b/lib/lambda/actions/food.ts @@ -134,17 +134,17 @@ const estimateFood = async ( // @ts-ignore const leftoverRatio = foodWasteRatioData.Items.find( - // @ts-ignore + // @ts-ignore (item: { key: string }) => item.key === 'leftover-per-food-waste' ) // @ts-ignore const directWasteRatio = foodWasteRatioData?.Items.find( - // @ts-ignore + // @ts-ignore (item: { key: string }) => item.key === 'direct-waste-per-food-waste' ) // @ts-ignore const foodWasteRatio = foodWasteRatioData?.Items.find( - // @ts-ignore + // @ts-ignore (item: { key: string }) => item.key === 'food-waste-per-food' ) @@ -364,7 +364,7 @@ const estimateFood = async ( (beforeReadyMealKeyArray.reduce( (res, key) => res + - // @ts-ignore + // @ts-ignore getCategoryCustomTotal(baselines, key, estimationAmount[key].value), 0 ) / @@ -422,7 +422,7 @@ const estimateFood = async ( ) baseTotalAmount = EatOutArray.reduce( (res, key) => - // @ts-ignore + // @ts-ignore res + findBaseline(baselines, 'food', key, 'amount').value, 0 ) @@ -434,7 +434,7 @@ const estimateFood = async ( getCategoryCustomTotal( baselines, key, - // @ts-ignore + // @ts-ignore estimationAmount[key].value ) ) diff --git a/lib/lambda/actions/mobility.ts b/lib/lambda/actions/mobility.ts index f0ab44b..ba976e9 100644 --- a/lib/lambda/actions/mobility.ts +++ b/lib/lambda/actions/mobility.ts @@ -445,7 +445,7 @@ const estimateMobility = async ( const data = await dynamodb.send(new QueryCommand(params)) // @ts-ignore const consumptionByArea = data.Items.reduce( - // @ts-ignore + // @ts-ignore (a: { [x: string]: any }, x: { key: string | number; value: any }) => { a[x.key] = x.value return a diff --git a/swagger/favicon-16x16.png b/swagger/favicon-16x16.png new file mode 100644 index 0000000000000000000000000000000000000000..8b194e617af1c135e6b37939591d24ac3a5efa18 GIT binary patch literal 665 zcmV;K0%rY*P)}JKSduyL>)s!A4EhTMMEM%Q;aL6%l#xiZiF>S;#Y{N2Zz%pvTGHJduXuC6Lx-)0EGfRy*N{Tv4i8@4oJ41gw zKzThrcRe|7J~(YYIBq{SYCkn-KQm=N8$CrEK1CcqMI1dv9z#VRL_{D)L|`QmF8}}l zJ9JV`Q}p!p_4f7m_U`WQ@apR4;o;!mnU<7}iG_qr zF(e)x9~BG-3IzcG2M4an0002kNkl41`ZiN1i62V%{PM@Ry|IS_+Yc7{bb`MM~xm(7p4|kMHP&!VGuDW4kFixat zXw43VmgwEvB$hXt_u=vZ>+v4i7E}n~eG6;n4Z=zF1n?T*yg<;W6kOfxpC6nao>VR% z?fpr=asSJ&`L*wu^rLJ5Peq*PB0;alL#XazZCBxJLd&giTfw@!hW167F^`7kobi;( ze<<>qNlP|xy7S1zl@lZNIBR7#o9ybJsptO#%}P0hz~sBp00000NkvXXu0mjfUsDF? literal 0 HcmV?d00001 diff --git a/swagger/favicon-32x32.png b/swagger/favicon-32x32.png new file mode 100644 index 0000000000000000000000000000000000000000..249737fe44558e679f0b67134e274461d988fa98 GIT binary patch literal 628 zcmV-)0*n2LP)Ma*GM0}OV<074bNCP7P7GVd{iMr*I6y~TMLss@FjvgL~HxU z%Vvj33AwpD(Z4*$Mfx=HaU16axM zt2xG_rloN<$iy9j9I5 + + + + + Swagger UI + + + + + + + +
+ + + + + + diff --git a/swagger/swagger-initializer.js b/swagger/swagger-initializer.js new file mode 100644 index 0000000..8ea0ea3 --- /dev/null +++ b/swagger/swagger-initializer.js @@ -0,0 +1,20 @@ +window.onload = function() { + // + + // the following lines will be replaced by docker/configurator, when it runs in a docker-container + window.ui = SwaggerUIBundle({ + url: "https://petstore.swagger.io/v2/swagger.json", + dom_id: '#swagger-ui', + deepLinking: true, + presets: [ + SwaggerUIBundle.presets.apis, + SwaggerUIStandalonePreset + ], + plugins: [ + SwaggerUIBundle.plugins.DownloadUrl + ], + layout: "StandaloneLayout" + }); + + // +}; diff --git a/swagger/swagger-ui-bundle.js b/swagger/swagger-ui-bundle.js new file mode 100644 index 0000000..ef539d2 --- /dev/null +++ b/swagger/swagger-ui-bundle.js @@ -0,0 +1,2 @@ +/*! For license information please see swagger-ui-bundle.js.LICENSE.txt */ +!function webpackUniversalModuleDefinition(s,i){"object"==typeof exports&&"object"==typeof module?module.exports=i():"function"==typeof define&&define.amd?define([],i):"object"==typeof exports?exports.SwaggerUIBundle=i():s.SwaggerUIBundle=i()}(this,(()=>(()=>{var s,i,u={69119:(s,i)=>{"use strict";Object.defineProperty(i,"__esModule",{value:!0}),i.BLANK_URL=i.relativeFirstCharacters=i.urlSchemeRegex=i.ctrlCharactersRegex=i.htmlCtrlEntityRegex=i.htmlEntitiesRegex=i.invalidProtocolRegex=void 0,i.invalidProtocolRegex=/^([^\w]*)(javascript|data|vbscript)/im,i.htmlEntitiesRegex=/&#(\w+)(^\w|;)?/g,i.htmlCtrlEntityRegex=/&(newline|tab);/gi,i.ctrlCharactersRegex=/[\u0000-\u001F\u007F-\u009F\u2000-\u200D\uFEFF]/gim,i.urlSchemeRegex=/^.+(:|:)/gim,i.relativeFirstCharacters=[".","/"],i.BLANK_URL="about:blank"},16750:(s,i,u)=>{"use strict";i.J=void 0;var _=u(69119);i.J=function sanitizeUrl(s){if(!s)return _.BLANK_URL;var i,u,w=s;do{i=(w=(u=w,u.replace(_.ctrlCharactersRegex,"").replace(_.htmlEntitiesRegex,(function(s,i){return String.fromCharCode(i)}))).replace(_.htmlCtrlEntityRegex,"").replace(_.ctrlCharactersRegex,"").trim()).match(_.ctrlCharactersRegex)||w.match(_.htmlEntitiesRegex)||w.match(_.htmlCtrlEntityRegex)}while(i&&i.length>0);var x=w;if(!x)return _.BLANK_URL;if(function isRelativeUrlWithoutProtocol(s){return _.relativeFirstCharacters.indexOf(s[0])>-1}(x))return x;var j=x.match(_.urlSchemeRegex);if(!j)return x;var L=j[0];return _.invalidProtocolRegex.test(L)?_.BLANK_URL:x}},67526:(s,i)=>{"use strict";i.byteLength=function byteLength(s){var i=getLens(s),u=i[0],_=i[1];return 3*(u+_)/4-_},i.toByteArray=function toByteArray(s){var i,u,x=getLens(s),j=x[0],L=x[1],B=new w(function _byteLength(s,i,u){return 3*(i+u)/4-u}(0,j,L)),$=0,U=L>0?j-4:j;for(u=0;u>16&255,B[$++]=i>>8&255,B[$++]=255&i;2===L&&(i=_[s.charCodeAt(u)]<<2|_[s.charCodeAt(u+1)]>>4,B[$++]=255&i);1===L&&(i=_[s.charCodeAt(u)]<<10|_[s.charCodeAt(u+1)]<<4|_[s.charCodeAt(u+2)]>>2,B[$++]=i>>8&255,B[$++]=255&i);return B},i.fromByteArray=function fromByteArray(s){for(var i,_=s.length,w=_%3,x=[],j=16383,L=0,B=_-w;LB?B:L+j));1===w?(i=s[_-1],x.push(u[i>>2]+u[i<<4&63]+"==")):2===w&&(i=(s[_-2]<<8)+s[_-1],x.push(u[i>>10]+u[i>>4&63]+u[i<<2&63]+"="));return x.join("")};for(var u=[],_=[],w="undefined"!=typeof Uint8Array?Uint8Array:Array,x="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",j=0;j<64;++j)u[j]=x[j],_[x.charCodeAt(j)]=j;function getLens(s){var i=s.length;if(i%4>0)throw new Error("Invalid string. Length must be a multiple of 4");var u=s.indexOf("=");return-1===u&&(u=i),[u,u===i?0:4-u%4]}function encodeChunk(s,i,_){for(var w,x,j=[],L=i;L<_;L+=3)w=(s[L]<<16&16711680)+(s[L+1]<<8&65280)+(255&s[L+2]),j.push(u[(x=w)>>18&63]+u[x>>12&63]+u[x>>6&63]+u[63&x]);return j.join("")}_["-".charCodeAt(0)]=62,_["_".charCodeAt(0)]=63},48287:(s,i,u)=>{"use strict";const _=u(67526),w=u(251),x="function"==typeof Symbol&&"function"==typeof Symbol.for?Symbol.for("nodejs.util.inspect.custom"):null;i.Buffer=Buffer,i.SlowBuffer=function SlowBuffer(s){+s!=s&&(s=0);return Buffer.alloc(+s)},i.INSPECT_MAX_BYTES=50;const j=2147483647;function createBuffer(s){if(s>j)throw new RangeError('The value "'+s+'" is invalid for option "size"');const i=new Uint8Array(s);return Object.setPrototypeOf(i,Buffer.prototype),i}function Buffer(s,i,u){if("number"==typeof s){if("string"==typeof i)throw new TypeError('The "string" argument must be of type string. Received type number');return allocUnsafe(s)}return from(s,i,u)}function from(s,i,u){if("string"==typeof s)return function fromString(s,i){"string"==typeof i&&""!==i||(i="utf8");if(!Buffer.isEncoding(i))throw new TypeError("Unknown encoding: "+i);const u=0|byteLength(s,i);let _=createBuffer(u);const w=_.write(s,i);w!==u&&(_=_.slice(0,w));return _}(s,i);if(ArrayBuffer.isView(s))return function fromArrayView(s){if(isInstance(s,Uint8Array)){const i=new Uint8Array(s);return fromArrayBuffer(i.buffer,i.byteOffset,i.byteLength)}return fromArrayLike(s)}(s);if(null==s)throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof s);if(isInstance(s,ArrayBuffer)||s&&isInstance(s.buffer,ArrayBuffer))return fromArrayBuffer(s,i,u);if("undefined"!=typeof SharedArrayBuffer&&(isInstance(s,SharedArrayBuffer)||s&&isInstance(s.buffer,SharedArrayBuffer)))return fromArrayBuffer(s,i,u);if("number"==typeof s)throw new TypeError('The "value" argument must not be of type number. Received type number');const _=s.valueOf&&s.valueOf();if(null!=_&&_!==s)return Buffer.from(_,i,u);const w=function fromObject(s){if(Buffer.isBuffer(s)){const i=0|checked(s.length),u=createBuffer(i);return 0===u.length||s.copy(u,0,0,i),u}if(void 0!==s.length)return"number"!=typeof s.length||numberIsNaN(s.length)?createBuffer(0):fromArrayLike(s);if("Buffer"===s.type&&Array.isArray(s.data))return fromArrayLike(s.data)}(s);if(w)return w;if("undefined"!=typeof Symbol&&null!=Symbol.toPrimitive&&"function"==typeof s[Symbol.toPrimitive])return Buffer.from(s[Symbol.toPrimitive]("string"),i,u);throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof s)}function assertSize(s){if("number"!=typeof s)throw new TypeError('"size" argument must be of type number');if(s<0)throw new RangeError('The value "'+s+'" is invalid for option "size"')}function allocUnsafe(s){return assertSize(s),createBuffer(s<0?0:0|checked(s))}function fromArrayLike(s){const i=s.length<0?0:0|checked(s.length),u=createBuffer(i);for(let _=0;_=j)throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x"+j.toString(16)+" bytes");return 0|s}function byteLength(s,i){if(Buffer.isBuffer(s))return s.length;if(ArrayBuffer.isView(s)||isInstance(s,ArrayBuffer))return s.byteLength;if("string"!=typeof s)throw new TypeError('The "string" argument must be one of type string, Buffer, or ArrayBuffer. Received type '+typeof s);const u=s.length,_=arguments.length>2&&!0===arguments[2];if(!_&&0===u)return 0;let w=!1;for(;;)switch(i){case"ascii":case"latin1":case"binary":return u;case"utf8":case"utf-8":return utf8ToBytes(s).length;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return 2*u;case"hex":return u>>>1;case"base64":return base64ToBytes(s).length;default:if(w)return _?-1:utf8ToBytes(s).length;i=(""+i).toLowerCase(),w=!0}}function slowToString(s,i,u){let _=!1;if((void 0===i||i<0)&&(i=0),i>this.length)return"";if((void 0===u||u>this.length)&&(u=this.length),u<=0)return"";if((u>>>=0)<=(i>>>=0))return"";for(s||(s="utf8");;)switch(s){case"hex":return hexSlice(this,i,u);case"utf8":case"utf-8":return utf8Slice(this,i,u);case"ascii":return asciiSlice(this,i,u);case"latin1":case"binary":return latin1Slice(this,i,u);case"base64":return base64Slice(this,i,u);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return utf16leSlice(this,i,u);default:if(_)throw new TypeError("Unknown encoding: "+s);s=(s+"").toLowerCase(),_=!0}}function swap(s,i,u){const _=s[i];s[i]=s[u],s[u]=_}function bidirectionalIndexOf(s,i,u,_,w){if(0===s.length)return-1;if("string"==typeof u?(_=u,u=0):u>2147483647?u=2147483647:u<-2147483648&&(u=-2147483648),numberIsNaN(u=+u)&&(u=w?0:s.length-1),u<0&&(u=s.length+u),u>=s.length){if(w)return-1;u=s.length-1}else if(u<0){if(!w)return-1;u=0}if("string"==typeof i&&(i=Buffer.from(i,_)),Buffer.isBuffer(i))return 0===i.length?-1:arrayIndexOf(s,i,u,_,w);if("number"==typeof i)return i&=255,"function"==typeof Uint8Array.prototype.indexOf?w?Uint8Array.prototype.indexOf.call(s,i,u):Uint8Array.prototype.lastIndexOf.call(s,i,u):arrayIndexOf(s,[i],u,_,w);throw new TypeError("val must be string, number or Buffer")}function arrayIndexOf(s,i,u,_,w){let x,j=1,L=s.length,B=i.length;if(void 0!==_&&("ucs2"===(_=String(_).toLowerCase())||"ucs-2"===_||"utf16le"===_||"utf-16le"===_)){if(s.length<2||i.length<2)return-1;j=2,L/=2,B/=2,u/=2}function read(s,i){return 1===j?s[i]:s.readUInt16BE(i*j)}if(w){let _=-1;for(x=u;xL&&(u=L-B),x=u;x>=0;x--){let u=!0;for(let _=0;_w&&(_=w):_=w;const x=i.length;let j;for(_>x/2&&(_=x/2),j=0;j<_;++j){const _=parseInt(i.substr(2*j,2),16);if(numberIsNaN(_))return j;s[u+j]=_}return j}function utf8Write(s,i,u,_){return blitBuffer(utf8ToBytes(i,s.length-u),s,u,_)}function asciiWrite(s,i,u,_){return blitBuffer(function asciiToBytes(s){const i=[];for(let u=0;u>8,w=u%256,x.push(w),x.push(_);return x}(i,s.length-u),s,u,_)}function base64Slice(s,i,u){return 0===i&&u===s.length?_.fromByteArray(s):_.fromByteArray(s.slice(i,u))}function utf8Slice(s,i,u){u=Math.min(s.length,u);const _=[];let w=i;for(;w239?4:i>223?3:i>191?2:1;if(w+j<=u){let u,_,L,B;switch(j){case 1:i<128&&(x=i);break;case 2:u=s[w+1],128==(192&u)&&(B=(31&i)<<6|63&u,B>127&&(x=B));break;case 3:u=s[w+1],_=s[w+2],128==(192&u)&&128==(192&_)&&(B=(15&i)<<12|(63&u)<<6|63&_,B>2047&&(B<55296||B>57343)&&(x=B));break;case 4:u=s[w+1],_=s[w+2],L=s[w+3],128==(192&u)&&128==(192&_)&&128==(192&L)&&(B=(15&i)<<18|(63&u)<<12|(63&_)<<6|63&L,B>65535&&B<1114112&&(x=B))}}null===x?(x=65533,j=1):x>65535&&(x-=65536,_.push(x>>>10&1023|55296),x=56320|1023&x),_.push(x),w+=j}return function decodeCodePointsArray(s){const i=s.length;if(i<=L)return String.fromCharCode.apply(String,s);let u="",_=0;for(;__.length?(Buffer.isBuffer(i)||(i=Buffer.from(i)),i.copy(_,w)):Uint8Array.prototype.set.call(_,i,w);else{if(!Buffer.isBuffer(i))throw new TypeError('"list" argument must be an Array of Buffers');i.copy(_,w)}w+=i.length}return _},Buffer.byteLength=byteLength,Buffer.prototype._isBuffer=!0,Buffer.prototype.swap16=function swap16(){const s=this.length;if(s%2!=0)throw new RangeError("Buffer size must be a multiple of 16-bits");for(let i=0;iu&&(s+=" ... "),""},x&&(Buffer.prototype[x]=Buffer.prototype.inspect),Buffer.prototype.compare=function compare(s,i,u,_,w){if(isInstance(s,Uint8Array)&&(s=Buffer.from(s,s.offset,s.byteLength)),!Buffer.isBuffer(s))throw new TypeError('The "target" argument must be one of type Buffer or Uint8Array. Received type '+typeof s);if(void 0===i&&(i=0),void 0===u&&(u=s?s.length:0),void 0===_&&(_=0),void 0===w&&(w=this.length),i<0||u>s.length||_<0||w>this.length)throw new RangeError("out of range index");if(_>=w&&i>=u)return 0;if(_>=w)return-1;if(i>=u)return 1;if(this===s)return 0;let x=(w>>>=0)-(_>>>=0),j=(u>>>=0)-(i>>>=0);const L=Math.min(x,j),B=this.slice(_,w),$=s.slice(i,u);for(let s=0;s>>=0,isFinite(u)?(u>>>=0,void 0===_&&(_="utf8")):(_=u,u=void 0)}const w=this.length-i;if((void 0===u||u>w)&&(u=w),s.length>0&&(u<0||i<0)||i>this.length)throw new RangeError("Attempt to write outside buffer bounds");_||(_="utf8");let x=!1;for(;;)switch(_){case"hex":return hexWrite(this,s,i,u);case"utf8":case"utf-8":return utf8Write(this,s,i,u);case"ascii":case"latin1":case"binary":return asciiWrite(this,s,i,u);case"base64":return base64Write(this,s,i,u);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return ucs2Write(this,s,i,u);default:if(x)throw new TypeError("Unknown encoding: "+_);_=(""+_).toLowerCase(),x=!0}},Buffer.prototype.toJSON=function toJSON(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};const L=4096;function asciiSlice(s,i,u){let _="";u=Math.min(s.length,u);for(let w=i;w_)&&(u=_);let w="";for(let _=i;_u)throw new RangeError("Trying to access beyond buffer length")}function checkInt(s,i,u,_,w,x){if(!Buffer.isBuffer(s))throw new TypeError('"buffer" argument must be a Buffer instance');if(i>w||is.length)throw new RangeError("Index out of range")}function wrtBigUInt64LE(s,i,u,_,w){checkIntBI(i,_,w,s,u,7);let x=Number(i&BigInt(4294967295));s[u++]=x,x>>=8,s[u++]=x,x>>=8,s[u++]=x,x>>=8,s[u++]=x;let j=Number(i>>BigInt(32)&BigInt(4294967295));return s[u++]=j,j>>=8,s[u++]=j,j>>=8,s[u++]=j,j>>=8,s[u++]=j,u}function wrtBigUInt64BE(s,i,u,_,w){checkIntBI(i,_,w,s,u,7);let x=Number(i&BigInt(4294967295));s[u+7]=x,x>>=8,s[u+6]=x,x>>=8,s[u+5]=x,x>>=8,s[u+4]=x;let j=Number(i>>BigInt(32)&BigInt(4294967295));return s[u+3]=j,j>>=8,s[u+2]=j,j>>=8,s[u+1]=j,j>>=8,s[u]=j,u+8}function checkIEEE754(s,i,u,_,w,x){if(u+_>s.length)throw new RangeError("Index out of range");if(u<0)throw new RangeError("Index out of range")}function writeFloat(s,i,u,_,x){return i=+i,u>>>=0,x||checkIEEE754(s,0,u,4),w.write(s,i,u,_,23,4),u+4}function writeDouble(s,i,u,_,x){return i=+i,u>>>=0,x||checkIEEE754(s,0,u,8),w.write(s,i,u,_,52,8),u+8}Buffer.prototype.slice=function slice(s,i){const u=this.length;(s=~~s)<0?(s+=u)<0&&(s=0):s>u&&(s=u),(i=void 0===i?u:~~i)<0?(i+=u)<0&&(i=0):i>u&&(i=u),i>>=0,i>>>=0,u||checkOffset(s,i,this.length);let _=this[s],w=1,x=0;for(;++x>>=0,i>>>=0,u||checkOffset(s,i,this.length);let _=this[s+--i],w=1;for(;i>0&&(w*=256);)_+=this[s+--i]*w;return _},Buffer.prototype.readUint8=Buffer.prototype.readUInt8=function readUInt8(s,i){return s>>>=0,i||checkOffset(s,1,this.length),this[s]},Buffer.prototype.readUint16LE=Buffer.prototype.readUInt16LE=function readUInt16LE(s,i){return s>>>=0,i||checkOffset(s,2,this.length),this[s]|this[s+1]<<8},Buffer.prototype.readUint16BE=Buffer.prototype.readUInt16BE=function readUInt16BE(s,i){return s>>>=0,i||checkOffset(s,2,this.length),this[s]<<8|this[s+1]},Buffer.prototype.readUint32LE=Buffer.prototype.readUInt32LE=function readUInt32LE(s,i){return s>>>=0,i||checkOffset(s,4,this.length),(this[s]|this[s+1]<<8|this[s+2]<<16)+16777216*this[s+3]},Buffer.prototype.readUint32BE=Buffer.prototype.readUInt32BE=function readUInt32BE(s,i){return s>>>=0,i||checkOffset(s,4,this.length),16777216*this[s]+(this[s+1]<<16|this[s+2]<<8|this[s+3])},Buffer.prototype.readBigUInt64LE=defineBigIntMethod((function readBigUInt64LE(s){validateNumber(s>>>=0,"offset");const i=this[s],u=this[s+7];void 0!==i&&void 0!==u||boundsError(s,this.length-8);const _=i+256*this[++s]+65536*this[++s]+this[++s]*2**24,w=this[++s]+256*this[++s]+65536*this[++s]+u*2**24;return BigInt(_)+(BigInt(w)<>>=0,"offset");const i=this[s],u=this[s+7];void 0!==i&&void 0!==u||boundsError(s,this.length-8);const _=i*2**24+65536*this[++s]+256*this[++s]+this[++s],w=this[++s]*2**24+65536*this[++s]+256*this[++s]+u;return(BigInt(_)<>>=0,i>>>=0,u||checkOffset(s,i,this.length);let _=this[s],w=1,x=0;for(;++x=w&&(_-=Math.pow(2,8*i)),_},Buffer.prototype.readIntBE=function readIntBE(s,i,u){s>>>=0,i>>>=0,u||checkOffset(s,i,this.length);let _=i,w=1,x=this[s+--_];for(;_>0&&(w*=256);)x+=this[s+--_]*w;return w*=128,x>=w&&(x-=Math.pow(2,8*i)),x},Buffer.prototype.readInt8=function readInt8(s,i){return s>>>=0,i||checkOffset(s,1,this.length),128&this[s]?-1*(255-this[s]+1):this[s]},Buffer.prototype.readInt16LE=function readInt16LE(s,i){s>>>=0,i||checkOffset(s,2,this.length);const u=this[s]|this[s+1]<<8;return 32768&u?4294901760|u:u},Buffer.prototype.readInt16BE=function readInt16BE(s,i){s>>>=0,i||checkOffset(s,2,this.length);const u=this[s+1]|this[s]<<8;return 32768&u?4294901760|u:u},Buffer.prototype.readInt32LE=function readInt32LE(s,i){return s>>>=0,i||checkOffset(s,4,this.length),this[s]|this[s+1]<<8|this[s+2]<<16|this[s+3]<<24},Buffer.prototype.readInt32BE=function readInt32BE(s,i){return s>>>=0,i||checkOffset(s,4,this.length),this[s]<<24|this[s+1]<<16|this[s+2]<<8|this[s+3]},Buffer.prototype.readBigInt64LE=defineBigIntMethod((function readBigInt64LE(s){validateNumber(s>>>=0,"offset");const i=this[s],u=this[s+7];void 0!==i&&void 0!==u||boundsError(s,this.length-8);const _=this[s+4]+256*this[s+5]+65536*this[s+6]+(u<<24);return(BigInt(_)<>>=0,"offset");const i=this[s],u=this[s+7];void 0!==i&&void 0!==u||boundsError(s,this.length-8);const _=(i<<24)+65536*this[++s]+256*this[++s]+this[++s];return(BigInt(_)<>>=0,i||checkOffset(s,4,this.length),w.read(this,s,!0,23,4)},Buffer.prototype.readFloatBE=function readFloatBE(s,i){return s>>>=0,i||checkOffset(s,4,this.length),w.read(this,s,!1,23,4)},Buffer.prototype.readDoubleLE=function readDoubleLE(s,i){return s>>>=0,i||checkOffset(s,8,this.length),w.read(this,s,!0,52,8)},Buffer.prototype.readDoubleBE=function readDoubleBE(s,i){return s>>>=0,i||checkOffset(s,8,this.length),w.read(this,s,!1,52,8)},Buffer.prototype.writeUintLE=Buffer.prototype.writeUIntLE=function writeUIntLE(s,i,u,_){if(s=+s,i>>>=0,u>>>=0,!_){checkInt(this,s,i,u,Math.pow(2,8*u)-1,0)}let w=1,x=0;for(this[i]=255&s;++x>>=0,u>>>=0,!_){checkInt(this,s,i,u,Math.pow(2,8*u)-1,0)}let w=u-1,x=1;for(this[i+w]=255&s;--w>=0&&(x*=256);)this[i+w]=s/x&255;return i+u},Buffer.prototype.writeUint8=Buffer.prototype.writeUInt8=function writeUInt8(s,i,u){return s=+s,i>>>=0,u||checkInt(this,s,i,1,255,0),this[i]=255&s,i+1},Buffer.prototype.writeUint16LE=Buffer.prototype.writeUInt16LE=function writeUInt16LE(s,i,u){return s=+s,i>>>=0,u||checkInt(this,s,i,2,65535,0),this[i]=255&s,this[i+1]=s>>>8,i+2},Buffer.prototype.writeUint16BE=Buffer.prototype.writeUInt16BE=function writeUInt16BE(s,i,u){return s=+s,i>>>=0,u||checkInt(this,s,i,2,65535,0),this[i]=s>>>8,this[i+1]=255&s,i+2},Buffer.prototype.writeUint32LE=Buffer.prototype.writeUInt32LE=function writeUInt32LE(s,i,u){return s=+s,i>>>=0,u||checkInt(this,s,i,4,4294967295,0),this[i+3]=s>>>24,this[i+2]=s>>>16,this[i+1]=s>>>8,this[i]=255&s,i+4},Buffer.prototype.writeUint32BE=Buffer.prototype.writeUInt32BE=function writeUInt32BE(s,i,u){return s=+s,i>>>=0,u||checkInt(this,s,i,4,4294967295,0),this[i]=s>>>24,this[i+1]=s>>>16,this[i+2]=s>>>8,this[i+3]=255&s,i+4},Buffer.prototype.writeBigUInt64LE=defineBigIntMethod((function writeBigUInt64LE(s,i=0){return wrtBigUInt64LE(this,s,i,BigInt(0),BigInt("0xffffffffffffffff"))})),Buffer.prototype.writeBigUInt64BE=defineBigIntMethod((function writeBigUInt64BE(s,i=0){return wrtBigUInt64BE(this,s,i,BigInt(0),BigInt("0xffffffffffffffff"))})),Buffer.prototype.writeIntLE=function writeIntLE(s,i,u,_){if(s=+s,i>>>=0,!_){const _=Math.pow(2,8*u-1);checkInt(this,s,i,u,_-1,-_)}let w=0,x=1,j=0;for(this[i]=255&s;++w>0)-j&255;return i+u},Buffer.prototype.writeIntBE=function writeIntBE(s,i,u,_){if(s=+s,i>>>=0,!_){const _=Math.pow(2,8*u-1);checkInt(this,s,i,u,_-1,-_)}let w=u-1,x=1,j=0;for(this[i+w]=255&s;--w>=0&&(x*=256);)s<0&&0===j&&0!==this[i+w+1]&&(j=1),this[i+w]=(s/x>>0)-j&255;return i+u},Buffer.prototype.writeInt8=function writeInt8(s,i,u){return s=+s,i>>>=0,u||checkInt(this,s,i,1,127,-128),s<0&&(s=255+s+1),this[i]=255&s,i+1},Buffer.prototype.writeInt16LE=function writeInt16LE(s,i,u){return s=+s,i>>>=0,u||checkInt(this,s,i,2,32767,-32768),this[i]=255&s,this[i+1]=s>>>8,i+2},Buffer.prototype.writeInt16BE=function writeInt16BE(s,i,u){return s=+s,i>>>=0,u||checkInt(this,s,i,2,32767,-32768),this[i]=s>>>8,this[i+1]=255&s,i+2},Buffer.prototype.writeInt32LE=function writeInt32LE(s,i,u){return s=+s,i>>>=0,u||checkInt(this,s,i,4,2147483647,-2147483648),this[i]=255&s,this[i+1]=s>>>8,this[i+2]=s>>>16,this[i+3]=s>>>24,i+4},Buffer.prototype.writeInt32BE=function writeInt32BE(s,i,u){return s=+s,i>>>=0,u||checkInt(this,s,i,4,2147483647,-2147483648),s<0&&(s=4294967295+s+1),this[i]=s>>>24,this[i+1]=s>>>16,this[i+2]=s>>>8,this[i+3]=255&s,i+4},Buffer.prototype.writeBigInt64LE=defineBigIntMethod((function writeBigInt64LE(s,i=0){return wrtBigUInt64LE(this,s,i,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))})),Buffer.prototype.writeBigInt64BE=defineBigIntMethod((function writeBigInt64BE(s,i=0){return wrtBigUInt64BE(this,s,i,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))})),Buffer.prototype.writeFloatLE=function writeFloatLE(s,i,u){return writeFloat(this,s,i,!0,u)},Buffer.prototype.writeFloatBE=function writeFloatBE(s,i,u){return writeFloat(this,s,i,!1,u)},Buffer.prototype.writeDoubleLE=function writeDoubleLE(s,i,u){return writeDouble(this,s,i,!0,u)},Buffer.prototype.writeDoubleBE=function writeDoubleBE(s,i,u){return writeDouble(this,s,i,!1,u)},Buffer.prototype.copy=function copy(s,i,u,_){if(!Buffer.isBuffer(s))throw new TypeError("argument should be a Buffer");if(u||(u=0),_||0===_||(_=this.length),i>=s.length&&(i=s.length),i||(i=0),_>0&&_=this.length)throw new RangeError("Index out of range");if(_<0)throw new RangeError("sourceEnd out of bounds");_>this.length&&(_=this.length),s.length-i<_-u&&(_=s.length-i+u);const w=_-u;return this===s&&"function"==typeof Uint8Array.prototype.copyWithin?this.copyWithin(i,u,_):Uint8Array.prototype.set.call(s,this.subarray(u,_),i),w},Buffer.prototype.fill=function fill(s,i,u,_){if("string"==typeof s){if("string"==typeof i?(_=i,i=0,u=this.length):"string"==typeof u&&(_=u,u=this.length),void 0!==_&&"string"!=typeof _)throw new TypeError("encoding must be a string");if("string"==typeof _&&!Buffer.isEncoding(_))throw new TypeError("Unknown encoding: "+_);if(1===s.length){const i=s.charCodeAt(0);("utf8"===_&&i<128||"latin1"===_)&&(s=i)}}else"number"==typeof s?s&=255:"boolean"==typeof s&&(s=Number(s));if(i<0||this.length>>=0,u=void 0===u?this.length:u>>>0,s||(s=0),"number"==typeof s)for(w=i;w=_+4;u-=3)i=`_${s.slice(u-3,u)}${i}`;return`${s.slice(0,u)}${i}`}function checkIntBI(s,i,u,_,w,x){if(s>u||s3?0===i||i===BigInt(0)?`>= 0${_} and < 2${_} ** ${8*(x+1)}${_}`:`>= -(2${_} ** ${8*(x+1)-1}${_}) and < 2 ** ${8*(x+1)-1}${_}`:`>= ${i}${_} and <= ${u}${_}`,new B.ERR_OUT_OF_RANGE("value",w,s)}!function checkBounds(s,i,u){validateNumber(i,"offset"),void 0!==s[i]&&void 0!==s[i+u]||boundsError(i,s.length-(u+1))}(_,w,x)}function validateNumber(s,i){if("number"!=typeof s)throw new B.ERR_INVALID_ARG_TYPE(i,"number",s)}function boundsError(s,i,u){if(Math.floor(s)!==s)throw validateNumber(s,u),new B.ERR_OUT_OF_RANGE(u||"offset","an integer",s);if(i<0)throw new B.ERR_BUFFER_OUT_OF_BOUNDS;throw new B.ERR_OUT_OF_RANGE(u||"offset",`>= ${u?1:0} and <= ${i}`,s)}E("ERR_BUFFER_OUT_OF_BOUNDS",(function(s){return s?`${s} is outside of buffer bounds`:"Attempt to access memory outside buffer bounds"}),RangeError),E("ERR_INVALID_ARG_TYPE",(function(s,i){return`The "${s}" argument must be of type number. Received type ${typeof i}`}),TypeError),E("ERR_OUT_OF_RANGE",(function(s,i,u){let _=`The value of "${s}" is out of range.`,w=u;return Number.isInteger(u)&&Math.abs(u)>2**32?w=addNumericalSeparator(String(u)):"bigint"==typeof u&&(w=String(u),(u>BigInt(2)**BigInt(32)||u<-(BigInt(2)**BigInt(32)))&&(w=addNumericalSeparator(w)),w+="n"),_+=` It must be ${i}. Received ${w}`,_}),RangeError);const $=/[^+/0-9A-Za-z-_]/g;function utf8ToBytes(s,i){let u;i=i||1/0;const _=s.length;let w=null;const x=[];for(let j=0;j<_;++j){if(u=s.charCodeAt(j),u>55295&&u<57344){if(!w){if(u>56319){(i-=3)>-1&&x.push(239,191,189);continue}if(j+1===_){(i-=3)>-1&&x.push(239,191,189);continue}w=u;continue}if(u<56320){(i-=3)>-1&&x.push(239,191,189),w=u;continue}u=65536+(w-55296<<10|u-56320)}else w&&(i-=3)>-1&&x.push(239,191,189);if(w=null,u<128){if((i-=1)<0)break;x.push(u)}else if(u<2048){if((i-=2)<0)break;x.push(u>>6|192,63&u|128)}else if(u<65536){if((i-=3)<0)break;x.push(u>>12|224,u>>6&63|128,63&u|128)}else{if(!(u<1114112))throw new Error("Invalid code point");if((i-=4)<0)break;x.push(u>>18|240,u>>12&63|128,u>>6&63|128,63&u|128)}}return x}function base64ToBytes(s){return _.toByteArray(function base64clean(s){if((s=(s=s.split("=")[0]).trim().replace($,"")).length<2)return"";for(;s.length%4!=0;)s+="=";return s}(s))}function blitBuffer(s,i,u,_){let w;for(w=0;w<_&&!(w+u>=i.length||w>=s.length);++w)i[w+u]=s[w];return w}function isInstance(s,i){return s instanceof i||null!=s&&null!=s.constructor&&null!=s.constructor.name&&s.constructor.name===i.name}function numberIsNaN(s){return s!=s}const U=function(){const s="0123456789abcdef",i=new Array(256);for(let u=0;u<16;++u){const _=16*u;for(let w=0;w<16;++w)i[_+w]=s[u]+s[w]}return i}();function defineBigIntMethod(s){return"undefined"==typeof BigInt?BufferBigIntNotDefined:s}function BufferBigIntNotDefined(){throw new Error("BigInt not supported")}},38075:(s,i,u)=>{"use strict";var _=u(70453),w=u(10487),x=w(_("String.prototype.indexOf"));s.exports=function callBoundIntrinsic(s,i){var u=_(s,!!i);return"function"==typeof u&&x(s,".prototype.")>-1?w(u):u}},10487:(s,i,u)=>{"use strict";var _=u(66743),w=u(70453),x=u(96897),j=u(69675),L=w("%Function.prototype.apply%"),B=w("%Function.prototype.call%"),$=w("%Reflect.apply%",!0)||_.call(B,L),U=u(30655),Y=w("%Math.max%");s.exports=function callBind(s){if("function"!=typeof s)throw new j("a function is required");var i=$(_,B,arguments);return x(i,1+Y(0,s.length-(arguments.length-1)),!0)};var Z=function applyBind(){return $(_,L,arguments)};U?U(s.exports,"apply",{value:Z}):s.exports.apply=Z},57427:(s,i)=>{"use strict";i.parse=function parse(s,i){if("string"!=typeof s)throw new TypeError("argument str must be a string");var u={},_=(i||{}).decode||decode,w=0;for(;w{"use strict";var _=u(16426),w={"text/plain":"Text","text/html":"Url",default:"Text"};s.exports=function copy(s,i){var u,x,j,L,B,$,U=!1;i||(i={}),u=i.debug||!1;try{if(j=_(),L=document.createRange(),B=document.getSelection(),($=document.createElement("span")).textContent=s,$.ariaHidden="true",$.style.all="unset",$.style.position="fixed",$.style.top=0,$.style.clip="rect(0, 0, 0, 0)",$.style.whiteSpace="pre",$.style.webkitUserSelect="text",$.style.MozUserSelect="text",$.style.msUserSelect="text",$.style.userSelect="text",$.addEventListener("copy",(function(_){if(_.stopPropagation(),i.format)if(_.preventDefault(),void 0===_.clipboardData){u&&console.warn("unable to use e.clipboardData"),u&&console.warn("trying IE specific stuff"),window.clipboardData.clearData();var x=w[i.format]||w.default;window.clipboardData.setData(x,s)}else _.clipboardData.clearData(),_.clipboardData.setData(i.format,s);i.onCopy&&(_.preventDefault(),i.onCopy(_.clipboardData))})),document.body.appendChild($),L.selectNodeContents($),B.addRange(L),!document.execCommand("copy"))throw new Error("copy command was unsuccessful");U=!0}catch(_){u&&console.error("unable to copy using execCommand: ",_),u&&console.warn("trying IE specific stuff");try{window.clipboardData.setData(i.format||"text",s),i.onCopy&&i.onCopy(window.clipboardData),U=!0}catch(_){u&&console.error("unable to copy using clipboardData: ",_),u&&console.error("falling back to prompt"),x=function format(s){var i=(/mac os x/i.test(navigator.userAgent)?"⌘":"Ctrl")+"+C";return s.replace(/#{\s*key\s*}/g,i)}("message"in i?i.message:"Copy to clipboard: #{key}, Enter"),window.prompt(x,s)}}finally{B&&("function"==typeof B.removeRange?B.removeRange(L):B.removeAllRanges()),$&&document.body.removeChild($),j()}return U}},2205:function(s,i,u){var _;_=void 0!==u.g?u.g:this,s.exports=function(s){if(s.CSS&&s.CSS.escape)return s.CSS.escape;var cssEscape=function(s){if(0==arguments.length)throw new TypeError("`CSS.escape` requires an argument.");for(var i,u=String(s),_=u.length,w=-1,x="",j=u.charCodeAt(0);++w<_;)0!=(i=u.charCodeAt(w))?x+=i>=1&&i<=31||127==i||0==w&&i>=48&&i<=57||1==w&&i>=48&&i<=57&&45==j?"\\"+i.toString(16)+" ":0==w&&1==_&&45==i||!(i>=128||45==i||95==i||i>=48&&i<=57||i>=65&&i<=90||i>=97&&i<=122)?"\\"+u.charAt(w):u.charAt(w):x+="�";return x};return s.CSS||(s.CSS={}),s.CSS.escape=cssEscape,cssEscape}(_)},81919:(s,i,u)=>{"use strict";var _=u(48287).Buffer;function isSpecificValue(s){return s instanceof _||s instanceof Date||s instanceof RegExp}function cloneSpecificValue(s){if(s instanceof _){var i=_.alloc?_.alloc(s.length):new _(s.length);return s.copy(i),i}if(s instanceof Date)return new Date(s.getTime());if(s instanceof RegExp)return new RegExp(s);throw new Error("Unexpected situation")}function deepCloneArray(s){var i=[];return s.forEach((function(s,u){"object"==typeof s&&null!==s?Array.isArray(s)?i[u]=deepCloneArray(s):isSpecificValue(s)?i[u]=cloneSpecificValue(s):i[u]=w({},s):i[u]=s})),i}function safeGetProperty(s,i){return"__proto__"===i?void 0:s[i]}var w=s.exports=function(){if(arguments.length<1||"object"!=typeof arguments[0])return!1;if(arguments.length<2)return arguments[0];var s,i,u=arguments[0];return Array.prototype.slice.call(arguments,1).forEach((function(_){"object"!=typeof _||null===_||Array.isArray(_)||Object.keys(_).forEach((function(x){return i=safeGetProperty(u,x),(s=safeGetProperty(_,x))===u?void 0:"object"!=typeof s||null===s?void(u[x]=s):Array.isArray(s)?void(u[x]=deepCloneArray(s)):isSpecificValue(s)?void(u[x]=cloneSpecificValue(s)):"object"!=typeof i||null===i||Array.isArray(i)?void(u[x]=w({},s)):void(u[x]=w(i,s))}))})),u}},14744:s=>{"use strict";var i=function isMergeableObject(s){return function isNonNullObject(s){return!!s&&"object"==typeof s}(s)&&!function isSpecial(s){var i=Object.prototype.toString.call(s);return"[object RegExp]"===i||"[object Date]"===i||function isReactElement(s){return s.$$typeof===u}(s)}(s)};var u="function"==typeof Symbol&&Symbol.for?Symbol.for("react.element"):60103;function cloneUnlessOtherwiseSpecified(s,i){return!1!==i.clone&&i.isMergeableObject(s)?deepmerge(function emptyTarget(s){return Array.isArray(s)?[]:{}}(s),s,i):s}function defaultArrayMerge(s,i,u){return s.concat(i).map((function(s){return cloneUnlessOtherwiseSpecified(s,u)}))}function getKeys(s){return Object.keys(s).concat(function getEnumerableOwnPropertySymbols(s){return Object.getOwnPropertySymbols?Object.getOwnPropertySymbols(s).filter((function(i){return Object.propertyIsEnumerable.call(s,i)})):[]}(s))}function propertyIsOnObject(s,i){try{return i in s}catch(s){return!1}}function mergeObject(s,i,u){var _={};return u.isMergeableObject(s)&&getKeys(s).forEach((function(i){_[i]=cloneUnlessOtherwiseSpecified(s[i],u)})),getKeys(i).forEach((function(w){(function propertyIsUnsafe(s,i){return propertyIsOnObject(s,i)&&!(Object.hasOwnProperty.call(s,i)&&Object.propertyIsEnumerable.call(s,i))})(s,w)||(propertyIsOnObject(s,w)&&u.isMergeableObject(i[w])?_[w]=function getMergeFunction(s,i){if(!i.customMerge)return deepmerge;var u=i.customMerge(s);return"function"==typeof u?u:deepmerge}(w,u)(s[w],i[w],u):_[w]=cloneUnlessOtherwiseSpecified(i[w],u))})),_}function deepmerge(s,u,_){(_=_||{}).arrayMerge=_.arrayMerge||defaultArrayMerge,_.isMergeableObject=_.isMergeableObject||i,_.cloneUnlessOtherwiseSpecified=cloneUnlessOtherwiseSpecified;var w=Array.isArray(u);return w===Array.isArray(s)?w?_.arrayMerge(s,u,_):mergeObject(s,u,_):cloneUnlessOtherwiseSpecified(u,_)}deepmerge.all=function deepmergeAll(s,i){if(!Array.isArray(s))throw new Error("first argument should be an array");return s.reduce((function(s,u){return deepmerge(s,u,i)}),{})};var _=deepmerge;s.exports=_},30041:(s,i,u)=>{"use strict";var _=u(30655),w=u(58068),x=u(69675),j=u(75795);s.exports=function defineDataProperty(s,i,u){if(!s||"object"!=typeof s&&"function"!=typeof s)throw new x("`obj` must be an object or a function`");if("string"!=typeof i&&"symbol"!=typeof i)throw new x("`property` must be a string or a symbol`");if(arguments.length>3&&"boolean"!=typeof arguments[3]&&null!==arguments[3])throw new x("`nonEnumerable`, if provided, must be a boolean or null");if(arguments.length>4&&"boolean"!=typeof arguments[4]&&null!==arguments[4])throw new x("`nonWritable`, if provided, must be a boolean or null");if(arguments.length>5&&"boolean"!=typeof arguments[5]&&null!==arguments[5])throw new x("`nonConfigurable`, if provided, must be a boolean or null");if(arguments.length>6&&"boolean"!=typeof arguments[6])throw new x("`loose`, if provided, must be a boolean");var L=arguments.length>3?arguments[3]:null,B=arguments.length>4?arguments[4]:null,$=arguments.length>5?arguments[5]:null,U=arguments.length>6&&arguments[6],Y=!!j&&j(s,i);if(_)_(s,i,{configurable:null===$&&Y?Y.configurable:!$,enumerable:null===L&&Y?Y.enumerable:!L,value:u,writable:null===B&&Y?Y.writable:!B});else{if(!U&&(L||B||$))throw new w("This environment does not support defining a property as non-configurable, non-writable, or non-enumerable.");s[i]=u}}},42838:function(s){s.exports=function(){"use strict";const{entries:s,setPrototypeOf:i,isFrozen:u,getPrototypeOf:_,getOwnPropertyDescriptor:w}=Object;let{freeze:x,seal:j,create:L}=Object,{apply:B,construct:$}="undefined"!=typeof Reflect&&Reflect;x||(x=function freeze(s){return s}),j||(j=function seal(s){return s}),B||(B=function apply(s,i,u){return s.apply(i,u)}),$||($=function construct(s,i){return new s(...i)});const U=unapply(Array.prototype.forEach),Y=unapply(Array.prototype.pop),Z=unapply(Array.prototype.push),ee=unapply(String.prototype.toLowerCase),ie=unapply(String.prototype.toString),ae=unapply(String.prototype.match),le=unapply(String.prototype.replace),ce=unapply(String.prototype.indexOf),pe=unapply(String.prototype.trim),de=unapply(Object.prototype.hasOwnProperty),fe=unapply(RegExp.prototype.test),ye=unconstruct(TypeError);function unapply(s){return function(i){for(var u=arguments.length,_=new Array(u>1?u-1:0),w=1;w2&&void 0!==arguments[2]?arguments[2]:ee;i&&i(s,null);let x=_.length;for(;x--;){let i=_[x];if("string"==typeof i){const s=w(i);s!==i&&(u(_)||(_[x]=s),i=s)}s[i]=!0}return s}function cleanArray(s){for(let i=0;i/gm),Ye=j(/\${[\w\W]*}/gm),Xe=j(/^data-[\-\w.\u00B7-\uFFFF]/),Qe=j(/^aria-[\-\w]+$/),et=j(/^(?:(?:(?:f|ht)tps?|mailto|tel|callto|sms|cid|xmpp):|[^a-z]|[a-z+.\-]+(?:[^a-z+.\-:]|$))/i),tt=j(/^(?:\w+script|data):/i),rt=j(/[\u0000-\u0020\u00A0\u1680\u180E\u2000-\u2029\u205F\u3000]/g),nt=j(/^html$/i),ot=j(/^[a-z][.\w]*(-[.\w]+)+$/i);var st=Object.freeze({__proto__:null,MUSTACHE_EXPR:We,ERB_EXPR:He,TMPLIT_EXPR:Ye,DATA_ATTR:Xe,ARIA_ATTR:Qe,IS_ALLOWED_URI:et,IS_SCRIPT_OR_DATA:tt,ATTR_WHITESPACE:rt,DOCTYPE_NAME:nt,CUSTOM_ELEMENT:ot});const it=function getGlobal(){return"undefined"==typeof window?null:window},at=function _createTrustedTypesPolicy(s,i){if("object"!=typeof s||"function"!=typeof s.createPolicy)return null;let u=null;const _="data-tt-policy-suffix";i&&i.hasAttribute(_)&&(u=i.getAttribute(_));const w="dompurify"+(u?"#"+u:"");try{return s.createPolicy(w,{createHTML:s=>s,createScriptURL:s=>s})}catch(s){return console.warn("TrustedTypes policy "+w+" could not be created."),null}};function createDOMPurify(){let i=arguments.length>0&&void 0!==arguments[0]?arguments[0]:it();const DOMPurify=s=>createDOMPurify(s);if(DOMPurify.version="3.1.2",DOMPurify.removed=[],!i||!i.document||9!==i.document.nodeType)return DOMPurify.isSupported=!1,DOMPurify;let{document:u}=i;const _=u,w=_.currentScript,{DocumentFragment:j,HTMLTemplateElement:B,Node:$,Element:We,NodeFilter:He,NamedNodeMap:Ye=i.NamedNodeMap||i.MozNamedAttrMap,HTMLFormElement:Xe,DOMParser:Qe,trustedTypes:tt}=i,rt=We.prototype,ot=lookupGetter(rt,"cloneNode"),lt=lookupGetter(rt,"nextSibling"),ct=lookupGetter(rt,"childNodes"),ut=lookupGetter(rt,"parentNode");if("function"==typeof B){const s=u.createElement("template");s.content&&s.content.ownerDocument&&(u=s.content.ownerDocument)}let pt,ht="";const{implementation:dt,createNodeIterator:mt,createDocumentFragment:gt,getElementsByTagName:yt}=u,{importNode:vt}=_;let bt={};DOMPurify.isSupported="function"==typeof s&&"function"==typeof ut&&dt&&void 0!==dt.createHTMLDocument;const{MUSTACHE_EXPR:_t,ERB_EXPR:Et,TMPLIT_EXPR:wt,DATA_ATTR:St,ARIA_ATTR:xt,IS_SCRIPT_OR_DATA:kt,ATTR_WHITESPACE:Ot,CUSTOM_ELEMENT:Ct}=st;let{IS_ALLOWED_URI:At}=st,jt=null;const Pt=addToSet({},[...be,..._e,...we,...xe,...Te]);let It=null;const Nt=addToSet({},[...Re,...qe,...$e,...ze]);let Mt=Object.seal(L(null,{tagNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},attributeNameCheck:{writable:!0,configurable:!1,enumerable:!0,value:null},allowCustomizedBuiltInElements:{writable:!0,configurable:!1,enumerable:!0,value:!1}})),Tt=null,Rt=null,Dt=!0,Lt=!0,Bt=!1,Ft=!0,qt=!1,$t=!0,Vt=!1,Ut=!1,zt=!1,Wt=!1,Kt=!1,Ht=!1,Jt=!0,Gt=!1;const Yt="user-content-";let Xt=!0,Qt=!1,Zt={},er=null;const tr=addToSet({},["annotation-xml","audio","colgroup","desc","foreignobject","head","iframe","math","mi","mn","mo","ms","mtext","noembed","noframes","noscript","plaintext","script","style","svg","template","thead","title","video","xmp"]);let rr=null;const nr=addToSet({},["audio","video","img","source","image","track"]);let sr=null;const ir=addToSet({},["alt","class","for","id","label","name","pattern","placeholder","role","summary","title","value","style","xmlns"]),ar="http://www.w3.org/1998/Math/MathML",lr="http://www.w3.org/2000/svg",cr="http://www.w3.org/1999/xhtml";let ur=cr,pr=!1,dr=null;const fr=addToSet({},[ar,lr,cr],ie);let mr=null;const gr=["application/xhtml+xml","text/html"],yr="text/html";let vr=null,br=null;const _r=255,Er=u.createElement("form"),wr=function isRegexOrFunction(s){return s instanceof RegExp||s instanceof Function},Sr=function _parseConfig(){let s=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if(!br||br!==s){if(s&&"object"==typeof s||(s={}),s=clone(s),mr=-1===gr.indexOf(s.PARSER_MEDIA_TYPE)?yr:s.PARSER_MEDIA_TYPE,vr="application/xhtml+xml"===mr?ie:ee,jt=de(s,"ALLOWED_TAGS")?addToSet({},s.ALLOWED_TAGS,vr):Pt,It=de(s,"ALLOWED_ATTR")?addToSet({},s.ALLOWED_ATTR,vr):Nt,dr=de(s,"ALLOWED_NAMESPACES")?addToSet({},s.ALLOWED_NAMESPACES,ie):fr,sr=de(s,"ADD_URI_SAFE_ATTR")?addToSet(clone(ir),s.ADD_URI_SAFE_ATTR,vr):ir,rr=de(s,"ADD_DATA_URI_TAGS")?addToSet(clone(nr),s.ADD_DATA_URI_TAGS,vr):nr,er=de(s,"FORBID_CONTENTS")?addToSet({},s.FORBID_CONTENTS,vr):tr,Tt=de(s,"FORBID_TAGS")?addToSet({},s.FORBID_TAGS,vr):{},Rt=de(s,"FORBID_ATTR")?addToSet({},s.FORBID_ATTR,vr):{},Zt=!!de(s,"USE_PROFILES")&&s.USE_PROFILES,Dt=!1!==s.ALLOW_ARIA_ATTR,Lt=!1!==s.ALLOW_DATA_ATTR,Bt=s.ALLOW_UNKNOWN_PROTOCOLS||!1,Ft=!1!==s.ALLOW_SELF_CLOSE_IN_ATTR,qt=s.SAFE_FOR_TEMPLATES||!1,$t=!1!==s.SAFE_FOR_XML,Vt=s.WHOLE_DOCUMENT||!1,Wt=s.RETURN_DOM||!1,Kt=s.RETURN_DOM_FRAGMENT||!1,Ht=s.RETURN_TRUSTED_TYPE||!1,zt=s.FORCE_BODY||!1,Jt=!1!==s.SANITIZE_DOM,Gt=s.SANITIZE_NAMED_PROPS||!1,Xt=!1!==s.KEEP_CONTENT,Qt=s.IN_PLACE||!1,At=s.ALLOWED_URI_REGEXP||et,ur=s.NAMESPACE||cr,Mt=s.CUSTOM_ELEMENT_HANDLING||{},s.CUSTOM_ELEMENT_HANDLING&&wr(s.CUSTOM_ELEMENT_HANDLING.tagNameCheck)&&(Mt.tagNameCheck=s.CUSTOM_ELEMENT_HANDLING.tagNameCheck),s.CUSTOM_ELEMENT_HANDLING&&wr(s.CUSTOM_ELEMENT_HANDLING.attributeNameCheck)&&(Mt.attributeNameCheck=s.CUSTOM_ELEMENT_HANDLING.attributeNameCheck),s.CUSTOM_ELEMENT_HANDLING&&"boolean"==typeof s.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements&&(Mt.allowCustomizedBuiltInElements=s.CUSTOM_ELEMENT_HANDLING.allowCustomizedBuiltInElements),qt&&(Lt=!1),Kt&&(Wt=!0),Zt&&(jt=addToSet({},Te),It=[],!0===Zt.html&&(addToSet(jt,be),addToSet(It,Re)),!0===Zt.svg&&(addToSet(jt,_e),addToSet(It,qe),addToSet(It,ze)),!0===Zt.svgFilters&&(addToSet(jt,we),addToSet(It,qe),addToSet(It,ze)),!0===Zt.mathMl&&(addToSet(jt,xe),addToSet(It,$e),addToSet(It,ze))),s.ADD_TAGS&&(jt===Pt&&(jt=clone(jt)),addToSet(jt,s.ADD_TAGS,vr)),s.ADD_ATTR&&(It===Nt&&(It=clone(It)),addToSet(It,s.ADD_ATTR,vr)),s.ADD_URI_SAFE_ATTR&&addToSet(sr,s.ADD_URI_SAFE_ATTR,vr),s.FORBID_CONTENTS&&(er===tr&&(er=clone(er)),addToSet(er,s.FORBID_CONTENTS,vr)),Xt&&(jt["#text"]=!0),Vt&&addToSet(jt,["html","head","body"]),jt.table&&(addToSet(jt,["tbody"]),delete Tt.tbody),s.TRUSTED_TYPES_POLICY){if("function"!=typeof s.TRUSTED_TYPES_POLICY.createHTML)throw ye('TRUSTED_TYPES_POLICY configuration option must provide a "createHTML" hook.');if("function"!=typeof s.TRUSTED_TYPES_POLICY.createScriptURL)throw ye('TRUSTED_TYPES_POLICY configuration option must provide a "createScriptURL" hook.');pt=s.TRUSTED_TYPES_POLICY,ht=pt.createHTML("")}else void 0===pt&&(pt=at(tt,w)),null!==pt&&"string"==typeof ht&&(ht=pt.createHTML(""));x&&x(s),br=s}},xr=addToSet({},["mi","mo","mn","ms","mtext"]),kr=addToSet({},["foreignobject","annotation-xml"]),Or=addToSet({},["title","style","font","a","script"]),Cr=addToSet({},[..._e,...we,...Se]),Ar=addToSet({},[...xe,...Pe]),jr=function _checkValidNamespace(s){let i=ut(s);i&&i.tagName||(i={namespaceURI:ur,tagName:"template"});const u=ee(s.tagName),_=ee(i.tagName);return!!dr[s.namespaceURI]&&(s.namespaceURI===lr?i.namespaceURI===cr?"svg"===u:i.namespaceURI===ar?"svg"===u&&("annotation-xml"===_||xr[_]):Boolean(Cr[u]):s.namespaceURI===ar?i.namespaceURI===cr?"math"===u:i.namespaceURI===lr?"math"===u&&kr[_]:Boolean(Ar[u]):s.namespaceURI===cr?!(i.namespaceURI===lr&&!kr[_])&&!(i.namespaceURI===ar&&!xr[_])&&!Ar[u]&&(Or[u]||!Cr[u]):!("application/xhtml+xml"!==mr||!dr[s.namespaceURI]))},Pr=function _forceRemove(s){Z(DOMPurify.removed,{element:s});try{s.parentNode.removeChild(s)}catch(i){s.remove()}},Ir=function _removeAttribute(s,i){try{Z(DOMPurify.removed,{attribute:i.getAttributeNode(s),from:i})}catch(s){Z(DOMPurify.removed,{attribute:null,from:i})}if(i.removeAttribute(s),"is"===s&&!It[s])if(Wt||Kt)try{Pr(i)}catch(s){}else try{i.setAttribute(s,"")}catch(s){}},Nr=function _initDocument(s){let i=null,_=null;if(zt)s=""+s;else{const i=ae(s,/^[\r\n\t ]+/);_=i&&i[0]}"application/xhtml+xml"===mr&&ur===cr&&(s=''+s+"");const w=pt?pt.createHTML(s):s;if(ur===cr)try{i=(new Qe).parseFromString(w,mr)}catch(s){}if(!i||!i.documentElement){i=dt.createDocument(ur,"template",null);try{i.documentElement.innerHTML=pr?ht:w}catch(s){}}const x=i.body||i.documentElement;return s&&_&&x.insertBefore(u.createTextNode(_),x.childNodes[0]||null),ur===cr?yt.call(i,Vt?"html":"body")[0]:Vt?i.documentElement:x},Mr=function _createNodeIterator(s){return mt.call(s.ownerDocument||s,s,He.SHOW_ELEMENT|He.SHOW_COMMENT|He.SHOW_TEXT|He.SHOW_PROCESSING_INSTRUCTION|He.SHOW_CDATA_SECTION,null)},Tr=function _isClobbered(s){return s instanceof Xe&&(void 0!==s.__depth&&"number"!=typeof s.__depth||void 0!==s.__removalCount&&"number"!=typeof s.__removalCount||"string"!=typeof s.nodeName||"string"!=typeof s.textContent||"function"!=typeof s.removeChild||!(s.attributes instanceof Ye)||"function"!=typeof s.removeAttribute||"function"!=typeof s.setAttribute||"string"!=typeof s.namespaceURI||"function"!=typeof s.insertBefore||"function"!=typeof s.hasChildNodes)},Rr=function _isNode(s){return"function"==typeof $&&s instanceof $},Dr=function _executeHook(s,i,u){bt[s]&&U(bt[s],(s=>{s.call(DOMPurify,i,u,br)}))},Lr=function _sanitizeElements(s){let i=null;if(Dr("beforeSanitizeElements",s,null),Tr(s))return Pr(s),!0;const u=vr(s.nodeName);if(Dr("uponSanitizeElement",s,{tagName:u,allowedTags:jt}),s.hasChildNodes()&&!Rr(s.firstElementChild)&&fe(/<[/\w]/g,s.innerHTML)&&fe(/<[/\w]/g,s.textContent))return Pr(s),!0;if(7===s.nodeType)return Pr(s),!0;if($t&&8===s.nodeType&&fe(/<[/\w]/g,s.data))return Pr(s),!0;if(!jt[u]||Tt[u]){if(!Tt[u]&&Fr(u)){if(Mt.tagNameCheck instanceof RegExp&&fe(Mt.tagNameCheck,u))return!1;if(Mt.tagNameCheck instanceof Function&&Mt.tagNameCheck(u))return!1}if(Xt&&!er[u]){const i=ut(s)||s.parentNode,u=ct(s)||s.childNodes;if(u&&i)for(let _=u.length-1;_>=0;--_){const w=ot(u[_],!0);w.__removalCount=(s.__removalCount||0)+1,i.insertBefore(w,lt(s))}}return Pr(s),!0}return s instanceof We&&!jr(s)?(Pr(s),!0):"noscript"!==u&&"noembed"!==u&&"noframes"!==u||!fe(/<\/no(script|embed|frames)/i,s.innerHTML)?(qt&&3===s.nodeType&&(i=s.textContent,U([_t,Et,wt],(s=>{i=le(i,s," ")})),s.textContent!==i&&(Z(DOMPurify.removed,{element:s.cloneNode()}),s.textContent=i)),Dr("afterSanitizeElements",s,null),!1):(Pr(s),!0)},Br=function _isValidAttribute(s,i,_){if(Jt&&("id"===i||"name"===i)&&(_ in u||_ in Er))return!1;if(Lt&&!Rt[i]&&fe(St,i));else if(Dt&&fe(xt,i));else if(!It[i]||Rt[i]){if(!(Fr(s)&&(Mt.tagNameCheck instanceof RegExp&&fe(Mt.tagNameCheck,s)||Mt.tagNameCheck instanceof Function&&Mt.tagNameCheck(s))&&(Mt.attributeNameCheck instanceof RegExp&&fe(Mt.attributeNameCheck,i)||Mt.attributeNameCheck instanceof Function&&Mt.attributeNameCheck(i))||"is"===i&&Mt.allowCustomizedBuiltInElements&&(Mt.tagNameCheck instanceof RegExp&&fe(Mt.tagNameCheck,_)||Mt.tagNameCheck instanceof Function&&Mt.tagNameCheck(_))))return!1}else if(sr[i]);else if(fe(At,le(_,Ot,"")));else if("src"!==i&&"xlink:href"!==i&&"href"!==i||"script"===s||0!==ce(_,"data:")||!rr[s])if(Bt&&!fe(kt,le(_,Ot,"")));else if(_)return!1;return!0},Fr=function _isBasicCustomElement(s){return"annotation-xml"!==s&&ae(s,Ct)},qr=function _sanitizeAttributes(s){Dr("beforeSanitizeAttributes",s,null);const{attributes:i}=s;if(!i)return;const u={attrName:"",attrValue:"",keepAttr:!0,allowedAttributes:It};let _=i.length;for(;_--;){const w=i[_],{name:x,namespaceURI:j,value:L}=w,B=vr(x);let $="value"===x?L:pe(L);if(u.attrName=B,u.attrValue=$,u.keepAttr=!0,u.forceKeepAttr=void 0,Dr("uponSanitizeAttribute",s,u),$=u.attrValue,u.forceKeepAttr)continue;if(Ir(x,s),!u.keepAttr)continue;if(!Ft&&fe(/\/>/i,$)){Ir(x,s);continue}qt&&U([_t,Et,wt],(s=>{$=le($,s," ")}));const Z=vr(s.nodeName);if(Br(Z,B,$)){if(!Gt||"id"!==B&&"name"!==B||(Ir(x,s),$=Yt+$),pt&&"object"==typeof tt&&"function"==typeof tt.getAttributeType)if(j);else switch(tt.getAttributeType(Z,B)){case"TrustedHTML":$=pt.createHTML($);break;case"TrustedScriptURL":$=pt.createScriptURL($)}try{j?s.setAttributeNS(j,x,$):s.setAttribute(x,$),Y(DOMPurify.removed)}catch(s){}}}Dr("afterSanitizeAttributes",s,null)},$r=function _sanitizeShadowDOM(s){let i=null;const u=Mr(s);for(Dr("beforeSanitizeShadowDOM",s,null);i=u.nextNode();){if(Dr("uponSanitizeShadowNode",i,null),Lr(i))continue;const s=ut(i);1===i.nodeType&&(s&&s.__depth?i.__depth=(i.__removalCount||0)+s.__depth+1:i.__depth=1),i.__depth>=_r&&Pr(i),i.content instanceof j&&(i.content.__depth=i.__depth,_sanitizeShadowDOM(i.content)),qr(i)}Dr("afterSanitizeShadowDOM",s,null)};return DOMPurify.sanitize=function(s){let i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},u=null,w=null,x=null,L=null;if(pr=!s,pr&&(s="\x3c!--\x3e"),"string"!=typeof s&&!Rr(s)){if("function"!=typeof s.toString)throw ye("toString is not a function");if("string"!=typeof(s=s.toString()))throw ye("dirty is not a string, aborting")}if(!DOMPurify.isSupported)return s;if(Ut||Sr(i),DOMPurify.removed=[],"string"==typeof s&&(Qt=!1),Qt){if(s.nodeName){const i=vr(s.nodeName);if(!jt[i]||Tt[i])throw ye("root node is forbidden and cannot be sanitized in-place")}}else if(s instanceof $)u=Nr("\x3c!----\x3e"),w=u.ownerDocument.importNode(s,!0),1===w.nodeType&&"BODY"===w.nodeName||"HTML"===w.nodeName?u=w:u.appendChild(w);else{if(!Wt&&!qt&&!Vt&&-1===s.indexOf("<"))return pt&&Ht?pt.createHTML(s):s;if(u=Nr(s),!u)return Wt?null:Ht?ht:""}u&&zt&&Pr(u.firstChild);const B=Mr(Qt?s:u);for(;x=B.nextNode();){if(Lr(x))continue;const s=ut(x);1===x.nodeType&&(s&&s.__depth?x.__depth=(x.__removalCount||0)+s.__depth+1:x.__depth=1),x.__depth>=_r&&Pr(x),x.content instanceof j&&(x.content.__depth=x.__depth,$r(x.content)),qr(x)}if(Qt)return s;if(Wt){if(Kt)for(L=gt.call(u.ownerDocument);u.firstChild;)L.appendChild(u.firstChild);else L=u;return(It.shadowroot||It.shadowrootmode)&&(L=vt.call(_,L,!0)),L}let Y=Vt?u.outerHTML:u.innerHTML;return Vt&&jt["!doctype"]&&u.ownerDocument&&u.ownerDocument.doctype&&u.ownerDocument.doctype.name&&fe(nt,u.ownerDocument.doctype.name)&&(Y="\n"+Y),qt&&U([_t,Et,wt],(s=>{Y=le(Y,s," ")})),pt&&Ht?pt.createHTML(Y):Y},DOMPurify.setConfig=function(){Sr(arguments.length>0&&void 0!==arguments[0]?arguments[0]:{}),Ut=!0},DOMPurify.clearConfig=function(){br=null,Ut=!1},DOMPurify.isValidAttribute=function(s,i,u){br||Sr({});const _=vr(s),w=vr(i);return Br(_,w,u)},DOMPurify.addHook=function(s,i){"function"==typeof i&&(bt[s]=bt[s]||[],Z(bt[s],i))},DOMPurify.removeHook=function(s){if(bt[s])return Y(bt[s])},DOMPurify.removeHooks=function(s){bt[s]&&(bt[s]=[])},DOMPurify.removeAllHooks=function(){bt={}},DOMPurify}return createDOMPurify()}()},78004:s=>{"use strict";class SubRange{constructor(s,i){this.low=s,this.high=i,this.length=1+i-s}overlaps(s){return!(this.highs.high)}touches(s){return!(this.high+1s.high)}add(s){return new SubRange(Math.min(this.low,s.low),Math.max(this.high,s.high))}subtract(s){return s.low<=this.low&&s.high>=this.high?[]:s.low>this.low&&s.highs+i.length),0)}add(s,i){var _add=s=>{for(var i=0;i{for(var i=0;i{for(var i=0;i{for(var u=i.low;u<=i.high;)s.push(u),u++;return s}),[])}subranges(){return this.ranges.map((s=>({low:s.low,high:s.high,length:1+s.high-s.low})))}}s.exports=DRange},30655:(s,i,u)=>{"use strict";var _=u(70453)("%Object.defineProperty%",!0)||!1;if(_)try{_({},"a",{value:1})}catch(s){_=!1}s.exports=_},41237:s=>{"use strict";s.exports=EvalError},69383:s=>{"use strict";s.exports=Error},79290:s=>{"use strict";s.exports=RangeError},79538:s=>{"use strict";s.exports=ReferenceError},58068:s=>{"use strict";s.exports=SyntaxError},69675:s=>{"use strict";s.exports=TypeError},35345:s=>{"use strict";s.exports=URIError},37007:s=>{"use strict";var i,u="object"==typeof Reflect?Reflect:null,_=u&&"function"==typeof u.apply?u.apply:function ReflectApply(s,i,u){return Function.prototype.apply.call(s,i,u)};i=u&&"function"==typeof u.ownKeys?u.ownKeys:Object.getOwnPropertySymbols?function ReflectOwnKeys(s){return Object.getOwnPropertyNames(s).concat(Object.getOwnPropertySymbols(s))}:function ReflectOwnKeys(s){return Object.getOwnPropertyNames(s)};var w=Number.isNaN||function NumberIsNaN(s){return s!=s};function EventEmitter(){EventEmitter.init.call(this)}s.exports=EventEmitter,s.exports.once=function once(s,i){return new Promise((function(u,_){function errorListener(u){s.removeListener(i,resolver),_(u)}function resolver(){"function"==typeof s.removeListener&&s.removeListener("error",errorListener),u([].slice.call(arguments))}eventTargetAgnosticAddListener(s,i,resolver,{once:!0}),"error"!==i&&function addErrorHandlerIfEventEmitter(s,i,u){"function"==typeof s.on&&eventTargetAgnosticAddListener(s,"error",i,u)}(s,errorListener,{once:!0})}))},EventEmitter.EventEmitter=EventEmitter,EventEmitter.prototype._events=void 0,EventEmitter.prototype._eventsCount=0,EventEmitter.prototype._maxListeners=void 0;var x=10;function checkListener(s){if("function"!=typeof s)throw new TypeError('The "listener" argument must be of type Function. Received type '+typeof s)}function _getMaxListeners(s){return void 0===s._maxListeners?EventEmitter.defaultMaxListeners:s._maxListeners}function _addListener(s,i,u,_){var w,x,j;if(checkListener(u),void 0===(x=s._events)?(x=s._events=Object.create(null),s._eventsCount=0):(void 0!==x.newListener&&(s.emit("newListener",i,u.listener?u.listener:u),x=s._events),j=x[i]),void 0===j)j=x[i]=u,++s._eventsCount;else if("function"==typeof j?j=x[i]=_?[u,j]:[j,u]:_?j.unshift(u):j.push(u),(w=_getMaxListeners(s))>0&&j.length>w&&!j.warned){j.warned=!0;var L=new Error("Possible EventEmitter memory leak detected. "+j.length+" "+String(i)+" listeners added. Use emitter.setMaxListeners() to increase limit");L.name="MaxListenersExceededWarning",L.emitter=s,L.type=i,L.count=j.length,function ProcessEmitWarning(s){console&&console.warn&&console.warn(s)}(L)}return s}function onceWrapper(){if(!this.fired)return this.target.removeListener(this.type,this.wrapFn),this.fired=!0,0===arguments.length?this.listener.call(this.target):this.listener.apply(this.target,arguments)}function _onceWrap(s,i,u){var _={fired:!1,wrapFn:void 0,target:s,type:i,listener:u},w=onceWrapper.bind(_);return w.listener=u,_.wrapFn=w,w}function _listeners(s,i,u){var _=s._events;if(void 0===_)return[];var w=_[i];return void 0===w?[]:"function"==typeof w?u?[w.listener||w]:[w]:u?function unwrapListeners(s){for(var i=new Array(s.length),u=0;u0&&(j=i[0]),j instanceof Error)throw j;var L=new Error("Unhandled error."+(j?" ("+j.message+")":""));throw L.context=j,L}var B=x[s];if(void 0===B)return!1;if("function"==typeof B)_(B,this,i);else{var $=B.length,U=arrayClone(B,$);for(u=0;u<$;++u)_(U[u],this,i)}return!0},EventEmitter.prototype.addListener=function addListener(s,i){return _addListener(this,s,i,!1)},EventEmitter.prototype.on=EventEmitter.prototype.addListener,EventEmitter.prototype.prependListener=function prependListener(s,i){return _addListener(this,s,i,!0)},EventEmitter.prototype.once=function once(s,i){return checkListener(i),this.on(s,_onceWrap(this,s,i)),this},EventEmitter.prototype.prependOnceListener=function prependOnceListener(s,i){return checkListener(i),this.prependListener(s,_onceWrap(this,s,i)),this},EventEmitter.prototype.removeListener=function removeListener(s,i){var u,_,w,x,j;if(checkListener(i),void 0===(_=this._events))return this;if(void 0===(u=_[s]))return this;if(u===i||u.listener===i)0==--this._eventsCount?this._events=Object.create(null):(delete _[s],_.removeListener&&this.emit("removeListener",s,u.listener||i));else if("function"!=typeof u){for(w=-1,x=u.length-1;x>=0;x--)if(u[x]===i||u[x].listener===i){j=u[x].listener,w=x;break}if(w<0)return this;0===w?u.shift():function spliceOne(s,i){for(;i+1=0;_--)this.removeListener(s,i[_]);return this},EventEmitter.prototype.listeners=function listeners(s){return _listeners(this,s,!0)},EventEmitter.prototype.rawListeners=function rawListeners(s){return _listeners(this,s,!1)},EventEmitter.listenerCount=function(s,i){return"function"==typeof s.listenerCount?s.listenerCount(i):listenerCount.call(s,i)},EventEmitter.prototype.listenerCount=listenerCount,EventEmitter.prototype.eventNames=function eventNames(){return this._eventsCount>0?i(this._events):[]}},85587:(s,i,u)=>{"use strict";var _=u(26311),w=create(Error);function create(s){return FormattedError.displayName=s.displayName||s.name,FormattedError;function FormattedError(i){return i&&(i=_.apply(null,arguments)),new s(i)}}s.exports=w,w.eval=create(EvalError),w.range=create(RangeError),w.reference=create(ReferenceError),w.syntax=create(SyntaxError),w.type=create(TypeError),w.uri=create(URIError),w.create=create},26311:s=>{!function(){var i;function format(s){for(var i,u,_,w,x=1,j=[].slice.call(arguments),L=0,B=s.length,$="",U=!1,Y=!1,nextArg=function(){return j[x++]},slurpNumber=function(){for(var u="";/\d/.test(s[L]);)u+=s[L++],i=s[L];return u.length>0?parseInt(u):null};L{"use strict";var i=Object.prototype.toString,u=Math.max,_=function concatty(s,i){for(var u=[],_=0;_{"use strict";var _=u(89353);s.exports=Function.prototype.bind||_},70453:(s,i,u)=>{"use strict";var _,w=u(69383),x=u(41237),j=u(79290),L=u(79538),B=u(58068),$=u(69675),U=u(35345),Y=Function,getEvalledConstructor=function(s){try{return Y('"use strict"; return ('+s+").constructor;")()}catch(s){}},Z=Object.getOwnPropertyDescriptor;if(Z)try{Z({},"")}catch(s){Z=null}var throwTypeError=function(){throw new $},ee=Z?function(){try{return throwTypeError}catch(s){try{return Z(arguments,"callee").get}catch(s){return throwTypeError}}}():throwTypeError,ie=u(64039)(),ae=u(80024)(),le=Object.getPrototypeOf||(ae?function(s){return s.__proto__}:null),ce={},pe="undefined"!=typeof Uint8Array&&le?le(Uint8Array):_,de={__proto__:null,"%AggregateError%":"undefined"==typeof AggregateError?_:AggregateError,"%Array%":Array,"%ArrayBuffer%":"undefined"==typeof ArrayBuffer?_:ArrayBuffer,"%ArrayIteratorPrototype%":ie&&le?le([][Symbol.iterator]()):_,"%AsyncFromSyncIteratorPrototype%":_,"%AsyncFunction%":ce,"%AsyncGenerator%":ce,"%AsyncGeneratorFunction%":ce,"%AsyncIteratorPrototype%":ce,"%Atomics%":"undefined"==typeof Atomics?_:Atomics,"%BigInt%":"undefined"==typeof BigInt?_:BigInt,"%BigInt64Array%":"undefined"==typeof BigInt64Array?_:BigInt64Array,"%BigUint64Array%":"undefined"==typeof BigUint64Array?_:BigUint64Array,"%Boolean%":Boolean,"%DataView%":"undefined"==typeof DataView?_:DataView,"%Date%":Date,"%decodeURI%":decodeURI,"%decodeURIComponent%":decodeURIComponent,"%encodeURI%":encodeURI,"%encodeURIComponent%":encodeURIComponent,"%Error%":w,"%eval%":eval,"%EvalError%":x,"%Float32Array%":"undefined"==typeof Float32Array?_:Float32Array,"%Float64Array%":"undefined"==typeof Float64Array?_:Float64Array,"%FinalizationRegistry%":"undefined"==typeof FinalizationRegistry?_:FinalizationRegistry,"%Function%":Y,"%GeneratorFunction%":ce,"%Int8Array%":"undefined"==typeof Int8Array?_:Int8Array,"%Int16Array%":"undefined"==typeof Int16Array?_:Int16Array,"%Int32Array%":"undefined"==typeof Int32Array?_:Int32Array,"%isFinite%":isFinite,"%isNaN%":isNaN,"%IteratorPrototype%":ie&&le?le(le([][Symbol.iterator]())):_,"%JSON%":"object"==typeof JSON?JSON:_,"%Map%":"undefined"==typeof Map?_:Map,"%MapIteratorPrototype%":"undefined"!=typeof Map&&ie&&le?le((new Map)[Symbol.iterator]()):_,"%Math%":Math,"%Number%":Number,"%Object%":Object,"%parseFloat%":parseFloat,"%parseInt%":parseInt,"%Promise%":"undefined"==typeof Promise?_:Promise,"%Proxy%":"undefined"==typeof Proxy?_:Proxy,"%RangeError%":j,"%ReferenceError%":L,"%Reflect%":"undefined"==typeof Reflect?_:Reflect,"%RegExp%":RegExp,"%Set%":"undefined"==typeof Set?_:Set,"%SetIteratorPrototype%":"undefined"!=typeof Set&&ie&&le?le((new Set)[Symbol.iterator]()):_,"%SharedArrayBuffer%":"undefined"==typeof SharedArrayBuffer?_:SharedArrayBuffer,"%String%":String,"%StringIteratorPrototype%":ie&&le?le(""[Symbol.iterator]()):_,"%Symbol%":ie?Symbol:_,"%SyntaxError%":B,"%ThrowTypeError%":ee,"%TypedArray%":pe,"%TypeError%":$,"%Uint8Array%":"undefined"==typeof Uint8Array?_:Uint8Array,"%Uint8ClampedArray%":"undefined"==typeof Uint8ClampedArray?_:Uint8ClampedArray,"%Uint16Array%":"undefined"==typeof Uint16Array?_:Uint16Array,"%Uint32Array%":"undefined"==typeof Uint32Array?_:Uint32Array,"%URIError%":U,"%WeakMap%":"undefined"==typeof WeakMap?_:WeakMap,"%WeakRef%":"undefined"==typeof WeakRef?_:WeakRef,"%WeakSet%":"undefined"==typeof WeakSet?_:WeakSet};if(le)try{null.error}catch(s){var fe=le(le(s));de["%Error.prototype%"]=fe}var ye=function doEval(s){var i;if("%AsyncFunction%"===s)i=getEvalledConstructor("async function () {}");else if("%GeneratorFunction%"===s)i=getEvalledConstructor("function* () {}");else if("%AsyncGeneratorFunction%"===s)i=getEvalledConstructor("async function* () {}");else if("%AsyncGenerator%"===s){var u=doEval("%AsyncGeneratorFunction%");u&&(i=u.prototype)}else if("%AsyncIteratorPrototype%"===s){var _=doEval("%AsyncGenerator%");_&&le&&(i=le(_.prototype))}return de[s]=i,i},be={__proto__:null,"%ArrayBufferPrototype%":["ArrayBuffer","prototype"],"%ArrayPrototype%":["Array","prototype"],"%ArrayProto_entries%":["Array","prototype","entries"],"%ArrayProto_forEach%":["Array","prototype","forEach"],"%ArrayProto_keys%":["Array","prototype","keys"],"%ArrayProto_values%":["Array","prototype","values"],"%AsyncFunctionPrototype%":["AsyncFunction","prototype"],"%AsyncGenerator%":["AsyncGeneratorFunction","prototype"],"%AsyncGeneratorPrototype%":["AsyncGeneratorFunction","prototype","prototype"],"%BooleanPrototype%":["Boolean","prototype"],"%DataViewPrototype%":["DataView","prototype"],"%DatePrototype%":["Date","prototype"],"%ErrorPrototype%":["Error","prototype"],"%EvalErrorPrototype%":["EvalError","prototype"],"%Float32ArrayPrototype%":["Float32Array","prototype"],"%Float64ArrayPrototype%":["Float64Array","prototype"],"%FunctionPrototype%":["Function","prototype"],"%Generator%":["GeneratorFunction","prototype"],"%GeneratorPrototype%":["GeneratorFunction","prototype","prototype"],"%Int8ArrayPrototype%":["Int8Array","prototype"],"%Int16ArrayPrototype%":["Int16Array","prototype"],"%Int32ArrayPrototype%":["Int32Array","prototype"],"%JSONParse%":["JSON","parse"],"%JSONStringify%":["JSON","stringify"],"%MapPrototype%":["Map","prototype"],"%NumberPrototype%":["Number","prototype"],"%ObjectPrototype%":["Object","prototype"],"%ObjProto_toString%":["Object","prototype","toString"],"%ObjProto_valueOf%":["Object","prototype","valueOf"],"%PromisePrototype%":["Promise","prototype"],"%PromiseProto_then%":["Promise","prototype","then"],"%Promise_all%":["Promise","all"],"%Promise_reject%":["Promise","reject"],"%Promise_resolve%":["Promise","resolve"],"%RangeErrorPrototype%":["RangeError","prototype"],"%ReferenceErrorPrototype%":["ReferenceError","prototype"],"%RegExpPrototype%":["RegExp","prototype"],"%SetPrototype%":["Set","prototype"],"%SharedArrayBufferPrototype%":["SharedArrayBuffer","prototype"],"%StringPrototype%":["String","prototype"],"%SymbolPrototype%":["Symbol","prototype"],"%SyntaxErrorPrototype%":["SyntaxError","prototype"],"%TypedArrayPrototype%":["TypedArray","prototype"],"%TypeErrorPrototype%":["TypeError","prototype"],"%Uint8ArrayPrototype%":["Uint8Array","prototype"],"%Uint8ClampedArrayPrototype%":["Uint8ClampedArray","prototype"],"%Uint16ArrayPrototype%":["Uint16Array","prototype"],"%Uint32ArrayPrototype%":["Uint32Array","prototype"],"%URIErrorPrototype%":["URIError","prototype"],"%WeakMapPrototype%":["WeakMap","prototype"],"%WeakSetPrototype%":["WeakSet","prototype"]},_e=u(66743),we=u(9957),Se=_e.call(Function.call,Array.prototype.concat),xe=_e.call(Function.apply,Array.prototype.splice),Pe=_e.call(Function.call,String.prototype.replace),Te=_e.call(Function.call,String.prototype.slice),Re=_e.call(Function.call,RegExp.prototype.exec),qe=/[^%.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|%$))/g,$e=/\\(\\)?/g,ze=function getBaseIntrinsic(s,i){var u,_=s;if(we(be,_)&&(_="%"+(u=be[_])[0]+"%"),we(de,_)){var w=de[_];if(w===ce&&(w=ye(_)),void 0===w&&!i)throw new $("intrinsic "+s+" exists, but is not available. Please file an issue!");return{alias:u,name:_,value:w}}throw new B("intrinsic "+s+" does not exist!")};s.exports=function GetIntrinsic(s,i){if("string"!=typeof s||0===s.length)throw new $("intrinsic name must be a non-empty string");if(arguments.length>1&&"boolean"!=typeof i)throw new $('"allowMissing" argument must be a boolean');if(null===Re(/^%?[^%]*%?$/,s))throw new B("`%` may not be present anywhere but at the beginning and end of the intrinsic name");var u=function stringToPath(s){var i=Te(s,0,1),u=Te(s,-1);if("%"===i&&"%"!==u)throw new B("invalid intrinsic syntax, expected closing `%`");if("%"===u&&"%"!==i)throw new B("invalid intrinsic syntax, expected opening `%`");var _=[];return Pe(s,qe,(function(s,i,u,w){_[_.length]=u?Pe(w,$e,"$1"):i||s})),_}(s),_=u.length>0?u[0]:"",w=ze("%"+_+"%",i),x=w.name,j=w.value,L=!1,U=w.alias;U&&(_=U[0],xe(u,Se([0,1],U)));for(var Y=1,ee=!0;Y=u.length){var ce=Z(j,ie);j=(ee=!!ce)&&"get"in ce&&!("originalValue"in ce.get)?ce.get:j[ie]}else ee=we(j,ie),j=j[ie];ee&&!L&&(de[x]=j)}}return j}},75795:(s,i,u)=>{"use strict";var _=u(70453)("%Object.getOwnPropertyDescriptor%",!0);if(_)try{_([],"length")}catch(s){_=null}s.exports=_},30592:(s,i,u)=>{"use strict";var _=u(30655),w=function hasPropertyDescriptors(){return!!_};w.hasArrayLengthDefineBug=function hasArrayLengthDefineBug(){if(!_)return null;try{return 1!==_([],"length",{value:1}).length}catch(s){return!0}},s.exports=w},80024:s=>{"use strict";var i={__proto__:null,foo:{}},u=Object;s.exports=function hasProto(){return{__proto__:i}.foo===i.foo&&!(i instanceof u)}},64039:(s,i,u)=>{"use strict";var _="undefined"!=typeof Symbol&&Symbol,w=u(41333);s.exports=function hasNativeSymbols(){return"function"==typeof _&&("function"==typeof Symbol&&("symbol"==typeof _("foo")&&("symbol"==typeof Symbol("bar")&&w())))}},41333:s=>{"use strict";s.exports=function hasSymbols(){if("function"!=typeof Symbol||"function"!=typeof Object.getOwnPropertySymbols)return!1;if("symbol"==typeof Symbol.iterator)return!0;var s={},i=Symbol("test"),u=Object(i);if("string"==typeof i)return!1;if("[object Symbol]"!==Object.prototype.toString.call(i))return!1;if("[object Symbol]"!==Object.prototype.toString.call(u))return!1;for(i in s[i]=42,s)return!1;if("function"==typeof Object.keys&&0!==Object.keys(s).length)return!1;if("function"==typeof Object.getOwnPropertyNames&&0!==Object.getOwnPropertyNames(s).length)return!1;var _=Object.getOwnPropertySymbols(s);if(1!==_.length||_[0]!==i)return!1;if(!Object.prototype.propertyIsEnumerable.call(s,i))return!1;if("function"==typeof Object.getOwnPropertyDescriptor){var w=Object.getOwnPropertyDescriptor(s,i);if(42!==w.value||!0!==w.enumerable)return!1}return!0}},9957:(s,i,u)=>{"use strict";var _=Function.prototype.call,w=Object.prototype.hasOwnProperty,x=u(66743);s.exports=x.call(_,w)},45981:s=>{function deepFreeze(s){return s instanceof Map?s.clear=s.delete=s.set=function(){throw new Error("map is read-only")}:s instanceof Set&&(s.add=s.clear=s.delete=function(){throw new Error("set is read-only")}),Object.freeze(s),Object.getOwnPropertyNames(s).forEach((function(i){var u=s[i];"object"!=typeof u||Object.isFrozen(u)||deepFreeze(u)})),s}var i=deepFreeze,u=deepFreeze;i.default=u;class Response{constructor(s){void 0===s.data&&(s.data={}),this.data=s.data,this.isMatchIgnored=!1}ignoreMatch(){this.isMatchIgnored=!0}}function escapeHTML(s){return s.replace(/&/g,"&").replace(//g,">").replace(/"/g,""").replace(/'/g,"'")}function inherit(s,...i){const u=Object.create(null);for(const i in s)u[i]=s[i];return i.forEach((function(s){for(const i in s)u[i]=s[i]})),u}const emitsWrappingTags=s=>!!s.kind;class HTMLRenderer{constructor(s,i){this.buffer="",this.classPrefix=i.classPrefix,s.walk(this)}addText(s){this.buffer+=escapeHTML(s)}openNode(s){if(!emitsWrappingTags(s))return;let i=s.kind;s.sublanguage||(i=`${this.classPrefix}${i}`),this.span(i)}closeNode(s){emitsWrappingTags(s)&&(this.buffer+="")}value(){return this.buffer}span(s){this.buffer+=``}}class TokenTree{constructor(){this.rootNode={children:[]},this.stack=[this.rootNode]}get top(){return this.stack[this.stack.length-1]}get root(){return this.rootNode}add(s){this.top.children.push(s)}openNode(s){const i={kind:s,children:[]};this.add(i),this.stack.push(i)}closeNode(){if(this.stack.length>1)return this.stack.pop()}closeAllNodes(){for(;this.closeNode(););}toJSON(){return JSON.stringify(this.rootNode,null,4)}walk(s){return this.constructor._walk(s,this.rootNode)}static _walk(s,i){return"string"==typeof i?s.addText(i):i.children&&(s.openNode(i),i.children.forEach((i=>this._walk(s,i))),s.closeNode(i)),s}static _collapse(s){"string"!=typeof s&&s.children&&(s.children.every((s=>"string"==typeof s))?s.children=[s.children.join("")]:s.children.forEach((s=>{TokenTree._collapse(s)})))}}class TokenTreeEmitter extends TokenTree{constructor(s){super(),this.options=s}addKeyword(s,i){""!==s&&(this.openNode(i),this.addText(s),this.closeNode())}addText(s){""!==s&&this.add(s)}addSublanguage(s,i){const u=s.root;u.kind=i,u.sublanguage=!0,this.add(u)}toHTML(){return new HTMLRenderer(this,this.options).value()}finalize(){return!0}}function source(s){return s?"string"==typeof s?s:s.source:null}const _=/\[(?:[^\\\]]|\\.)*\]|\(\??|\\([1-9][0-9]*)|\\./;const w="[a-zA-Z]\\w*",x="[a-zA-Z_]\\w*",j="\\b\\d+(\\.\\d+)?",L="(-?)(\\b0[xX][a-fA-F0-9]+|(\\b\\d+(\\.\\d*)?|\\.\\d+)([eE][-+]?\\d+)?)",B="\\b(0b[01]+)",$={begin:"\\\\[\\s\\S]",relevance:0},U={className:"string",begin:"'",end:"'",illegal:"\\n",contains:[$]},Y={className:"string",begin:'"',end:'"',illegal:"\\n",contains:[$]},Z={begin:/\b(a|an|the|are|I'm|isn't|don't|doesn't|won't|but|just|should|pretty|simply|enough|gonna|going|wtf|so|such|will|you|your|they|like|more)\b/},COMMENT=function(s,i,u={}){const _=inherit({className:"comment",begin:s,end:i,contains:[]},u);return _.contains.push(Z),_.contains.push({className:"doctag",begin:"(?:TODO|FIXME|NOTE|BUG|OPTIMIZE|HACK|XXX):",relevance:0}),_},ee=COMMENT("//","$"),ie=COMMENT("/\\*","\\*/"),ae=COMMENT("#","$"),le={className:"number",begin:j,relevance:0},ce={className:"number",begin:L,relevance:0},pe={className:"number",begin:B,relevance:0},de={className:"number",begin:j+"(%|em|ex|ch|rem|vw|vh|vmin|vmax|cm|mm|in|pt|pc|px|deg|grad|rad|turn|s|ms|Hz|kHz|dpi|dpcm|dppx)?",relevance:0},fe={begin:/(?=\/[^/\n]*\/)/,contains:[{className:"regexp",begin:/\//,end:/\/[gimuy]*/,illegal:/\n/,contains:[$,{begin:/\[/,end:/\]/,relevance:0,contains:[$]}]}]},ye={className:"title",begin:w,relevance:0},be={className:"title",begin:x,relevance:0},_e={begin:"\\.\\s*"+x,relevance:0};var we=Object.freeze({__proto__:null,MATCH_NOTHING_RE:/\b\B/,IDENT_RE:w,UNDERSCORE_IDENT_RE:x,NUMBER_RE:j,C_NUMBER_RE:L,BINARY_NUMBER_RE:B,RE_STARTERS_RE:"!|!=|!==|%|%=|&|&&|&=|\\*|\\*=|\\+|\\+=|,|-|-=|/=|/|:|;|<<|<<=|<=|<|===|==|=|>>>=|>>=|>=|>>>|>>|>|\\?|\\[|\\{|\\(|\\^|\\^=|\\||\\|=|\\|\\||~",SHEBANG:(s={})=>{const i=/^#![ ]*\//;return s.binary&&(s.begin=function concat(...s){return s.map((s=>source(s))).join("")}(i,/.*\b/,s.binary,/\b.*/)),inherit({className:"meta",begin:i,end:/$/,relevance:0,"on:begin":(s,i)=>{0!==s.index&&i.ignoreMatch()}},s)},BACKSLASH_ESCAPE:$,APOS_STRING_MODE:U,QUOTE_STRING_MODE:Y,PHRASAL_WORDS_MODE:Z,COMMENT,C_LINE_COMMENT_MODE:ee,C_BLOCK_COMMENT_MODE:ie,HASH_COMMENT_MODE:ae,NUMBER_MODE:le,C_NUMBER_MODE:ce,BINARY_NUMBER_MODE:pe,CSS_NUMBER_MODE:de,REGEXP_MODE:fe,TITLE_MODE:ye,UNDERSCORE_TITLE_MODE:be,METHOD_GUARD:_e,END_SAME_AS_BEGIN:function(s){return Object.assign(s,{"on:begin":(s,i)=>{i.data._beginMatch=s[1]},"on:end":(s,i)=>{i.data._beginMatch!==s[1]&&i.ignoreMatch()}})}});function skipIfhasPrecedingDot(s,i){"."===s.input[s.index-1]&&i.ignoreMatch()}function beginKeywords(s,i){i&&s.beginKeywords&&(s.begin="\\b("+s.beginKeywords.split(" ").join("|")+")(?!\\.)(?=\\b|\\s)",s.__beforeBegin=skipIfhasPrecedingDot,s.keywords=s.keywords||s.beginKeywords,delete s.beginKeywords,void 0===s.relevance&&(s.relevance=0))}function compileIllegal(s,i){Array.isArray(s.illegal)&&(s.illegal=function either(...s){return"("+s.map((s=>source(s))).join("|")+")"}(...s.illegal))}function compileMatch(s,i){if(s.match){if(s.begin||s.end)throw new Error("begin & end are not supported with match");s.begin=s.match,delete s.match}}function compileRelevance(s,i){void 0===s.relevance&&(s.relevance=1)}const Se=["of","and","for","in","not","or","if","then","parent","list","value"],xe="keyword";function compileKeywords(s,i,u=xe){const _={};return"string"==typeof s?compileList(u,s.split(" ")):Array.isArray(s)?compileList(u,s):Object.keys(s).forEach((function(u){Object.assign(_,compileKeywords(s[u],i,u))})),_;function compileList(s,u){i&&(u=u.map((s=>s.toLowerCase()))),u.forEach((function(i){const u=i.split("|");_[u[0]]=[s,scoreForKeyword(u[0],u[1])]}))}}function scoreForKeyword(s,i){return i?Number(i):function commonKeyword(s){return Se.includes(s.toLowerCase())}(s)?0:1}function compileLanguage(s,{plugins:i}){function langRe(i,u){return new RegExp(source(i),"m"+(s.case_insensitive?"i":"")+(u?"g":""))}class MultiRegex{constructor(){this.matchIndexes={},this.regexes=[],this.matchAt=1,this.position=0}addRule(s,i){i.position=this.position++,this.matchIndexes[this.matchAt]=i,this.regexes.push([i,s]),this.matchAt+=function countMatchGroups(s){return new RegExp(s.toString()+"|").exec("").length-1}(s)+1}compile(){0===this.regexes.length&&(this.exec=()=>null);const s=this.regexes.map((s=>s[1]));this.matcherRe=langRe(function join(s,i="|"){let u=0;return s.map((s=>{u+=1;const i=u;let w=source(s),x="";for(;w.length>0;){const s=_.exec(w);if(!s){x+=w;break}x+=w.substring(0,s.index),w=w.substring(s.index+s[0].length),"\\"===s[0][0]&&s[1]?x+="\\"+String(Number(s[1])+i):(x+=s[0],"("===s[0]&&u++)}return x})).map((s=>`(${s})`)).join(i)}(s),!0),this.lastIndex=0}exec(s){this.matcherRe.lastIndex=this.lastIndex;const i=this.matcherRe.exec(s);if(!i)return null;const u=i.findIndex(((s,i)=>i>0&&void 0!==s)),_=this.matchIndexes[u];return i.splice(0,u),Object.assign(i,_)}}class ResumableMultiRegex{constructor(){this.rules=[],this.multiRegexes=[],this.count=0,this.lastIndex=0,this.regexIndex=0}getMatcher(s){if(this.multiRegexes[s])return this.multiRegexes[s];const i=new MultiRegex;return this.rules.slice(s).forEach((([s,u])=>i.addRule(s,u))),i.compile(),this.multiRegexes[s]=i,i}resumingScanAtSamePosition(){return 0!==this.regexIndex}considerAll(){this.regexIndex=0}addRule(s,i){this.rules.push([s,i]),"begin"===i.type&&this.count++}exec(s){const i=this.getMatcher(this.regexIndex);i.lastIndex=this.lastIndex;let u=i.exec(s);if(this.resumingScanAtSamePosition())if(u&&u.index===this.lastIndex);else{const i=this.getMatcher(0);i.lastIndex=this.lastIndex+1,u=i.exec(s)}return u&&(this.regexIndex+=u.position+1,this.regexIndex===this.count&&this.considerAll()),u}}if(s.compilerExtensions||(s.compilerExtensions=[]),s.contains&&s.contains.includes("self"))throw new Error("ERR: contains `self` is not supported at the top-level of a language. See documentation.");return s.classNameAliases=inherit(s.classNameAliases||{}),function compileMode(i,u){const _=i;if(i.isCompiled)return _;[compileMatch].forEach((s=>s(i,u))),s.compilerExtensions.forEach((s=>s(i,u))),i.__beforeBegin=null,[beginKeywords,compileIllegal,compileRelevance].forEach((s=>s(i,u))),i.isCompiled=!0;let w=null;if("object"==typeof i.keywords&&(w=i.keywords.$pattern,delete i.keywords.$pattern),i.keywords&&(i.keywords=compileKeywords(i.keywords,s.case_insensitive)),i.lexemes&&w)throw new Error("ERR: Prefer `keywords.$pattern` to `mode.lexemes`, BOTH are not allowed. (see mode reference) ");return w=w||i.lexemes||/\w+/,_.keywordPatternRe=langRe(w,!0),u&&(i.begin||(i.begin=/\B|\b/),_.beginRe=langRe(i.begin),i.endSameAsBegin&&(i.end=i.begin),i.end||i.endsWithParent||(i.end=/\B|\b/),i.end&&(_.endRe=langRe(i.end)),_.terminatorEnd=source(i.end)||"",i.endsWithParent&&u.terminatorEnd&&(_.terminatorEnd+=(i.end?"|":"")+u.terminatorEnd)),i.illegal&&(_.illegalRe=langRe(i.illegal)),i.contains||(i.contains=[]),i.contains=[].concat(...i.contains.map((function(s){return function expandOrCloneMode(s){s.variants&&!s.cachedVariants&&(s.cachedVariants=s.variants.map((function(i){return inherit(s,{variants:null},i)})));if(s.cachedVariants)return s.cachedVariants;if(dependencyOnParent(s))return inherit(s,{starts:s.starts?inherit(s.starts):null});if(Object.isFrozen(s))return inherit(s);return s}("self"===s?i:s)}))),i.contains.forEach((function(s){compileMode(s,_)})),i.starts&&compileMode(i.starts,u),_.matcher=function buildModeRegex(s){const i=new ResumableMultiRegex;return s.contains.forEach((s=>i.addRule(s.begin,{rule:s,type:"begin"}))),s.terminatorEnd&&i.addRule(s.terminatorEnd,{type:"end"}),s.illegal&&i.addRule(s.illegal,{type:"illegal"}),i}(_),_}(s)}function dependencyOnParent(s){return!!s&&(s.endsWithParent||dependencyOnParent(s.starts))}function BuildVuePlugin(s){const i={props:["language","code","autodetect"],data:function(){return{detectedLanguage:"",unknownLanguage:!1}},computed:{className(){return this.unknownLanguage?"":"hljs "+this.detectedLanguage},highlighted(){if(!this.autoDetect&&!s.getLanguage(this.language))return console.warn(`The language "${this.language}" you specified could not be found.`),this.unknownLanguage=!0,escapeHTML(this.code);let i={};return this.autoDetect?(i=s.highlightAuto(this.code),this.detectedLanguage=i.language):(i=s.highlight(this.language,this.code,this.ignoreIllegals),this.detectedLanguage=this.language),i.value},autoDetect(){return!this.language||function hasValueOrEmptyAttribute(s){return Boolean(s||""===s)}(this.autodetect)},ignoreIllegals:()=>!0},render(s){return s("pre",{},[s("code",{class:this.className,domProps:{innerHTML:this.highlighted}})])}};return{Component:i,VuePlugin:{install(s){s.component("highlightjs",i)}}}}const Pe={"after:highlightElement":({el:s,result:i,text:u})=>{const _=nodeStream(s);if(!_.length)return;const w=document.createElement("div");w.innerHTML=i.value,i.value=function mergeStreams(s,i,u){let _=0,w="";const x=[];function selectStream(){return s.length&&i.length?s[0].offset!==i[0].offset?s[0].offset"}function close(s){w+=""}function render(s){("start"===s.event?open:close)(s.node)}for(;s.length||i.length;){let i=selectStream();if(w+=escapeHTML(u.substring(_,i[0].offset)),_=i[0].offset,i===s){x.reverse().forEach(close);do{render(i.splice(0,1)[0]),i=selectStream()}while(i===s&&i.length&&i[0].offset===_);x.reverse().forEach(open)}else"start"===i[0].event?x.push(i[0].node):x.pop(),render(i.splice(0,1)[0])}return w+escapeHTML(u.substr(_))}(_,nodeStream(w),u)}};function tag(s){return s.nodeName.toLowerCase()}function nodeStream(s){const i=[];return function _nodeStream(s,u){for(let _=s.firstChild;_;_=_.nextSibling)3===_.nodeType?u+=_.nodeValue.length:1===_.nodeType&&(i.push({event:"start",offset:u,node:_}),u=_nodeStream(_,u),tag(_).match(/br|hr|img|input/)||i.push({event:"stop",offset:u,node:_}));return u}(s,0),i}const Te={},error=s=>{console.error(s)},warn=(s,...i)=>{console.log(`WARN: ${s}`,...i)},deprecated=(s,i)=>{Te[`${s}/${i}`]||(console.log(`Deprecated as of ${s}. ${i}`),Te[`${s}/${i}`]=!0)},Re=escapeHTML,qe=inherit,$e=Symbol("nomatch");var ze=function(s){const u=Object.create(null),_=Object.create(null),w=[];let x=!0;const j=/(^(<[^>]+>|\t|)+|\n)/gm,L="Could not find the language '{}', did you forget to load/include a language module?",B={disableAutodetect:!0,name:"Plain text",contains:[]};let $={noHighlightRe:/^(no-?highlight)$/i,languageDetectRe:/\blang(?:uage)?-([\w-]+)\b/i,classPrefix:"hljs-",tabReplace:null,useBR:!1,languages:null,__emitter:TokenTreeEmitter};function shouldNotHighlight(s){return $.noHighlightRe.test(s)}function highlight(s,i,u,_){let w="",x="";"object"==typeof i?(w=s,u=i.ignoreIllegals,x=i.language,_=void 0):(deprecated("10.7.0","highlight(lang, code, ...args) has been deprecated."),deprecated("10.7.0","Please use highlight(code, options) instead.\nhttps://github.com/highlightjs/highlight.js/issues/2277"),x=s,w=i);const j={code:w,language:x};fire("before:highlight",j);const L=j.result?j.result:_highlight(j.language,j.code,u,_);return L.code=j.code,fire("after:highlight",L),L}function _highlight(s,i,_,j){function keywordData(s,i){const u=U.case_insensitive?i[0].toLowerCase():i[0];return Object.prototype.hasOwnProperty.call(s.keywords,u)&&s.keywords[u]}function processBuffer(){null!=ee.subLanguage?function processSubLanguage(){if(""===le)return;let s=null;if("string"==typeof ee.subLanguage){if(!u[ee.subLanguage])return void ae.addText(le);s=_highlight(ee.subLanguage,le,!0,ie[ee.subLanguage]),ie[ee.subLanguage]=s.top}else s=highlightAuto(le,ee.subLanguage.length?ee.subLanguage:null);ee.relevance>0&&(ce+=s.relevance),ae.addSublanguage(s.emitter,s.language)}():function processKeywords(){if(!ee.keywords)return void ae.addText(le);let s=0;ee.keywordPatternRe.lastIndex=0;let i=ee.keywordPatternRe.exec(le),u="";for(;i;){u+=le.substring(s,i.index);const _=keywordData(ee,i);if(_){const[s,w]=_;if(ae.addText(u),u="",ce+=w,s.startsWith("_"))u+=i[0];else{const u=U.classNameAliases[s]||s;ae.addKeyword(i[0],u)}}else u+=i[0];s=ee.keywordPatternRe.lastIndex,i=ee.keywordPatternRe.exec(le)}u+=le.substr(s),ae.addText(u)}(),le=""}function startNewMode(s){return s.className&&ae.openNode(U.classNameAliases[s.className]||s.className),ee=Object.create(s,{parent:{value:ee}}),ee}function endOfMode(s,i,u){let _=function startsWith(s,i){const u=s&&s.exec(i);return u&&0===u.index}(s.endRe,u);if(_){if(s["on:end"]){const u=new Response(s);s["on:end"](i,u),u.isMatchIgnored&&(_=!1)}if(_){for(;s.endsParent&&s.parent;)s=s.parent;return s}}if(s.endsWithParent)return endOfMode(s.parent,i,u)}function doIgnore(s){return 0===ee.matcher.regexIndex?(le+=s[0],1):(fe=!0,0)}function doBeginMatch(s){const i=s[0],u=s.rule,_=new Response(u),w=[u.__beforeBegin,u["on:begin"]];for(const u of w)if(u&&(u(s,_),_.isMatchIgnored))return doIgnore(i);return u&&u.endSameAsBegin&&(u.endRe=function escape(s){return new RegExp(s.replace(/[-/\\^$*+?.()|[\]{}]/g,"\\$&"),"m")}(i)),u.skip?le+=i:(u.excludeBegin&&(le+=i),processBuffer(),u.returnBegin||u.excludeBegin||(le=i)),startNewMode(u),u.returnBegin?0:i.length}function doEndMatch(s){const u=s[0],_=i.substr(s.index),w=endOfMode(ee,s,_);if(!w)return $e;const x=ee;x.skip?le+=u:(x.returnEnd||x.excludeEnd||(le+=u),processBuffer(),x.excludeEnd&&(le=u));do{ee.className&&ae.closeNode(),ee.skip||ee.subLanguage||(ce+=ee.relevance),ee=ee.parent}while(ee!==w.parent);return w.starts&&(w.endSameAsBegin&&(w.starts.endRe=w.endRe),startNewMode(w.starts)),x.returnEnd?0:u.length}let B={};function processLexeme(u,w){const j=w&&w[0];if(le+=u,null==j)return processBuffer(),0;if("begin"===B.type&&"end"===w.type&&B.index===w.index&&""===j){if(le+=i.slice(w.index,w.index+1),!x){const i=new Error("0 width match regex");throw i.languageName=s,i.badRule=B.rule,i}return 1}if(B=w,"begin"===w.type)return doBeginMatch(w);if("illegal"===w.type&&!_){const s=new Error('Illegal lexeme "'+j+'" for mode "'+(ee.className||"")+'"');throw s.mode=ee,s}if("end"===w.type){const s=doEndMatch(w);if(s!==$e)return s}if("illegal"===w.type&&""===j)return 1;if(de>1e5&&de>3*w.index){throw new Error("potential infinite loop, way more iterations than matches")}return le+=j,j.length}const U=getLanguage(s);if(!U)throw error(L.replace("{}",s)),new Error('Unknown language: "'+s+'"');const Y=compileLanguage(U,{plugins:w});let Z="",ee=j||Y;const ie={},ae=new $.__emitter($);!function processContinuations(){const s=[];for(let i=ee;i!==U;i=i.parent)i.className&&s.unshift(i.className);s.forEach((s=>ae.openNode(s)))}();let le="",ce=0,pe=0,de=0,fe=!1;try{for(ee.matcher.considerAll();;){de++,fe?fe=!1:ee.matcher.considerAll(),ee.matcher.lastIndex=pe;const s=ee.matcher.exec(i);if(!s)break;const u=processLexeme(i.substring(pe,s.index),s);pe=s.index+u}return processLexeme(i.substr(pe)),ae.closeAllNodes(),ae.finalize(),Z=ae.toHTML(),{relevance:Math.floor(ce),value:Z,language:s,illegal:!1,emitter:ae,top:ee}}catch(u){if(u.message&&u.message.includes("Illegal"))return{illegal:!0,illegalBy:{msg:u.message,context:i.slice(pe-100,pe+100),mode:u.mode},sofar:Z,relevance:0,value:Re(i),emitter:ae};if(x)return{illegal:!1,relevance:0,value:Re(i),emitter:ae,language:s,top:ee,errorRaised:u};throw u}}function highlightAuto(s,i){i=i||$.languages||Object.keys(u);const _=function justTextHighlightResult(s){const i={relevance:0,emitter:new $.__emitter($),value:Re(s),illegal:!1,top:B};return i.emitter.addText(s),i}(s),w=i.filter(getLanguage).filter(autoDetection).map((i=>_highlight(i,s,!1)));w.unshift(_);const x=w.sort(((s,i)=>{if(s.relevance!==i.relevance)return i.relevance-s.relevance;if(s.language&&i.language){if(getLanguage(s.language).supersetOf===i.language)return 1;if(getLanguage(i.language).supersetOf===s.language)return-1}return 0})),[j,L]=x,U=j;return U.second_best=L,U}const U={"before:highlightElement":({el:s})=>{$.useBR&&(s.innerHTML=s.innerHTML.replace(/\n/g,"").replace(//g,"\n"))},"after:highlightElement":({result:s})=>{$.useBR&&(s.value=s.value.replace(/\n/g,"
"))}},Y=/^(<[^>]+>|\t)+/gm,Z={"after:highlightElement":({result:s})=>{$.tabReplace&&(s.value=s.value.replace(Y,(s=>s.replace(/\t/g,$.tabReplace))))}};function highlightElement(s){let i=null;const u=function blockLanguage(s){let i=s.className+" ";i+=s.parentNode?s.parentNode.className:"";const u=$.languageDetectRe.exec(i);if(u){const i=getLanguage(u[1]);return i||(warn(L.replace("{}",u[1])),warn("Falling back to no-highlight mode for this block.",s)),i?u[1]:"no-highlight"}return i.split(/\s+/).find((s=>shouldNotHighlight(s)||getLanguage(s)))}(s);if(shouldNotHighlight(u))return;fire("before:highlightElement",{el:s,language:u}),i=s;const w=i.textContent,x=u?highlight(w,{language:u,ignoreIllegals:!0}):highlightAuto(w);fire("after:highlightElement",{el:s,result:x,text:w}),s.innerHTML=x.value,function updateClassName(s,i,u){const w=i?_[i]:u;s.classList.add("hljs"),w&&s.classList.add(w)}(s,u,x.language),s.result={language:x.language,re:x.relevance,relavance:x.relevance},x.second_best&&(s.second_best={language:x.second_best.language,re:x.second_best.relevance,relavance:x.second_best.relevance})}const initHighlighting=()=>{if(initHighlighting.called)return;initHighlighting.called=!0,deprecated("10.6.0","initHighlighting() is deprecated. Use highlightAll() instead.");document.querySelectorAll("pre code").forEach(highlightElement)};let ee=!1;function highlightAll(){if("loading"===document.readyState)return void(ee=!0);document.querySelectorAll("pre code").forEach(highlightElement)}function getLanguage(s){return s=(s||"").toLowerCase(),u[s]||u[_[s]]}function registerAliases(s,{languageName:i}){"string"==typeof s&&(s=[s]),s.forEach((s=>{_[s.toLowerCase()]=i}))}function autoDetection(s){const i=getLanguage(s);return i&&!i.disableAutodetect}function fire(s,i){const u=s;w.forEach((function(s){s[u]&&s[u](i)}))}"undefined"!=typeof window&&window.addEventListener&&window.addEventListener("DOMContentLoaded",(function boot(){ee&&highlightAll()}),!1),Object.assign(s,{highlight,highlightAuto,highlightAll,fixMarkup:function deprecateFixMarkup(s){return deprecated("10.2.0","fixMarkup will be removed entirely in v11.0"),deprecated("10.2.0","Please see https://github.com/highlightjs/highlight.js/issues/2534"),function fixMarkup(s){return $.tabReplace||$.useBR?s.replace(j,(s=>"\n"===s?$.useBR?"
":s:$.tabReplace?s.replace(/\t/g,$.tabReplace):s)):s}(s)},highlightElement,highlightBlock:function deprecateHighlightBlock(s){return deprecated("10.7.0","highlightBlock will be removed entirely in v12.0"),deprecated("10.7.0","Please use highlightElement now."),highlightElement(s)},configure:function configure(s){s.useBR&&(deprecated("10.3.0","'useBR' will be removed entirely in v11.0"),deprecated("10.3.0","Please see https://github.com/highlightjs/highlight.js/issues/2559")),$=qe($,s)},initHighlighting,initHighlightingOnLoad:function initHighlightingOnLoad(){deprecated("10.6.0","initHighlightingOnLoad() is deprecated. Use highlightAll() instead."),ee=!0},registerLanguage:function registerLanguage(i,_){let w=null;try{w=_(s)}catch(s){if(error("Language definition for '{}' could not be registered.".replace("{}",i)),!x)throw s;error(s),w=B}w.name||(w.name=i),u[i]=w,w.rawDefinition=_.bind(null,s),w.aliases&®isterAliases(w.aliases,{languageName:i})},unregisterLanguage:function unregisterLanguage(s){delete u[s];for(const i of Object.keys(_))_[i]===s&&delete _[i]},listLanguages:function listLanguages(){return Object.keys(u)},getLanguage,registerAliases,requireLanguage:function requireLanguage(s){deprecated("10.4.0","requireLanguage will be removed entirely in v11."),deprecated("10.4.0","Please see https://github.com/highlightjs/highlight.js/pull/2844");const i=getLanguage(s);if(i)return i;throw new Error("The '{}' language is required, but not loaded.".replace("{}",s))},autoDetection,inherit:qe,addPlugin:function addPlugin(s){!function upgradePluginAPI(s){s["before:highlightBlock"]&&!s["before:highlightElement"]&&(s["before:highlightElement"]=i=>{s["before:highlightBlock"](Object.assign({block:i.el},i))}),s["after:highlightBlock"]&&!s["after:highlightElement"]&&(s["after:highlightElement"]=i=>{s["after:highlightBlock"](Object.assign({block:i.el},i))})}(s),w.push(s)},vuePlugin:BuildVuePlugin(s).VuePlugin}),s.debugMode=function(){x=!1},s.safeMode=function(){x=!0},s.versionString="10.7.3";for(const s in we)"object"==typeof we[s]&&i(we[s]);return Object.assign(s,we),s.addPlugin(U),s.addPlugin(Pe),s.addPlugin(Z),s}({});s.exports=ze},35344:s=>{function concat(...s){return s.map((s=>function source(s){return s?"string"==typeof s?s:s.source:null}(s))).join("")}s.exports=function bash(s){const i={},u={begin:/\$\{/,end:/\}/,contains:["self",{begin:/:-/,contains:[i]}]};Object.assign(i,{className:"variable",variants:[{begin:concat(/\$[\w\d#@][\w\d_]*/,"(?![\\w\\d])(?![$])")},u]});const _={className:"subst",begin:/\$\(/,end:/\)/,contains:[s.BACKSLASH_ESCAPE]},w={begin:/<<-?\s*(?=\w+)/,starts:{contains:[s.END_SAME_AS_BEGIN({begin:/(\w+)/,end:/(\w+)/,className:"string"})]}},x={className:"string",begin:/"/,end:/"/,contains:[s.BACKSLASH_ESCAPE,i,_]};_.contains.push(x);const j={begin:/\$\(\(/,end:/\)\)/,contains:[{begin:/\d+#[0-9a-f]+/,className:"number"},s.NUMBER_MODE,i]},L=s.SHEBANG({binary:`(${["fish","bash","zsh","sh","csh","ksh","tcsh","dash","scsh"].join("|")})`,relevance:10}),B={className:"function",begin:/\w[\w\d_]*\s*\(\s*\)\s*\{/,returnBegin:!0,contains:[s.inherit(s.TITLE_MODE,{begin:/\w[\w\d_]*/})],relevance:0};return{name:"Bash",aliases:["sh","zsh"],keywords:{$pattern:/\b[a-z._-]+\b/,keyword:"if then else elif fi for while in do done case esac function",literal:"true false",built_in:"break cd continue eval exec exit export getopts hash pwd readonly return shift test times trap umask unset alias bind builtin caller command declare echo enable help let local logout mapfile printf read readarray source type typeset ulimit unalias set shopt autoload bg bindkey bye cap chdir clone comparguments compcall compctl compdescribe compfiles compgroups compquote comptags comptry compvalues dirs disable disown echotc echoti emulate fc fg float functions getcap getln history integer jobs kill limit log noglob popd print pushd pushln rehash sched setcap setopt stat suspend ttyctl unfunction unhash unlimit unsetopt vared wait whence where which zcompile zformat zftp zle zmodload zparseopts zprof zpty zregexparse zsocket zstyle ztcp"},contains:[L,s.SHEBANG(),B,j,s.HASH_COMMENT_MODE,w,x,{className:"",begin:/\\"/},{className:"string",begin:/'/,end:/'/},i]}}},73402:s=>{function concat(...s){return s.map((s=>function source(s){return s?"string"==typeof s?s:s.source:null}(s))).join("")}s.exports=function http(s){const i="HTTP/(2|1\\.[01])",u={className:"attribute",begin:concat("^",/[A-Za-z][A-Za-z0-9-]*/,"(?=\\:\\s)"),starts:{contains:[{className:"punctuation",begin:/: /,relevance:0,starts:{end:"$",relevance:0}}]}},_=[u,{begin:"\\n\\n",starts:{subLanguage:[],endsWithParent:!0}}];return{name:"HTTP",aliases:["https"],illegal:/\S/,contains:[{begin:"^(?="+i+" \\d{3})",end:/$/,contains:[{className:"meta",begin:i},{className:"number",begin:"\\b\\d{3}\\b"}],starts:{end:/\b\B/,illegal:/\S/,contains:_}},{begin:"(?=^[A-Z]+ (.*?) "+i+"$)",end:/$/,contains:[{className:"string",begin:" ",end:" ",excludeBegin:!0,excludeEnd:!0},{className:"meta",begin:i},{className:"keyword",begin:"[A-Z]+"}],starts:{end:/\b\B/,illegal:/\S/,contains:_}},s.inherit(u,{relevance:0})]}}},95089:s=>{const i="[A-Za-z$_][0-9A-Za-z$_]*",u=["as","in","of","if","for","while","finally","var","new","function","do","return","void","else","break","catch","instanceof","with","throw","case","default","try","switch","continue","typeof","delete","let","yield","const","class","debugger","async","await","static","import","from","export","extends"],_=["true","false","null","undefined","NaN","Infinity"],w=[].concat(["setInterval","setTimeout","clearInterval","clearTimeout","require","exports","eval","isFinite","isNaN","parseFloat","parseInt","decodeURI","decodeURIComponent","encodeURI","encodeURIComponent","escape","unescape"],["arguments","this","super","console","window","document","localStorage","module","global"],["Intl","DataView","Number","Math","Date","String","RegExp","Object","Function","Boolean","Error","Symbol","Set","Map","WeakSet","WeakMap","Proxy","Reflect","JSON","Promise","Float64Array","Int16Array","Int32Array","Int8Array","Uint16Array","Uint32Array","Float32Array","Array","Uint8Array","Uint8ClampedArray","ArrayBuffer","BigInt64Array","BigUint64Array","BigInt"],["EvalError","InternalError","RangeError","ReferenceError","SyntaxError","TypeError","URIError"]);function lookahead(s){return concat("(?=",s,")")}function concat(...s){return s.map((s=>function source(s){return s?"string"==typeof s?s:s.source:null}(s))).join("")}s.exports=function javascript(s){const x=i,j="<>",L="",B={begin:/<[A-Za-z0-9\\._:-]+/,end:/\/[A-Za-z0-9\\._:-]+>|\/>/,isTrulyOpeningTag:(s,i)=>{const u=s[0].length+s.index,_=s.input[u];"<"!==_?">"===_&&(((s,{after:i})=>{const u="",returnBegin:!0,end:"\\s*=>",contains:[{className:"params",variants:[{begin:s.UNDERSCORE_IDENT_RE,relevance:0},{className:null,begin:/\(\s*\)/,skip:!0},{begin:/\(/,end:/\)/,excludeBegin:!0,excludeEnd:!0,keywords:$,contains:ye}]}]},{begin:/,/,relevance:0},{className:"",begin:/\s/,end:/\s*/,skip:!0},{variants:[{begin:j,end:L},{begin:B.begin,"on:begin":B.isTrulyOpeningTag,end:B.end}],subLanguage:"xml",contains:[{begin:B.begin,end:B.end,skip:!0,contains:["self"]}]}],relevance:0},{className:"function",beginKeywords:"function",end:/[{;]/,excludeEnd:!0,keywords:$,contains:["self",s.inherit(s.TITLE_MODE,{begin:x}),be],illegal:/%/},{beginKeywords:"while if switch catch for"},{className:"function",begin:s.UNDERSCORE_IDENT_RE+"\\([^()]*(\\([^()]*(\\([^()]*\\)[^()]*)*\\)[^()]*)*\\)\\s*\\{",returnBegin:!0,contains:[be,s.inherit(s.TITLE_MODE,{begin:x})]},{variants:[{begin:"\\."+x},{begin:"\\$"+x}],relevance:0},{className:"class",beginKeywords:"class",end:/[{;=]/,excludeEnd:!0,illegal:/[:"[\]]/,contains:[{beginKeywords:"extends"},s.UNDERSCORE_TITLE_MODE]},{begin:/\b(?=constructor)/,end:/[{;]/,excludeEnd:!0,contains:[s.inherit(s.TITLE_MODE,{begin:x}),"self",be]},{begin:"(get|set)\\s+(?="+x+"\\()",end:/\{/,keywords:"get set",contains:[s.inherit(s.TITLE_MODE,{begin:x}),{begin:/\(\)/},be]},{begin:/\$[(.]/}]}}},65772:s=>{s.exports=function json(s){const i={literal:"true false null"},u=[s.C_LINE_COMMENT_MODE,s.C_BLOCK_COMMENT_MODE],_=[s.QUOTE_STRING_MODE,s.C_NUMBER_MODE],w={end:",",endsWithParent:!0,excludeEnd:!0,contains:_,keywords:i},x={begin:/\{/,end:/\}/,contains:[{className:"attr",begin:/"/,end:/"/,contains:[s.BACKSLASH_ESCAPE],illegal:"\\n"},s.inherit(w,{begin:/:/})].concat(u),illegal:"\\S"},j={begin:"\\[",end:"\\]",contains:[s.inherit(w)],illegal:"\\S"};return _.push(x,j),u.forEach((function(s){_.push(s)})),{name:"JSON",contains:_,keywords:i,illegal:"\\S"}}},26571:s=>{s.exports=function powershell(s){const i={$pattern:/-?[A-z\.\-]+\b/,keyword:"if else foreach return do while until elseif begin for trap data dynamicparam end break throw param continue finally in switch exit filter try process catch hidden static parameter",built_in:"ac asnp cat cd CFS chdir clc clear clhy cli clp cls clv cnsn compare copy cp cpi cpp curl cvpa dbp del diff dir dnsn ebp echo|0 epal epcsv epsn erase etsn exsn fc fhx fl ft fw gal gbp gc gcb gci gcm gcs gdr gerr ghy gi gin gjb gl gm gmo gp gps gpv group gsn gsnp gsv gtz gu gv gwmi h history icm iex ihy ii ipal ipcsv ipmo ipsn irm ise iwmi iwr kill lp ls man md measure mi mount move mp mv nal ndr ni nmo npssc nsn nv ogv oh popd ps pushd pwd r rbp rcjb rcsn rd rdr ren ri rjb rm rmdir rmo rni rnp rp rsn rsnp rujb rv rvpa rwmi sajb sal saps sasv sbp sc scb select set shcm si sl sleep sls sort sp spjb spps spsv start stz sujb sv swmi tee trcm type wget where wjb write"},u={begin:"`[\\s\\S]",relevance:0},_={className:"variable",variants:[{begin:/\$\B/},{className:"keyword",begin:/\$this/},{begin:/\$[\w\d][\w\d_:]*/}]},w={className:"string",variants:[{begin:/"/,end:/"/},{begin:/@"/,end:/^"@/}],contains:[u,_,{className:"variable",begin:/\$[A-z]/,end:/[^A-z]/}]},x={className:"string",variants:[{begin:/'/,end:/'/},{begin:/@'/,end:/^'@/}]},j=s.inherit(s.COMMENT(null,null),{variants:[{begin:/#/,end:/$/},{begin:/<#/,end:/#>/}],contains:[{className:"doctag",variants:[{begin:/\.(synopsis|description|example|inputs|outputs|notes|link|component|role|functionality)/},{begin:/\.(parameter|forwardhelptargetname|forwardhelpcategory|remotehelprunspace|externalhelp)\s+\S+/}]}]}),L={className:"built_in",variants:[{begin:"(".concat("Add|Clear|Close|Copy|Enter|Exit|Find|Format|Get|Hide|Join|Lock|Move|New|Open|Optimize|Pop|Push|Redo|Remove|Rename|Reset|Resize|Search|Select|Set|Show|Skip|Split|Step|Switch|Undo|Unlock|Watch|Backup|Checkpoint|Compare|Compress|Convert|ConvertFrom|ConvertTo|Dismount|Edit|Expand|Export|Group|Import|Initialize|Limit|Merge|Mount|Out|Publish|Restore|Save|Sync|Unpublish|Update|Approve|Assert|Build|Complete|Confirm|Deny|Deploy|Disable|Enable|Install|Invoke|Register|Request|Restart|Resume|Start|Stop|Submit|Suspend|Uninstall|Unregister|Wait|Debug|Measure|Ping|Repair|Resolve|Test|Trace|Connect|Disconnect|Read|Receive|Send|Write|Block|Grant|Protect|Revoke|Unblock|Unprotect|Use|ForEach|Sort|Tee|Where",")+(-)[\\w\\d]+")}]},B={className:"class",beginKeywords:"class enum",end:/\s*[{]/,excludeEnd:!0,relevance:0,contains:[s.TITLE_MODE]},$={className:"function",begin:/function\s+/,end:/\s*\{|$/,excludeEnd:!0,returnBegin:!0,relevance:0,contains:[{begin:"function",relevance:0,className:"keyword"},{className:"title",begin:/\w[\w\d]*((-)[\w\d]+)*/,relevance:0},{begin:/\(/,end:/\)/,className:"params",relevance:0,contains:[_]}]},U={begin:/using\s/,end:/$/,returnBegin:!0,contains:[w,x,{className:"keyword",begin:/(using|assembly|command|module|namespace|type)/}]},Y={variants:[{className:"operator",begin:"(".concat("-and|-as|-band|-bnot|-bor|-bxor|-casesensitive|-ccontains|-ceq|-cge|-cgt|-cle|-clike|-clt|-cmatch|-cne|-cnotcontains|-cnotlike|-cnotmatch|-contains|-creplace|-csplit|-eq|-exact|-f|-file|-ge|-gt|-icontains|-ieq|-ige|-igt|-ile|-ilike|-ilt|-imatch|-in|-ine|-inotcontains|-inotlike|-inotmatch|-ireplace|-is|-isnot|-isplit|-join|-le|-like|-lt|-match|-ne|-not|-notcontains|-notin|-notlike|-notmatch|-or|-regex|-replace|-shl|-shr|-split|-wildcard|-xor",")\\b")},{className:"literal",begin:/(-)[\w\d]+/,relevance:0}]},Z={className:"function",begin:/\[.*\]\s*[\w]+[ ]??\(/,end:/$/,returnBegin:!0,relevance:0,contains:[{className:"keyword",begin:"(".concat(i.keyword.toString().replace(/\s/g,"|"),")\\b"),endsParent:!0,relevance:0},s.inherit(s.TITLE_MODE,{endsParent:!0})]},ee=[Z,j,u,s.NUMBER_MODE,w,x,L,_,{className:"literal",begin:/\$(null|true|false)\b/},{className:"selector-tag",begin:/@\B/,relevance:0}],ie={begin:/\[/,end:/\]/,excludeBegin:!0,excludeEnd:!0,relevance:0,contains:[].concat("self",ee,{begin:"("+["string","char","byte","int","long","bool","decimal","single","double","DateTime","xml","array","hashtable","void"].join("|")+")",className:"built_in",relevance:0},{className:"type",begin:/[\.\w\d]+/,relevance:0})};return Z.contains.unshift(ie),{name:"PowerShell",aliases:["ps","ps1"],case_insensitive:!0,keywords:i,contains:ee.concat(B,$,U,Y,ie)}}},17285:s=>{function source(s){return s?"string"==typeof s?s:s.source:null}function lookahead(s){return concat("(?=",s,")")}function concat(...s){return s.map((s=>source(s))).join("")}function either(...s){return"("+s.map((s=>source(s))).join("|")+")"}s.exports=function xml(s){const i=concat(/[A-Z_]/,function optional(s){return concat("(",s,")?")}(/[A-Z0-9_.-]*:/),/[A-Z0-9_.-]*/),u={className:"symbol",begin:/&[a-z]+;|&#[0-9]+;|&#x[a-f0-9]+;/},_={begin:/\s/,contains:[{className:"meta-keyword",begin:/#?[a-z_][a-z1-9_-]+/,illegal:/\n/}]},w=s.inherit(_,{begin:/\(/,end:/\)/}),x=s.inherit(s.APOS_STRING_MODE,{className:"meta-string"}),j=s.inherit(s.QUOTE_STRING_MODE,{className:"meta-string"}),L={endsWithParent:!0,illegal:/`]+/}]}]}]};return{name:"HTML, XML",aliases:["html","xhtml","rss","atom","xjb","xsd","xsl","plist","wsf","svg"],case_insensitive:!0,contains:[{className:"meta",begin://,relevance:10,contains:[_,j,x,w,{begin:/\[/,end:/\]/,contains:[{className:"meta",begin://,contains:[_,w,j,x]}]}]},s.COMMENT(//,{relevance:10}),{begin://,relevance:10},u,{className:"meta",begin:/<\?xml/,end:/\?>/,relevance:10},{className:"tag",begin:/)/,end:/>/,keywords:{name:"style"},contains:[L],starts:{end:/<\/style>/,returnEnd:!0,subLanguage:["css","xml"]}},{className:"tag",begin:/)/,end:/>/,keywords:{name:"script"},contains:[L],starts:{end:/<\/script>/,returnEnd:!0,subLanguage:["javascript","handlebars","xml"]}},{className:"tag",begin:/<>|<\/>/},{className:"tag",begin:concat(//,/>/,/\s/)))),end:/\/?>/,contains:[{className:"name",begin:i,relevance:0,starts:L}]},{className:"tag",begin:concat(/<\//,lookahead(concat(i,/>/))),contains:[{className:"name",begin:i,relevance:0},{begin:/>/,relevance:0,endsParent:!0}]}]}}},17533:s=>{s.exports=function yaml(s){var i="true false yes no null",u="[\\w#;/?:@&=+$,.~*'()[\\]]+",_={className:"string",relevance:0,variants:[{begin:/'/,end:/'/},{begin:/"/,end:/"/},{begin:/\S+/}],contains:[s.BACKSLASH_ESCAPE,{className:"template-variable",variants:[{begin:/\{\{/,end:/\}\}/},{begin:/%\{/,end:/\}/}]}]},w=s.inherit(_,{variants:[{begin:/'/,end:/'/},{begin:/"/,end:/"/},{begin:/[^\s,{}[\]]+/}]}),x={className:"number",begin:"\\b[0-9]{4}(-[0-9][0-9]){0,2}([Tt \\t][0-9][0-9]?(:[0-9][0-9]){2})?(\\.[0-9]*)?([ \\t])*(Z|[-+][0-9][0-9]?(:[0-9][0-9])?)?\\b"},j={end:",",endsWithParent:!0,excludeEnd:!0,keywords:i,relevance:0},L={begin:/\{/,end:/\}/,contains:[j],illegal:"\\n",relevance:0},B={begin:"\\[",end:"\\]",contains:[j],illegal:"\\n",relevance:0},$=[{className:"attr",variants:[{begin:"\\w[\\w :\\/.-]*:(?=[ \t]|$)"},{begin:'"\\w[\\w :\\/.-]*":(?=[ \t]|$)'},{begin:"'\\w[\\w :\\/.-]*':(?=[ \t]|$)"}]},{className:"meta",begin:"^---\\s*$",relevance:10},{className:"string",begin:"[\\|>]([1-9]?[+-])?[ ]*\\n( +)[^ ][^\\n]*\\n(\\2[^\\n]+\\n?)*"},{begin:"<%[%=-]?",end:"[%-]?%>",subLanguage:"ruby",excludeBegin:!0,excludeEnd:!0,relevance:0},{className:"type",begin:"!\\w+!"+u},{className:"type",begin:"!<"+u+">"},{className:"type",begin:"!"+u},{className:"type",begin:"!!"+u},{className:"meta",begin:"&"+s.UNDERSCORE_IDENT_RE+"$"},{className:"meta",begin:"\\*"+s.UNDERSCORE_IDENT_RE+"$"},{className:"bullet",begin:"-(?=[ ]|$)",relevance:0},s.HASH_COMMENT_MODE,{beginKeywords:i,keywords:{literal:i}},x,{className:"number",begin:s.C_NUMBER_RE+"\\b",relevance:0},L,B,_],U=[...$];return U.pop(),U.push(w),j.contains=U,{name:"YAML",case_insensitive:!0,aliases:["yml"],contains:$}}},251:(s,i)=>{i.read=function(s,i,u,_,w){var x,j,L=8*w-_-1,B=(1<>1,U=-7,Y=u?w-1:0,Z=u?-1:1,ee=s[i+Y];for(Y+=Z,x=ee&(1<<-U)-1,ee>>=-U,U+=L;U>0;x=256*x+s[i+Y],Y+=Z,U-=8);for(j=x&(1<<-U)-1,x>>=-U,U+=_;U>0;j=256*j+s[i+Y],Y+=Z,U-=8);if(0===x)x=1-$;else{if(x===B)return j?NaN:1/0*(ee?-1:1);j+=Math.pow(2,_),x-=$}return(ee?-1:1)*j*Math.pow(2,x-_)},i.write=function(s,i,u,_,w,x){var j,L,B,$=8*x-w-1,U=(1<<$)-1,Y=U>>1,Z=23===w?Math.pow(2,-24)-Math.pow(2,-77):0,ee=_?0:x-1,ie=_?1:-1,ae=i<0||0===i&&1/i<0?1:0;for(i=Math.abs(i),isNaN(i)||i===1/0?(L=isNaN(i)?1:0,j=U):(j=Math.floor(Math.log(i)/Math.LN2),i*(B=Math.pow(2,-j))<1&&(j--,B*=2),(i+=j+Y>=1?Z/B:Z*Math.pow(2,1-Y))*B>=2&&(j++,B/=2),j+Y>=U?(L=0,j=U):j+Y>=1?(L=(i*B-1)*Math.pow(2,w),j+=Y):(L=i*Math.pow(2,Y-1)*Math.pow(2,w),j=0));w>=8;s[u+ee]=255&L,ee+=ie,L/=256,w-=8);for(j=j<0;s[u+ee]=255&j,ee+=ie,j/=256,$-=8);s[u+ee-ie]|=128*ae}},9404:function(s){s.exports=function(){"use strict";var s=Array.prototype.slice;function createClass(s,i){i&&(s.prototype=Object.create(i.prototype)),s.prototype.constructor=s}function Iterable(s){return isIterable(s)?s:Seq(s)}function KeyedIterable(s){return isKeyed(s)?s:KeyedSeq(s)}function IndexedIterable(s){return isIndexed(s)?s:IndexedSeq(s)}function SetIterable(s){return isIterable(s)&&!isAssociative(s)?s:SetSeq(s)}function isIterable(s){return!(!s||!s[i])}function isKeyed(s){return!(!s||!s[u])}function isIndexed(s){return!(!s||!s[_])}function isAssociative(s){return isKeyed(s)||isIndexed(s)}function isOrdered(s){return!(!s||!s[w])}createClass(KeyedIterable,Iterable),createClass(IndexedIterable,Iterable),createClass(SetIterable,Iterable),Iterable.isIterable=isIterable,Iterable.isKeyed=isKeyed,Iterable.isIndexed=isIndexed,Iterable.isAssociative=isAssociative,Iterable.isOrdered=isOrdered,Iterable.Keyed=KeyedIterable,Iterable.Indexed=IndexedIterable,Iterable.Set=SetIterable;var i="@@__IMMUTABLE_ITERABLE__@@",u="@@__IMMUTABLE_KEYED__@@",_="@@__IMMUTABLE_INDEXED__@@",w="@@__IMMUTABLE_ORDERED__@@",x="delete",j=5,L=1<>>0;if(""+u!==i||4294967295===u)return NaN;i=u}return i<0?ensureSize(s)+i:i}function returnTrue(){return!0}function wholeSlice(s,i,u){return(0===s||void 0!==u&&s<=-u)&&(void 0===i||void 0!==u&&i>=u)}function resolveBegin(s,i){return resolveIndex(s,i,0)}function resolveEnd(s,i){return resolveIndex(s,i,i)}function resolveIndex(s,i,u){return void 0===s?u:s<0?Math.max(0,i+s):void 0===i?s:Math.min(i,s)}var Z=0,ee=1,ie=2,ae="function"==typeof Symbol&&Symbol.iterator,le="@@iterator",ce=ae||le;function Iterator(s){this.next=s}function iteratorValue(s,i,u,_){var w=0===s?i:1===s?u:[i,u];return _?_.value=w:_={value:w,done:!1},_}function iteratorDone(){return{value:void 0,done:!0}}function hasIterator(s){return!!getIteratorFn(s)}function isIterator(s){return s&&"function"==typeof s.next}function getIterator(s){var i=getIteratorFn(s);return i&&i.call(s)}function getIteratorFn(s){var i=s&&(ae&&s[ae]||s[le]);if("function"==typeof i)return i}function isArrayLike(s){return s&&"number"==typeof s.length}function Seq(s){return null==s?emptySequence():isIterable(s)?s.toSeq():seqFromValue(s)}function KeyedSeq(s){return null==s?emptySequence().toKeyedSeq():isIterable(s)?isKeyed(s)?s.toSeq():s.fromEntrySeq():keyedSeqFromValue(s)}function IndexedSeq(s){return null==s?emptySequence():isIterable(s)?isKeyed(s)?s.entrySeq():s.toIndexedSeq():indexedSeqFromValue(s)}function SetSeq(s){return(null==s?emptySequence():isIterable(s)?isKeyed(s)?s.entrySeq():s:indexedSeqFromValue(s)).toSetSeq()}Iterator.prototype.toString=function(){return"[Iterator]"},Iterator.KEYS=Z,Iterator.VALUES=ee,Iterator.ENTRIES=ie,Iterator.prototype.inspect=Iterator.prototype.toSource=function(){return this.toString()},Iterator.prototype[ce]=function(){return this},createClass(Seq,Iterable),Seq.of=function(){return Seq(arguments)},Seq.prototype.toSeq=function(){return this},Seq.prototype.toString=function(){return this.__toString("Seq {","}")},Seq.prototype.cacheResult=function(){return!this._cache&&this.__iterateUncached&&(this._cache=this.entrySeq().toArray(),this.size=this._cache.length),this},Seq.prototype.__iterate=function(s,i){return seqIterate(this,s,i,!0)},Seq.prototype.__iterator=function(s,i){return seqIterator(this,s,i,!0)},createClass(KeyedSeq,Seq),KeyedSeq.prototype.toKeyedSeq=function(){return this},createClass(IndexedSeq,Seq),IndexedSeq.of=function(){return IndexedSeq(arguments)},IndexedSeq.prototype.toIndexedSeq=function(){return this},IndexedSeq.prototype.toString=function(){return this.__toString("Seq [","]")},IndexedSeq.prototype.__iterate=function(s,i){return seqIterate(this,s,i,!1)},IndexedSeq.prototype.__iterator=function(s,i){return seqIterator(this,s,i,!1)},createClass(SetSeq,Seq),SetSeq.of=function(){return SetSeq(arguments)},SetSeq.prototype.toSetSeq=function(){return this},Seq.isSeq=isSeq,Seq.Keyed=KeyedSeq,Seq.Set=SetSeq,Seq.Indexed=IndexedSeq;var pe,de,fe,ye="@@__IMMUTABLE_SEQ__@@";function ArraySeq(s){this._array=s,this.size=s.length}function ObjectSeq(s){var i=Object.keys(s);this._object=s,this._keys=i,this.size=i.length}function IterableSeq(s){this._iterable=s,this.size=s.length||s.size}function IteratorSeq(s){this._iterator=s,this._iteratorCache=[]}function isSeq(s){return!(!s||!s[ye])}function emptySequence(){return pe||(pe=new ArraySeq([]))}function keyedSeqFromValue(s){var i=Array.isArray(s)?new ArraySeq(s).fromEntrySeq():isIterator(s)?new IteratorSeq(s).fromEntrySeq():hasIterator(s)?new IterableSeq(s).fromEntrySeq():"object"==typeof s?new ObjectSeq(s):void 0;if(!i)throw new TypeError("Expected Array or iterable object of [k, v] entries, or keyed object: "+s);return i}function indexedSeqFromValue(s){var i=maybeIndexedSeqFromValue(s);if(!i)throw new TypeError("Expected Array or iterable object of values: "+s);return i}function seqFromValue(s){var i=maybeIndexedSeqFromValue(s)||"object"==typeof s&&new ObjectSeq(s);if(!i)throw new TypeError("Expected Array or iterable object of values, or keyed object: "+s);return i}function maybeIndexedSeqFromValue(s){return isArrayLike(s)?new ArraySeq(s):isIterator(s)?new IteratorSeq(s):hasIterator(s)?new IterableSeq(s):void 0}function seqIterate(s,i,u,_){var w=s._cache;if(w){for(var x=w.length-1,j=0;j<=x;j++){var L=w[u?x-j:j];if(!1===i(L[1],_?L[0]:j,s))return j+1}return j}return s.__iterateUncached(i,u)}function seqIterator(s,i,u,_){var w=s._cache;if(w){var x=w.length-1,j=0;return new Iterator((function(){var s=w[u?x-j:j];return j++>x?iteratorDone():iteratorValue(i,_?s[0]:j-1,s[1])}))}return s.__iteratorUncached(i,u)}function fromJS(s,i){return i?fromJSWith(i,s,"",{"":s}):fromJSDefault(s)}function fromJSWith(s,i,u,_){return Array.isArray(i)?s.call(_,u,IndexedSeq(i).map((function(u,_){return fromJSWith(s,u,_,i)}))):isPlainObj(i)?s.call(_,u,KeyedSeq(i).map((function(u,_){return fromJSWith(s,u,_,i)}))):i}function fromJSDefault(s){return Array.isArray(s)?IndexedSeq(s).map(fromJSDefault).toList():isPlainObj(s)?KeyedSeq(s).map(fromJSDefault).toMap():s}function isPlainObj(s){return s&&(s.constructor===Object||void 0===s.constructor)}function is(s,i){if(s===i||s!=s&&i!=i)return!0;if(!s||!i)return!1;if("function"==typeof s.valueOf&&"function"==typeof i.valueOf){if((s=s.valueOf())===(i=i.valueOf())||s!=s&&i!=i)return!0;if(!s||!i)return!1}return!("function"!=typeof s.equals||"function"!=typeof i.equals||!s.equals(i))}function deepEqual(s,i){if(s===i)return!0;if(!isIterable(i)||void 0!==s.size&&void 0!==i.size&&s.size!==i.size||void 0!==s.__hash&&void 0!==i.__hash&&s.__hash!==i.__hash||isKeyed(s)!==isKeyed(i)||isIndexed(s)!==isIndexed(i)||isOrdered(s)!==isOrdered(i))return!1;if(0===s.size&&0===i.size)return!0;var u=!isAssociative(s);if(isOrdered(s)){var _=s.entries();return i.every((function(s,i){var w=_.next().value;return w&&is(w[1],s)&&(u||is(w[0],i))}))&&_.next().done}var w=!1;if(void 0===s.size)if(void 0===i.size)"function"==typeof s.cacheResult&&s.cacheResult();else{w=!0;var x=s;s=i,i=x}var j=!0,L=i.__iterate((function(i,_){if(u?!s.has(i):w?!is(i,s.get(_,$)):!is(s.get(_,$),i))return j=!1,!1}));return j&&s.size===L}function Repeat(s,i){if(!(this instanceof Repeat))return new Repeat(s,i);if(this._value=s,this.size=void 0===i?1/0:Math.max(0,i),0===this.size){if(de)return de;de=this}}function invariant(s,i){if(!s)throw new Error(i)}function Range(s,i,u){if(!(this instanceof Range))return new Range(s,i,u);if(invariant(0!==u,"Cannot step a Range by 0"),s=s||0,void 0===i&&(i=1/0),u=void 0===u?1:Math.abs(u),i_?iteratorDone():iteratorValue(s,w,u[i?_-w++:w++])}))},createClass(ObjectSeq,KeyedSeq),ObjectSeq.prototype.get=function(s,i){return void 0===i||this.has(s)?this._object[s]:i},ObjectSeq.prototype.has=function(s){return this._object.hasOwnProperty(s)},ObjectSeq.prototype.__iterate=function(s,i){for(var u=this._object,_=this._keys,w=_.length-1,x=0;x<=w;x++){var j=_[i?w-x:x];if(!1===s(u[j],j,this))return x+1}return x},ObjectSeq.prototype.__iterator=function(s,i){var u=this._object,_=this._keys,w=_.length-1,x=0;return new Iterator((function(){var j=_[i?w-x:x];return x++>w?iteratorDone():iteratorValue(s,j,u[j])}))},ObjectSeq.prototype[w]=!0,createClass(IterableSeq,IndexedSeq),IterableSeq.prototype.__iterateUncached=function(s,i){if(i)return this.cacheResult().__iterate(s,i);var u=getIterator(this._iterable),_=0;if(isIterator(u))for(var w;!(w=u.next()).done&&!1!==s(w.value,_++,this););return _},IterableSeq.prototype.__iteratorUncached=function(s,i){if(i)return this.cacheResult().__iterator(s,i);var u=getIterator(this._iterable);if(!isIterator(u))return new Iterator(iteratorDone);var _=0;return new Iterator((function(){var i=u.next();return i.done?i:iteratorValue(s,_++,i.value)}))},createClass(IteratorSeq,IndexedSeq),IteratorSeq.prototype.__iterateUncached=function(s,i){if(i)return this.cacheResult().__iterate(s,i);for(var u,_=this._iterator,w=this._iteratorCache,x=0;x=_.length){var i=u.next();if(i.done)return i;_[w]=i.value}return iteratorValue(s,w,_[w++])}))},createClass(Repeat,IndexedSeq),Repeat.prototype.toString=function(){return 0===this.size?"Repeat []":"Repeat [ "+this._value+" "+this.size+" times ]"},Repeat.prototype.get=function(s,i){return this.has(s)?this._value:i},Repeat.prototype.includes=function(s){return is(this._value,s)},Repeat.prototype.slice=function(s,i){var u=this.size;return wholeSlice(s,i,u)?this:new Repeat(this._value,resolveEnd(i,u)-resolveBegin(s,u))},Repeat.prototype.reverse=function(){return this},Repeat.prototype.indexOf=function(s){return is(this._value,s)?0:-1},Repeat.prototype.lastIndexOf=function(s){return is(this._value,s)?this.size:-1},Repeat.prototype.__iterate=function(s,i){for(var u=0;u=0&&i=0&&uu?iteratorDone():iteratorValue(s,x++,j)}))},Range.prototype.equals=function(s){return s instanceof Range?this._start===s._start&&this._end===s._end&&this._step===s._step:deepEqual(this,s)},createClass(Collection,Iterable),createClass(KeyedCollection,Collection),createClass(IndexedCollection,Collection),createClass(SetCollection,Collection),Collection.Keyed=KeyedCollection,Collection.Indexed=IndexedCollection,Collection.Set=SetCollection;var be="function"==typeof Math.imul&&-2===Math.imul(4294967295,2)?Math.imul:function imul(s,i){var u=65535&(s|=0),_=65535&(i|=0);return u*_+((s>>>16)*_+u*(i>>>16)<<16>>>0)|0};function smi(s){return s>>>1&1073741824|3221225471&s}function hash(s){if(!1===s||null==s)return 0;if("function"==typeof s.valueOf&&(!1===(s=s.valueOf())||null==s))return 0;if(!0===s)return 1;var i=typeof s;if("number"===i){if(s!=s||s===1/0)return 0;var u=0|s;for(u!==s&&(u^=4294967295*s);s>4294967295;)u^=s/=4294967295;return smi(u)}if("string"===i)return s.length>Re?cachedHashString(s):hashString(s);if("function"==typeof s.hashCode)return s.hashCode();if("object"===i)return hashJSObj(s);if("function"==typeof s.toString)return hashString(s.toString());throw new Error("Value type "+i+" cannot be hashed.")}function cachedHashString(s){var i=ze[s];return void 0===i&&(i=hashString(s),$e===qe&&($e=0,ze={}),$e++,ze[s]=i),i}function hashString(s){for(var i=0,u=0;u0)switch(s.nodeType){case 1:return s.uniqueID;case 9:return s.documentElement&&s.documentElement.uniqueID}}var Se,xe="function"==typeof WeakMap;xe&&(Se=new WeakMap);var Pe=0,Te="__immutablehash__";"function"==typeof Symbol&&(Te=Symbol(Te));var Re=16,qe=255,$e=0,ze={};function assertNotInfinite(s){invariant(s!==1/0,"Cannot perform this action with an infinite size.")}function Map(s){return null==s?emptyMap():isMap(s)&&!isOrdered(s)?s:emptyMap().withMutations((function(i){var u=KeyedIterable(s);assertNotInfinite(u.size),u.forEach((function(s,u){return i.set(u,s)}))}))}function isMap(s){return!(!s||!s[He])}createClass(Map,KeyedCollection),Map.of=function(){var i=s.call(arguments,0);return emptyMap().withMutations((function(s){for(var u=0;u=i.length)throw new Error("Missing value for key: "+i[u]);s.set(i[u],i[u+1])}}))},Map.prototype.toString=function(){return this.__toString("Map {","}")},Map.prototype.get=function(s,i){return this._root?this._root.get(0,void 0,s,i):i},Map.prototype.set=function(s,i){return updateMap(this,s,i)},Map.prototype.setIn=function(s,i){return this.updateIn(s,$,(function(){return i}))},Map.prototype.remove=function(s){return updateMap(this,s,$)},Map.prototype.deleteIn=function(s){return this.updateIn(s,(function(){return $}))},Map.prototype.update=function(s,i,u){return 1===arguments.length?s(this):this.updateIn([s],i,u)},Map.prototype.updateIn=function(s,i,u){u||(u=i,i=void 0);var _=updateInDeepMap(this,forceIterator(s),i,u);return _===$?void 0:_},Map.prototype.clear=function(){return 0===this.size?this:this.__ownerID?(this.size=0,this._root=null,this.__hash=void 0,this.__altered=!0,this):emptyMap()},Map.prototype.merge=function(){return mergeIntoMapWith(this,void 0,arguments)},Map.prototype.mergeWith=function(i){return mergeIntoMapWith(this,i,s.call(arguments,1))},Map.prototype.mergeIn=function(i){var u=s.call(arguments,1);return this.updateIn(i,emptyMap(),(function(s){return"function"==typeof s.merge?s.merge.apply(s,u):u[u.length-1]}))},Map.prototype.mergeDeep=function(){return mergeIntoMapWith(this,deepMerger,arguments)},Map.prototype.mergeDeepWith=function(i){var u=s.call(arguments,1);return mergeIntoMapWith(this,deepMergerWith(i),u)},Map.prototype.mergeDeepIn=function(i){var u=s.call(arguments,1);return this.updateIn(i,emptyMap(),(function(s){return"function"==typeof s.mergeDeep?s.mergeDeep.apply(s,u):u[u.length-1]}))},Map.prototype.sort=function(s){return OrderedMap(sortFactory(this,s))},Map.prototype.sortBy=function(s,i){return OrderedMap(sortFactory(this,i,s))},Map.prototype.withMutations=function(s){var i=this.asMutable();return s(i),i.wasAltered()?i.__ensureOwner(this.__ownerID):this},Map.prototype.asMutable=function(){return this.__ownerID?this:this.__ensureOwner(new OwnerID)},Map.prototype.asImmutable=function(){return this.__ensureOwner()},Map.prototype.wasAltered=function(){return this.__altered},Map.prototype.__iterator=function(s,i){return new MapIterator(this,s,i)},Map.prototype.__iterate=function(s,i){var u=this,_=0;return this._root&&this._root.iterate((function(i){return _++,s(i[1],i[0],u)}),i),_},Map.prototype.__ensureOwner=function(s){return s===this.__ownerID?this:s?makeMap(this.size,this._root,s,this.__hash):(this.__ownerID=s,this.__altered=!1,this)},Map.isMap=isMap;var We,He="@@__IMMUTABLE_MAP__@@",Ye=Map.prototype;function ArrayMapNode(s,i){this.ownerID=s,this.entries=i}function BitmapIndexedNode(s,i,u){this.ownerID=s,this.bitmap=i,this.nodes=u}function HashArrayMapNode(s,i,u){this.ownerID=s,this.count=i,this.nodes=u}function HashCollisionNode(s,i,u){this.ownerID=s,this.keyHash=i,this.entries=u}function ValueNode(s,i,u){this.ownerID=s,this.keyHash=i,this.entry=u}function MapIterator(s,i,u){this._type=i,this._reverse=u,this._stack=s._root&&mapIteratorFrame(s._root)}function mapIteratorValue(s,i){return iteratorValue(s,i[0],i[1])}function mapIteratorFrame(s,i){return{node:s,index:0,__prev:i}}function makeMap(s,i,u,_){var w=Object.create(Ye);return w.size=s,w._root=i,w.__ownerID=u,w.__hash=_,w.__altered=!1,w}function emptyMap(){return We||(We=makeMap(0))}function updateMap(s,i,u){var _,w;if(s._root){var x=MakeRef(U),j=MakeRef(Y);if(_=updateNode(s._root,s.__ownerID,0,void 0,i,u,x,j),!j.value)return s;w=s.size+(x.value?u===$?-1:1:0)}else{if(u===$)return s;w=1,_=new ArrayMapNode(s.__ownerID,[[i,u]])}return s.__ownerID?(s.size=w,s._root=_,s.__hash=void 0,s.__altered=!0,s):_?makeMap(w,_):emptyMap()}function updateNode(s,i,u,_,w,x,j,L){return s?s.update(i,u,_,w,x,j,L):x===$?s:(SetRef(L),SetRef(j),new ValueNode(i,_,[w,x]))}function isLeafNode(s){return s.constructor===ValueNode||s.constructor===HashCollisionNode}function mergeIntoNode(s,i,u,_,w){if(s.keyHash===_)return new HashCollisionNode(i,_,[s.entry,w]);var x,L=(0===u?s.keyHash:s.keyHash>>>u)&B,$=(0===u?_:_>>>u)&B;return new BitmapIndexedNode(i,1<>>=1)j[B]=1&u?i[x++]:void 0;return j[_]=w,new HashArrayMapNode(s,x+1,j)}function mergeIntoMapWith(s,i,u){for(var _=[],w=0;w>1&1431655765))+(s>>2&858993459))+(s>>4)&252645135,s+=s>>8,127&(s+=s>>16)}function setIn(s,i,u,_){var w=_?s:arrCopy(s);return w[i]=u,w}function spliceIn(s,i,u,_){var w=s.length+1;if(_&&i+1===w)return s[i]=u,s;for(var x=new Array(w),j=0,L=0;L=Xe)return createNodes(s,B,_,w);var ee=s&&s===this.ownerID,ie=ee?B:arrCopy(B);return Z?L?U===Y-1?ie.pop():ie[U]=ie.pop():ie[U]=[_,w]:ie.push([_,w]),ee?(this.entries=ie,this):new ArrayMapNode(s,ie)}},BitmapIndexedNode.prototype.get=function(s,i,u,_){void 0===i&&(i=hash(u));var w=1<<((0===s?i:i>>>s)&B),x=this.bitmap;return 0==(x&w)?_:this.nodes[popCount(x&w-1)].get(s+j,i,u,_)},BitmapIndexedNode.prototype.update=function(s,i,u,_,w,x,L){void 0===u&&(u=hash(_));var U=(0===i?u:u>>>i)&B,Y=1<=Qe)return expandNodes(s,ae,Z,U,ce);if(ee&&!ce&&2===ae.length&&isLeafNode(ae[1^ie]))return ae[1^ie];if(ee&&ce&&1===ae.length&&isLeafNode(ce))return ce;var pe=s&&s===this.ownerID,de=ee?ce?Z:Z^Y:Z|Y,fe=ee?ce?setIn(ae,ie,ce,pe):spliceOut(ae,ie,pe):spliceIn(ae,ie,ce,pe);return pe?(this.bitmap=de,this.nodes=fe,this):new BitmapIndexedNode(s,de,fe)},HashArrayMapNode.prototype.get=function(s,i,u,_){void 0===i&&(i=hash(u));var w=(0===s?i:i>>>s)&B,x=this.nodes[w];return x?x.get(s+j,i,u,_):_},HashArrayMapNode.prototype.update=function(s,i,u,_,w,x,L){void 0===u&&(u=hash(_));var U=(0===i?u:u>>>i)&B,Y=w===$,Z=this.nodes,ee=Z[U];if(Y&&!ee)return this;var ie=updateNode(ee,s,i+j,u,_,w,x,L);if(ie===ee)return this;var ae=this.count;if(ee){if(!ie&&--ae0&&_=0&&s>>i&B;if(_>=this.array.length)return new VNode([],s);var w,x=0===_;if(i>0){var L=this.array[_];if((w=L&&L.removeBefore(s,i-j,u))===L&&x)return this}if(x&&!w)return this;var $=editableVNode(this,s);if(!x)for(var U=0;U<_;U++)$.array[U]=void 0;return w&&($.array[_]=w),$},VNode.prototype.removeAfter=function(s,i,u){if(u===(i?1<>>i&B;if(w>=this.array.length)return this;if(i>0){var x=this.array[w];if((_=x&&x.removeAfter(s,i-j,u))===x&&w===this.array.length-1)return this}var L=editableVNode(this,s);return L.array.splice(w+1),_&&(L.array[w]=_),L};var nt,ot,st={};function iterateList(s,i){var u=s._origin,_=s._capacity,w=getTailOffset(_),x=s._tail;return iterateNodeOrLeaf(s._root,s._level,0);function iterateNodeOrLeaf(s,i,u){return 0===i?iterateLeaf(s,u):iterateNode(s,i,u)}function iterateLeaf(s,j){var B=j===w?x&&x.array:s&&s.array,$=j>u?0:u-j,U=_-j;return U>L&&(U=L),function(){if($===U)return st;var s=i?--U:$++;return B&&B[s]}}function iterateNode(s,w,x){var B,$=s&&s.array,U=x>u?0:u-x>>w,Y=1+(_-x>>w);return Y>L&&(Y=L),function(){for(;;){if(B){var s=B();if(s!==st)return s;B=null}if(U===Y)return st;var u=i?--Y:U++;B=iterateNodeOrLeaf($&&$[u],w-j,x+(u<=s.size||i<0)return s.withMutations((function(s){i<0?setListBounds(s,i).set(0,u):setListBounds(s,0,i+1).set(i,u)}));i+=s._origin;var _=s._tail,w=s._root,x=MakeRef(Y);return i>=getTailOffset(s._capacity)?_=updateVNode(_,s.__ownerID,0,i,u,x):w=updateVNode(w,s.__ownerID,s._level,i,u,x),x.value?s.__ownerID?(s._root=w,s._tail=_,s.__hash=void 0,s.__altered=!0,s):makeList(s._origin,s._capacity,s._level,w,_):s}function updateVNode(s,i,u,_,w,x){var L,$=_>>>u&B,U=s&&$0){var Y=s&&s.array[$],Z=updateVNode(Y,i,u-j,_,w,x);return Z===Y?s:((L=editableVNode(s,i)).array[$]=Z,L)}return U&&s.array[$]===w?s:(SetRef(x),L=editableVNode(s,i),void 0===w&&$===L.array.length-1?L.array.pop():L.array[$]=w,L)}function editableVNode(s,i){return i&&s&&i===s.ownerID?s:new VNode(s?s.array.slice():[],i)}function listNodeFor(s,i){if(i>=getTailOffset(s._capacity))return s._tail;if(i<1<0;)u=u.array[i>>>_&B],_-=j;return u}}function setListBounds(s,i,u){void 0!==i&&(i|=0),void 0!==u&&(u|=0);var _=s.__ownerID||new OwnerID,w=s._origin,x=s._capacity,L=w+i,$=void 0===u?x:u<0?x+u:w+u;if(L===w&&$===x)return s;if(L>=$)return s.clear();for(var U=s._level,Y=s._root,Z=0;L+Z<0;)Y=new VNode(Y&&Y.array.length?[void 0,Y]:[],_),Z+=1<<(U+=j);Z&&(L+=Z,w+=Z,$+=Z,x+=Z);for(var ee=getTailOffset(x),ie=getTailOffset($);ie>=1<ee?new VNode([],_):ae;if(ae&&ie>ee&&Lj;pe-=j){var de=ee>>>pe&B;ce=ce.array[de]=editableVNode(ce.array[de],_)}ce.array[ee>>>j&B]=ae}if($=ie)L-=ie,$-=ie,U=j,Y=null,le=le&&le.removeBefore(_,0,L);else if(L>w||ie>>U&B;if(fe!==ie>>>U&B)break;fe&&(Z+=(1<w&&(Y=Y.removeBefore(_,U,L-Z)),Y&&iew&&(w=L.size),isIterable(j)||(L=L.map((function(s){return fromJS(s)}))),_.push(L)}return w>s.size&&(s=s.setSize(w)),mergeIntoCollectionWith(s,i,_)}function getTailOffset(s){return s>>j<=L&&j.size>=2*x.size?(_=(w=j.filter((function(s,i){return void 0!==s&&B!==i}))).toKeyedSeq().map((function(s){return s[0]})).flip().toMap(),s.__ownerID&&(_.__ownerID=w.__ownerID=s.__ownerID)):(_=x.remove(i),w=B===j.size-1?j.pop():j.set(B,void 0))}else if(U){if(u===j.get(B)[1])return s;_=x,w=j.set(B,[i,u])}else _=x.set(i,j.size),w=j.set(j.size,[i,u]);return s.__ownerID?(s.size=_.size,s._map=_,s._list=w,s.__hash=void 0,s):makeOrderedMap(_,w)}function ToKeyedSequence(s,i){this._iter=s,this._useKeys=i,this.size=s.size}function ToIndexedSequence(s){this._iter=s,this.size=s.size}function ToSetSequence(s){this._iter=s,this.size=s.size}function FromEntriesSequence(s){this._iter=s,this.size=s.size}function flipFactory(s){var i=makeSequence(s);return i._iter=s,i.size=s.size,i.flip=function(){return s},i.reverse=function(){var i=s.reverse.apply(this);return i.flip=function(){return s.reverse()},i},i.has=function(i){return s.includes(i)},i.includes=function(i){return s.has(i)},i.cacheResult=cacheResultThrough,i.__iterateUncached=function(i,u){var _=this;return s.__iterate((function(s,u){return!1!==i(u,s,_)}),u)},i.__iteratorUncached=function(i,u){if(i===ie){var _=s.__iterator(i,u);return new Iterator((function(){var s=_.next();if(!s.done){var i=s.value[0];s.value[0]=s.value[1],s.value[1]=i}return s}))}return s.__iterator(i===ee?Z:ee,u)},i}function mapFactory(s,i,u){var _=makeSequence(s);return _.size=s.size,_.has=function(i){return s.has(i)},_.get=function(_,w){var x=s.get(_,$);return x===$?w:i.call(u,x,_,s)},_.__iterateUncached=function(_,w){var x=this;return s.__iterate((function(s,w,j){return!1!==_(i.call(u,s,w,j),w,x)}),w)},_.__iteratorUncached=function(_,w){var x=s.__iterator(ie,w);return new Iterator((function(){var w=x.next();if(w.done)return w;var j=w.value,L=j[0];return iteratorValue(_,L,i.call(u,j[1],L,s),w)}))},_}function reverseFactory(s,i){var u=makeSequence(s);return u._iter=s,u.size=s.size,u.reverse=function(){return s},s.flip&&(u.flip=function(){var i=flipFactory(s);return i.reverse=function(){return s.flip()},i}),u.get=function(u,_){return s.get(i?u:-1-u,_)},u.has=function(u){return s.has(i?u:-1-u)},u.includes=function(i){return s.includes(i)},u.cacheResult=cacheResultThrough,u.__iterate=function(i,u){var _=this;return s.__iterate((function(s,u){return i(s,u,_)}),!u)},u.__iterator=function(i,u){return s.__iterator(i,!u)},u}function filterFactory(s,i,u,_){var w=makeSequence(s);return _&&(w.has=function(_){var w=s.get(_,$);return w!==$&&!!i.call(u,w,_,s)},w.get=function(_,w){var x=s.get(_,$);return x!==$&&i.call(u,x,_,s)?x:w}),w.__iterateUncached=function(w,x){var j=this,L=0;return s.__iterate((function(s,x,B){if(i.call(u,s,x,B))return L++,w(s,_?x:L-1,j)}),x),L},w.__iteratorUncached=function(w,x){var j=s.__iterator(ie,x),L=0;return new Iterator((function(){for(;;){var x=j.next();if(x.done)return x;var B=x.value,$=B[0],U=B[1];if(i.call(u,U,$,s))return iteratorValue(w,_?$:L++,U,x)}}))},w}function countByFactory(s,i,u){var _=Map().asMutable();return s.__iterate((function(w,x){_.update(i.call(u,w,x,s),0,(function(s){return s+1}))})),_.asImmutable()}function groupByFactory(s,i,u){var _=isKeyed(s),w=(isOrdered(s)?OrderedMap():Map()).asMutable();s.__iterate((function(x,j){w.update(i.call(u,x,j,s),(function(s){return(s=s||[]).push(_?[j,x]:x),s}))}));var x=iterableClass(s);return w.map((function(i){return reify(s,x(i))}))}function sliceFactory(s,i,u,_){var w=s.size;if(void 0!==i&&(i|=0),void 0!==u&&(u===1/0?u=w:u|=0),wholeSlice(i,u,w))return s;var x=resolveBegin(i,w),j=resolveEnd(u,w);if(x!=x||j!=j)return sliceFactory(s.toSeq().cacheResult(),i,u,_);var L,B=j-x;B==B&&(L=B<0?0:B);var $=makeSequence(s);return $.size=0===L?L:s.size&&L||void 0,!_&&isSeq(s)&&L>=0&&($.get=function(i,u){return(i=wrapIndex(this,i))>=0&&iL)return iteratorDone();var s=w.next();return _||i===ee?s:iteratorValue(i,B-1,i===Z?void 0:s.value[1],s)}))},$}function takeWhileFactory(s,i,u){var _=makeSequence(s);return _.__iterateUncached=function(_,w){var x=this;if(w)return this.cacheResult().__iterate(_,w);var j=0;return s.__iterate((function(s,w,L){return i.call(u,s,w,L)&&++j&&_(s,w,x)})),j},_.__iteratorUncached=function(_,w){var x=this;if(w)return this.cacheResult().__iterator(_,w);var j=s.__iterator(ie,w),L=!0;return new Iterator((function(){if(!L)return iteratorDone();var s=j.next();if(s.done)return s;var w=s.value,B=w[0],$=w[1];return i.call(u,$,B,x)?_===ie?s:iteratorValue(_,B,$,s):(L=!1,iteratorDone())}))},_}function skipWhileFactory(s,i,u,_){var w=makeSequence(s);return w.__iterateUncached=function(w,x){var j=this;if(x)return this.cacheResult().__iterate(w,x);var L=!0,B=0;return s.__iterate((function(s,x,$){if(!L||!(L=i.call(u,s,x,$)))return B++,w(s,_?x:B-1,j)})),B},w.__iteratorUncached=function(w,x){var j=this;if(x)return this.cacheResult().__iterator(w,x);var L=s.__iterator(ie,x),B=!0,$=0;return new Iterator((function(){var s,x,U;do{if((s=L.next()).done)return _||w===ee?s:iteratorValue(w,$++,w===Z?void 0:s.value[1],s);var Y=s.value;x=Y[0],U=Y[1],B&&(B=i.call(u,U,x,j))}while(B);return w===ie?s:iteratorValue(w,x,U,s)}))},w}function concatFactory(s,i){var u=isKeyed(s),_=[s].concat(i).map((function(s){return isIterable(s)?u&&(s=KeyedIterable(s)):s=u?keyedSeqFromValue(s):indexedSeqFromValue(Array.isArray(s)?s:[s]),s})).filter((function(s){return 0!==s.size}));if(0===_.length)return s;if(1===_.length){var w=_[0];if(w===s||u&&isKeyed(w)||isIndexed(s)&&isIndexed(w))return w}var x=new ArraySeq(_);return u?x=x.toKeyedSeq():isIndexed(s)||(x=x.toSetSeq()),(x=x.flatten(!0)).size=_.reduce((function(s,i){if(void 0!==s){var u=i.size;if(void 0!==u)return s+u}}),0),x}function flattenFactory(s,i,u){var _=makeSequence(s);return _.__iterateUncached=function(_,w){var x=0,j=!1;function flatDeep(s,L){var B=this;s.__iterate((function(s,w){return(!i||L0}function zipWithFactory(s,i,u){var _=makeSequence(s);return _.size=new ArraySeq(u).map((function(s){return s.size})).min(),_.__iterate=function(s,i){for(var u,_=this.__iterator(ee,i),w=0;!(u=_.next()).done&&!1!==s(u.value,w++,this););return w},_.__iteratorUncached=function(s,_){var w=u.map((function(s){return s=Iterable(s),getIterator(_?s.reverse():s)})),x=0,j=!1;return new Iterator((function(){var u;return j||(u=w.map((function(s){return s.next()})),j=u.some((function(s){return s.done}))),j?iteratorDone():iteratorValue(s,x++,i.apply(null,u.map((function(s){return s.value}))))}))},_}function reify(s,i){return isSeq(s)?i:s.constructor(i)}function validateEntry(s){if(s!==Object(s))throw new TypeError("Expected [K, V] tuple: "+s)}function resolveSize(s){return assertNotInfinite(s.size),ensureSize(s)}function iterableClass(s){return isKeyed(s)?KeyedIterable:isIndexed(s)?IndexedIterable:SetIterable}function makeSequence(s){return Object.create((isKeyed(s)?KeyedSeq:isIndexed(s)?IndexedSeq:SetSeq).prototype)}function cacheResultThrough(){return this._iter.cacheResult?(this._iter.cacheResult(),this.size=this._iter.size,this):Seq.prototype.cacheResult.call(this)}function defaultComparator(s,i){return s>i?1:s=0;u--)i={value:arguments[u],next:i};return this.__ownerID?(this.size=s,this._head=i,this.__hash=void 0,this.__altered=!0,this):makeStack(s,i)},Stack.prototype.pushAll=function(s){if(0===(s=IndexedIterable(s)).size)return this;assertNotInfinite(s.size);var i=this.size,u=this._head;return s.reverse().forEach((function(s){i++,u={value:s,next:u}})),this.__ownerID?(this.size=i,this._head=u,this.__hash=void 0,this.__altered=!0,this):makeStack(i,u)},Stack.prototype.pop=function(){return this.slice(1)},Stack.prototype.unshift=function(){return this.push.apply(this,arguments)},Stack.prototype.unshiftAll=function(s){return this.pushAll(s)},Stack.prototype.shift=function(){return this.pop.apply(this,arguments)},Stack.prototype.clear=function(){return 0===this.size?this:this.__ownerID?(this.size=0,this._head=void 0,this.__hash=void 0,this.__altered=!0,this):emptyStack()},Stack.prototype.slice=function(s,i){if(wholeSlice(s,i,this.size))return this;var u=resolveBegin(s,this.size);if(resolveEnd(i,this.size)!==this.size)return IndexedCollection.prototype.slice.call(this,s,i);for(var _=this.size-u,w=this._head;u--;)w=w.next;return this.__ownerID?(this.size=_,this._head=w,this.__hash=void 0,this.__altered=!0,this):makeStack(_,w)},Stack.prototype.__ensureOwner=function(s){return s===this.__ownerID?this:s?makeStack(this.size,this._head,s,this.__hash):(this.__ownerID=s,this.__altered=!1,this)},Stack.prototype.__iterate=function(s,i){if(i)return this.reverse().__iterate(s);for(var u=0,_=this._head;_&&!1!==s(_.value,u++,this);)_=_.next;return u},Stack.prototype.__iterator=function(s,i){if(i)return this.reverse().__iterator(s);var u=0,_=this._head;return new Iterator((function(){if(_){var i=_.value;return _=_.next,iteratorValue(s,u++,i)}return iteratorDone()}))},Stack.isStack=isStack;var ht,dt="@@__IMMUTABLE_STACK__@@",mt=Stack.prototype;function makeStack(s,i,u,_){var w=Object.create(mt);return w.size=s,w._head=i,w.__ownerID=u,w.__hash=_,w.__altered=!1,w}function emptyStack(){return ht||(ht=makeStack(0))}function mixin(s,i){var keyCopier=function(u){s.prototype[u]=i[u]};return Object.keys(i).forEach(keyCopier),Object.getOwnPropertySymbols&&Object.getOwnPropertySymbols(i).forEach(keyCopier),s}mt[dt]=!0,mt.withMutations=Ye.withMutations,mt.asMutable=Ye.asMutable,mt.asImmutable=Ye.asImmutable,mt.wasAltered=Ye.wasAltered,Iterable.Iterator=Iterator,mixin(Iterable,{toArray:function(){assertNotInfinite(this.size);var s=new Array(this.size||0);return this.valueSeq().__iterate((function(i,u){s[u]=i})),s},toIndexedSeq:function(){return new ToIndexedSequence(this)},toJS:function(){return this.toSeq().map((function(s){return s&&"function"==typeof s.toJS?s.toJS():s})).__toJS()},toJSON:function(){return this.toSeq().map((function(s){return s&&"function"==typeof s.toJSON?s.toJSON():s})).__toJS()},toKeyedSeq:function(){return new ToKeyedSequence(this,!0)},toMap:function(){return Map(this.toKeyedSeq())},toObject:function(){assertNotInfinite(this.size);var s={};return this.__iterate((function(i,u){s[u]=i})),s},toOrderedMap:function(){return OrderedMap(this.toKeyedSeq())},toOrderedSet:function(){return OrderedSet(isKeyed(this)?this.valueSeq():this)},toSet:function(){return Set(isKeyed(this)?this.valueSeq():this)},toSetSeq:function(){return new ToSetSequence(this)},toSeq:function(){return isIndexed(this)?this.toIndexedSeq():isKeyed(this)?this.toKeyedSeq():this.toSetSeq()},toStack:function(){return Stack(isKeyed(this)?this.valueSeq():this)},toList:function(){return List(isKeyed(this)?this.valueSeq():this)},toString:function(){return"[Iterable]"},__toString:function(s,i){return 0===this.size?s+i:s+" "+this.toSeq().map(this.__toStringMapper).join(", ")+" "+i},concat:function(){return reify(this,concatFactory(this,s.call(arguments,0)))},includes:function(s){return this.some((function(i){return is(i,s)}))},entries:function(){return this.__iterator(ie)},every:function(s,i){assertNotInfinite(this.size);var u=!0;return this.__iterate((function(_,w,x){if(!s.call(i,_,w,x))return u=!1,!1})),u},filter:function(s,i){return reify(this,filterFactory(this,s,i,!0))},find:function(s,i,u){var _=this.findEntry(s,i);return _?_[1]:u},forEach:function(s,i){return assertNotInfinite(this.size),this.__iterate(i?s.bind(i):s)},join:function(s){assertNotInfinite(this.size),s=void 0!==s?""+s:",";var i="",u=!0;return this.__iterate((function(_){u?u=!1:i+=s,i+=null!=_?_.toString():""})),i},keys:function(){return this.__iterator(Z)},map:function(s,i){return reify(this,mapFactory(this,s,i))},reduce:function(s,i,u){var _,w;return assertNotInfinite(this.size),arguments.length<2?w=!0:_=i,this.__iterate((function(i,x,j){w?(w=!1,_=i):_=s.call(u,_,i,x,j)})),_},reduceRight:function(s,i,u){var _=this.toKeyedSeq().reverse();return _.reduce.apply(_,arguments)},reverse:function(){return reify(this,reverseFactory(this,!0))},slice:function(s,i){return reify(this,sliceFactory(this,s,i,!0))},some:function(s,i){return!this.every(not(s),i)},sort:function(s){return reify(this,sortFactory(this,s))},values:function(){return this.__iterator(ee)},butLast:function(){return this.slice(0,-1)},isEmpty:function(){return void 0!==this.size?0===this.size:!this.some((function(){return!0}))},count:function(s,i){return ensureSize(s?this.toSeq().filter(s,i):this)},countBy:function(s,i){return countByFactory(this,s,i)},equals:function(s){return deepEqual(this,s)},entrySeq:function(){var s=this;if(s._cache)return new ArraySeq(s._cache);var i=s.toSeq().map(entryMapper).toIndexedSeq();return i.fromEntrySeq=function(){return s.toSeq()},i},filterNot:function(s,i){return this.filter(not(s),i)},findEntry:function(s,i,u){var _=u;return this.__iterate((function(u,w,x){if(s.call(i,u,w,x))return _=[w,u],!1})),_},findKey:function(s,i){var u=this.findEntry(s,i);return u&&u[0]},findLast:function(s,i,u){return this.toKeyedSeq().reverse().find(s,i,u)},findLastEntry:function(s,i,u){return this.toKeyedSeq().reverse().findEntry(s,i,u)},findLastKey:function(s,i){return this.toKeyedSeq().reverse().findKey(s,i)},first:function(){return this.find(returnTrue)},flatMap:function(s,i){return reify(this,flatMapFactory(this,s,i))},flatten:function(s){return reify(this,flattenFactory(this,s,!0))},fromEntrySeq:function(){return new FromEntriesSequence(this)},get:function(s,i){return this.find((function(i,u){return is(u,s)}),void 0,i)},getIn:function(s,i){for(var u,_=this,w=forceIterator(s);!(u=w.next()).done;){var x=u.value;if((_=_&&_.get?_.get(x,$):$)===$)return i}return _},groupBy:function(s,i){return groupByFactory(this,s,i)},has:function(s){return this.get(s,$)!==$},hasIn:function(s){return this.getIn(s,$)!==$},isSubset:function(s){return s="function"==typeof s.includes?s:Iterable(s),this.every((function(i){return s.includes(i)}))},isSuperset:function(s){return(s="function"==typeof s.isSubset?s:Iterable(s)).isSubset(this)},keyOf:function(s){return this.findKey((function(i){return is(i,s)}))},keySeq:function(){return this.toSeq().map(keyMapper).toIndexedSeq()},last:function(){return this.toSeq().reverse().first()},lastKeyOf:function(s){return this.toKeyedSeq().reverse().keyOf(s)},max:function(s){return maxFactory(this,s)},maxBy:function(s,i){return maxFactory(this,i,s)},min:function(s){return maxFactory(this,s?neg(s):defaultNegComparator)},minBy:function(s,i){return maxFactory(this,i?neg(i):defaultNegComparator,s)},rest:function(){return this.slice(1)},skip:function(s){return this.slice(Math.max(0,s))},skipLast:function(s){return reify(this,this.toSeq().reverse().skip(s).reverse())},skipWhile:function(s,i){return reify(this,skipWhileFactory(this,s,i,!0))},skipUntil:function(s,i){return this.skipWhile(not(s),i)},sortBy:function(s,i){return reify(this,sortFactory(this,i,s))},take:function(s){return this.slice(0,Math.max(0,s))},takeLast:function(s){return reify(this,this.toSeq().reverse().take(s).reverse())},takeWhile:function(s,i){return reify(this,takeWhileFactory(this,s,i))},takeUntil:function(s,i){return this.takeWhile(not(s),i)},valueSeq:function(){return this.toIndexedSeq()},hashCode:function(){return this.__hash||(this.__hash=hashIterable(this))}});var gt=Iterable.prototype;gt[i]=!0,gt[ce]=gt.values,gt.__toJS=gt.toArray,gt.__toStringMapper=quoteString,gt.inspect=gt.toSource=function(){return this.toString()},gt.chain=gt.flatMap,gt.contains=gt.includes,mixin(KeyedIterable,{flip:function(){return reify(this,flipFactory(this))},mapEntries:function(s,i){var u=this,_=0;return reify(this,this.toSeq().map((function(w,x){return s.call(i,[x,w],_++,u)})).fromEntrySeq())},mapKeys:function(s,i){var u=this;return reify(this,this.toSeq().flip().map((function(_,w){return s.call(i,_,w,u)})).flip())}});var yt=KeyedIterable.prototype;function keyMapper(s,i){return i}function entryMapper(s,i){return[i,s]}function not(s){return function(){return!s.apply(this,arguments)}}function neg(s){return function(){return-s.apply(this,arguments)}}function quoteString(s){return"string"==typeof s?JSON.stringify(s):String(s)}function defaultZipper(){return arrCopy(arguments)}function defaultNegComparator(s,i){return si?-1:0}function hashIterable(s){if(s.size===1/0)return 0;var i=isOrdered(s),u=isKeyed(s),_=i?1:0;return murmurHashOfSize(s.__iterate(u?i?function(s,i){_=31*_+hashMerge(hash(s),hash(i))|0}:function(s,i){_=_+hashMerge(hash(s),hash(i))|0}:i?function(s){_=31*_+hash(s)|0}:function(s){_=_+hash(s)|0}),_)}function murmurHashOfSize(s,i){return i=be(i,3432918353),i=be(i<<15|i>>>-15,461845907),i=be(i<<13|i>>>-13,5),i=be((i=(i+3864292196|0)^s)^i>>>16,2246822507),i=smi((i=be(i^i>>>13,3266489909))^i>>>16)}function hashMerge(s,i){return s^i+2654435769+(s<<6)+(s>>2)|0}return yt[u]=!0,yt[ce]=gt.entries,yt.__toJS=gt.toObject,yt.__toStringMapper=function(s,i){return JSON.stringify(i)+": "+quoteString(s)},mixin(IndexedIterable,{toKeyedSeq:function(){return new ToKeyedSequence(this,!1)},filter:function(s,i){return reify(this,filterFactory(this,s,i,!1))},findIndex:function(s,i){var u=this.findEntry(s,i);return u?u[0]:-1},indexOf:function(s){var i=this.keyOf(s);return void 0===i?-1:i},lastIndexOf:function(s){var i=this.lastKeyOf(s);return void 0===i?-1:i},reverse:function(){return reify(this,reverseFactory(this,!1))},slice:function(s,i){return reify(this,sliceFactory(this,s,i,!1))},splice:function(s,i){var u=arguments.length;if(i=Math.max(0|i,0),0===u||2===u&&!i)return this;s=resolveBegin(s,s<0?this.count():this.size);var _=this.slice(0,s);return reify(this,1===u?_:_.concat(arrCopy(arguments,2),this.slice(s+i)))},findLastIndex:function(s,i){var u=this.findLastEntry(s,i);return u?u[0]:-1},first:function(){return this.get(0)},flatten:function(s){return reify(this,flattenFactory(this,s,!1))},get:function(s,i){return(s=wrapIndex(this,s))<0||this.size===1/0||void 0!==this.size&&s>this.size?i:this.find((function(i,u){return u===s}),void 0,i)},has:function(s){return(s=wrapIndex(this,s))>=0&&(void 0!==this.size?this.size===1/0||s{"function"==typeof Object.create?s.exports=function inherits(s,i){i&&(s.super_=i,s.prototype=Object.create(i.prototype,{constructor:{value:s,enumerable:!1,writable:!0,configurable:!0}}))}:s.exports=function inherits(s,i){if(i){s.super_=i;var TempCtor=function(){};TempCtor.prototype=i.prototype,s.prototype=new TempCtor,s.prototype.constructor=s}}},5419:s=>{s.exports=function(s,i,u,_){var w=new Blob(void 0!==_?[_,s]:[s],{type:u||"application/octet-stream"});if(void 0!==window.navigator.msSaveBlob)window.navigator.msSaveBlob(w,i);else{var x=window.URL&&window.URL.createObjectURL?window.URL.createObjectURL(w):window.webkitURL.createObjectURL(w),j=document.createElement("a");j.style.display="none",j.href=x,j.setAttribute("download",i),void 0===j.download&&j.setAttribute("target","_blank"),document.body.appendChild(j),j.click(),setTimeout((function(){document.body.removeChild(j),window.URL.revokeObjectURL(x)}),200)}}},20181:(s,i,u)=>{var _=NaN,w="[object Symbol]",x=/^\s+|\s+$/g,j=/^[-+]0x[0-9a-f]+$/i,L=/^0b[01]+$/i,B=/^0o[0-7]+$/i,$=parseInt,U="object"==typeof u.g&&u.g&&u.g.Object===Object&&u.g,Y="object"==typeof self&&self&&self.Object===Object&&self,Z=U||Y||Function("return this")(),ee=Object.prototype.toString,ie=Math.max,ae=Math.min,now=function(){return Z.Date.now()};function isObject(s){var i=typeof s;return!!s&&("object"==i||"function"==i)}function toNumber(s){if("number"==typeof s)return s;if(function isSymbol(s){return"symbol"==typeof s||function isObjectLike(s){return!!s&&"object"==typeof s}(s)&&ee.call(s)==w}(s))return _;if(isObject(s)){var i="function"==typeof s.valueOf?s.valueOf():s;s=isObject(i)?i+"":i}if("string"!=typeof s)return 0===s?s:+s;s=s.replace(x,"");var u=L.test(s);return u||B.test(s)?$(s.slice(2),u?2:8):j.test(s)?_:+s}s.exports=function debounce(s,i,u){var _,w,x,j,L,B,$=0,U=!1,Y=!1,Z=!0;if("function"!=typeof s)throw new TypeError("Expected a function");function invokeFunc(i){var u=_,x=w;return _=w=void 0,$=i,j=s.apply(x,u)}function shouldInvoke(s){var u=s-B;return void 0===B||u>=i||u<0||Y&&s-$>=x}function timerExpired(){var s=now();if(shouldInvoke(s))return trailingEdge(s);L=setTimeout(timerExpired,function remainingWait(s){var u=i-(s-B);return Y?ae(u,x-(s-$)):u}(s))}function trailingEdge(s){return L=void 0,Z&&_?invokeFunc(s):(_=w=void 0,j)}function debounced(){var s=now(),u=shouldInvoke(s);if(_=arguments,w=this,B=s,u){if(void 0===L)return function leadingEdge(s){return $=s,L=setTimeout(timerExpired,i),U?invokeFunc(s):j}(B);if(Y)return L=setTimeout(timerExpired,i),invokeFunc(B)}return void 0===L&&(L=setTimeout(timerExpired,i)),j}return i=toNumber(i)||0,isObject(u)&&(U=!!u.leading,x=(Y="maxWait"in u)?ie(toNumber(u.maxWait)||0,i):x,Z="trailing"in u?!!u.trailing:Z),debounced.cancel=function cancel(){void 0!==L&&clearTimeout(L),$=0,_=B=w=L=void 0},debounced.flush=function flush(){return void 0===L?j:trailingEdge(now())},debounced}},55580:(s,i,u)=>{var _=u(56110)(u(9325),"DataView");s.exports=_},21549:(s,i,u)=>{var _=u(22032),w=u(63862),x=u(66721),j=u(12749),L=u(35749);function Hash(s){var i=-1,u=null==s?0:s.length;for(this.clear();++i{var _=u(39344),w=u(94033);function LazyWrapper(s){this.__wrapped__=s,this.__actions__=[],this.__dir__=1,this.__filtered__=!1,this.__iteratees__=[],this.__takeCount__=4294967295,this.__views__=[]}LazyWrapper.prototype=_(w.prototype),LazyWrapper.prototype.constructor=LazyWrapper,s.exports=LazyWrapper},80079:(s,i,u)=>{var _=u(63702),w=u(70080),x=u(24739),j=u(48655),L=u(31175);function ListCache(s){var i=-1,u=null==s?0:s.length;for(this.clear();++i{var _=u(39344),w=u(94033);function LodashWrapper(s,i){this.__wrapped__=s,this.__actions__=[],this.__chain__=!!i,this.__index__=0,this.__values__=void 0}LodashWrapper.prototype=_(w.prototype),LodashWrapper.prototype.constructor=LodashWrapper,s.exports=LodashWrapper},68223:(s,i,u)=>{var _=u(56110)(u(9325),"Map");s.exports=_},53661:(s,i,u)=>{var _=u(63040),w=u(17670),x=u(90289),j=u(4509),L=u(72949);function MapCache(s){var i=-1,u=null==s?0:s.length;for(this.clear();++i{var _=u(56110)(u(9325),"Promise");s.exports=_},76545:(s,i,u)=>{var _=u(56110)(u(9325),"Set");s.exports=_},38859:(s,i,u)=>{var _=u(53661),w=u(31380),x=u(51459);function SetCache(s){var i=-1,u=null==s?0:s.length;for(this.__data__=new _;++i{var _=u(80079),w=u(51420),x=u(90938),j=u(63605),L=u(29817),B=u(80945);function Stack(s){var i=this.__data__=new _(s);this.size=i.size}Stack.prototype.clear=w,Stack.prototype.delete=x,Stack.prototype.get=j,Stack.prototype.has=L,Stack.prototype.set=B,s.exports=Stack},51873:(s,i,u)=>{var _=u(9325).Symbol;s.exports=_},37828:(s,i,u)=>{var _=u(9325).Uint8Array;s.exports=_},28303:(s,i,u)=>{var _=u(56110)(u(9325),"WeakMap");s.exports=_},91033:s=>{s.exports=function apply(s,i,u){switch(u.length){case 0:return s.call(i);case 1:return s.call(i,u[0]);case 2:return s.call(i,u[0],u[1]);case 3:return s.call(i,u[0],u[1],u[2])}return s.apply(i,u)}},83729:s=>{s.exports=function arrayEach(s,i){for(var u=-1,_=null==s?0:s.length;++u<_&&!1!==i(s[u],u,s););return s}},79770:s=>{s.exports=function arrayFilter(s,i){for(var u=-1,_=null==s?0:s.length,w=0,x=[];++u<_;){var j=s[u];i(j,u,s)&&(x[w++]=j)}return x}},15325:(s,i,u)=>{var _=u(96131);s.exports=function arrayIncludes(s,i){return!!(null==s?0:s.length)&&_(s,i,0)>-1}},70695:(s,i,u)=>{var _=u(78096),w=u(72428),x=u(56449),j=u(3656),L=u(30361),B=u(37167),$=Object.prototype.hasOwnProperty;s.exports=function arrayLikeKeys(s,i){var u=x(s),U=!u&&w(s),Y=!u&&!U&&j(s),Z=!u&&!U&&!Y&&B(s),ee=u||U||Y||Z,ie=ee?_(s.length,String):[],ae=ie.length;for(var le in s)!i&&!$.call(s,le)||ee&&("length"==le||Y&&("offset"==le||"parent"==le)||Z&&("buffer"==le||"byteLength"==le||"byteOffset"==le)||L(le,ae))||ie.push(le);return ie}},34932:s=>{s.exports=function arrayMap(s,i){for(var u=-1,_=null==s?0:s.length,w=Array(_);++u<_;)w[u]=i(s[u],u,s);return w}},14528:s=>{s.exports=function arrayPush(s,i){for(var u=-1,_=i.length,w=s.length;++u<_;)s[w+u]=i[u];return s}},40882:s=>{s.exports=function arrayReduce(s,i,u,_){var w=-1,x=null==s?0:s.length;for(_&&x&&(u=s[++w]);++w{s.exports=function arraySome(s,i){for(var u=-1,_=null==s?0:s.length;++u<_;)if(i(s[u],u,s))return!0;return!1}},61074:s=>{s.exports=function asciiToArray(s){return s.split("")}},1733:s=>{var i=/[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g;s.exports=function asciiWords(s){return s.match(i)||[]}},87805:(s,i,u)=>{var _=u(43360),w=u(75288);s.exports=function assignMergeValue(s,i,u){(void 0!==u&&!w(s[i],u)||void 0===u&&!(i in s))&&_(s,i,u)}},16547:(s,i,u)=>{var _=u(43360),w=u(75288),x=Object.prototype.hasOwnProperty;s.exports=function assignValue(s,i,u){var j=s[i];x.call(s,i)&&w(j,u)&&(void 0!==u||i in s)||_(s,i,u)}},26025:(s,i,u)=>{var _=u(75288);s.exports=function assocIndexOf(s,i){for(var u=s.length;u--;)if(_(s[u][0],i))return u;return-1}},74733:(s,i,u)=>{var _=u(21791),w=u(95950);s.exports=function baseAssign(s,i){return s&&_(i,w(i),s)}},43838:(s,i,u)=>{var _=u(21791),w=u(37241);s.exports=function baseAssignIn(s,i){return s&&_(i,w(i),s)}},43360:(s,i,u)=>{var _=u(93243);s.exports=function baseAssignValue(s,i,u){"__proto__"==i&&_?_(s,i,{configurable:!0,enumerable:!0,value:u,writable:!0}):s[i]=u}},9999:(s,i,u)=>{var _=u(37217),w=u(83729),x=u(16547),j=u(74733),L=u(43838),B=u(93290),$=u(23007),U=u(92271),Y=u(48948),Z=u(50002),ee=u(83349),ie=u(5861),ae=u(76189),le=u(77199),ce=u(35529),pe=u(56449),de=u(3656),fe=u(87730),ye=u(23805),be=u(38440),_e=u(95950),we=u(37241),Se="[object Arguments]",xe="[object Function]",Pe="[object Object]",Te={};Te[Se]=Te["[object Array]"]=Te["[object ArrayBuffer]"]=Te["[object DataView]"]=Te["[object Boolean]"]=Te["[object Date]"]=Te["[object Float32Array]"]=Te["[object Float64Array]"]=Te["[object Int8Array]"]=Te["[object Int16Array]"]=Te["[object Int32Array]"]=Te["[object Map]"]=Te["[object Number]"]=Te[Pe]=Te["[object RegExp]"]=Te["[object Set]"]=Te["[object String]"]=Te["[object Symbol]"]=Te["[object Uint8Array]"]=Te["[object Uint8ClampedArray]"]=Te["[object Uint16Array]"]=Te["[object Uint32Array]"]=!0,Te["[object Error]"]=Te[xe]=Te["[object WeakMap]"]=!1,s.exports=function baseClone(s,i,u,Re,qe,$e){var ze,We=1&i,He=2&i,Ye=4&i;if(u&&(ze=qe?u(s,Re,qe,$e):u(s)),void 0!==ze)return ze;if(!ye(s))return s;var Xe=pe(s);if(Xe){if(ze=ae(s),!We)return $(s,ze)}else{var Qe=ie(s),et=Qe==xe||"[object GeneratorFunction]"==Qe;if(de(s))return B(s,We);if(Qe==Pe||Qe==Se||et&&!qe){if(ze=He||et?{}:ce(s),!We)return He?Y(s,L(ze,s)):U(s,j(ze,s))}else{if(!Te[Qe])return qe?s:{};ze=le(s,Qe,We)}}$e||($e=new _);var tt=$e.get(s);if(tt)return tt;$e.set(s,ze),be(s)?s.forEach((function(_){ze.add(baseClone(_,i,u,_,s,$e))})):fe(s)&&s.forEach((function(_,w){ze.set(w,baseClone(_,i,u,w,s,$e))}));var rt=Xe?void 0:(Ye?He?ee:Z:He?we:_e)(s);return w(rt||s,(function(_,w){rt&&(_=s[w=_]),x(ze,w,baseClone(_,i,u,w,s,$e))})),ze}},39344:(s,i,u)=>{var _=u(23805),w=Object.create,x=function(){function object(){}return function(s){if(!_(s))return{};if(w)return w(s);object.prototype=s;var i=new object;return object.prototype=void 0,i}}();s.exports=x},80909:(s,i,u)=>{var _=u(30641),w=u(38329)(_);s.exports=w},2523:s=>{s.exports=function baseFindIndex(s,i,u,_){for(var w=s.length,x=u+(_?1:-1);_?x--:++x{var _=u(14528),w=u(45891);s.exports=function baseFlatten(s,i,u,x,j){var L=-1,B=s.length;for(u||(u=w),j||(j=[]);++L0&&u($)?i>1?baseFlatten($,i-1,u,x,j):_(j,$):x||(j[j.length]=$)}return j}},86649:(s,i,u)=>{var _=u(83221)();s.exports=_},30641:(s,i,u)=>{var _=u(86649),w=u(95950);s.exports=function baseForOwn(s,i){return s&&_(s,i,w)}},47422:(s,i,u)=>{var _=u(31769),w=u(77797);s.exports=function baseGet(s,i){for(var u=0,x=(i=_(i,s)).length;null!=s&&u{var _=u(14528),w=u(56449);s.exports=function baseGetAllKeys(s,i,u){var x=i(s);return w(s)?x:_(x,u(s))}},72552:(s,i,u)=>{var _=u(51873),w=u(659),x=u(59350),j=_?_.toStringTag:void 0;s.exports=function baseGetTag(s){return null==s?void 0===s?"[object Undefined]":"[object Null]":j&&j in Object(s)?w(s):x(s)}},20426:s=>{var i=Object.prototype.hasOwnProperty;s.exports=function baseHas(s,u){return null!=s&&i.call(s,u)}},28077:s=>{s.exports=function baseHasIn(s,i){return null!=s&&i in Object(s)}},96131:(s,i,u)=>{var _=u(2523),w=u(85463),x=u(76959);s.exports=function baseIndexOf(s,i,u){return i==i?x(s,i,u):_(s,w,u)}},27534:(s,i,u)=>{var _=u(72552),w=u(40346);s.exports=function baseIsArguments(s){return w(s)&&"[object Arguments]"==_(s)}},60270:(s,i,u)=>{var _=u(87068),w=u(40346);s.exports=function baseIsEqual(s,i,u,x,j){return s===i||(null==s||null==i||!w(s)&&!w(i)?s!=s&&i!=i:_(s,i,u,x,baseIsEqual,j))}},87068:(s,i,u)=>{var _=u(37217),w=u(25911),x=u(21986),j=u(50689),L=u(5861),B=u(56449),$=u(3656),U=u(37167),Y="[object Arguments]",Z="[object Array]",ee="[object Object]",ie=Object.prototype.hasOwnProperty;s.exports=function baseIsEqualDeep(s,i,u,ae,le,ce){var pe=B(s),de=B(i),fe=pe?Z:L(s),ye=de?Z:L(i),be=(fe=fe==Y?ee:fe)==ee,_e=(ye=ye==Y?ee:ye)==ee,we=fe==ye;if(we&&$(s)){if(!$(i))return!1;pe=!0,be=!1}if(we&&!be)return ce||(ce=new _),pe||U(s)?w(s,i,u,ae,le,ce):x(s,i,fe,u,ae,le,ce);if(!(1&u)){var Se=be&&ie.call(s,"__wrapped__"),xe=_e&&ie.call(i,"__wrapped__");if(Se||xe){var Pe=Se?s.value():s,Te=xe?i.value():i;return ce||(ce=new _),le(Pe,Te,u,ae,ce)}}return!!we&&(ce||(ce=new _),j(s,i,u,ae,le,ce))}},29172:(s,i,u)=>{var _=u(5861),w=u(40346);s.exports=function baseIsMap(s){return w(s)&&"[object Map]"==_(s)}},41799:(s,i,u)=>{var _=u(37217),w=u(60270);s.exports=function baseIsMatch(s,i,u,x){var j=u.length,L=j,B=!x;if(null==s)return!L;for(s=Object(s);j--;){var $=u[j];if(B&&$[2]?$[1]!==s[$[0]]:!($[0]in s))return!1}for(;++j{s.exports=function baseIsNaN(s){return s!=s}},45083:(s,i,u)=>{var _=u(1882),w=u(87296),x=u(23805),j=u(47473),L=/^\[object .+?Constructor\]$/,B=Function.prototype,$=Object.prototype,U=B.toString,Y=$.hasOwnProperty,Z=RegExp("^"+U.call(Y).replace(/[\\^$.*+?()[\]{}|]/g,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");s.exports=function baseIsNative(s){return!(!x(s)||w(s))&&(_(s)?Z:L).test(j(s))}},16038:(s,i,u)=>{var _=u(5861),w=u(40346);s.exports=function baseIsSet(s){return w(s)&&"[object Set]"==_(s)}},4901:(s,i,u)=>{var _=u(72552),w=u(30294),x=u(40346),j={};j["[object Float32Array]"]=j["[object Float64Array]"]=j["[object Int8Array]"]=j["[object Int16Array]"]=j["[object Int32Array]"]=j["[object Uint8Array]"]=j["[object Uint8ClampedArray]"]=j["[object Uint16Array]"]=j["[object Uint32Array]"]=!0,j["[object Arguments]"]=j["[object Array]"]=j["[object ArrayBuffer]"]=j["[object Boolean]"]=j["[object DataView]"]=j["[object Date]"]=j["[object Error]"]=j["[object Function]"]=j["[object Map]"]=j["[object Number]"]=j["[object Object]"]=j["[object RegExp]"]=j["[object Set]"]=j["[object String]"]=j["[object WeakMap]"]=!1,s.exports=function baseIsTypedArray(s){return x(s)&&w(s.length)&&!!j[_(s)]}},15389:(s,i,u)=>{var _=u(93663),w=u(87978),x=u(83488),j=u(56449),L=u(50583);s.exports=function baseIteratee(s){return"function"==typeof s?s:null==s?x:"object"==typeof s?j(s)?w(s[0],s[1]):_(s):L(s)}},88984:(s,i,u)=>{var _=u(55527),w=u(3650),x=Object.prototype.hasOwnProperty;s.exports=function baseKeys(s){if(!_(s))return w(s);var i=[];for(var u in Object(s))x.call(s,u)&&"constructor"!=u&&i.push(u);return i}},72903:(s,i,u)=>{var _=u(23805),w=u(55527),x=u(90181),j=Object.prototype.hasOwnProperty;s.exports=function baseKeysIn(s){if(!_(s))return x(s);var i=w(s),u=[];for(var L in s)("constructor"!=L||!i&&j.call(s,L))&&u.push(L);return u}},94033:s=>{s.exports=function baseLodash(){}},93663:(s,i,u)=>{var _=u(41799),w=u(10776),x=u(67197);s.exports=function baseMatches(s){var i=w(s);return 1==i.length&&i[0][2]?x(i[0][0],i[0][1]):function(u){return u===s||_(u,s,i)}}},87978:(s,i,u)=>{var _=u(60270),w=u(58156),x=u(80631),j=u(28586),L=u(30756),B=u(67197),$=u(77797);s.exports=function baseMatchesProperty(s,i){return j(s)&&L(i)?B($(s),i):function(u){var j=w(u,s);return void 0===j&&j===i?x(u,s):_(i,j,3)}}},85250:(s,i,u)=>{var _=u(37217),w=u(87805),x=u(86649),j=u(42824),L=u(23805),B=u(37241),$=u(14974);s.exports=function baseMerge(s,i,u,U,Y){s!==i&&x(i,(function(x,B){if(Y||(Y=new _),L(x))j(s,i,B,u,baseMerge,U,Y);else{var Z=U?U($(s,B),x,B+"",s,i,Y):void 0;void 0===Z&&(Z=x),w(s,B,Z)}}),B)}},42824:(s,i,u)=>{var _=u(87805),w=u(93290),x=u(71961),j=u(23007),L=u(35529),B=u(72428),$=u(56449),U=u(83693),Y=u(3656),Z=u(1882),ee=u(23805),ie=u(11331),ae=u(37167),le=u(14974),ce=u(69884);s.exports=function baseMergeDeep(s,i,u,pe,de,fe,ye){var be=le(s,u),_e=le(i,u),we=ye.get(_e);if(we)_(s,u,we);else{var Se=fe?fe(be,_e,u+"",s,i,ye):void 0,xe=void 0===Se;if(xe){var Pe=$(_e),Te=!Pe&&Y(_e),Re=!Pe&&!Te&&ae(_e);Se=_e,Pe||Te||Re?$(be)?Se=be:U(be)?Se=j(be):Te?(xe=!1,Se=w(_e,!0)):Re?(xe=!1,Se=x(_e,!0)):Se=[]:ie(_e)||B(_e)?(Se=be,B(be)?Se=ce(be):ee(be)&&!Z(be)||(Se=L(_e))):xe=!1}xe&&(ye.set(_e,Se),de(Se,_e,pe,fe,ye),ye.delete(_e)),_(s,u,Se)}}},47237:s=>{s.exports=function baseProperty(s){return function(i){return null==i?void 0:i[s]}}},17255:(s,i,u)=>{var _=u(47422);s.exports=function basePropertyDeep(s){return function(i){return _(i,s)}}},54552:s=>{s.exports=function basePropertyOf(s){return function(i){return null==s?void 0:s[i]}}},85558:s=>{s.exports=function baseReduce(s,i,u,_,w){return w(s,(function(s,w,x){u=_?(_=!1,s):i(u,s,w,x)})),u}},69302:(s,i,u)=>{var _=u(83488),w=u(56757),x=u(32865);s.exports=function baseRest(s,i){return x(w(s,i,_),s+"")}},73170:(s,i,u)=>{var _=u(16547),w=u(31769),x=u(30361),j=u(23805),L=u(77797);s.exports=function baseSet(s,i,u,B){if(!j(s))return s;for(var $=-1,U=(i=w(i,s)).length,Y=U-1,Z=s;null!=Z&&++${var _=u(83488),w=u(48152),x=w?function(s,i){return w.set(s,i),s}:_;s.exports=x},19570:(s,i,u)=>{var _=u(37334),w=u(93243),x=u(83488),j=w?function(s,i){return w(s,"toString",{configurable:!0,enumerable:!1,value:_(i),writable:!0})}:x;s.exports=j},25160:s=>{s.exports=function baseSlice(s,i,u){var _=-1,w=s.length;i<0&&(i=-i>w?0:w+i),(u=u>w?w:u)<0&&(u+=w),w=i>u?0:u-i>>>0,i>>>=0;for(var x=Array(w);++_{var _=u(80909);s.exports=function baseSome(s,i){var u;return _(s,(function(s,_,w){return!(u=i(s,_,w))})),!!u}},78096:s=>{s.exports=function baseTimes(s,i){for(var u=-1,_=Array(s);++u{var _=u(51873),w=u(34932),x=u(56449),j=u(44394),L=_?_.prototype:void 0,B=L?L.toString:void 0;s.exports=function baseToString(s){if("string"==typeof s)return s;if(x(s))return w(s,baseToString)+"";if(j(s))return B?B.call(s):"";var i=s+"";return"0"==i&&1/s==-Infinity?"-0":i}},54128:(s,i,u)=>{var _=u(31800),w=/^\s+/;s.exports=function baseTrim(s){return s?s.slice(0,_(s)+1).replace(w,""):s}},27301:s=>{s.exports=function baseUnary(s){return function(i){return s(i)}}},19931:(s,i,u)=>{var _=u(31769),w=u(68090),x=u(68969),j=u(77797);s.exports=function baseUnset(s,i){return i=_(i,s),null==(s=x(s,i))||delete s[j(w(i))]}},51234:s=>{s.exports=function baseZipObject(s,i,u){for(var _=-1,w=s.length,x=i.length,j={};++_{s.exports=function cacheHas(s,i){return s.has(i)}},31769:(s,i,u)=>{var _=u(56449),w=u(28586),x=u(61802),j=u(13222);s.exports=function castPath(s,i){return _(s)?s:w(s,i)?[s]:x(j(s))}},28754:(s,i,u)=>{var _=u(25160);s.exports=function castSlice(s,i,u){var w=s.length;return u=void 0===u?w:u,!i&&u>=w?s:_(s,i,u)}},49653:(s,i,u)=>{var _=u(37828);s.exports=function cloneArrayBuffer(s){var i=new s.constructor(s.byteLength);return new _(i).set(new _(s)),i}},93290:(s,i,u)=>{s=u.nmd(s);var _=u(9325),w=i&&!i.nodeType&&i,x=w&&s&&!s.nodeType&&s,j=x&&x.exports===w?_.Buffer:void 0,L=j?j.allocUnsafe:void 0;s.exports=function cloneBuffer(s,i){if(i)return s.slice();var u=s.length,_=L?L(u):new s.constructor(u);return s.copy(_),_}},76169:(s,i,u)=>{var _=u(49653);s.exports=function cloneDataView(s,i){var u=i?_(s.buffer):s.buffer;return new s.constructor(u,s.byteOffset,s.byteLength)}},73201:s=>{var i=/\w*$/;s.exports=function cloneRegExp(s){var u=new s.constructor(s.source,i.exec(s));return u.lastIndex=s.lastIndex,u}},93736:(s,i,u)=>{var _=u(51873),w=_?_.prototype:void 0,x=w?w.valueOf:void 0;s.exports=function cloneSymbol(s){return x?Object(x.call(s)):{}}},71961:(s,i,u)=>{var _=u(49653);s.exports=function cloneTypedArray(s,i){var u=i?_(s.buffer):s.buffer;return new s.constructor(u,s.byteOffset,s.length)}},91596:s=>{var i=Math.max;s.exports=function composeArgs(s,u,_,w){for(var x=-1,j=s.length,L=_.length,B=-1,$=u.length,U=i(j-L,0),Y=Array($+U),Z=!w;++B<$;)Y[B]=u[B];for(;++x{var i=Math.max;s.exports=function composeArgsRight(s,u,_,w){for(var x=-1,j=s.length,L=-1,B=_.length,$=-1,U=u.length,Y=i(j-B,0),Z=Array(Y+U),ee=!w;++x{s.exports=function copyArray(s,i){var u=-1,_=s.length;for(i||(i=Array(_));++u<_;)i[u]=s[u];return i}},21791:(s,i,u)=>{var _=u(16547),w=u(43360);s.exports=function copyObject(s,i,u,x){var j=!u;u||(u={});for(var L=-1,B=i.length;++L{var _=u(21791),w=u(4664);s.exports=function copySymbols(s,i){return _(s,w(s),i)}},48948:(s,i,u)=>{var _=u(21791),w=u(86375);s.exports=function copySymbolsIn(s,i){return _(s,w(s),i)}},55481:(s,i,u)=>{var _=u(9325)["__core-js_shared__"];s.exports=_},58523:s=>{s.exports=function countHolders(s,i){for(var u=s.length,_=0;u--;)s[u]===i&&++_;return _}},20999:(s,i,u)=>{var _=u(69302),w=u(36800);s.exports=function createAssigner(s){return _((function(i,u){var _=-1,x=u.length,j=x>1?u[x-1]:void 0,L=x>2?u[2]:void 0;for(j=s.length>3&&"function"==typeof j?(x--,j):void 0,L&&w(u[0],u[1],L)&&(j=x<3?void 0:j,x=1),i=Object(i);++_{var _=u(64894);s.exports=function createBaseEach(s,i){return function(u,w){if(null==u)return u;if(!_(u))return s(u,w);for(var x=u.length,j=i?x:-1,L=Object(u);(i?j--:++j{s.exports=function createBaseFor(s){return function(i,u,_){for(var w=-1,x=Object(i),j=_(i),L=j.length;L--;){var B=j[s?L:++w];if(!1===u(x[B],B,x))break}return i}}},11842:(s,i,u)=>{var _=u(82819),w=u(9325);s.exports=function createBind(s,i,u){var x=1&i,j=_(s);return function wrapper(){return(this&&this!==w&&this instanceof wrapper?j:s).apply(x?u:this,arguments)}}},12507:(s,i,u)=>{var _=u(28754),w=u(49698),x=u(63912),j=u(13222);s.exports=function createCaseFirst(s){return function(i){i=j(i);var u=w(i)?x(i):void 0,L=u?u[0]:i.charAt(0),B=u?_(u,1).join(""):i.slice(1);return L[s]()+B}}},45539:(s,i,u)=>{var _=u(40882),w=u(50828),x=u(66645),j=RegExp("['’]","g");s.exports=function createCompounder(s){return function(i){return _(x(w(i).replace(j,"")),s,"")}}},82819:(s,i,u)=>{var _=u(39344),w=u(23805);s.exports=function createCtor(s){return function(){var i=arguments;switch(i.length){case 0:return new s;case 1:return new s(i[0]);case 2:return new s(i[0],i[1]);case 3:return new s(i[0],i[1],i[2]);case 4:return new s(i[0],i[1],i[2],i[3]);case 5:return new s(i[0],i[1],i[2],i[3],i[4]);case 6:return new s(i[0],i[1],i[2],i[3],i[4],i[5]);case 7:return new s(i[0],i[1],i[2],i[3],i[4],i[5],i[6])}var u=_(s.prototype),x=s.apply(u,i);return w(x)?x:u}}},77078:(s,i,u)=>{var _=u(91033),w=u(82819),x=u(37471),j=u(18073),L=u(11287),B=u(36306),$=u(9325);s.exports=function createCurry(s,i,u){var U=w(s);return function wrapper(){for(var w=arguments.length,Y=Array(w),Z=w,ee=L(wrapper);Z--;)Y[Z]=arguments[Z];var ie=w<3&&Y[0]!==ee&&Y[w-1]!==ee?[]:B(Y,ee);return(w-=ie.length){var _=u(15389),w=u(64894),x=u(95950);s.exports=function createFind(s){return function(i,u,j){var L=Object(i);if(!w(i)){var B=_(u,3);i=x(i),u=function(s){return B(L[s],s,L)}}var $=s(i,u,j);return $>-1?L[B?i[$]:$]:void 0}}},37471:(s,i,u)=>{var _=u(91596),w=u(53320),x=u(58523),j=u(82819),L=u(18073),B=u(11287),$=u(68294),U=u(36306),Y=u(9325);s.exports=function createHybrid(s,i,u,Z,ee,ie,ae,le,ce,pe){var de=128&i,fe=1&i,ye=2&i,be=24&i,_e=512&i,we=ye?void 0:j(s);return function wrapper(){for(var Se=arguments.length,xe=Array(Se),Pe=Se;Pe--;)xe[Pe]=arguments[Pe];if(be)var Te=B(wrapper),Re=x(xe,Te);if(Z&&(xe=_(xe,Z,ee,be)),ie&&(xe=w(xe,ie,ae,be)),Se-=Re,be&&Se1&&xe.reverse(),de&&ce{var _=u(91033),w=u(82819),x=u(9325);s.exports=function createPartial(s,i,u,j){var L=1&i,B=w(s);return function wrapper(){for(var i=-1,w=arguments.length,$=-1,U=j.length,Y=Array(U+w),Z=this&&this!==x&&this instanceof wrapper?B:s;++${var _=u(85087),w=u(54641),x=u(70981);s.exports=function createRecurry(s,i,u,j,L,B,$,U,Y,Z){var ee=8&i;i|=ee?32:64,4&(i&=~(ee?64:32))||(i&=-4);var ie=[s,i,L,ee?B:void 0,ee?$:void 0,ee?void 0:B,ee?void 0:$,U,Y,Z],ae=u.apply(void 0,ie);return _(s)&&w(ae,ie),ae.placeholder=j,x(ae,s,i)}},66977:(s,i,u)=>{var _=u(68882),w=u(11842),x=u(77078),j=u(37471),L=u(24168),B=u(37381),$=u(3209),U=u(54641),Y=u(70981),Z=u(61489),ee=Math.max;s.exports=function createWrap(s,i,u,ie,ae,le,ce,pe){var de=2&i;if(!de&&"function"!=typeof s)throw new TypeError("Expected a function");var fe=ie?ie.length:0;if(fe||(i&=-97,ie=ae=void 0),ce=void 0===ce?ce:ee(Z(ce),0),pe=void 0===pe?pe:Z(pe),fe-=ae?ae.length:0,64&i){var ye=ie,be=ae;ie=ae=void 0}var _e=de?void 0:B(s),we=[s,i,u,ie,ae,ye,be,le,ce,pe];if(_e&&$(we,_e),s=we[0],i=we[1],u=we[2],ie=we[3],ae=we[4],!(pe=we[9]=void 0===we[9]?de?0:s.length:ee(we[9]-fe,0))&&24&i&&(i&=-25),i&&1!=i)Se=8==i||16==i?x(s,i,pe):32!=i&&33!=i||ae.length?j.apply(void 0,we):L(s,i,u,ie);else var Se=w(s,i,u);return Y((_e?_:U)(Se,we),s,i)}},53138:(s,i,u)=>{var _=u(11331);s.exports=function customOmitClone(s){return _(s)?void 0:s}},24647:(s,i,u)=>{var _=u(54552)({À:"A",Á:"A",Â:"A",Ã:"A",Ä:"A",Å:"A",à:"a",á:"a",â:"a",ã:"a",ä:"a",å:"a",Ç:"C",ç:"c",Ð:"D",ð:"d",È:"E",É:"E",Ê:"E",Ë:"E",è:"e",é:"e",ê:"e",ë:"e",Ì:"I",Í:"I",Î:"I",Ï:"I",ì:"i",í:"i",î:"i",ï:"i",Ñ:"N",ñ:"n",Ò:"O",Ó:"O",Ô:"O",Õ:"O",Ö:"O",Ø:"O",ò:"o",ó:"o",ô:"o",õ:"o",ö:"o",ø:"o",Ù:"U",Ú:"U",Û:"U",Ü:"U",ù:"u",ú:"u",û:"u",ü:"u",Ý:"Y",ý:"y",ÿ:"y",Æ:"Ae",æ:"ae",Þ:"Th",þ:"th",ß:"ss",Ā:"A",Ă:"A",Ą:"A",ā:"a",ă:"a",ą:"a",Ć:"C",Ĉ:"C",Ċ:"C",Č:"C",ć:"c",ĉ:"c",ċ:"c",č:"c",Ď:"D",Đ:"D",ď:"d",đ:"d",Ē:"E",Ĕ:"E",Ė:"E",Ę:"E",Ě:"E",ē:"e",ĕ:"e",ė:"e",ę:"e",ě:"e",Ĝ:"G",Ğ:"G",Ġ:"G",Ģ:"G",ĝ:"g",ğ:"g",ġ:"g",ģ:"g",Ĥ:"H",Ħ:"H",ĥ:"h",ħ:"h",Ĩ:"I",Ī:"I",Ĭ:"I",Į:"I",İ:"I",ĩ:"i",ī:"i",ĭ:"i",į:"i",ı:"i",Ĵ:"J",ĵ:"j",Ķ:"K",ķ:"k",ĸ:"k",Ĺ:"L",Ļ:"L",Ľ:"L",Ŀ:"L",Ł:"L",ĺ:"l",ļ:"l",ľ:"l",ŀ:"l",ł:"l",Ń:"N",Ņ:"N",Ň:"N",Ŋ:"N",ń:"n",ņ:"n",ň:"n",ŋ:"n",Ō:"O",Ŏ:"O",Ő:"O",ō:"o",ŏ:"o",ő:"o",Ŕ:"R",Ŗ:"R",Ř:"R",ŕ:"r",ŗ:"r",ř:"r",Ś:"S",Ŝ:"S",Ş:"S",Š:"S",ś:"s",ŝ:"s",ş:"s",š:"s",Ţ:"T",Ť:"T",Ŧ:"T",ţ:"t",ť:"t",ŧ:"t",Ũ:"U",Ū:"U",Ŭ:"U",Ů:"U",Ű:"U",Ų:"U",ũ:"u",ū:"u",ŭ:"u",ů:"u",ű:"u",ų:"u",Ŵ:"W",ŵ:"w",Ŷ:"Y",ŷ:"y",Ÿ:"Y",Ź:"Z",Ż:"Z",Ž:"Z",ź:"z",ż:"z",ž:"z",IJ:"IJ",ij:"ij",Œ:"Oe",œ:"oe",ʼn:"'n",ſ:"s"});s.exports=_},93243:(s,i,u)=>{var _=u(56110),w=function(){try{var s=_(Object,"defineProperty");return s({},"",{}),s}catch(s){}}();s.exports=w},25911:(s,i,u)=>{var _=u(38859),w=u(14248),x=u(19219);s.exports=function equalArrays(s,i,u,j,L,B){var $=1&u,U=s.length,Y=i.length;if(U!=Y&&!($&&Y>U))return!1;var Z=B.get(s),ee=B.get(i);if(Z&&ee)return Z==i&&ee==s;var ie=-1,ae=!0,le=2&u?new _:void 0;for(B.set(s,i),B.set(i,s);++ie{var _=u(51873),w=u(37828),x=u(75288),j=u(25911),L=u(20317),B=u(84247),$=_?_.prototype:void 0,U=$?$.valueOf:void 0;s.exports=function equalByTag(s,i,u,_,$,Y,Z){switch(u){case"[object DataView]":if(s.byteLength!=i.byteLength||s.byteOffset!=i.byteOffset)return!1;s=s.buffer,i=i.buffer;case"[object ArrayBuffer]":return!(s.byteLength!=i.byteLength||!Y(new w(s),new w(i)));case"[object Boolean]":case"[object Date]":case"[object Number]":return x(+s,+i);case"[object Error]":return s.name==i.name&&s.message==i.message;case"[object RegExp]":case"[object String]":return s==i+"";case"[object Map]":var ee=L;case"[object Set]":var ie=1&_;if(ee||(ee=B),s.size!=i.size&&!ie)return!1;var ae=Z.get(s);if(ae)return ae==i;_|=2,Z.set(s,i);var le=j(ee(s),ee(i),_,$,Y,Z);return Z.delete(s),le;case"[object Symbol]":if(U)return U.call(s)==U.call(i)}return!1}},50689:(s,i,u)=>{var _=u(50002),w=Object.prototype.hasOwnProperty;s.exports=function equalObjects(s,i,u,x,j,L){var B=1&u,$=_(s),U=$.length;if(U!=_(i).length&&!B)return!1;for(var Y=U;Y--;){var Z=$[Y];if(!(B?Z in i:w.call(i,Z)))return!1}var ee=L.get(s),ie=L.get(i);if(ee&&ie)return ee==i&&ie==s;var ae=!0;L.set(s,i),L.set(i,s);for(var le=B;++Y{var _=u(35970),w=u(56757),x=u(32865);s.exports=function flatRest(s){return x(w(s,void 0,_),s+"")}},34840:(s,i,u)=>{var _="object"==typeof u.g&&u.g&&u.g.Object===Object&&u.g;s.exports=_},50002:(s,i,u)=>{var _=u(82199),w=u(4664),x=u(95950);s.exports=function getAllKeys(s){return _(s,x,w)}},83349:(s,i,u)=>{var _=u(82199),w=u(86375),x=u(37241);s.exports=function getAllKeysIn(s){return _(s,x,w)}},37381:(s,i,u)=>{var _=u(48152),w=u(63950),x=_?function(s){return _.get(s)}:w;s.exports=x},62284:(s,i,u)=>{var _=u(84629),w=Object.prototype.hasOwnProperty;s.exports=function getFuncName(s){for(var i=s.name+"",u=_[i],x=w.call(_,i)?u.length:0;x--;){var j=u[x],L=j.func;if(null==L||L==s)return j.name}return i}},11287:s=>{s.exports=function getHolder(s){return s.placeholder}},12651:(s,i,u)=>{var _=u(74218);s.exports=function getMapData(s,i){var u=s.__data__;return _(i)?u["string"==typeof i?"string":"hash"]:u.map}},10776:(s,i,u)=>{var _=u(30756),w=u(95950);s.exports=function getMatchData(s){for(var i=w(s),u=i.length;u--;){var x=i[u],j=s[x];i[u]=[x,j,_(j)]}return i}},56110:(s,i,u)=>{var _=u(45083),w=u(10392);s.exports=function getNative(s,i){var u=w(s,i);return _(u)?u:void 0}},28879:(s,i,u)=>{var _=u(74335)(Object.getPrototypeOf,Object);s.exports=_},659:(s,i,u)=>{var _=u(51873),w=Object.prototype,x=w.hasOwnProperty,j=w.toString,L=_?_.toStringTag:void 0;s.exports=function getRawTag(s){var i=x.call(s,L),u=s[L];try{s[L]=void 0;var _=!0}catch(s){}var w=j.call(s);return _&&(i?s[L]=u:delete s[L]),w}},4664:(s,i,u)=>{var _=u(79770),w=u(63345),x=Object.prototype.propertyIsEnumerable,j=Object.getOwnPropertySymbols,L=j?function(s){return null==s?[]:(s=Object(s),_(j(s),(function(i){return x.call(s,i)})))}:w;s.exports=L},86375:(s,i,u)=>{var _=u(14528),w=u(28879),x=u(4664),j=u(63345),L=Object.getOwnPropertySymbols?function(s){for(var i=[];s;)_(i,x(s)),s=w(s);return i}:j;s.exports=L},5861:(s,i,u)=>{var _=u(55580),w=u(68223),x=u(32804),j=u(76545),L=u(28303),B=u(72552),$=u(47473),U="[object Map]",Y="[object Promise]",Z="[object Set]",ee="[object WeakMap]",ie="[object DataView]",ae=$(_),le=$(w),ce=$(x),pe=$(j),de=$(L),fe=B;(_&&fe(new _(new ArrayBuffer(1)))!=ie||w&&fe(new w)!=U||x&&fe(x.resolve())!=Y||j&&fe(new j)!=Z||L&&fe(new L)!=ee)&&(fe=function(s){var i=B(s),u="[object Object]"==i?s.constructor:void 0,_=u?$(u):"";if(_)switch(_){case ae:return ie;case le:return U;case ce:return Y;case pe:return Z;case de:return ee}return i}),s.exports=fe},10392:s=>{s.exports=function getValue(s,i){return null==s?void 0:s[i]}},75251:s=>{var i=/\{\n\/\* \[wrapped with (.+)\] \*/,u=/,? & /;s.exports=function getWrapDetails(s){var _=s.match(i);return _?_[1].split(u):[]}},49326:(s,i,u)=>{var _=u(31769),w=u(72428),x=u(56449),j=u(30361),L=u(30294),B=u(77797);s.exports=function hasPath(s,i,u){for(var $=-1,U=(i=_(i,s)).length,Y=!1;++${var i=RegExp("[\\u200d\\ud800-\\udfff\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff\\ufe0e\\ufe0f]");s.exports=function hasUnicode(s){return i.test(s)}},45434:s=>{var i=/[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/;s.exports=function hasUnicodeWord(s){return i.test(s)}},22032:(s,i,u)=>{var _=u(81042);s.exports=function hashClear(){this.__data__=_?_(null):{},this.size=0}},63862:s=>{s.exports=function hashDelete(s){var i=this.has(s)&&delete this.__data__[s];return this.size-=i?1:0,i}},66721:(s,i,u)=>{var _=u(81042),w=Object.prototype.hasOwnProperty;s.exports=function hashGet(s){var i=this.__data__;if(_){var u=i[s];return"__lodash_hash_undefined__"===u?void 0:u}return w.call(i,s)?i[s]:void 0}},12749:(s,i,u)=>{var _=u(81042),w=Object.prototype.hasOwnProperty;s.exports=function hashHas(s){var i=this.__data__;return _?void 0!==i[s]:w.call(i,s)}},35749:(s,i,u)=>{var _=u(81042);s.exports=function hashSet(s,i){var u=this.__data__;return this.size+=this.has(s)?0:1,u[s]=_&&void 0===i?"__lodash_hash_undefined__":i,this}},76189:s=>{var i=Object.prototype.hasOwnProperty;s.exports=function initCloneArray(s){var u=s.length,_=new s.constructor(u);return u&&"string"==typeof s[0]&&i.call(s,"index")&&(_.index=s.index,_.input=s.input),_}},77199:(s,i,u)=>{var _=u(49653),w=u(76169),x=u(73201),j=u(93736),L=u(71961);s.exports=function initCloneByTag(s,i,u){var B=s.constructor;switch(i){case"[object ArrayBuffer]":return _(s);case"[object Boolean]":case"[object Date]":return new B(+s);case"[object DataView]":return w(s,u);case"[object Float32Array]":case"[object Float64Array]":case"[object Int8Array]":case"[object Int16Array]":case"[object Int32Array]":case"[object Uint8Array]":case"[object Uint8ClampedArray]":case"[object Uint16Array]":case"[object Uint32Array]":return L(s,u);case"[object Map]":case"[object Set]":return new B;case"[object Number]":case"[object String]":return new B(s);case"[object RegExp]":return x(s);case"[object Symbol]":return j(s)}}},35529:(s,i,u)=>{var _=u(39344),w=u(28879),x=u(55527);s.exports=function initCloneObject(s){return"function"!=typeof s.constructor||x(s)?{}:_(w(s))}},62060:s=>{var i=/\{(?:\n\/\* \[wrapped with .+\] \*\/)?\n?/;s.exports=function insertWrapDetails(s,u){var _=u.length;if(!_)return s;var w=_-1;return u[w]=(_>1?"& ":"")+u[w],u=u.join(_>2?", ":" "),s.replace(i,"{\n/* [wrapped with "+u+"] */\n")}},45891:(s,i,u)=>{var _=u(51873),w=u(72428),x=u(56449),j=_?_.isConcatSpreadable:void 0;s.exports=function isFlattenable(s){return x(s)||w(s)||!!(j&&s&&s[j])}},30361:s=>{var i=/^(?:0|[1-9]\d*)$/;s.exports=function isIndex(s,u){var _=typeof s;return!!(u=null==u?9007199254740991:u)&&("number"==_||"symbol"!=_&&i.test(s))&&s>-1&&s%1==0&&s{var _=u(75288),w=u(64894),x=u(30361),j=u(23805);s.exports=function isIterateeCall(s,i,u){if(!j(u))return!1;var L=typeof i;return!!("number"==L?w(u)&&x(i,u.length):"string"==L&&i in u)&&_(u[i],s)}},28586:(s,i,u)=>{var _=u(56449),w=u(44394),x=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,j=/^\w*$/;s.exports=function isKey(s,i){if(_(s))return!1;var u=typeof s;return!("number"!=u&&"symbol"!=u&&"boolean"!=u&&null!=s&&!w(s))||(j.test(s)||!x.test(s)||null!=i&&s in Object(i))}},74218:s=>{s.exports=function isKeyable(s){var i=typeof s;return"string"==i||"number"==i||"symbol"==i||"boolean"==i?"__proto__"!==s:null===s}},85087:(s,i,u)=>{var _=u(30980),w=u(37381),x=u(62284),j=u(53758);s.exports=function isLaziable(s){var i=x(s),u=j[i];if("function"!=typeof u||!(i in _.prototype))return!1;if(s===u)return!0;var L=w(u);return!!L&&s===L[0]}},87296:(s,i,u)=>{var _,w=u(55481),x=(_=/[^.]+$/.exec(w&&w.keys&&w.keys.IE_PROTO||""))?"Symbol(src)_1."+_:"";s.exports=function isMasked(s){return!!x&&x in s}},55527:s=>{var i=Object.prototype;s.exports=function isPrototype(s){var u=s&&s.constructor;return s===("function"==typeof u&&u.prototype||i)}},30756:(s,i,u)=>{var _=u(23805);s.exports=function isStrictComparable(s){return s==s&&!_(s)}},63702:s=>{s.exports=function listCacheClear(){this.__data__=[],this.size=0}},70080:(s,i,u)=>{var _=u(26025),w=Array.prototype.splice;s.exports=function listCacheDelete(s){var i=this.__data__,u=_(i,s);return!(u<0)&&(u==i.length-1?i.pop():w.call(i,u,1),--this.size,!0)}},24739:(s,i,u)=>{var _=u(26025);s.exports=function listCacheGet(s){var i=this.__data__,u=_(i,s);return u<0?void 0:i[u][1]}},48655:(s,i,u)=>{var _=u(26025);s.exports=function listCacheHas(s){return _(this.__data__,s)>-1}},31175:(s,i,u)=>{var _=u(26025);s.exports=function listCacheSet(s,i){var u=this.__data__,w=_(u,s);return w<0?(++this.size,u.push([s,i])):u[w][1]=i,this}},63040:(s,i,u)=>{var _=u(21549),w=u(80079),x=u(68223);s.exports=function mapCacheClear(){this.size=0,this.__data__={hash:new _,map:new(x||w),string:new _}}},17670:(s,i,u)=>{var _=u(12651);s.exports=function mapCacheDelete(s){var i=_(this,s).delete(s);return this.size-=i?1:0,i}},90289:(s,i,u)=>{var _=u(12651);s.exports=function mapCacheGet(s){return _(this,s).get(s)}},4509:(s,i,u)=>{var _=u(12651);s.exports=function mapCacheHas(s){return _(this,s).has(s)}},72949:(s,i,u)=>{var _=u(12651);s.exports=function mapCacheSet(s,i){var u=_(this,s),w=u.size;return u.set(s,i),this.size+=u.size==w?0:1,this}},20317:s=>{s.exports=function mapToArray(s){var i=-1,u=Array(s.size);return s.forEach((function(s,_){u[++i]=[_,s]})),u}},67197:s=>{s.exports=function matchesStrictComparable(s,i){return function(u){return null!=u&&(u[s]===i&&(void 0!==i||s in Object(u)))}}},62224:(s,i,u)=>{var _=u(50104);s.exports=function memoizeCapped(s){var i=_(s,(function(s){return 500===u.size&&u.clear(),s})),u=i.cache;return i}},3209:(s,i,u)=>{var _=u(91596),w=u(53320),x=u(36306),j="__lodash_placeholder__",L=128,B=Math.min;s.exports=function mergeData(s,i){var u=s[1],$=i[1],U=u|$,Y=U<131,Z=$==L&&8==u||$==L&&256==u&&s[7].length<=i[8]||384==$&&i[7].length<=i[8]&&8==u;if(!Y&&!Z)return s;1&$&&(s[2]=i[2],U|=1&u?0:4);var ee=i[3];if(ee){var ie=s[3];s[3]=ie?_(ie,ee,i[4]):ee,s[4]=ie?x(s[3],j):i[4]}return(ee=i[5])&&(ie=s[5],s[5]=ie?w(ie,ee,i[6]):ee,s[6]=ie?x(s[5],j):i[6]),(ee=i[7])&&(s[7]=ee),$&L&&(s[8]=null==s[8]?i[8]:B(s[8],i[8])),null==s[9]&&(s[9]=i[9]),s[0]=i[0],s[1]=U,s}},48152:(s,i,u)=>{var _=u(28303),w=_&&new _;s.exports=w},81042:(s,i,u)=>{var _=u(56110)(Object,"create");s.exports=_},3650:(s,i,u)=>{var _=u(74335)(Object.keys,Object);s.exports=_},90181:s=>{s.exports=function nativeKeysIn(s){var i=[];if(null!=s)for(var u in Object(s))i.push(u);return i}},86009:(s,i,u)=>{s=u.nmd(s);var _=u(34840),w=i&&!i.nodeType&&i,x=w&&s&&!s.nodeType&&s,j=x&&x.exports===w&&_.process,L=function(){try{var s=x&&x.require&&x.require("util").types;return s||j&&j.binding&&j.binding("util")}catch(s){}}();s.exports=L},59350:s=>{var i=Object.prototype.toString;s.exports=function objectToString(s){return i.call(s)}},74335:s=>{s.exports=function overArg(s,i){return function(u){return s(i(u))}}},56757:(s,i,u)=>{var _=u(91033),w=Math.max;s.exports=function overRest(s,i,u){return i=w(void 0===i?s.length-1:i,0),function(){for(var x=arguments,j=-1,L=w(x.length-i,0),B=Array(L);++j{var _=u(47422),w=u(25160);s.exports=function parent(s,i){return i.length<2?s:_(s,w(i,0,-1))}},84629:s=>{s.exports={}},68294:(s,i,u)=>{var _=u(23007),w=u(30361),x=Math.min;s.exports=function reorder(s,i){for(var u=s.length,j=x(i.length,u),L=_(s);j--;){var B=i[j];s[j]=w(B,u)?L[B]:void 0}return s}},36306:s=>{var i="__lodash_placeholder__";s.exports=function replaceHolders(s,u){for(var _=-1,w=s.length,x=0,j=[];++_{var _=u(34840),w="object"==typeof self&&self&&self.Object===Object&&self,x=_||w||Function("return this")();s.exports=x},14974:s=>{s.exports=function safeGet(s,i){if(("constructor"!==i||"function"!=typeof s[i])&&"__proto__"!=i)return s[i]}},31380:s=>{s.exports=function setCacheAdd(s){return this.__data__.set(s,"__lodash_hash_undefined__"),this}},51459:s=>{s.exports=function setCacheHas(s){return this.__data__.has(s)}},54641:(s,i,u)=>{var _=u(68882),w=u(51811)(_);s.exports=w},84247:s=>{s.exports=function setToArray(s){var i=-1,u=Array(s.size);return s.forEach((function(s){u[++i]=s})),u}},32865:(s,i,u)=>{var _=u(19570),w=u(51811)(_);s.exports=w},70981:(s,i,u)=>{var _=u(75251),w=u(62060),x=u(32865),j=u(75948);s.exports=function setWrapToString(s,i,u){var L=i+"";return x(s,w(L,j(_(L),u)))}},51811:s=>{var i=Date.now;s.exports=function shortOut(s){var u=0,_=0;return function(){var w=i(),x=16-(w-_);if(_=w,x>0){if(++u>=800)return arguments[0]}else u=0;return s.apply(void 0,arguments)}}},51420:(s,i,u)=>{var _=u(80079);s.exports=function stackClear(){this.__data__=new _,this.size=0}},90938:s=>{s.exports=function stackDelete(s){var i=this.__data__,u=i.delete(s);return this.size=i.size,u}},63605:s=>{s.exports=function stackGet(s){return this.__data__.get(s)}},29817:s=>{s.exports=function stackHas(s){return this.__data__.has(s)}},80945:(s,i,u)=>{var _=u(80079),w=u(68223),x=u(53661);s.exports=function stackSet(s,i){var u=this.__data__;if(u instanceof _){var j=u.__data__;if(!w||j.length<199)return j.push([s,i]),this.size=++u.size,this;u=this.__data__=new x(j)}return u.set(s,i),this.size=u.size,this}},76959:s=>{s.exports=function strictIndexOf(s,i,u){for(var _=u-1,w=s.length;++_{var _=u(61074),w=u(49698),x=u(42054);s.exports=function stringToArray(s){return w(s)?x(s):_(s)}},61802:(s,i,u)=>{var _=u(62224),w=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,x=/\\(\\)?/g,j=_((function(s){var i=[];return 46===s.charCodeAt(0)&&i.push(""),s.replace(w,(function(s,u,_,w){i.push(_?w.replace(x,"$1"):u||s)})),i}));s.exports=j},77797:(s,i,u)=>{var _=u(44394);s.exports=function toKey(s){if("string"==typeof s||_(s))return s;var i=s+"";return"0"==i&&1/s==-Infinity?"-0":i}},47473:s=>{var i=Function.prototype.toString;s.exports=function toSource(s){if(null!=s){try{return i.call(s)}catch(s){}try{return s+""}catch(s){}}return""}},31800:s=>{var i=/\s/;s.exports=function trimmedEndIndex(s){for(var u=s.length;u--&&i.test(s.charAt(u)););return u}},42054:s=>{var i="\\ud800-\\udfff",u="["+i+"]",_="[\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff]",w="\\ud83c[\\udffb-\\udfff]",x="[^"+i+"]",j="(?:\\ud83c[\\udde6-\\uddff]){2}",L="[\\ud800-\\udbff][\\udc00-\\udfff]",B="(?:"+_+"|"+w+")"+"?",$="[\\ufe0e\\ufe0f]?",U=$+B+("(?:\\u200d(?:"+[x,j,L].join("|")+")"+$+B+")*"),Y="(?:"+[x+_+"?",_,j,L,u].join("|")+")",Z=RegExp(w+"(?="+w+")|"+Y+U,"g");s.exports=function unicodeToArray(s){return s.match(Z)||[]}},22225:s=>{var i="\\ud800-\\udfff",u="\\u2700-\\u27bf",_="a-z\\xdf-\\xf6\\xf8-\\xff",w="A-Z\\xc0-\\xd6\\xd8-\\xde",x="\\xac\\xb1\\xd7\\xf7\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf\\u2000-\\u206f \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000",j="["+x+"]",L="\\d+",B="["+u+"]",$="["+_+"]",U="[^"+i+x+L+u+_+w+"]",Y="(?:\\ud83c[\\udde6-\\uddff]){2}",Z="[\\ud800-\\udbff][\\udc00-\\udfff]",ee="["+w+"]",ie="(?:"+$+"|"+U+")",ae="(?:"+ee+"|"+U+")",le="(?:['’](?:d|ll|m|re|s|t|ve))?",ce="(?:['’](?:D|LL|M|RE|S|T|VE))?",pe="(?:[\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff]|\\ud83c[\\udffb-\\udfff])?",de="[\\ufe0e\\ufe0f]?",fe=de+pe+("(?:\\u200d(?:"+["[^"+i+"]",Y,Z].join("|")+")"+de+pe+")*"),ye="(?:"+[B,Y,Z].join("|")+")"+fe,be=RegExp([ee+"?"+$+"+"+le+"(?="+[j,ee,"$"].join("|")+")",ae+"+"+ce+"(?="+[j,ee+ie,"$"].join("|")+")",ee+"?"+ie+"+"+le,ee+"+"+ce,"\\d*(?:1ST|2ND|3RD|(?![123])\\dTH)(?=\\b|[a-z_])","\\d*(?:1st|2nd|3rd|(?![123])\\dth)(?=\\b|[A-Z_])",L,ye].join("|"),"g");s.exports=function unicodeWords(s){return s.match(be)||[]}},75948:(s,i,u)=>{var _=u(83729),w=u(15325),x=[["ary",128],["bind",1],["bindKey",2],["curry",8],["curryRight",16],["flip",512],["partial",32],["partialRight",64],["rearg",256]];s.exports=function updateWrapDetails(s,i){return _(x,(function(u){var _="_."+u[0];i&u[1]&&!w(s,_)&&s.push(_)})),s.sort()}},80257:(s,i,u)=>{var _=u(30980),w=u(56017),x=u(23007);s.exports=function wrapperClone(s){if(s instanceof _)return s.clone();var i=new w(s.__wrapped__,s.__chain__);return i.__actions__=x(s.__actions__),i.__index__=s.__index__,i.__values__=s.__values__,i}},64626:(s,i,u)=>{var _=u(66977);s.exports=function ary(s,i,u){return i=u?void 0:i,i=s&&null==i?s.length:i,_(s,128,void 0,void 0,void 0,void 0,i)}},84058:(s,i,u)=>{var _=u(14792),w=u(45539)((function(s,i,u){return i=i.toLowerCase(),s+(u?_(i):i)}));s.exports=w},14792:(s,i,u)=>{var _=u(13222),w=u(55808);s.exports=function capitalize(s){return w(_(s).toLowerCase())}},32629:(s,i,u)=>{var _=u(9999);s.exports=function clone(s){return _(s,4)}},37334:s=>{s.exports=function constant(s){return function(){return s}}},49747:(s,i,u)=>{var _=u(66977);function curry(s,i,u){var w=_(s,8,void 0,void 0,void 0,void 0,void 0,i=u?void 0:i);return w.placeholder=curry.placeholder,w}curry.placeholder={},s.exports=curry},38221:(s,i,u)=>{var _=u(23805),w=u(10124),x=u(99374),j=Math.max,L=Math.min;s.exports=function debounce(s,i,u){var B,$,U,Y,Z,ee,ie=0,ae=!1,le=!1,ce=!0;if("function"!=typeof s)throw new TypeError("Expected a function");function invokeFunc(i){var u=B,_=$;return B=$=void 0,ie=i,Y=s.apply(_,u)}function shouldInvoke(s){var u=s-ee;return void 0===ee||u>=i||u<0||le&&s-ie>=U}function timerExpired(){var s=w();if(shouldInvoke(s))return trailingEdge(s);Z=setTimeout(timerExpired,function remainingWait(s){var u=i-(s-ee);return le?L(u,U-(s-ie)):u}(s))}function trailingEdge(s){return Z=void 0,ce&&B?invokeFunc(s):(B=$=void 0,Y)}function debounced(){var s=w(),u=shouldInvoke(s);if(B=arguments,$=this,ee=s,u){if(void 0===Z)return function leadingEdge(s){return ie=s,Z=setTimeout(timerExpired,i),ae?invokeFunc(s):Y}(ee);if(le)return clearTimeout(Z),Z=setTimeout(timerExpired,i),invokeFunc(ee)}return void 0===Z&&(Z=setTimeout(timerExpired,i)),Y}return i=x(i)||0,_(u)&&(ae=!!u.leading,U=(le="maxWait"in u)?j(x(u.maxWait)||0,i):U,ce="trailing"in u?!!u.trailing:ce),debounced.cancel=function cancel(){void 0!==Z&&clearTimeout(Z),ie=0,B=ee=$=Z=void 0},debounced.flush=function flush(){return void 0===Z?Y:trailingEdge(w())},debounced}},50828:(s,i,u)=>{var _=u(24647),w=u(13222),x=/[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g,j=RegExp("[\\u0300-\\u036f\\ufe20-\\ufe2f\\u20d0-\\u20ff]","g");s.exports=function deburr(s){return(s=w(s))&&s.replace(x,_).replace(j,"")}},75288:s=>{s.exports=function eq(s,i){return s===i||s!=s&&i!=i}},60680:(s,i,u)=>{var _=u(13222),w=/[\\^$.*+?()[\]{}|]/g,x=RegExp(w.source);s.exports=function escapeRegExp(s){return(s=_(s))&&x.test(s)?s.replace(w,"\\$&"):s}},7309:(s,i,u)=>{var _=u(62006)(u(24713));s.exports=_},24713:(s,i,u)=>{var _=u(2523),w=u(15389),x=u(61489),j=Math.max;s.exports=function findIndex(s,i,u){var L=null==s?0:s.length;if(!L)return-1;var B=null==u?0:x(u);return B<0&&(B=j(L+B,0)),_(s,w(i,3),B)}},35970:(s,i,u)=>{var _=u(83120);s.exports=function flatten(s){return(null==s?0:s.length)?_(s,1):[]}},73424:(s,i,u)=>{var _=u(16962),w=u(2874),x=Array.prototype.push;function baseAry(s,i){return 2==i?function(i,u){return s(i,u)}:function(i){return s(i)}}function cloneArray(s){for(var i=s?s.length:0,u=Array(i);i--;)u[i]=s[i];return u}function wrapImmutable(s,i){return function(){var u=arguments.length;if(u){for(var _=Array(u);u--;)_[u]=arguments[u];var w=_[0]=i.apply(void 0,_);return s.apply(void 0,_),w}}}s.exports=function baseConvert(s,i,u,j){var L="function"==typeof i,B=i===Object(i);if(B&&(j=u,u=i,i=void 0),null==u)throw new TypeError;j||(j={});var $={cap:!("cap"in j)||j.cap,curry:!("curry"in j)||j.curry,fixed:!("fixed"in j)||j.fixed,immutable:!("immutable"in j)||j.immutable,rearg:!("rearg"in j)||j.rearg},U=L?u:w,Y="curry"in j&&j.curry,Z="fixed"in j&&j.fixed,ee="rearg"in j&&j.rearg,ie=L?u.runInContext():void 0,ae=L?u:{ary:s.ary,assign:s.assign,clone:s.clone,curry:s.curry,forEach:s.forEach,isArray:s.isArray,isError:s.isError,isFunction:s.isFunction,isWeakMap:s.isWeakMap,iteratee:s.iteratee,keys:s.keys,rearg:s.rearg,toInteger:s.toInteger,toPath:s.toPath},le=ae.ary,ce=ae.assign,pe=ae.clone,de=ae.curry,fe=ae.forEach,ye=ae.isArray,be=ae.isError,_e=ae.isFunction,we=ae.isWeakMap,Se=ae.keys,xe=ae.rearg,Pe=ae.toInteger,Te=ae.toPath,Re=Se(_.aryMethod),qe={castArray:function(s){return function(){var i=arguments[0];return ye(i)?s(cloneArray(i)):s.apply(void 0,arguments)}},iteratee:function(s){return function(){var i=arguments[1],u=s(arguments[0],i),_=u.length;return $.cap&&"number"==typeof i?(i=i>2?i-2:1,_&&_<=i?u:baseAry(u,i)):u}},mixin:function(s){return function(i){var u=this;if(!_e(u))return s(u,Object(i));var _=[];return fe(Se(i),(function(s){_e(i[s])&&_.push([s,u.prototype[s]])})),s(u,Object(i)),fe(_,(function(s){var i=s[1];_e(i)?u.prototype[s[0]]=i:delete u.prototype[s[0]]})),u}},nthArg:function(s){return function(i){var u=i<0?1:Pe(i)+1;return de(s(i),u)}},rearg:function(s){return function(i,u){var _=u?u.length:0;return de(s(i,u),_)}},runInContext:function(i){return function(u){return baseConvert(s,i(u),j)}}};function castCap(s,i){if($.cap){var u=_.iterateeRearg[s];if(u)return function iterateeRearg(s,i){return overArg(s,(function(s){var u=i.length;return function baseArity(s,i){return 2==i?function(i,u){return s.apply(void 0,arguments)}:function(i){return s.apply(void 0,arguments)}}(xe(baseAry(s,u),i),u)}))}(i,u);var w=!L&&_.iterateeAry[s];if(w)return function iterateeAry(s,i){return overArg(s,(function(s){return"function"==typeof s?baseAry(s,i):s}))}(i,w)}return i}function castFixed(s,i,u){if($.fixed&&(Z||!_.skipFixed[s])){var w=_.methodSpread[s],j=w&&w.start;return void 0===j?le(i,u):function flatSpread(s,i){return function(){for(var u=arguments.length,_=u-1,w=Array(u);u--;)w[u]=arguments[u];var j=w[i],L=w.slice(0,i);return j&&x.apply(L,j),i!=_&&x.apply(L,w.slice(i+1)),s.apply(this,L)}}(i,j)}return i}function castRearg(s,i,u){return $.rearg&&u>1&&(ee||!_.skipRearg[s])?xe(i,_.methodRearg[s]||_.aryRearg[u]):i}function cloneByPath(s,i){for(var u=-1,_=(i=Te(i)).length,w=_-1,x=pe(Object(s)),j=x;null!=j&&++u<_;){var L=i[u],B=j[L];null==B||_e(B)||be(B)||we(B)||(j[L]=pe(u==w?B:Object(B))),j=j[L]}return x}function createConverter(s,i){var u=_.aliasToReal[s]||s,w=_.remap[u]||u,x=j;return function(s){var _=L?ie:ae,j=L?ie[w]:i,B=ce(ce({},x),s);return baseConvert(_,u,j,B)}}function overArg(s,i){return function(){var u=arguments.length;if(!u)return s();for(var _=Array(u);u--;)_[u]=arguments[u];var w=$.rearg?0:u-1;return _[w]=i(_[w]),s.apply(void 0,_)}}function wrap(s,i,u){var w,x=_.aliasToReal[s]||s,j=i,L=qe[x];return L?j=L(i):$.immutable&&(_.mutate.array[x]?j=wrapImmutable(i,cloneArray):_.mutate.object[x]?j=wrapImmutable(i,function createCloner(s){return function(i){return s({},i)}}(i)):_.mutate.set[x]&&(j=wrapImmutable(i,cloneByPath))),fe(Re,(function(s){return fe(_.aryMethod[s],(function(i){if(x==i){var u=_.methodSpread[x],L=u&&u.afterRearg;return w=L?castFixed(x,castRearg(x,j,s),s):castRearg(x,castFixed(x,j,s),s),w=function castCurry(s,i,u){return Y||$.curry&&u>1?de(i,u):i}(0,w=castCap(x,w),s),!1}})),!w})),w||(w=j),w==i&&(w=Y?de(w,1):function(){return i.apply(this,arguments)}),w.convert=createConverter(x,i),w.placeholder=i.placeholder=u,w}if(!B)return wrap(i,u,U);var $e=u,ze=[];return fe(Re,(function(s){fe(_.aryMethod[s],(function(s){var i=$e[_.remap[s]||s];i&&ze.push([s,wrap(s,i,$e)])}))})),fe(Se($e),(function(s){var i=$e[s];if("function"==typeof i){for(var u=ze.length;u--;)if(ze[u][0]==s)return;i.convert=createConverter(s,i),ze.push([s,i])}})),fe(ze,(function(s){$e[s[0]]=s[1]})),$e.convert=function convertLib(s){return $e.runInContext.convert(s)(void 0)},$e.placeholder=$e,fe(Se($e),(function(s){fe(_.realToAlias[s]||[],(function(i){$e[i]=$e[s]}))})),$e}},16962:(s,i)=>{i.aliasToReal={each:"forEach",eachRight:"forEachRight",entries:"toPairs",entriesIn:"toPairsIn",extend:"assignIn",extendAll:"assignInAll",extendAllWith:"assignInAllWith",extendWith:"assignInWith",first:"head",conforms:"conformsTo",matches:"isMatch",property:"get",__:"placeholder",F:"stubFalse",T:"stubTrue",all:"every",allPass:"overEvery",always:"constant",any:"some",anyPass:"overSome",apply:"spread",assoc:"set",assocPath:"set",complement:"negate",compose:"flowRight",contains:"includes",dissoc:"unset",dissocPath:"unset",dropLast:"dropRight",dropLastWhile:"dropRightWhile",equals:"isEqual",identical:"eq",indexBy:"keyBy",init:"initial",invertObj:"invert",juxt:"over",omitAll:"omit",nAry:"ary",path:"get",pathEq:"matchesProperty",pathOr:"getOr",paths:"at",pickAll:"pick",pipe:"flow",pluck:"map",prop:"get",propEq:"matchesProperty",propOr:"getOr",props:"at",symmetricDifference:"xor",symmetricDifferenceBy:"xorBy",symmetricDifferenceWith:"xorWith",takeLast:"takeRight",takeLastWhile:"takeRightWhile",unapply:"rest",unnest:"flatten",useWith:"overArgs",where:"conformsTo",whereEq:"isMatch",zipObj:"zipObject"},i.aryMethod={1:["assignAll","assignInAll","attempt","castArray","ceil","create","curry","curryRight","defaultsAll","defaultsDeepAll","floor","flow","flowRight","fromPairs","invert","iteratee","memoize","method","mergeAll","methodOf","mixin","nthArg","over","overEvery","overSome","rest","reverse","round","runInContext","spread","template","trim","trimEnd","trimStart","uniqueId","words","zipAll"],2:["add","after","ary","assign","assignAllWith","assignIn","assignInAllWith","at","before","bind","bindAll","bindKey","chunk","cloneDeepWith","cloneWith","concat","conformsTo","countBy","curryN","curryRightN","debounce","defaults","defaultsDeep","defaultTo","delay","difference","divide","drop","dropRight","dropRightWhile","dropWhile","endsWith","eq","every","filter","find","findIndex","findKey","findLast","findLastIndex","findLastKey","flatMap","flatMapDeep","flattenDepth","forEach","forEachRight","forIn","forInRight","forOwn","forOwnRight","get","groupBy","gt","gte","has","hasIn","includes","indexOf","intersection","invertBy","invoke","invokeMap","isEqual","isMatch","join","keyBy","lastIndexOf","lt","lte","map","mapKeys","mapValues","matchesProperty","maxBy","meanBy","merge","mergeAllWith","minBy","multiply","nth","omit","omitBy","overArgs","pad","padEnd","padStart","parseInt","partial","partialRight","partition","pick","pickBy","propertyOf","pull","pullAll","pullAt","random","range","rangeRight","rearg","reject","remove","repeat","restFrom","result","sampleSize","some","sortBy","sortedIndex","sortedIndexOf","sortedLastIndex","sortedLastIndexOf","sortedUniqBy","split","spreadFrom","startsWith","subtract","sumBy","take","takeRight","takeRightWhile","takeWhile","tap","throttle","thru","times","trimChars","trimCharsEnd","trimCharsStart","truncate","union","uniqBy","uniqWith","unset","unzipWith","without","wrap","xor","zip","zipObject","zipObjectDeep"],3:["assignInWith","assignWith","clamp","differenceBy","differenceWith","findFrom","findIndexFrom","findLastFrom","findLastIndexFrom","getOr","includesFrom","indexOfFrom","inRange","intersectionBy","intersectionWith","invokeArgs","invokeArgsMap","isEqualWith","isMatchWith","flatMapDepth","lastIndexOfFrom","mergeWith","orderBy","padChars","padCharsEnd","padCharsStart","pullAllBy","pullAllWith","rangeStep","rangeStepRight","reduce","reduceRight","replace","set","slice","sortedIndexBy","sortedLastIndexBy","transform","unionBy","unionWith","update","xorBy","xorWith","zipWith"],4:["fill","setWith","updateWith"]},i.aryRearg={2:[1,0],3:[2,0,1],4:[3,2,0,1]},i.iterateeAry={dropRightWhile:1,dropWhile:1,every:1,filter:1,find:1,findFrom:1,findIndex:1,findIndexFrom:1,findKey:1,findLast:1,findLastFrom:1,findLastIndex:1,findLastIndexFrom:1,findLastKey:1,flatMap:1,flatMapDeep:1,flatMapDepth:1,forEach:1,forEachRight:1,forIn:1,forInRight:1,forOwn:1,forOwnRight:1,map:1,mapKeys:1,mapValues:1,partition:1,reduce:2,reduceRight:2,reject:1,remove:1,some:1,takeRightWhile:1,takeWhile:1,times:1,transform:2},i.iterateeRearg={mapKeys:[1],reduceRight:[1,0]},i.methodRearg={assignInAllWith:[1,0],assignInWith:[1,2,0],assignAllWith:[1,0],assignWith:[1,2,0],differenceBy:[1,2,0],differenceWith:[1,2,0],getOr:[2,1,0],intersectionBy:[1,2,0],intersectionWith:[1,2,0],isEqualWith:[1,2,0],isMatchWith:[2,1,0],mergeAllWith:[1,0],mergeWith:[1,2,0],padChars:[2,1,0],padCharsEnd:[2,1,0],padCharsStart:[2,1,0],pullAllBy:[2,1,0],pullAllWith:[2,1,0],rangeStep:[1,2,0],rangeStepRight:[1,2,0],setWith:[3,1,2,0],sortedIndexBy:[2,1,0],sortedLastIndexBy:[2,1,0],unionBy:[1,2,0],unionWith:[1,2,0],updateWith:[3,1,2,0],xorBy:[1,2,0],xorWith:[1,2,0],zipWith:[1,2,0]},i.methodSpread={assignAll:{start:0},assignAllWith:{start:0},assignInAll:{start:0},assignInAllWith:{start:0},defaultsAll:{start:0},defaultsDeepAll:{start:0},invokeArgs:{start:2},invokeArgsMap:{start:2},mergeAll:{start:0},mergeAllWith:{start:0},partial:{start:1},partialRight:{start:1},without:{start:1},zipAll:{start:0}},i.mutate={array:{fill:!0,pull:!0,pullAll:!0,pullAllBy:!0,pullAllWith:!0,pullAt:!0,remove:!0,reverse:!0},object:{assign:!0,assignAll:!0,assignAllWith:!0,assignIn:!0,assignInAll:!0,assignInAllWith:!0,assignInWith:!0,assignWith:!0,defaults:!0,defaultsAll:!0,defaultsDeep:!0,defaultsDeepAll:!0,merge:!0,mergeAll:!0,mergeAllWith:!0,mergeWith:!0},set:{set:!0,setWith:!0,unset:!0,update:!0,updateWith:!0}},i.realToAlias=function(){var s=Object.prototype.hasOwnProperty,u=i.aliasToReal,_={};for(var w in u){var x=u[w];s.call(_,x)?_[x].push(w):_[x]=[w]}return _}(),i.remap={assignAll:"assign",assignAllWith:"assignWith",assignInAll:"assignIn",assignInAllWith:"assignInWith",curryN:"curry",curryRightN:"curryRight",defaultsAll:"defaults",defaultsDeepAll:"defaultsDeep",findFrom:"find",findIndexFrom:"findIndex",findLastFrom:"findLast",findLastIndexFrom:"findLastIndex",getOr:"get",includesFrom:"includes",indexOfFrom:"indexOf",invokeArgs:"invoke",invokeArgsMap:"invokeMap",lastIndexOfFrom:"lastIndexOf",mergeAll:"merge",mergeAllWith:"mergeWith",padChars:"pad",padCharsEnd:"padEnd",padCharsStart:"padStart",propertyOf:"get",rangeStep:"range",rangeStepRight:"rangeRight",restFrom:"rest",spreadFrom:"spread",trimChars:"trim",trimCharsEnd:"trimEnd",trimCharsStart:"trimStart",zipAll:"zip"},i.skipFixed={castArray:!0,flow:!0,flowRight:!0,iteratee:!0,mixin:!0,rearg:!0,runInContext:!0},i.skipRearg={add:!0,assign:!0,assignIn:!0,bind:!0,bindKey:!0,concat:!0,difference:!0,divide:!0,eq:!0,gt:!0,gte:!0,isEqual:!0,lt:!0,lte:!0,matchesProperty:!0,merge:!0,multiply:!0,overArgs:!0,partial:!0,partialRight:!0,propertyOf:!0,random:!0,range:!0,rangeRight:!0,subtract:!0,zip:!0,zipObject:!0,zipObjectDeep:!0}},47934:(s,i,u)=>{s.exports={ary:u(64626),assign:u(74733),clone:u(32629),curry:u(49747),forEach:u(83729),isArray:u(56449),isError:u(23546),isFunction:u(1882),isWeakMap:u(47886),iteratee:u(33855),keys:u(88984),rearg:u(84195),toInteger:u(61489),toPath:u(42072)}},56367:(s,i,u)=>{s.exports=u(77731)},79920:(s,i,u)=>{var _=u(73424),w=u(47934);s.exports=function convert(s,i,u){return _(w,s,i,u)}},2874:s=>{s.exports={}},77731:(s,i,u)=>{var _=u(79920)("set",u(63560));_.placeholder=u(2874),s.exports=_},58156:(s,i,u)=>{var _=u(47422);s.exports=function get(s,i,u){var w=null==s?void 0:_(s,i);return void 0===w?u:w}},61448:(s,i,u)=>{var _=u(20426),w=u(49326);s.exports=function has(s,i){return null!=s&&w(s,i,_)}},80631:(s,i,u)=>{var _=u(28077),w=u(49326);s.exports=function hasIn(s,i){return null!=s&&w(s,i,_)}},83488:s=>{s.exports=function identity(s){return s}},72428:(s,i,u)=>{var _=u(27534),w=u(40346),x=Object.prototype,j=x.hasOwnProperty,L=x.propertyIsEnumerable,B=_(function(){return arguments}())?_:function(s){return w(s)&&j.call(s,"callee")&&!L.call(s,"callee")};s.exports=B},56449:s=>{var i=Array.isArray;s.exports=i},64894:(s,i,u)=>{var _=u(1882),w=u(30294);s.exports=function isArrayLike(s){return null!=s&&w(s.length)&&!_(s)}},83693:(s,i,u)=>{var _=u(64894),w=u(40346);s.exports=function isArrayLikeObject(s){return w(s)&&_(s)}},53812:(s,i,u)=>{var _=u(72552),w=u(40346);s.exports=function isBoolean(s){return!0===s||!1===s||w(s)&&"[object Boolean]"==_(s)}},3656:(s,i,u)=>{s=u.nmd(s);var _=u(9325),w=u(89935),x=i&&!i.nodeType&&i,j=x&&s&&!s.nodeType&&s,L=j&&j.exports===x?_.Buffer:void 0,B=(L?L.isBuffer:void 0)||w;s.exports=B},62193:(s,i,u)=>{var _=u(88984),w=u(5861),x=u(72428),j=u(56449),L=u(64894),B=u(3656),$=u(55527),U=u(37167),Y=Object.prototype.hasOwnProperty;s.exports=function isEmpty(s){if(null==s)return!0;if(L(s)&&(j(s)||"string"==typeof s||"function"==typeof s.splice||B(s)||U(s)||x(s)))return!s.length;var i=w(s);if("[object Map]"==i||"[object Set]"==i)return!s.size;if($(s))return!_(s).length;for(var u in s)if(Y.call(s,u))return!1;return!0}},2404:(s,i,u)=>{var _=u(60270);s.exports=function isEqual(s,i){return _(s,i)}},23546:(s,i,u)=>{var _=u(72552),w=u(40346),x=u(11331);s.exports=function isError(s){if(!w(s))return!1;var i=_(s);return"[object Error]"==i||"[object DOMException]"==i||"string"==typeof s.message&&"string"==typeof s.name&&!x(s)}},1882:(s,i,u)=>{var _=u(72552),w=u(23805);s.exports=function isFunction(s){if(!w(s))return!1;var i=_(s);return"[object Function]"==i||"[object GeneratorFunction]"==i||"[object AsyncFunction]"==i||"[object Proxy]"==i}},30294:s=>{s.exports=function isLength(s){return"number"==typeof s&&s>-1&&s%1==0&&s<=9007199254740991}},87730:(s,i,u)=>{var _=u(29172),w=u(27301),x=u(86009),j=x&&x.isMap,L=j?w(j):_;s.exports=L},5187:s=>{s.exports=function isNull(s){return null===s}},98023:(s,i,u)=>{var _=u(72552),w=u(40346);s.exports=function isNumber(s){return"number"==typeof s||w(s)&&"[object Number]"==_(s)}},23805:s=>{s.exports=function isObject(s){var i=typeof s;return null!=s&&("object"==i||"function"==i)}},40346:s=>{s.exports=function isObjectLike(s){return null!=s&&"object"==typeof s}},11331:(s,i,u)=>{var _=u(72552),w=u(28879),x=u(40346),j=Function.prototype,L=Object.prototype,B=j.toString,$=L.hasOwnProperty,U=B.call(Object);s.exports=function isPlainObject(s){if(!x(s)||"[object Object]"!=_(s))return!1;var i=w(s);if(null===i)return!0;var u=$.call(i,"constructor")&&i.constructor;return"function"==typeof u&&u instanceof u&&B.call(u)==U}},38440:(s,i,u)=>{var _=u(16038),w=u(27301),x=u(86009),j=x&&x.isSet,L=j?w(j):_;s.exports=L},85015:(s,i,u)=>{var _=u(72552),w=u(56449),x=u(40346);s.exports=function isString(s){return"string"==typeof s||!w(s)&&x(s)&&"[object String]"==_(s)}},44394:(s,i,u)=>{var _=u(72552),w=u(40346);s.exports=function isSymbol(s){return"symbol"==typeof s||w(s)&&"[object Symbol]"==_(s)}},37167:(s,i,u)=>{var _=u(4901),w=u(27301),x=u(86009),j=x&&x.isTypedArray,L=j?w(j):_;s.exports=L},47886:(s,i,u)=>{var _=u(5861),w=u(40346);s.exports=function isWeakMap(s){return w(s)&&"[object WeakMap]"==_(s)}},33855:(s,i,u)=>{var _=u(9999),w=u(15389);s.exports=function iteratee(s){return w("function"==typeof s?s:_(s,1))}},95950:(s,i,u)=>{var _=u(70695),w=u(88984),x=u(64894);s.exports=function keys(s){return x(s)?_(s):w(s)}},37241:(s,i,u)=>{var _=u(70695),w=u(72903),x=u(64894);s.exports=function keysIn(s){return x(s)?_(s,!0):w(s)}},68090:s=>{s.exports=function last(s){var i=null==s?0:s.length;return i?s[i-1]:void 0}},50104:(s,i,u)=>{var _=u(53661);function memoize(s,i){if("function"!=typeof s||null!=i&&"function"!=typeof i)throw new TypeError("Expected a function");var memoized=function(){var u=arguments,_=i?i.apply(this,u):u[0],w=memoized.cache;if(w.has(_))return w.get(_);var x=s.apply(this,u);return memoized.cache=w.set(_,x)||w,x};return memoized.cache=new(memoize.Cache||_),memoized}memoize.Cache=_,s.exports=memoize},55364:(s,i,u)=>{var _=u(85250),w=u(20999)((function(s,i,u){_(s,i,u)}));s.exports=w},6048:s=>{s.exports=function negate(s){if("function"!=typeof s)throw new TypeError("Expected a function");return function(){var i=arguments;switch(i.length){case 0:return!s.call(this);case 1:return!s.call(this,i[0]);case 2:return!s.call(this,i[0],i[1]);case 3:return!s.call(this,i[0],i[1],i[2])}return!s.apply(this,i)}}},63950:s=>{s.exports=function noop(){}},10124:(s,i,u)=>{var _=u(9325);s.exports=function(){return _.Date.now()}},90179:(s,i,u)=>{var _=u(34932),w=u(9999),x=u(19931),j=u(31769),L=u(21791),B=u(53138),$=u(38816),U=u(83349),Y=$((function(s,i){var u={};if(null==s)return u;var $=!1;i=_(i,(function(i){return i=j(i,s),$||($=i.length>1),i})),L(s,U(s),u),$&&(u=w(u,7,B));for(var Y=i.length;Y--;)x(u,i[Y]);return u}));s.exports=Y},50583:(s,i,u)=>{var _=u(47237),w=u(17255),x=u(28586),j=u(77797);s.exports=function property(s){return x(s)?_(j(s)):w(s)}},84195:(s,i,u)=>{var _=u(66977),w=u(38816),x=w((function(s,i){return _(s,256,void 0,void 0,void 0,i)}));s.exports=x},40860:(s,i,u)=>{var _=u(40882),w=u(80909),x=u(15389),j=u(85558),L=u(56449);s.exports=function reduce(s,i,u){var B=L(s)?_:j,$=arguments.length<3;return B(s,x(i,4),u,$,w)}},63560:(s,i,u)=>{var _=u(73170);s.exports=function set(s,i,u){return null==s?s:_(s,i,u)}},42426:(s,i,u)=>{var _=u(14248),w=u(15389),x=u(90916),j=u(56449),L=u(36800);s.exports=function some(s,i,u){var B=j(s)?_:x;return u&&L(s,i,u)&&(i=void 0),B(s,w(i,3))}},63345:s=>{s.exports=function stubArray(){return[]}},89935:s=>{s.exports=function stubFalse(){return!1}},17400:(s,i,u)=>{var _=u(99374),w=1/0;s.exports=function toFinite(s){return s?(s=_(s))===w||s===-1/0?17976931348623157e292*(s<0?-1:1):s==s?s:0:0===s?s:0}},61489:(s,i,u)=>{var _=u(17400);s.exports=function toInteger(s){var i=_(s),u=i%1;return i==i?u?i-u:i:0}},80218:(s,i,u)=>{var _=u(13222);s.exports=function toLower(s){return _(s).toLowerCase()}},99374:(s,i,u)=>{var _=u(54128),w=u(23805),x=u(44394),j=/^[-+]0x[0-9a-f]+$/i,L=/^0b[01]+$/i,B=/^0o[0-7]+$/i,$=parseInt;s.exports=function toNumber(s){if("number"==typeof s)return s;if(x(s))return NaN;if(w(s)){var i="function"==typeof s.valueOf?s.valueOf():s;s=w(i)?i+"":i}if("string"!=typeof s)return 0===s?s:+s;s=_(s);var u=L.test(s);return u||B.test(s)?$(s.slice(2),u?2:8):j.test(s)?NaN:+s}},42072:(s,i,u)=>{var _=u(34932),w=u(23007),x=u(56449),j=u(44394),L=u(61802),B=u(77797),$=u(13222);s.exports=function toPath(s){return x(s)?_(s,B):j(s)?[s]:w(L($(s)))}},69884:(s,i,u)=>{var _=u(21791),w=u(37241);s.exports=function toPlainObject(s){return _(s,w(s))}},13222:(s,i,u)=>{var _=u(77556);s.exports=function toString(s){return null==s?"":_(s)}},55808:(s,i,u)=>{var _=u(12507)("toUpperCase");s.exports=_},66645:(s,i,u)=>{var _=u(1733),w=u(45434),x=u(13222),j=u(22225);s.exports=function words(s,i,u){return s=x(s),void 0===(i=u?void 0:i)?w(s)?j(s):_(s):s.match(i)||[]}},53758:(s,i,u)=>{var _=u(30980),w=u(56017),x=u(94033),j=u(56449),L=u(40346),B=u(80257),$=Object.prototype.hasOwnProperty;function lodash(s){if(L(s)&&!j(s)&&!(s instanceof _)){if(s instanceof w)return s;if($.call(s,"__wrapped__"))return B(s)}return new w(s)}lodash.prototype=x.prototype,lodash.prototype.constructor=lodash,s.exports=lodash},47248:(s,i,u)=>{var _=u(16547),w=u(51234);s.exports=function zipObject(s,i){return w(s||[],i||[],_)}},43768:(s,i,u)=>{"use strict";var _=u(45981),w=u(85587);i.highlight=highlight,i.highlightAuto=function highlightAuto(s,i){var u,j,L,B,$=i||{},U=$.subset||_.listLanguages(),Y=$.prefix,Z=U.length,ee=-1;null==Y&&(Y=x);if("string"!=typeof s)throw w("Expected `string` for value, got `%s`",s);j={relevance:0,language:null,value:[]},u={relevance:0,language:null,value:[]};for(;++eej.relevance&&(j=L),L.relevance>u.relevance&&(j=u,u=L));j.language&&(u.secondBest=j);return u},i.registerLanguage=function registerLanguage(s,i){_.registerLanguage(s,i)},i.listLanguages=function listLanguages(){return _.listLanguages()},i.registerAlias=function registerAlias(s,i){var u,w=s;i&&((w={})[s]=i);for(u in w)_.registerAliases(w[u],{languageName:u})},Emitter.prototype.addText=function text(s){var i,u,_=this.stack;if(""===s)return;i=_[_.length-1],(u=i.children[i.children.length-1])&&"text"===u.type?u.value+=s:i.children.push({type:"text",value:s})},Emitter.prototype.addKeyword=function addKeyword(s,i){this.openNode(i),this.addText(s),this.closeNode()},Emitter.prototype.addSublanguage=function addSublanguage(s,i){var u=this.stack,_=u[u.length-1],w=s.rootNode.children,x=i?{type:"element",tagName:"span",properties:{className:[i]},children:w}:w;_.children=_.children.concat(x)},Emitter.prototype.openNode=function open(s){var i=this.stack,u=this.options.classPrefix+s,_=i[i.length-1],w={type:"element",tagName:"span",properties:{className:[u]},children:[]};_.children.push(w),i.push(w)},Emitter.prototype.closeNode=function close(){this.stack.pop()},Emitter.prototype.closeAllNodes=noop,Emitter.prototype.finalize=noop,Emitter.prototype.toHTML=function toHtmlNoop(){return""};var x="hljs-";function highlight(s,i,u){var j,L=_.configure({}),B=(u||{}).prefix;if("string"!=typeof s)throw w("Expected `string` for name, got `%s`",s);if(!_.getLanguage(s))throw w("Unknown language: `%s` is not registered",s);if("string"!=typeof i)throw w("Expected `string` for value, got `%s`",i);if(null==B&&(B=x),_.configure({__emitter:Emitter,classPrefix:B}),j=_.highlight(i,{language:s,ignoreIllegals:!0}),_.configure(L||{}),j.errorRaised)throw j.errorRaised;return{relevance:j.relevance,language:j.language,value:j.emitter.rootNode.children}}function Emitter(s){this.options=s,this.rootNode={children:[]},this.stack=[this.rootNode]}function noop(){}},92340:(s,i,u)=>{const _=u(6048);function coerceElementMatchingCallback(s){return"string"==typeof s?i=>i.element===s:s.constructor&&s.extend?i=>i instanceof s:s}class ArraySlice{constructor(s){this.elements=s||[]}toValue(){return this.elements.map((s=>s.toValue()))}map(s,i){return this.elements.map(s,i)}flatMap(s,i){return this.map(s,i).reduce(((s,i)=>s.concat(i)),[])}compactMap(s,i){const u=[];return this.forEach((_=>{const w=s.bind(i)(_);w&&u.push(w)})),u}filter(s,i){return s=coerceElementMatchingCallback(s),new ArraySlice(this.elements.filter(s,i))}reject(s,i){return s=coerceElementMatchingCallback(s),new ArraySlice(this.elements.filter(_(s),i))}find(s,i){return s=coerceElementMatchingCallback(s),this.elements.find(s,i)}forEach(s,i){this.elements.forEach(s,i)}reduce(s,i){return this.elements.reduce(s,i)}includes(s){return this.elements.some((i=>i.equals(s)))}shift(){return this.elements.shift()}unshift(s){this.elements.unshift(this.refract(s))}push(s){return this.elements.push(this.refract(s)),this}add(s){this.push(s)}get(s){return this.elements[s]}getValue(s){const i=this.elements[s];if(i)return i.toValue()}get length(){return this.elements.length}get isEmpty(){return 0===this.elements.length}get first(){return this.elements[0]}}"undefined"!=typeof Symbol&&(ArraySlice.prototype[Symbol.iterator]=function symbol(){return this.elements[Symbol.iterator]()}),s.exports=ArraySlice},55973:s=>{class KeyValuePair{constructor(s,i){this.key=s,this.value=i}clone(){const s=new KeyValuePair;return this.key&&(s.key=this.key.clone()),this.value&&(s.value=this.value.clone()),s}}s.exports=KeyValuePair},3110:(s,i,u)=>{const _=u(5187),w=u(85015),x=u(98023),j=u(53812),L=u(23805),B=u(85105),$=u(86804);class Namespace{constructor(s){this.elementMap={},this.elementDetection=[],this.Element=$.Element,this.KeyValuePair=$.KeyValuePair,s&&s.noDefault||this.useDefault(),this._attributeElementKeys=[],this._attributeElementArrayKeys=[]}use(s){return s.namespace&&s.namespace({base:this}),s.load&&s.load({base:this}),this}useDefault(){return this.register("null",$.NullElement).register("string",$.StringElement).register("number",$.NumberElement).register("boolean",$.BooleanElement).register("array",$.ArrayElement).register("object",$.ObjectElement).register("member",$.MemberElement).register("ref",$.RefElement).register("link",$.LinkElement),this.detect(_,$.NullElement,!1).detect(w,$.StringElement,!1).detect(x,$.NumberElement,!1).detect(j,$.BooleanElement,!1).detect(Array.isArray,$.ArrayElement,!1).detect(L,$.ObjectElement,!1),this}register(s,i){return this._elements=void 0,this.elementMap[s]=i,this}unregister(s){return this._elements=void 0,delete this.elementMap[s],this}detect(s,i,u){return void 0===u||u?this.elementDetection.unshift([s,i]):this.elementDetection.push([s,i]),this}toElement(s){if(s instanceof this.Element)return s;let i;for(let u=0;u{const i=s[0].toUpperCase()+s.substr(1);this._elements[i]=this.elementMap[s]}))),this._elements}get serialiser(){return new B(this)}}B.prototype.Namespace=Namespace,s.exports=Namespace},10866:(s,i,u)=>{const _=u(6048),w=u(92340);class ObjectSlice extends w{map(s,i){return this.elements.map((u=>s.bind(i)(u.value,u.key,u)))}filter(s,i){return new ObjectSlice(this.elements.filter((u=>s.bind(i)(u.value,u.key,u))))}reject(s,i){return this.filter(_(s.bind(i)))}forEach(s,i){return this.elements.forEach(((u,_)=>{s.bind(i)(u.value,u.key,u,_)}))}keys(){return this.map(((s,i)=>i.toValue()))}values(){return this.map((s=>s.toValue()))}}s.exports=ObjectSlice},86804:(s,i,u)=>{const _=u(10316),w=u(41067),x=u(71167),j=u(40239),L=u(12242),B=u(6233),$=u(87726),U=u(61045),Y=u(86303),Z=u(14540),ee=u(92340),ie=u(10866),ae=u(55973);function refract(s){if(s instanceof _)return s;if("string"==typeof s)return new x(s);if("number"==typeof s)return new j(s);if("boolean"==typeof s)return new L(s);if(null===s)return new w;if(Array.isArray(s))return new B(s.map(refract));if("object"==typeof s){return new U(s)}return s}_.prototype.ObjectElement=U,_.prototype.RefElement=Z,_.prototype.MemberElement=$,_.prototype.refract=refract,ee.prototype.refract=refract,s.exports={Element:_,NullElement:w,StringElement:x,NumberElement:j,BooleanElement:L,ArrayElement:B,MemberElement:$,ObjectElement:U,LinkElement:Y,RefElement:Z,refract,ArraySlice:ee,ObjectSlice:ie,KeyValuePair:ae}},86303:(s,i,u)=>{const _=u(10316);s.exports=class LinkElement extends _{constructor(s,i,u){super(s||[],i,u),this.element="link"}get relation(){return this.attributes.get("relation")}set relation(s){this.attributes.set("relation",s)}get href(){return this.attributes.get("href")}set href(s){this.attributes.set("href",s)}}},14540:(s,i,u)=>{const _=u(10316);s.exports=class RefElement extends _{constructor(s,i,u){super(s||[],i,u),this.element="ref",this.path||(this.path="element")}get path(){return this.attributes.get("path")}set path(s){this.attributes.set("path",s)}}},34035:(s,i,u)=>{const _=u(3110),w=u(86804);i.g$=_,i.KeyValuePair=u(55973),i.G6=w.ArraySlice,i.ot=w.ObjectSlice,i.Hg=w.Element,i.Om=w.StringElement,i.kT=w.NumberElement,i.bd=w.BooleanElement,i.Os=w.NullElement,i.wE=w.ArrayElement,i.Sh=w.ObjectElement,i.Pr=w.MemberElement,i.sI=w.RefElement,i.Ft=w.LinkElement,i.e=w.refract,u(85105),u(75147)},6233:(s,i,u)=>{const _=u(6048),w=u(10316),x=u(92340);class ArrayElement extends w{constructor(s,i,u){super(s||[],i,u),this.element="array"}primitive(){return"array"}get(s){return this.content[s]}getValue(s){const i=this.get(s);if(i)return i.toValue()}getIndex(s){return this.content[s]}set(s,i){return this.content[s]=this.refract(i),this}remove(s){const i=this.content.splice(s,1);return i.length?i[0]:null}map(s,i){return this.content.map(s,i)}flatMap(s,i){return this.map(s,i).reduce(((s,i)=>s.concat(i)),[])}compactMap(s,i){const u=[];return this.forEach((_=>{const w=s.bind(i)(_);w&&u.push(w)})),u}filter(s,i){return new x(this.content.filter(s,i))}reject(s,i){return this.filter(_(s),i)}reduce(s,i){let u,_;void 0!==i?(u=0,_=this.refract(i)):(u=1,_="object"===this.primitive()?this.first.value:this.first);for(let i=u;i{s.bind(i)(u,this.refract(_))}))}shift(){return this.content.shift()}unshift(s){this.content.unshift(this.refract(s))}push(s){return this.content.push(this.refract(s)),this}add(s){this.push(s)}findElements(s,i){const u=i||{},_=!!u.recursive,w=void 0===u.results?[]:u.results;return this.forEach(((i,u,x)=>{_&&void 0!==i.findElements&&i.findElements(s,{results:w,recursive:_}),s(i,u,x)&&w.push(i)})),w}find(s){return new x(this.findElements(s,{recursive:!0}))}findByElement(s){return this.find((i=>i.element===s))}findByClass(s){return this.find((i=>i.classes.includes(s)))}getById(s){return this.find((i=>i.id.toValue()===s)).first}includes(s){return this.content.some((i=>i.equals(s)))}contains(s){return this.includes(s)}empty(){return new this.constructor([])}"fantasy-land/empty"(){return this.empty()}concat(s){return new this.constructor(this.content.concat(s.content))}"fantasy-land/concat"(s){return this.concat(s)}"fantasy-land/map"(s){return new this.constructor(this.map(s))}"fantasy-land/chain"(s){return this.map((i=>s(i)),this).reduce(((s,i)=>s.concat(i)),this.empty())}"fantasy-land/filter"(s){return new this.constructor(this.content.filter(s))}"fantasy-land/reduce"(s,i){return this.content.reduce(s,i)}get length(){return this.content.length}get isEmpty(){return 0===this.content.length}get first(){return this.getIndex(0)}get second(){return this.getIndex(1)}get last(){return this.getIndex(this.length-1)}}ArrayElement.empty=function empty(){return new this},ArrayElement["fantasy-land/empty"]=ArrayElement.empty,"undefined"!=typeof Symbol&&(ArrayElement.prototype[Symbol.iterator]=function symbol(){return this.content[Symbol.iterator]()}),s.exports=ArrayElement},12242:(s,i,u)=>{const _=u(10316);s.exports=class BooleanElement extends _{constructor(s,i,u){super(s,i,u),this.element="boolean"}primitive(){return"boolean"}}},10316:(s,i,u)=>{const _=u(2404),w=u(55973),x=u(92340);class Element{constructor(s,i,u){i&&(this.meta=i),u&&(this.attributes=u),this.content=s}freeze(){Object.isFrozen(this)||(this._meta&&(this.meta.parent=this,this.meta.freeze()),this._attributes&&(this.attributes.parent=this,this.attributes.freeze()),this.children.forEach((s=>{s.parent=this,s.freeze()}),this),this.content&&Array.isArray(this.content)&&Object.freeze(this.content),Object.freeze(this))}primitive(){}clone(){const s=new this.constructor;return s.element=this.element,this.meta.length&&(s._meta=this.meta.clone()),this.attributes.length&&(s._attributes=this.attributes.clone()),this.content?this.content.clone?s.content=this.content.clone():Array.isArray(this.content)?s.content=this.content.map((s=>s.clone())):s.content=this.content:s.content=this.content,s}toValue(){return this.content instanceof Element?this.content.toValue():this.content instanceof w?{key:this.content.key.toValue(),value:this.content.value?this.content.value.toValue():void 0}:this.content&&this.content.map?this.content.map((s=>s.toValue()),this):this.content}toRef(s){if(""===this.id.toValue())throw Error("Cannot create reference to an element that does not contain an ID");const i=new this.RefElement(this.id.toValue());return s&&(i.path=s),i}findRecursive(...s){if(arguments.length>1&&!this.isFrozen)throw new Error("Cannot find recursive with multiple element names without first freezing the element. Call `element.freeze()`");const i=s.pop();let u=new x;const append=(s,i)=>(s.push(i),s),checkElement=(s,u)=>{u.element===i&&s.push(u);const _=u.findRecursive(i);return _&&_.reduce(append,s),u.content instanceof w&&(u.content.key&&checkElement(s,u.content.key),u.content.value&&checkElement(s,u.content.value)),s};return this.content&&(this.content.element&&checkElement(u,this.content),Array.isArray(this.content)&&this.content.reduce(checkElement,u)),s.isEmpty||(u=u.filter((i=>{let u=i.parents.map((s=>s.element));for(const i in s){const _=s[i],w=u.indexOf(_);if(-1===w)return!1;u=u.splice(0,w)}return!0}))),u}set(s){return this.content=s,this}equals(s){return _(this.toValue(),s)}getMetaProperty(s,i){if(!this.meta.hasKey(s)){if(this.isFrozen){const s=this.refract(i);return s.freeze(),s}this.meta.set(s,i)}return this.meta.get(s)}setMetaProperty(s,i){this.meta.set(s,i)}get element(){return this._storedElement||"element"}set element(s){this._storedElement=s}get content(){return this._content}set content(s){if(s instanceof Element)this._content=s;else if(s instanceof x)this.content=s.elements;else if("string"==typeof s||"number"==typeof s||"boolean"==typeof s||"null"===s||null==s)this._content=s;else if(s instanceof w)this._content=s;else if(Array.isArray(s))this._content=s.map(this.refract);else{if("object"!=typeof s)throw new Error("Cannot set content to given value");this._content=Object.keys(s).map((i=>new this.MemberElement(i,s[i])))}}get meta(){if(!this._meta){if(this.isFrozen){const s=new this.ObjectElement;return s.freeze(),s}this._meta=new this.ObjectElement}return this._meta}set meta(s){s instanceof this.ObjectElement?this._meta=s:this.meta.set(s||{})}get attributes(){if(!this._attributes){if(this.isFrozen){const s=new this.ObjectElement;return s.freeze(),s}this._attributes=new this.ObjectElement}return this._attributes}set attributes(s){s instanceof this.ObjectElement?this._attributes=s:this.attributes.set(s||{})}get id(){return this.getMetaProperty("id","")}set id(s){this.setMetaProperty("id",s)}get classes(){return this.getMetaProperty("classes",[])}set classes(s){this.setMetaProperty("classes",s)}get title(){return this.getMetaProperty("title","")}set title(s){this.setMetaProperty("title",s)}get description(){return this.getMetaProperty("description","")}set description(s){this.setMetaProperty("description",s)}get links(){return this.getMetaProperty("links",[])}set links(s){this.setMetaProperty("links",s)}get isFrozen(){return Object.isFrozen(this)}get parents(){let{parent:s}=this;const i=new x;for(;s;)i.push(s),s=s.parent;return i}get children(){if(Array.isArray(this.content))return new x(this.content);if(this.content instanceof w){const s=new x([this.content.key]);return this.content.value&&s.push(this.content.value),s}return this.content instanceof Element?new x([this.content]):new x}get recursiveChildren(){const s=new x;return this.children.forEach((i=>{s.push(i),i.recursiveChildren.forEach((i=>{s.push(i)}))})),s}}s.exports=Element},87726:(s,i,u)=>{const _=u(55973),w=u(10316);s.exports=class MemberElement extends w{constructor(s,i,u,w){super(new _,u,w),this.element="member",this.key=s,this.value=i}get key(){return this.content.key}set key(s){this.content.key=this.refract(s)}get value(){return this.content.value}set value(s){this.content.value=this.refract(s)}}},41067:(s,i,u)=>{const _=u(10316);s.exports=class NullElement extends _{constructor(s,i,u){super(s||null,i,u),this.element="null"}primitive(){return"null"}set(){return new Error("Cannot set the value of null")}}},40239:(s,i,u)=>{const _=u(10316);s.exports=class NumberElement extends _{constructor(s,i,u){super(s,i,u),this.element="number"}primitive(){return"number"}}},61045:(s,i,u)=>{const _=u(6048),w=u(23805),x=u(6233),j=u(87726),L=u(10866);s.exports=class ObjectElement extends x{constructor(s,i,u){super(s||[],i,u),this.element="object"}primitive(){return"object"}toValue(){return this.content.reduce(((s,i)=>(s[i.key.toValue()]=i.value?i.value.toValue():void 0,s)),{})}get(s){const i=this.getMember(s);if(i)return i.value}getMember(s){if(void 0!==s)return this.content.find((i=>i.key.toValue()===s))}remove(s){let i=null;return this.content=this.content.filter((u=>u.key.toValue()!==s||(i=u,!1))),i}getKey(s){const i=this.getMember(s);if(i)return i.key}set(s,i){if(w(s))return Object.keys(s).forEach((i=>{this.set(i,s[i])})),this;const u=s,_=this.getMember(u);return _?_.value=i:this.content.push(new j(u,i)),this}keys(){return this.content.map((s=>s.key.toValue()))}values(){return this.content.map((s=>s.value.toValue()))}hasKey(s){return this.content.some((i=>i.key.equals(s)))}items(){return this.content.map((s=>[s.key.toValue(),s.value.toValue()]))}map(s,i){return this.content.map((u=>s.bind(i)(u.value,u.key,u)))}compactMap(s,i){const u=[];return this.forEach(((_,w,x)=>{const j=s.bind(i)(_,w,x);j&&u.push(j)})),u}filter(s,i){return new L(this.content).filter(s,i)}reject(s,i){return this.filter(_(s),i)}forEach(s,i){return this.content.forEach((u=>s.bind(i)(u.value,u.key,u)))}}},71167:(s,i,u)=>{const _=u(10316);s.exports=class StringElement extends _{constructor(s,i,u){super(s,i,u),this.element="string"}primitive(){return"string"}get length(){return this.content.length}}},75147:(s,i,u)=>{const _=u(85105);s.exports=class JSON06Serialiser extends _{serialise(s){if(!(s instanceof this.namespace.elements.Element))throw new TypeError(`Given element \`${s}\` is not an Element instance`);let i;s._attributes&&s.attributes.get("variable")&&(i=s.attributes.get("variable"));const u={element:s.element};s._meta&&s._meta.length>0&&(u.meta=this.serialiseObject(s.meta));const _="enum"===s.element||-1!==s.attributes.keys().indexOf("enumerations");if(_){const i=this.enumSerialiseAttributes(s);i&&(u.attributes=i)}else if(s._attributes&&s._attributes.length>0){let{attributes:_}=s;_.get("metadata")&&(_=_.clone(),_.set("meta",_.get("metadata")),_.remove("metadata")),"member"===s.element&&i&&(_=_.clone(),_.remove("variable")),_.length>0&&(u.attributes=this.serialiseObject(_))}if(_)u.content=this.enumSerialiseContent(s,u);else if(this[`${s.element}SerialiseContent`])u.content=this[`${s.element}SerialiseContent`](s,u);else if(void 0!==s.content){let _;i&&s.content.key?(_=s.content.clone(),_.key.attributes.set("variable",i),_=this.serialiseContent(_)):_=this.serialiseContent(s.content),this.shouldSerialiseContent(s,_)&&(u.content=_)}else this.shouldSerialiseContent(s,s.content)&&s instanceof this.namespace.elements.Array&&(u.content=[]);return u}shouldSerialiseContent(s,i){return"parseResult"===s.element||"httpRequest"===s.element||"httpResponse"===s.element||"category"===s.element||"link"===s.element||void 0!==i&&(!Array.isArray(i)||0!==i.length)}refSerialiseContent(s,i){return delete i.attributes,{href:s.toValue(),path:s.path.toValue()}}sourceMapSerialiseContent(s){return s.toValue()}dataStructureSerialiseContent(s){return[this.serialiseContent(s.content)]}enumSerialiseAttributes(s){const i=s.attributes.clone(),u=i.remove("enumerations")||new this.namespace.elements.Array([]),_=i.get("default");let w=i.get("samples")||new this.namespace.elements.Array([]);if(_&&_.content&&(_.content.attributes&&_.content.attributes.remove("typeAttributes"),i.set("default",new this.namespace.elements.Array([_.content]))),w.forEach((s=>{s.content&&s.content.element&&s.content.attributes.remove("typeAttributes")})),s.content&&0!==u.length&&w.unshift(s.content),w=w.map((s=>s instanceof this.namespace.elements.Array?[s]:new this.namespace.elements.Array([s.content]))),w.length&&i.set("samples",w),i.length>0)return this.serialiseObject(i)}enumSerialiseContent(s){if(s._attributes){const i=s.attributes.get("enumerations");if(i&&i.length>0)return i.content.map((s=>{const i=s.clone();return i.attributes.remove("typeAttributes"),this.serialise(i)}))}if(s.content){const i=s.content.clone();return i.attributes.remove("typeAttributes"),[this.serialise(i)]}return[]}deserialise(s){if("string"==typeof s)return new this.namespace.elements.String(s);if("number"==typeof s)return new this.namespace.elements.Number(s);if("boolean"==typeof s)return new this.namespace.elements.Boolean(s);if(null===s)return new this.namespace.elements.Null;if(Array.isArray(s))return new this.namespace.elements.Array(s.map(this.deserialise,this));const i=this.namespace.getElementClass(s.element),u=new i;u.element!==s.element&&(u.element=s.element),s.meta&&this.deserialiseObject(s.meta,u.meta),s.attributes&&this.deserialiseObject(s.attributes,u.attributes);const _=this.deserialiseContent(s.content);if(void 0===_&&null!==u.content||(u.content=_),"enum"===u.element){u.content&&u.attributes.set("enumerations",u.content);let s=u.attributes.get("samples");if(u.attributes.remove("samples"),s){const _=s;s=new this.namespace.elements.Array,_.forEach((_=>{_.forEach((_=>{const w=new i(_);w.element=u.element,s.push(w)}))}));const w=s.shift();u.content=w?w.content:void 0,u.attributes.set("samples",s)}else u.content=void 0;let _=u.attributes.get("default");if(_&&_.length>0){_=_.get(0);const s=new i(_);s.element=u.element,u.attributes.set("default",s)}}else if("dataStructure"===u.element&&Array.isArray(u.content))[u.content]=u.content;else if("category"===u.element){const s=u.attributes.get("meta");s&&(u.attributes.set("metadata",s),u.attributes.remove("meta"))}else"member"===u.element&&u.key&&u.key._attributes&&u.key._attributes.getValue("variable")&&(u.attributes.set("variable",u.key.attributes.get("variable")),u.key.attributes.remove("variable"));return u}serialiseContent(s){if(s instanceof this.namespace.elements.Element)return this.serialise(s);if(s instanceof this.namespace.KeyValuePair){const i={key:this.serialise(s.key)};return s.value&&(i.value=this.serialise(s.value)),i}return s&&s.map?s.map(this.serialise,this):s}deserialiseContent(s){if(s){if(s.element)return this.deserialise(s);if(s.key){const i=new this.namespace.KeyValuePair(this.deserialise(s.key));return s.value&&(i.value=this.deserialise(s.value)),i}if(s.map)return s.map(this.deserialise,this)}return s}shouldRefract(s){return!!(s._attributes&&s.attributes.keys().length||s._meta&&s.meta.keys().length)||"enum"!==s.element&&(s.element!==s.primitive()||"member"===s.element)}convertKeyToRefract(s,i){return this.shouldRefract(i)?this.serialise(i):"enum"===i.element?this.serialiseEnum(i):"array"===i.element?i.map((i=>this.shouldRefract(i)||"default"===s?this.serialise(i):"array"===i.element||"object"===i.element||"enum"===i.element?i.children.map((s=>this.serialise(s))):i.toValue())):"object"===i.element?(i.content||[]).map(this.serialise,this):i.toValue()}serialiseEnum(s){return s.children.map((s=>this.serialise(s)))}serialiseObject(s){const i={};return s.forEach(((s,u)=>{if(s){const _=u.toValue();i[_]=this.convertKeyToRefract(_,s)}})),i}deserialiseObject(s,i){Object.keys(s).forEach((u=>{i.set(u,this.deserialise(s[u]))}))}}},85105:s=>{s.exports=class JSONSerialiser{constructor(s){this.namespace=s||new this.Namespace}serialise(s){if(!(s instanceof this.namespace.elements.Element))throw new TypeError(`Given element \`${s}\` is not an Element instance`);const i={element:s.element};s._meta&&s._meta.length>0&&(i.meta=this.serialiseObject(s.meta)),s._attributes&&s._attributes.length>0&&(i.attributes=this.serialiseObject(s.attributes));const u=this.serialiseContent(s.content);return void 0!==u&&(i.content=u),i}deserialise(s){if(!s.element)throw new Error("Given value is not an object containing an element name");const i=new(this.namespace.getElementClass(s.element));i.element!==s.element&&(i.element=s.element),s.meta&&this.deserialiseObject(s.meta,i.meta),s.attributes&&this.deserialiseObject(s.attributes,i.attributes);const u=this.deserialiseContent(s.content);return void 0===u&&null!==i.content||(i.content=u),i}serialiseContent(s){if(s instanceof this.namespace.elements.Element)return this.serialise(s);if(s instanceof this.namespace.KeyValuePair){const i={key:this.serialise(s.key)};return s.value&&(i.value=this.serialise(s.value)),i}if(s&&s.map){if(0===s.length)return;return s.map(this.serialise,this)}return s}deserialiseContent(s){if(s){if(s.element)return this.deserialise(s);if(s.key){const i=new this.namespace.KeyValuePair(this.deserialise(s.key));return s.value&&(i.value=this.deserialise(s.value)),i}if(s.map)return s.map(this.deserialise,this)}return s}serialiseObject(s){const i={};if(s.forEach(((s,u)=>{s&&(i[u.toValue()]=this.serialise(s))})),0!==Object.keys(i).length)return i}deserialiseObject(s,i){Object.keys(s).forEach((u=>{i.set(u,this.deserialise(s[u]))}))}}},58859:(s,i,u)=>{var _="function"==typeof Map&&Map.prototype,w=Object.getOwnPropertyDescriptor&&_?Object.getOwnPropertyDescriptor(Map.prototype,"size"):null,x=_&&w&&"function"==typeof w.get?w.get:null,j=_&&Map.prototype.forEach,L="function"==typeof Set&&Set.prototype,B=Object.getOwnPropertyDescriptor&&L?Object.getOwnPropertyDescriptor(Set.prototype,"size"):null,$=L&&B&&"function"==typeof B.get?B.get:null,U=L&&Set.prototype.forEach,Y="function"==typeof WeakMap&&WeakMap.prototype?WeakMap.prototype.has:null,Z="function"==typeof WeakSet&&WeakSet.prototype?WeakSet.prototype.has:null,ee="function"==typeof WeakRef&&WeakRef.prototype?WeakRef.prototype.deref:null,ie=Boolean.prototype.valueOf,ae=Object.prototype.toString,le=Function.prototype.toString,ce=String.prototype.match,pe=String.prototype.slice,de=String.prototype.replace,fe=String.prototype.toUpperCase,ye=String.prototype.toLowerCase,be=RegExp.prototype.test,_e=Array.prototype.concat,we=Array.prototype.join,Se=Array.prototype.slice,xe=Math.floor,Pe="function"==typeof BigInt?BigInt.prototype.valueOf:null,Te=Object.getOwnPropertySymbols,Re="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?Symbol.prototype.toString:null,qe="function"==typeof Symbol&&"object"==typeof Symbol.iterator,$e="function"==typeof Symbol&&Symbol.toStringTag&&(typeof Symbol.toStringTag===qe||"symbol")?Symbol.toStringTag:null,ze=Object.prototype.propertyIsEnumerable,We=("function"==typeof Reflect?Reflect.getPrototypeOf:Object.getPrototypeOf)||([].__proto__===Array.prototype?function(s){return s.__proto__}:null);function addNumericSeparator(s,i){if(s===1/0||s===-1/0||s!=s||s&&s>-1e3&&s<1e3||be.call(/e/,i))return i;var u=/[0-9](?=(?:[0-9]{3})+(?![0-9]))/g;if("number"==typeof s){var _=s<0?-xe(-s):xe(s);if(_!==s){var w=String(_),x=pe.call(i,w.length+1);return de.call(w,u,"$&_")+"."+de.call(de.call(x,/([0-9]{3})/g,"$&_"),/_$/,"")}}return de.call(i,u,"$&_")}var He=u(42634),Ye=He.custom,Xe=isSymbol(Ye)?Ye:null;function wrapQuotes(s,i,u){var _="double"===(u.quoteStyle||i)?'"':"'";return _+s+_}function quote(s){return de.call(String(s),/"/g,""")}function isArray(s){return!("[object Array]"!==toStr(s)||$e&&"object"==typeof s&&$e in s)}function isRegExp(s){return!("[object RegExp]"!==toStr(s)||$e&&"object"==typeof s&&$e in s)}function isSymbol(s){if(qe)return s&&"object"==typeof s&&s instanceof Symbol;if("symbol"==typeof s)return!0;if(!s||"object"!=typeof s||!Re)return!1;try{return Re.call(s),!0}catch(s){}return!1}s.exports=function inspect_(s,i,_,w){var L=i||{};if(has(L,"quoteStyle")&&"single"!==L.quoteStyle&&"double"!==L.quoteStyle)throw new TypeError('option "quoteStyle" must be "single" or "double"');if(has(L,"maxStringLength")&&("number"==typeof L.maxStringLength?L.maxStringLength<0&&L.maxStringLength!==1/0:null!==L.maxStringLength))throw new TypeError('option "maxStringLength", if provided, must be a positive integer, Infinity, or `null`');var B=!has(L,"customInspect")||L.customInspect;if("boolean"!=typeof B&&"symbol"!==B)throw new TypeError("option \"customInspect\", if provided, must be `true`, `false`, or `'symbol'`");if(has(L,"indent")&&null!==L.indent&&"\t"!==L.indent&&!(parseInt(L.indent,10)===L.indent&&L.indent>0))throw new TypeError('option "indent" must be "\\t", an integer > 0, or `null`');if(has(L,"numericSeparator")&&"boolean"!=typeof L.numericSeparator)throw new TypeError('option "numericSeparator", if provided, must be `true` or `false`');var ae=L.numericSeparator;if(void 0===s)return"undefined";if(null===s)return"null";if("boolean"==typeof s)return s?"true":"false";if("string"==typeof s)return inspectString(s,L);if("number"==typeof s){if(0===s)return 1/0/s>0?"0":"-0";var fe=String(s);return ae?addNumericSeparator(s,fe):fe}if("bigint"==typeof s){var be=String(s)+"n";return ae?addNumericSeparator(s,be):be}var xe=void 0===L.depth?5:L.depth;if(void 0===_&&(_=0),_>=xe&&xe>0&&"object"==typeof s)return isArray(s)?"[Array]":"[Object]";var Te=function getIndent(s,i){var u;if("\t"===s.indent)u="\t";else{if(!("number"==typeof s.indent&&s.indent>0))return null;u=we.call(Array(s.indent+1)," ")}return{base:u,prev:we.call(Array(i+1),u)}}(L,_);if(void 0===w)w=[];else if(indexOf(w,s)>=0)return"[Circular]";function inspect(s,i,u){if(i&&(w=Se.call(w)).push(i),u){var x={depth:L.depth};return has(L,"quoteStyle")&&(x.quoteStyle=L.quoteStyle),inspect_(s,x,_+1,w)}return inspect_(s,L,_+1,w)}if("function"==typeof s&&!isRegExp(s)){var Ye=function nameOf(s){if(s.name)return s.name;var i=ce.call(le.call(s),/^function\s*([\w$]+)/);if(i)return i[1];return null}(s),Qe=arrObjKeys(s,inspect);return"[Function"+(Ye?": "+Ye:" (anonymous)")+"]"+(Qe.length>0?" { "+we.call(Qe,", ")+" }":"")}if(isSymbol(s)){var et=qe?de.call(String(s),/^(Symbol\(.*\))_[^)]*$/,"$1"):Re.call(s);return"object"!=typeof s||qe?et:markBoxed(et)}if(function isElement(s){if(!s||"object"!=typeof s)return!1;if("undefined"!=typeof HTMLElement&&s instanceof HTMLElement)return!0;return"string"==typeof s.nodeName&&"function"==typeof s.getAttribute}(s)){for(var tt="<"+ye.call(String(s.nodeName)),rt=s.attributes||[],nt=0;nt"}if(isArray(s)){if(0===s.length)return"[]";var ot=arrObjKeys(s,inspect);return Te&&!function singleLineValues(s){for(var i=0;i=0)return!1;return!0}(ot)?"["+indentedJoin(ot,Te)+"]":"[ "+we.call(ot,", ")+" ]"}if(function isError(s){return!("[object Error]"!==toStr(s)||$e&&"object"==typeof s&&$e in s)}(s)){var st=arrObjKeys(s,inspect);return"cause"in Error.prototype||!("cause"in s)||ze.call(s,"cause")?0===st.length?"["+String(s)+"]":"{ ["+String(s)+"] "+we.call(st,", ")+" }":"{ ["+String(s)+"] "+we.call(_e.call("[cause]: "+inspect(s.cause),st),", ")+" }"}if("object"==typeof s&&B){if(Xe&&"function"==typeof s[Xe]&&He)return He(s,{depth:xe-_});if("symbol"!==B&&"function"==typeof s.inspect)return s.inspect()}if(function isMap(s){if(!x||!s||"object"!=typeof s)return!1;try{x.call(s);try{$.call(s)}catch(s){return!0}return s instanceof Map}catch(s){}return!1}(s)){var it=[];return j&&j.call(s,(function(i,u){it.push(inspect(u,s,!0)+" => "+inspect(i,s))})),collectionOf("Map",x.call(s),it,Te)}if(function isSet(s){if(!$||!s||"object"!=typeof s)return!1;try{$.call(s);try{x.call(s)}catch(s){return!0}return s instanceof Set}catch(s){}return!1}(s)){var at=[];return U&&U.call(s,(function(i){at.push(inspect(i,s))})),collectionOf("Set",$.call(s),at,Te)}if(function isWeakMap(s){if(!Y||!s||"object"!=typeof s)return!1;try{Y.call(s,Y);try{Z.call(s,Z)}catch(s){return!0}return s instanceof WeakMap}catch(s){}return!1}(s))return weakCollectionOf("WeakMap");if(function isWeakSet(s){if(!Z||!s||"object"!=typeof s)return!1;try{Z.call(s,Z);try{Y.call(s,Y)}catch(s){return!0}return s instanceof WeakSet}catch(s){}return!1}(s))return weakCollectionOf("WeakSet");if(function isWeakRef(s){if(!ee||!s||"object"!=typeof s)return!1;try{return ee.call(s),!0}catch(s){}return!1}(s))return weakCollectionOf("WeakRef");if(function isNumber(s){return!("[object Number]"!==toStr(s)||$e&&"object"==typeof s&&$e in s)}(s))return markBoxed(inspect(Number(s)));if(function isBigInt(s){if(!s||"object"!=typeof s||!Pe)return!1;try{return Pe.call(s),!0}catch(s){}return!1}(s))return markBoxed(inspect(Pe.call(s)));if(function isBoolean(s){return!("[object Boolean]"!==toStr(s)||$e&&"object"==typeof s&&$e in s)}(s))return markBoxed(ie.call(s));if(function isString(s){return!("[object String]"!==toStr(s)||$e&&"object"==typeof s&&$e in s)}(s))return markBoxed(inspect(String(s)));if("undefined"!=typeof window&&s===window)return"{ [object Window] }";if(s===u.g)return"{ [object globalThis] }";if(!function isDate(s){return!("[object Date]"!==toStr(s)||$e&&"object"==typeof s&&$e in s)}(s)&&!isRegExp(s)){var lt=arrObjKeys(s,inspect),ct=We?We(s)===Object.prototype:s instanceof Object||s.constructor===Object,ut=s instanceof Object?"":"null prototype",pt=!ct&&$e&&Object(s)===s&&$e in s?pe.call(toStr(s),8,-1):ut?"Object":"",ht=(ct||"function"!=typeof s.constructor?"":s.constructor.name?s.constructor.name+" ":"")+(pt||ut?"["+we.call(_e.call([],pt||[],ut||[]),": ")+"] ":"");return 0===lt.length?ht+"{}":Te?ht+"{"+indentedJoin(lt,Te)+"}":ht+"{ "+we.call(lt,", ")+" }"}return String(s)};var Qe=Object.prototype.hasOwnProperty||function(s){return s in this};function has(s,i){return Qe.call(s,i)}function toStr(s){return ae.call(s)}function indexOf(s,i){if(s.indexOf)return s.indexOf(i);for(var u=0,_=s.length;u<_;u++)if(s[u]===i)return u;return-1}function inspectString(s,i){if(s.length>i.maxStringLength){var u=s.length-i.maxStringLength,_="... "+u+" more character"+(u>1?"s":"");return inspectString(pe.call(s,0,i.maxStringLength),i)+_}return wrapQuotes(de.call(de.call(s,/(['\\])/g,"\\$1"),/[\x00-\x1f]/g,lowbyte),"single",i)}function lowbyte(s){var i=s.charCodeAt(0),u={8:"b",9:"t",10:"n",12:"f",13:"r"}[i];return u?"\\"+u:"\\x"+(i<16?"0":"")+fe.call(i.toString(16))}function markBoxed(s){return"Object("+s+")"}function weakCollectionOf(s){return s+" { ? }"}function collectionOf(s,i,u,_){return s+" ("+i+") {"+(_?indentedJoin(u,_):we.call(u,", "))+"}"}function indentedJoin(s,i){if(0===s.length)return"";var u="\n"+i.prev+i.base;return u+we.call(s,","+u)+"\n"+i.prev}function arrObjKeys(s,i){var u=isArray(s),_=[];if(u){_.length=s.length;for(var w=0;w{var i,u,_=s.exports={};function defaultSetTimout(){throw new Error("setTimeout has not been defined")}function defaultClearTimeout(){throw new Error("clearTimeout has not been defined")}function runTimeout(s){if(i===setTimeout)return setTimeout(s,0);if((i===defaultSetTimout||!i)&&setTimeout)return i=setTimeout,setTimeout(s,0);try{return i(s,0)}catch(u){try{return i.call(null,s,0)}catch(u){return i.call(this,s,0)}}}!function(){try{i="function"==typeof setTimeout?setTimeout:defaultSetTimout}catch(s){i=defaultSetTimout}try{u="function"==typeof clearTimeout?clearTimeout:defaultClearTimeout}catch(s){u=defaultClearTimeout}}();var w,x=[],j=!1,L=-1;function cleanUpNextTick(){j&&w&&(j=!1,w.length?x=w.concat(x):L=-1,x.length&&drainQueue())}function drainQueue(){if(!j){var s=runTimeout(cleanUpNextTick);j=!0;for(var i=x.length;i;){for(w=x,x=[];++L1)for(var u=1;u{"use strict";var _=u(6925);function emptyFunction(){}function emptyFunctionWithReset(){}emptyFunctionWithReset.resetWarningCache=emptyFunction,s.exports=function(){function shim(s,i,u,w,x,j){if(j!==_){var L=new Error("Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types");throw L.name="Invariant Violation",L}}function getShim(){return shim}shim.isRequired=shim;var s={array:shim,bigint:shim,bool:shim,func:shim,number:shim,object:shim,string:shim,symbol:shim,any:shim,arrayOf:getShim,element:shim,elementType:shim,instanceOf:getShim,node:shim,objectOf:getShim,oneOf:getShim,oneOfType:getShim,shape:getShim,exact:getShim,checkPropTypes:emptyFunctionWithReset,resetWarningCache:emptyFunction};return s.PropTypes=s,s}},5556:(s,i,u)=>{s.exports=u(2694)()},6925:s=>{"use strict";s.exports="SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"},74765:s=>{"use strict";var i=String.prototype.replace,u=/%20/g,_="RFC1738",w="RFC3986";s.exports={default:w,formatters:{RFC1738:function(s){return i.call(s,u,"+")},RFC3986:function(s){return String(s)}},RFC1738:_,RFC3986:w}},55373:(s,i,u)=>{"use strict";var _=u(98636),w=u(62642),x=u(74765);s.exports={formats:x,parse:w,stringify:_}},62642:(s,i,u)=>{"use strict";var _=u(37720),w=Object.prototype.hasOwnProperty,x=Array.isArray,j={allowDots:!1,allowPrototypes:!1,allowSparse:!1,arrayLimit:20,charset:"utf-8",charsetSentinel:!1,comma:!1,decoder:_.decode,delimiter:"&",depth:5,ignoreQueryPrefix:!1,interpretNumericEntities:!1,parameterLimit:1e3,parseArrays:!0,plainObjects:!1,strictNullHandling:!1},interpretNumericEntities=function(s){return s.replace(/&#(\d+);/g,(function(s,i){return String.fromCharCode(parseInt(i,10))}))},parseArrayValue=function(s,i){return s&&"string"==typeof s&&i.comma&&s.indexOf(",")>-1?s.split(","):s},L=function parseQueryStringKeys(s,i,u,_){if(s){var x=u.allowDots?s.replace(/\.([^.[]+)/g,"[$1]"):s,j=/(\[[^[\]]*])/g,L=u.depth>0&&/(\[[^[\]]*])/.exec(x),B=L?x.slice(0,L.index):x,$=[];if(B){if(!u.plainObjects&&w.call(Object.prototype,B)&&!u.allowPrototypes)return;$.push(B)}for(var U=0;u.depth>0&&null!==(L=j.exec(x))&&U=0;--x){var j,L=s[x];if("[]"===L&&u.parseArrays)j=[].concat(w);else{j=u.plainObjects?Object.create(null):{};var B="["===L.charAt(0)&&"]"===L.charAt(L.length-1)?L.slice(1,-1):L,$=parseInt(B,10);u.parseArrays||""!==B?!isNaN($)&&L!==B&&String($)===B&&$>=0&&u.parseArrays&&$<=u.arrayLimit?(j=[])[$]=w:"__proto__"!==B&&(j[B]=w):j={0:w}}w=j}return w}($,i,u,_)}};s.exports=function(s,i){var u=function normalizeParseOptions(s){if(!s)return j;if(null!==s.decoder&&void 0!==s.decoder&&"function"!=typeof s.decoder)throw new TypeError("Decoder has to be a function.");if(void 0!==s.charset&&"utf-8"!==s.charset&&"iso-8859-1"!==s.charset)throw new TypeError("The charset option must be either utf-8, iso-8859-1, or undefined");var i=void 0===s.charset?j.charset:s.charset;return{allowDots:void 0===s.allowDots?j.allowDots:!!s.allowDots,allowPrototypes:"boolean"==typeof s.allowPrototypes?s.allowPrototypes:j.allowPrototypes,allowSparse:"boolean"==typeof s.allowSparse?s.allowSparse:j.allowSparse,arrayLimit:"number"==typeof s.arrayLimit?s.arrayLimit:j.arrayLimit,charset:i,charsetSentinel:"boolean"==typeof s.charsetSentinel?s.charsetSentinel:j.charsetSentinel,comma:"boolean"==typeof s.comma?s.comma:j.comma,decoder:"function"==typeof s.decoder?s.decoder:j.decoder,delimiter:"string"==typeof s.delimiter||_.isRegExp(s.delimiter)?s.delimiter:j.delimiter,depth:"number"==typeof s.depth||!1===s.depth?+s.depth:j.depth,ignoreQueryPrefix:!0===s.ignoreQueryPrefix,interpretNumericEntities:"boolean"==typeof s.interpretNumericEntities?s.interpretNumericEntities:j.interpretNumericEntities,parameterLimit:"number"==typeof s.parameterLimit?s.parameterLimit:j.parameterLimit,parseArrays:!1!==s.parseArrays,plainObjects:"boolean"==typeof s.plainObjects?s.plainObjects:j.plainObjects,strictNullHandling:"boolean"==typeof s.strictNullHandling?s.strictNullHandling:j.strictNullHandling}}(i);if(""===s||null==s)return u.plainObjects?Object.create(null):{};for(var B="string"==typeof s?function parseQueryStringValues(s,i){var u,L={},B=i.ignoreQueryPrefix?s.replace(/^\?/,""):s,$=i.parameterLimit===1/0?void 0:i.parameterLimit,U=B.split(i.delimiter,$),Y=-1,Z=i.charset;if(i.charsetSentinel)for(u=0;u-1&&(ie=x(ie)?[ie]:ie),w.call(L,ee)?L[ee]=_.combine(L[ee],ie):L[ee]=ie}return L}(s,u):s,$=u.plainObjects?Object.create(null):{},U=Object.keys(B),Y=0;Y{"use strict";var _=u(920),w=u(37720),x=u(74765),j=Object.prototype.hasOwnProperty,L={brackets:function brackets(s){return s+"[]"},comma:"comma",indices:function indices(s,i){return s+"["+i+"]"},repeat:function repeat(s){return s}},B=Array.isArray,$=String.prototype.split,U=Array.prototype.push,pushToArray=function(s,i){U.apply(s,B(i)?i:[i])},Y=Date.prototype.toISOString,Z=x.default,ee={addQueryPrefix:!1,allowDots:!1,charset:"utf-8",charsetSentinel:!1,delimiter:"&",encode:!0,encoder:w.encode,encodeValuesOnly:!1,format:Z,formatter:x.formatters[Z],indices:!1,serializeDate:function serializeDate(s){return Y.call(s)},skipNulls:!1,strictNullHandling:!1},ie={},ae=function stringify(s,i,u,x,j,L,U,Y,Z,ae,le,ce,pe,de,fe,ye){for(var be=s,_e=ye,we=0,Se=!1;void 0!==(_e=_e.get(ie))&&!Se;){var xe=_e.get(s);if(we+=1,void 0!==xe){if(xe===we)throw new RangeError("Cyclic object value");Se=!0}void 0===_e.get(ie)&&(we=0)}if("function"==typeof Y?be=Y(i,be):be instanceof Date?be=le(be):"comma"===u&&B(be)&&(be=w.maybeMap(be,(function(s){return s instanceof Date?le(s):s}))),null===be){if(j)return U&&!de?U(i,ee.encoder,fe,"key",ce):i;be=""}if(function isNonNullishPrimitive(s){return"string"==typeof s||"number"==typeof s||"boolean"==typeof s||"symbol"==typeof s||"bigint"==typeof s}(be)||w.isBuffer(be)){if(U){var Pe=de?i:U(i,ee.encoder,fe,"key",ce);if("comma"===u&&de){for(var Te=$.call(String(be),","),Re="",qe=0;qe0?be.join(",")||null:void 0}];else if(B(Y))$e=Y;else{var We=Object.keys(be);$e=Z?We.sort(Z):We}for(var He=x&&B(be)&&1===be.length?i+"[]":i,Ye=0;Ye<$e.length;++Ye){var Xe=$e[Ye],Qe="object"==typeof Xe&&void 0!==Xe.value?Xe.value:be[Xe];if(!L||null!==Qe){var et=B(be)?"function"==typeof u?u(He,Xe):He:He+(ae?"."+Xe:"["+Xe+"]");ye.set(s,we);var tt=_();tt.set(ie,ye),pushToArray(ze,stringify(Qe,et,u,x,j,L,U,Y,Z,ae,le,ce,pe,de,fe,tt))}}return ze};s.exports=function(s,i){var u,w=s,$=function normalizeStringifyOptions(s){if(!s)return ee;if(null!==s.encoder&&void 0!==s.encoder&&"function"!=typeof s.encoder)throw new TypeError("Encoder has to be a function.");var i=s.charset||ee.charset;if(void 0!==s.charset&&"utf-8"!==s.charset&&"iso-8859-1"!==s.charset)throw new TypeError("The charset option must be either utf-8, iso-8859-1, or undefined");var u=x.default;if(void 0!==s.format){if(!j.call(x.formatters,s.format))throw new TypeError("Unknown format option provided.");u=s.format}var _=x.formatters[u],w=ee.filter;return("function"==typeof s.filter||B(s.filter))&&(w=s.filter),{addQueryPrefix:"boolean"==typeof s.addQueryPrefix?s.addQueryPrefix:ee.addQueryPrefix,allowDots:void 0===s.allowDots?ee.allowDots:!!s.allowDots,charset:i,charsetSentinel:"boolean"==typeof s.charsetSentinel?s.charsetSentinel:ee.charsetSentinel,delimiter:void 0===s.delimiter?ee.delimiter:s.delimiter,encode:"boolean"==typeof s.encode?s.encode:ee.encode,encoder:"function"==typeof s.encoder?s.encoder:ee.encoder,encodeValuesOnly:"boolean"==typeof s.encodeValuesOnly?s.encodeValuesOnly:ee.encodeValuesOnly,filter:w,format:u,formatter:_,serializeDate:"function"==typeof s.serializeDate?s.serializeDate:ee.serializeDate,skipNulls:"boolean"==typeof s.skipNulls?s.skipNulls:ee.skipNulls,sort:"function"==typeof s.sort?s.sort:null,strictNullHandling:"boolean"==typeof s.strictNullHandling?s.strictNullHandling:ee.strictNullHandling}}(i);"function"==typeof $.filter?w=(0,$.filter)("",w):B($.filter)&&(u=$.filter);var U,Y=[];if("object"!=typeof w||null===w)return"";U=i&&i.arrayFormat in L?i.arrayFormat:i&&"indices"in i?i.indices?"indices":"repeat":"indices";var Z=L[U];if(i&&"commaRoundTrip"in i&&"boolean"!=typeof i.commaRoundTrip)throw new TypeError("`commaRoundTrip` must be a boolean, or absent");var ie="comma"===Z&&i&&i.commaRoundTrip;u||(u=Object.keys(w)),$.sort&&u.sort($.sort);for(var le=_(),ce=0;ce0?fe+de:""}},37720:(s,i,u)=>{"use strict";var _=u(74765),w=Object.prototype.hasOwnProperty,x=Array.isArray,j=function(){for(var s=[],i=0;i<256;++i)s.push("%"+((i<16?"0":"")+i.toString(16)).toUpperCase());return s}(),L=function arrayToObject(s,i){for(var u=i&&i.plainObjects?Object.create(null):{},_=0;_1;){var i=s.pop(),u=i.obj[i.prop];if(x(u)){for(var _=[],w=0;w=48&&U<=57||U>=65&&U<=90||U>=97&&U<=122||x===_.RFC1738&&(40===U||41===U)?B+=L.charAt($):U<128?B+=j[U]:U<2048?B+=j[192|U>>6]+j[128|63&U]:U<55296||U>=57344?B+=j[224|U>>12]+j[128|U>>6&63]+j[128|63&U]:($+=1,U=65536+((1023&U)<<10|1023&L.charCodeAt($)),B+=j[240|U>>18]+j[128|U>>12&63]+j[128|U>>6&63]+j[128|63&U])}return B},isBuffer:function isBuffer(s){return!(!s||"object"!=typeof s)&&!!(s.constructor&&s.constructor.isBuffer&&s.constructor.isBuffer(s))},isRegExp:function isRegExp(s){return"[object RegExp]"===Object.prototype.toString.call(s)},maybeMap:function maybeMap(s,i){if(x(s)){for(var u=[],_=0;_{"use strict";var u=Object.prototype.hasOwnProperty;function decode(s){try{return decodeURIComponent(s.replace(/\+/g," "))}catch(s){return null}}function encode(s){try{return encodeURIComponent(s)}catch(s){return null}}i.stringify=function querystringify(s,i){i=i||"";var _,w,x=[];for(w in"string"!=typeof i&&(i="?"),s)if(u.call(s,w)){if((_=s[w])||null!=_&&!isNaN(_)||(_=""),w=encode(w),_=encode(_),null===w||null===_)continue;x.push(w+"="+_)}return x.length?i+x.join("&"):""},i.parse=function querystring(s){for(var i,u=/([^=?#&]+)=?([^&]*)/g,_={};i=u.exec(s);){var w=decode(i[1]),x=decode(i[2]);null===w||null===x||w in _||(_[w]=x)}return _}},41859:(s,i,u)=>{const _=u(27096),w=u(78004),x=_.types;s.exports=class RandExp{constructor(s,i){if(this._setDefaults(s),s instanceof RegExp)this.ignoreCase=s.ignoreCase,this.multiline=s.multiline,s=s.source;else{if("string"!=typeof s)throw new Error("Expected a regexp or string");this.ignoreCase=i&&-1!==i.indexOf("i"),this.multiline=i&&-1!==i.indexOf("m")}this.tokens=_(s)}_setDefaults(s){this.max=null!=s.max?s.max:null!=RandExp.prototype.max?RandExp.prototype.max:100,this.defaultRange=s.defaultRange?s.defaultRange:this.defaultRange.clone(),s.randInt&&(this.randInt=s.randInt)}gen(){return this._gen(this.tokens,[])}_gen(s,i){var u,_,w,j,L;switch(s.type){case x.ROOT:case x.GROUP:if(s.followedBy||s.notFollowedBy)return"";for(s.remember&&void 0===s.groupNumber&&(s.groupNumber=i.push(null)-1),_="",j=0,L=(u=s.options?this._randSelect(s.options):s.stack).length;j{"use strict";var _=u(65606),w=65536,x=4294967295;var j=u(92861).Buffer,L=u.g.crypto||u.g.msCrypto;L&&L.getRandomValues?s.exports=function randomBytes(s,i){if(s>x)throw new RangeError("requested too many random bytes");var u=j.allocUnsafe(s);if(s>0)if(s>w)for(var B=0;B{"use strict";function _typeof(s){return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(s){return typeof s}:function(s){return s&&"function"==typeof Symbol&&s.constructor===Symbol&&s!==Symbol.prototype?"symbol":typeof s},_typeof(s)}Object.defineProperty(i,"__esModule",{value:!0}),i.CopyToClipboard=void 0;var _=_interopRequireDefault(u(96540)),w=_interopRequireDefault(u(17965)),x=["text","onCopy","options","children"];function _interopRequireDefault(s){return s&&s.__esModule?s:{default:s}}function ownKeys(s,i){var u=Object.keys(s);if(Object.getOwnPropertySymbols){var _=Object.getOwnPropertySymbols(s);i&&(_=_.filter((function(i){return Object.getOwnPropertyDescriptor(s,i).enumerable}))),u.push.apply(u,_)}return u}function _objectSpread(s){for(var i=1;i=0||(w[u]=s[u]);return w}(s,i);if(Object.getOwnPropertySymbols){var x=Object.getOwnPropertySymbols(s);for(_=0;_=0||Object.prototype.propertyIsEnumerable.call(s,u)&&(w[u]=s[u])}return w}function _defineProperties(s,i){for(var u=0;u{"use strict";var _=u(25264).CopyToClipboard;_.CopyToClipboard=_,s.exports=_},81214:(s,i,u)=>{"use strict";function _typeof(s){return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(s){return typeof s}:function(s){return s&&"function"==typeof Symbol&&s.constructor===Symbol&&s!==Symbol.prototype?"symbol":typeof s},_typeof(s)}Object.defineProperty(i,"__esModule",{value:!0}),i.DebounceInput=void 0;var _=_interopRequireDefault(u(96540)),w=_interopRequireDefault(u(20181)),x=["element","onChange","value","minLength","debounceTimeout","forceNotifyByEnter","forceNotifyOnBlur","onKeyDown","onBlur","inputRef"];function _interopRequireDefault(s){return s&&s.__esModule?s:{default:s}}function _objectWithoutProperties(s,i){if(null==s)return{};var u,_,w=function _objectWithoutPropertiesLoose(s,i){if(null==s)return{};var u,_,w={},x=Object.keys(s);for(_=0;_=0||(w[u]=s[u]);return w}(s,i);if(Object.getOwnPropertySymbols){var x=Object.getOwnPropertySymbols(s);for(_=0;_=0||Object.prototype.propertyIsEnumerable.call(s,u)&&(w[u]=s[u])}return w}function ownKeys(s,i){var u=Object.keys(s);if(Object.getOwnPropertySymbols){var _=Object.getOwnPropertySymbols(s);i&&(_=_.filter((function(i){return Object.getOwnPropertyDescriptor(s,i).enumerable}))),u.push.apply(u,_)}return u}function _objectSpread(s){for(var i=1;i=_?u.notify(s):i.length>w.length&&u.notify(_objectSpread(_objectSpread({},s),{},{target:_objectSpread(_objectSpread({},s.target),{},{value:""})}))}))})),_defineProperty(_assertThisInitialized(u),"onKeyDown",(function(s){"Enter"===s.key&&u.forceNotify(s);var i=u.props.onKeyDown;i&&(s.persist(),i(s))})),_defineProperty(_assertThisInitialized(u),"onBlur",(function(s){u.forceNotify(s);var i=u.props.onBlur;i&&(s.persist(),i(s))})),_defineProperty(_assertThisInitialized(u),"createNotifier",(function(s){if(s<0)u.notify=function(){return null};else if(0===s)u.notify=u.doNotify;else{var i=(0,w.default)((function(s){u.isDebouncing=!1,u.doNotify(s)}),s);u.notify=function(s){u.isDebouncing=!0,i(s)},u.flush=function(){return i.flush()},u.cancel=function(){u.isDebouncing=!1,i.cancel()}}})),_defineProperty(_assertThisInitialized(u),"doNotify",(function(){u.props.onChange.apply(void 0,arguments)})),_defineProperty(_assertThisInitialized(u),"forceNotify",(function(s){var i=u.props.debounceTimeout;if(u.isDebouncing||!(i>0)){u.cancel&&u.cancel();var _=u.state.value,w=u.props.minLength;_.length>=w?u.doNotify(s):u.doNotify(_objectSpread(_objectSpread({},s),{},{target:_objectSpread(_objectSpread({},s.target),{},{value:_})}))}})),u.isDebouncing=!1,u.state={value:void 0===s.value||null===s.value?"":s.value};var _=u.props.debounceTimeout;return u.createNotifier(_),u}return function _createClass(s,i,u){return i&&_defineProperties(s.prototype,i),u&&_defineProperties(s,u),Object.defineProperty(s,"prototype",{writable:!1}),s}(DebounceInput,[{key:"componentDidUpdate",value:function componentDidUpdate(s){if(!this.isDebouncing){var i=this.props,u=i.value,_=i.debounceTimeout,w=s.debounceTimeout,x=s.value,j=this.state.value;void 0!==u&&x!==u&&j!==u&&this.setState({value:u}),_!==w&&this.createNotifier(_)}}},{key:"componentWillUnmount",value:function componentWillUnmount(){this.flush&&this.flush()}},{key:"render",value:function render(){var s,i,u=this.props,w=u.element,j=(u.onChange,u.value,u.minLength,u.debounceTimeout,u.forceNotifyByEnter),L=u.forceNotifyOnBlur,B=u.onKeyDown,$=u.onBlur,U=u.inputRef,Y=_objectWithoutProperties(u,x),Z=this.state.value;s=j?{onKeyDown:this.onKeyDown}:B?{onKeyDown:B}:{},i=L?{onBlur:this.onBlur}:$?{onBlur:$}:{};var ee=U?{ref:U}:{};return _.default.createElement(w,_objectSpread(_objectSpread(_objectSpread(_objectSpread({},Y),{},{onChange:this.onChange,value:Z},s),i),ee))}}]),DebounceInput}(_.default.PureComponent);i.DebounceInput=j,_defineProperty(j,"defaultProps",{element:"input",type:"text",onKeyDown:void 0,onBlur:void 0,value:void 0,minLength:0,debounceTimeout:100,forceNotifyByEnter:!0,forceNotifyOnBlur:!0,inputRef:void 0})},24677:(s,i,u)=>{"use strict";var _=u(81214).DebounceInput;_.DebounceInput=_,s.exports=_},22551:(s,i,u)=>{"use strict";var _=u(96540),w=u(69982);function p(s){for(var i="https://reactjs.org/docs/error-decoder.html?invariant="+s,u=1;u