mirror of https://gitee.com/antv-l7/antv-l7
commit
c8a302f200
|
@ -16,6 +16,7 @@ module.exports = api => {
|
||||||
plugins: [
|
plugins: [
|
||||||
'@babel/plugin-proposal-optional-chaining',
|
'@babel/plugin-proposal-optional-chaining',
|
||||||
'@babel/plugin-proposal-nullish-coalescing-operator',
|
'@babel/plugin-proposal-nullish-coalescing-operator',
|
||||||
|
'transform-inline-environment-variables',
|
||||||
[
|
[
|
||||||
'@babel/plugin-proposal-decorators',
|
'@babel/plugin-proposal-decorators',
|
||||||
{
|
{
|
||||||
|
|
|
@ -77,6 +77,7 @@ Promise.all([
|
||||||
.color('#ff6b34')
|
.color('#ff6b34')
|
||||||
.shape('arc3d')
|
.shape('arc3d')
|
||||||
.size(2)
|
.size(2)
|
||||||
|
.active(true)
|
||||||
.animate({
|
.animate({
|
||||||
interval: 2,
|
interval: 2,
|
||||||
trailLength: 2,
|
trailLength: 2,
|
||||||
|
|
|
@ -80,6 +80,7 @@ Promise.all([
|
||||||
.color('#b97feb')
|
.color('#b97feb')
|
||||||
.shape('arc3d')
|
.shape('arc3d')
|
||||||
.size(2)
|
.size(2)
|
||||||
|
.active(true)
|
||||||
.animate({
|
.animate({
|
||||||
interval: 2,
|
interval: 2,
|
||||||
trailLength: 2,
|
trailLength: 2,
|
||||||
|
|
|
@ -43,6 +43,7 @@
|
||||||
"babel-plugin-inline-webgl-constants": "^1.0.1",
|
"babel-plugin-inline-webgl-constants": "^1.0.1",
|
||||||
"babel-plugin-lodash": "^3.3.4",
|
"babel-plugin-lodash": "^3.3.4",
|
||||||
"babel-plugin-transform-import-styles": "^0.0.11",
|
"babel-plugin-transform-import-styles": "^0.0.11",
|
||||||
|
"babel-plugin-transform-inline-environment-variables": "^0.4.3",
|
||||||
"babel-plugin-transform-postcss": "^0.3.0",
|
"babel-plugin-transform-postcss": "^0.3.0",
|
||||||
"babel-preset-gatsby": "^0.2.22",
|
"babel-preset-gatsby": "^0.2.22",
|
||||||
"babel-template": "^6.26.0",
|
"babel-template": "^6.26.0",
|
||||||
|
@ -144,7 +145,7 @@
|
||||||
"test-live": "cross-env BABEL_ENV=test DEBUG_MODE=1 jest --watch packages/scene/__tests__/index.spec.ts ",
|
"test-live": "cross-env BABEL_ENV=test DEBUG_MODE=1 jest --watch packages/scene/__tests__/index.spec.ts ",
|
||||||
"coveralls": "jest --coverage && cat ./tests/coverage/lcov.info | coveralls",
|
"coveralls": "jest --coverage && cat ./tests/coverage/lcov.info | coveralls",
|
||||||
"tsc": "tsc",
|
"tsc": "tsc",
|
||||||
"watch": "yarn clean && lerna exec --parallel -- cross-env BABEL_ENV=cjs babel --watch src --root-mode upward --out-dir lib --source-maps --extensions .ts,.tsx --delete-dir-on-start --no-comments",
|
"watch": "yarn clean && lerna exec --parallel -- cross-env BABEL_ENV=cjs NODE_ENV=production babel --watch src --root-mode upward --out-dir lib --source-maps --extensions .ts,.tsx --delete-dir-on-start --no-comments",
|
||||||
"bundle": "cross-env BABEL_ENV=bundle node_modules/.bin/rollup -c ./build/rollup.config.js",
|
"bundle": "cross-env BABEL_ENV=bundle node_modules/.bin/rollup -c ./build/rollup.config.js",
|
||||||
"bundle:watch": "cross-env BABEL_ENV=bundle node_modules/.bin/rollup -c ./build/rollup.config.js --watch",
|
"bundle:watch": "cross-env BABEL_ENV=bundle node_modules/.bin/rollup -c ./build/rollup.config.js --watch",
|
||||||
"glsl-minify": "node_modules/.bin/glsl-minifier -i ./build/example.frag -o ./build/example.min.frag",
|
"glsl-minify": "node_modules/.bin/glsl-minifier -i ./build/example.frag -o ./build/example.min.frag",
|
||||||
|
|
|
@ -16,7 +16,7 @@ export interface IMarkerOption {
|
||||||
export default class Marker extends EventEmitter {
|
export default class Marker extends EventEmitter {
|
||||||
private markerOption: IMarkerOption;
|
private markerOption: IMarkerOption;
|
||||||
private defaultMarker: boolean;
|
private defaultMarker: boolean;
|
||||||
private popup: IPopup; // TODO: POPup
|
private popup: IPopup;
|
||||||
private mapsService: IMapService<unknown>;
|
private mapsService: IMapService<unknown>;
|
||||||
private lngLat: ILngLat;
|
private lngLat: ILngLat;
|
||||||
private scene: Container;
|
private scene: Container;
|
||||||
|
|
|
@ -4,7 +4,7 @@ import { IMapWrapper } from '../map/IMapService';
|
||||||
import { IRenderConfig } from '../renderer/IRendererService';
|
import { IRenderConfig } from '../renderer/IRendererService';
|
||||||
|
|
||||||
export interface ISceneConfig extends IRenderConfig {
|
export interface ISceneConfig extends IRenderConfig {
|
||||||
id: string;
|
id: string | HTMLDivElement;
|
||||||
map: IMapWrapper;
|
map: IMapWrapper;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -14,6 +14,8 @@ export default class LayerService implements ILayerService {
|
||||||
|
|
||||||
private layerRenderID: number;
|
private layerRenderID: number;
|
||||||
|
|
||||||
|
private sceneInited: boolean = false;
|
||||||
|
|
||||||
private animateInstanceCount: number = 0;
|
private animateInstanceCount: number = 0;
|
||||||
|
|
||||||
private alreadyInRendering: boolean = false;
|
private alreadyInRendering: boolean = false;
|
||||||
|
@ -25,10 +27,14 @@ export default class LayerService implements ILayerService {
|
||||||
private readonly configService: IGlobalConfigService;
|
private readonly configService: IGlobalConfigService;
|
||||||
|
|
||||||
public add(layer: ILayer) {
|
public add(layer: ILayer) {
|
||||||
|
// if (this.sceneInited) {
|
||||||
|
// layer.init();
|
||||||
|
// }
|
||||||
this.layers.push(layer);
|
this.layers.push(layer);
|
||||||
}
|
}
|
||||||
|
|
||||||
public initLayers() {
|
public initLayers() {
|
||||||
|
this.sceneInited = true;
|
||||||
this.layers.forEach((layer) => {
|
this.layers.forEach((layer) => {
|
||||||
if (!layer.inited) {
|
if (!layer.inited) {
|
||||||
layer.init();
|
layer.init();
|
||||||
|
|
|
@ -3,7 +3,6 @@ import Probe, { Log } from 'probe.gl';
|
||||||
import { ILogService } from './ILogService';
|
import { ILogService } from './ILogService';
|
||||||
|
|
||||||
const Logger = new Log({ id: 'L7' }).enable(false);
|
const Logger = new Log({ id: 'L7' }).enable(false);
|
||||||
|
|
||||||
// // 只输出 debug 级别以上的日志信息
|
// // 只输出 debug 级别以上的日志信息
|
||||||
Logger.priority = 5;
|
Logger.priority = 5;
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@ export interface IPoint {
|
||||||
|
|
||||||
export type MapStyle = string | { [key: string]: any };
|
export type MapStyle = string | { [key: string]: any };
|
||||||
export interface IMapWrapper {
|
export interface IMapWrapper {
|
||||||
setContainer(container: Container, id: string): void;
|
setContainer(container: Container, id: string | HTMLDivElement): void;
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface IMapService<RawMap = {}> {
|
export interface IMapService<RawMap = {}> {
|
||||||
|
|
|
@ -200,6 +200,7 @@ export default class Scene extends EventEmitter implements ISceneService {
|
||||||
// FIXME: 初始化 marker 容器,可以放到 map 初始化方法中?
|
// FIXME: 初始化 marker 容器,可以放到 map 初始化方法中?
|
||||||
|
|
||||||
this.logger.info(' render inited');
|
this.logger.info(' render inited');
|
||||||
|
this.controlService.addControls();
|
||||||
this.emit('loaded');
|
this.emit('loaded');
|
||||||
this.inited = true;
|
this.inited = true;
|
||||||
}
|
}
|
||||||
|
@ -208,7 +209,7 @@ export default class Scene extends EventEmitter implements ISceneService {
|
||||||
this.layerService.initLayers();
|
this.layerService.initLayers();
|
||||||
this.layerService.renderLayers();
|
this.layerService.renderLayers();
|
||||||
// 组件需要等待layer 初始化完成之后添加
|
// 组件需要等待layer 初始化完成之后添加
|
||||||
this.controlService.addControls();
|
|
||||||
this.logger.debug(`scene ${this.id} render`);
|
this.logger.debug(`scene ${this.id} render`);
|
||||||
|
|
||||||
this.rendering = false;
|
this.rendering = false;
|
||||||
|
|
|
@ -61,8 +61,10 @@ export interface ISource {
|
||||||
data: IParserData;
|
data: IParserData;
|
||||||
cluster: boolean;
|
cluster: boolean;
|
||||||
clusterOptions: Partial<IClusterOptions>;
|
clusterOptions: Partial<IClusterOptions>;
|
||||||
|
setData(data: any): void;
|
||||||
updateClusterData(zoom: number): void;
|
updateClusterData(zoom: number): void;
|
||||||
getFeatureById(id: number): unknown;
|
getFeatureById(id: number): unknown;
|
||||||
|
getFeatureId(field: string, value: any): number | undefined;
|
||||||
getClusters(zoom: number): any;
|
getClusters(zoom: number): any;
|
||||||
getClustersLeaves(id: number): any;
|
getClustersLeaves(id: number): any;
|
||||||
}
|
}
|
||||||
|
|
|
@ -419,10 +419,14 @@ export default class BaseLayer<ChildLayerStyleOptions = {}> extends EventEmitter
|
||||||
}
|
}
|
||||||
|
|
||||||
public setData(data: any, options?: ISourceCFG) {
|
public setData(data: any, options?: ISourceCFG) {
|
||||||
this.sourceOption.data = data;
|
if (this.inited) {
|
||||||
this.sourceOption.options = options;
|
this.layerSource.setData(data);
|
||||||
this.hooks.init.call();
|
} else {
|
||||||
this.buildModels();
|
this.on('inited', () => {
|
||||||
|
this.layerSource.setData(data);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
public style(
|
public style(
|
||||||
|
@ -641,6 +645,8 @@ export default class BaseLayer<ChildLayerStyleOptions = {}> extends EventEmitter
|
||||||
|
|
||||||
public destroy() {
|
public destroy() {
|
||||||
this.hooks.beforeDestroy.call();
|
this.hooks.beforeDestroy.call();
|
||||||
|
// 清除sources事件
|
||||||
|
this.layerSource.off('update', this.sourceEvent);
|
||||||
|
|
||||||
// 清除所有属性以及关联的 vao
|
// 清除所有属性以及关联的 vao
|
||||||
this.styleAttributeService.clearAllAttributes();
|
this.styleAttributeService.clearAllAttributes();
|
||||||
|
@ -673,11 +679,12 @@ export default class BaseLayer<ChildLayerStyleOptions = {}> extends EventEmitter
|
||||||
|
|
||||||
public setSource(source: Source) {
|
public setSource(source: Source) {
|
||||||
this.layerSource = source;
|
this.layerSource = source;
|
||||||
const bounds = this.mapService.getBounds();
|
|
||||||
const zoom = this.mapService.getZoom();
|
const zoom = this.mapService.getZoom();
|
||||||
if (this.layerSource.cluster) {
|
if (this.layerSource.cluster) {
|
||||||
this.layerSource.updateClusterData(zoom);
|
this.layerSource.updateClusterData(zoom);
|
||||||
}
|
}
|
||||||
|
// source 可能会复用,会在其它layer被修改
|
||||||
|
this.layerSource.on('update', this.sourceEvent);
|
||||||
}
|
}
|
||||||
public getSource() {
|
public getSource() {
|
||||||
return this.layerSource;
|
return this.layerSource;
|
||||||
|
@ -793,6 +800,12 @@ export default class BaseLayer<ChildLayerStyleOptions = {}> extends EventEmitter
|
||||||
protected getDefaultConfig() {
|
protected getDefaultConfig() {
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private sourceEvent = () => {
|
||||||
|
this.dataState.dataSourceNeedUpdate = true;
|
||||||
|
this.reRender();
|
||||||
|
};
|
||||||
|
|
||||||
private reRender() {
|
private reRender() {
|
||||||
if (this.inited) {
|
if (this.inited) {
|
||||||
this.layerService.renderLayers();
|
this.layerService.renderLayers();
|
||||||
|
|
|
@ -13,9 +13,12 @@ export default class DataSourcePlugin implements ILayerPlugin {
|
||||||
this.updateClusterData(layer);
|
this.updateClusterData(layer);
|
||||||
});
|
});
|
||||||
|
|
||||||
// 检测数据是不否需要更新
|
// 检测数据不否需要更新
|
||||||
layer.hooks.beforeRenderData.tap('DataSourcePlugin', (flag) => {
|
layer.hooks.beforeRenderData.tap('DataSourcePlugin', (flag) => {
|
||||||
return this.updateClusterData(layer);
|
const neeUpdate1 = this.updateClusterData(layer);
|
||||||
|
const neeUpdate2 = layer.dataState.dataSourceNeedUpdate;
|
||||||
|
layer.dataState.dataSourceNeedUpdate = false;
|
||||||
|
return neeUpdate1 || neeUpdate2;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,6 @@ import {
|
||||||
TYPES,
|
TYPES,
|
||||||
} from '@antv/l7-core';
|
} from '@antv/l7-core';
|
||||||
import { Container } from 'inversify';
|
import { Container } from 'inversify';
|
||||||
|
|
||||||
export default class BaseMapWrapper<RawMap> implements IMapWrapper {
|
export default class BaseMapWrapper<RawMap> implements IMapWrapper {
|
||||||
@lazyInject(TYPES.ILogService)
|
@lazyInject(TYPES.ILogService)
|
||||||
protected readonly logger: ILogService;
|
protected readonly logger: ILogService;
|
||||||
|
@ -23,7 +22,7 @@ export default class BaseMapWrapper<RawMap> implements IMapWrapper {
|
||||||
}
|
}
|
||||||
|
|
||||||
public setContainer(sceneContainer: Container, id: string) {
|
public setContainer(sceneContainer: Container, id: string) {
|
||||||
// 首先使用全局配置服务校验地图参数
|
// // 首先使用全局配置服务校验地图参数
|
||||||
const { valid, errorText } = this.configService.validateMapConfig(
|
const { valid, errorText } = this.configService.validateMapConfig(
|
||||||
this.config,
|
this.config,
|
||||||
);
|
);
|
||||||
|
@ -32,7 +31,6 @@ export default class BaseMapWrapper<RawMap> implements IMapWrapper {
|
||||||
this.logger.error(errorText || '');
|
this.logger.error(errorText || '');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 绑定用户传入的原始地图参数
|
// 绑定用户传入的原始地图参数
|
||||||
sceneContainer.bind<Partial<IMapConfig>>(TYPES.MapConfig).toConstantValue({
|
sceneContainer.bind<Partial<IMapConfig>>(TYPES.MapConfig).toConstantValue({
|
||||||
...this.config,
|
...this.config,
|
||||||
|
|
|
@ -260,7 +260,7 @@ export default class AMapService
|
||||||
resolve();
|
resolve();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
if (!document.getElementById(AMAP_SCRIPT_ID)) {
|
if (!document.getElementById(AMAP_SCRIPT_ID) || !mapInstance) {
|
||||||
// 异步加载高德地图
|
// 异步加载高德地图
|
||||||
// @see https://lbs.amap.com/api/javascript-api/guide/abc/load
|
// @see https://lbs.amap.com/api/javascript-api/guide/abc/load
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
|
|
|
@ -61,7 +61,6 @@ class Scene
|
||||||
// 创建场景容器
|
// 创建场景容器
|
||||||
const sceneContainer = createSceneContainer();
|
const sceneContainer = createSceneContainer();
|
||||||
this.container = sceneContainer;
|
this.container = sceneContainer;
|
||||||
|
|
||||||
// 绑定地图服务
|
// 绑定地图服务
|
||||||
map.setContainer(sceneContainer, id);
|
map.setContainer(sceneContainer, id);
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
import {
|
import {
|
||||||
IClusterOptions,
|
IClusterOptions,
|
||||||
IMapService,
|
IMapService,
|
||||||
|
IParseDataItem,
|
||||||
IParserCfg,
|
IParserCfg,
|
||||||
IParserData,
|
IParserData,
|
||||||
ISourceCFG,
|
ISourceCFG,
|
||||||
|
@ -84,6 +85,13 @@ export default class Source extends EventEmitter {
|
||||||
});
|
});
|
||||||
this.init();
|
this.init();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public setData(data: any) {
|
||||||
|
this.rawData = data;
|
||||||
|
this.originData = cloneDeep(data);
|
||||||
|
this.init();
|
||||||
|
this.emit('update');
|
||||||
|
}
|
||||||
public getClusters(zoom: number): any {
|
public getClusters(zoom: number): any {
|
||||||
return this.clusterIndex.getClusters(this.extent, zoom);
|
return this.clusterIndex.getClusters(this.extent, zoom);
|
||||||
}
|
}
|
||||||
|
@ -128,7 +136,7 @@ export default class Source extends EventEmitter {
|
||||||
}
|
}
|
||||||
public getFeatureById(id: number): unknown {
|
public getFeatureById(id: number): unknown {
|
||||||
const { type = 'geojson' } = this.parser;
|
const { type = 'geojson' } = this.parser;
|
||||||
if (type === 'geojson') {
|
if (type === 'geojson' && !this.cluster) {
|
||||||
return id < this.rawData.features.length
|
return id < this.rawData.features.length
|
||||||
? this.rawData.features[id]
|
? this.rawData.features[id]
|
||||||
: 'null';
|
: 'null';
|
||||||
|
@ -137,6 +145,13 @@ export default class Source extends EventEmitter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public getFeatureId(field: string, value: any): number | undefined {
|
||||||
|
const feature = this.data.dataArray.find((dataItem: IParseDataItem) => {
|
||||||
|
return dataItem[field] === name;
|
||||||
|
});
|
||||||
|
return feature?._id;
|
||||||
|
}
|
||||||
|
|
||||||
private excuteParser(): void {
|
private excuteParser(): void {
|
||||||
const parser = this.parser;
|
const parser = this.parser;
|
||||||
const type: string = parser.type || 'geojson';
|
const type: string = parser.type || 'geojson';
|
||||||
|
|
|
@ -23,6 +23,7 @@ export default class ChartComponent extends React.Component {
|
||||||
});
|
});
|
||||||
addChart();
|
addChart();
|
||||||
scene.render();
|
scene.render();
|
||||||
|
this.scene = scene;
|
||||||
function addChart() {
|
function addChart() {
|
||||||
Promise.all([
|
Promise.all([
|
||||||
fetch(
|
fetch(
|
||||||
|
|
|
@ -35,16 +35,22 @@ export default class Point3D extends React.Component {
|
||||||
// .scale('point_count', {
|
// .scale('point_count', {
|
||||||
// type: 'quantile',
|
// type: 'quantile',
|
||||||
// })
|
// })
|
||||||
// .size('point_count', [5, 10, 15, 20, 25])
|
.size('mag', [5, 10, 15, 20, 25])
|
||||||
.size(5)
|
|
||||||
.animate(false)
|
.animate(false)
|
||||||
.active(true)
|
.active(true)
|
||||||
.color('yellow')
|
.color('yellow')
|
||||||
.style({
|
.style({
|
||||||
opacity: 1,
|
opacity: 0.5,
|
||||||
strokeWidth: 1,
|
strokeWidth: 1,
|
||||||
});
|
});
|
||||||
scene.addLayer(pointLayer);
|
scene.addLayer(pointLayer);
|
||||||
|
scene.on('loaded', () => {
|
||||||
|
const newData = {
|
||||||
|
type: 'FeatureCollection',
|
||||||
|
features: pointsData.features.slice(0, 100),
|
||||||
|
};
|
||||||
|
pointLayer.setData(newData);
|
||||||
|
});
|
||||||
this.scene = scene;
|
this.scene = scene;
|
||||||
// });
|
// });
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,6 +25,7 @@ export default class GaodeMapComponent extends React.Component {
|
||||||
center: [116.397428, 39.90923], // 初始化地图中心点
|
center: [116.397428, 39.90923], // 初始化地图中心点
|
||||||
});
|
});
|
||||||
const scene = new Scene({
|
const scene = new Scene({
|
||||||
|
// @ts-ignore
|
||||||
id: 'map',
|
id: 'map',
|
||||||
map: new GaodeMap({
|
map: new GaodeMap({
|
||||||
mapInstance: map,
|
mapInstance: map,
|
||||||
|
|
|
@ -17,7 +17,7 @@ export default class MapboxComponent extends React.Component {
|
||||||
const scene = new Scene({
|
const scene = new Scene({
|
||||||
id: 'map',
|
id: 'map',
|
||||||
map: new Mapbox({
|
map: new Mapbox({
|
||||||
style: 'mapbox://styles/mapbox/streets-v9',
|
style: 'dark',
|
||||||
center: [110.19382669582967, 30.258134],
|
center: [110.19382669582967, 30.258134],
|
||||||
pitch: 0,
|
pitch: 0,
|
||||||
zoom: 3,
|
zoom: 3,
|
||||||
|
|
|
@ -5259,6 +5259,11 @@ babel-plugin-transform-inline-consecutive-adds@^0.4.3:
|
||||||
resolved "https://registry.npmjs.org/babel-plugin-transform-inline-consecutive-adds/-/babel-plugin-transform-inline-consecutive-adds-0.4.3.tgz#323d47a3ea63a83a7ac3c811ae8e6941faf2b0d1"
|
resolved "https://registry.npmjs.org/babel-plugin-transform-inline-consecutive-adds/-/babel-plugin-transform-inline-consecutive-adds-0.4.3.tgz#323d47a3ea63a83a7ac3c811ae8e6941faf2b0d1"
|
||||||
integrity sha1-Mj1Ho+pjqDp6w8gRro5pQfrysNE=
|
integrity sha1-Mj1Ho+pjqDp6w8gRro5pQfrysNE=
|
||||||
|
|
||||||
|
babel-plugin-transform-inline-environment-variables@^0.4.3:
|
||||||
|
version "0.4.3"
|
||||||
|
resolved "https://registry.npmjs.org/babel-plugin-transform-inline-environment-variables/-/babel-plugin-transform-inline-environment-variables-0.4.3.tgz#a3b09883353be8b5e2336e3ff1ef8a5d93f9c489"
|
||||||
|
integrity sha1-o7CYgzU76LXiM24/8e+KXZP5xIk=
|
||||||
|
|
||||||
babel-plugin-transform-member-expression-literals@^6.9.4:
|
babel-plugin-transform-member-expression-literals@^6.9.4:
|
||||||
version "6.9.4"
|
version "6.9.4"
|
||||||
resolved "https://registry.npmjs.org/babel-plugin-transform-member-expression-literals/-/babel-plugin-transform-member-expression-literals-6.9.4.tgz#37039c9a0c3313a39495faac2ff3a6b5b9d038bf"
|
resolved "https://registry.npmjs.org/babel-plugin-transform-member-expression-literals/-/babel-plugin-transform-member-expression-literals-6.9.4.tgz#37039c9a0c3313a39495faac2ff3a6b5b9d038bf"
|
||||||
|
|
Loading…
Reference in New Issue