mirror of https://github.com/apache/superset.git
[explorev2] Breaking down large files, fixing JS warnings (#1773)
* Breaking down large files, fixing JS warnings * fix unit tests
This commit is contained in:
parent
3597fdb7f8
commit
c1558578d7
|
@ -165,7 +165,7 @@ class ChartContainer extends React.Component {
|
|||
id={this.props.containerId}
|
||||
ref={(ref) => { this.chartContainerRef = ref; }}
|
||||
className={this.props.viz_type}
|
||||
style={{ 'overflow-x': 'scroll' }}
|
||||
style={{ overflowX: 'scroll' }}
|
||||
/>
|
||||
);
|
||||
}
|
||||
|
|
|
@ -4,7 +4,7 @@ import { bindActionCreators } from 'redux';
|
|||
import * as actions from '../actions/exploreActions';
|
||||
import { connect } from 'react-redux';
|
||||
import { Panel, Alert } from 'react-bootstrap';
|
||||
import { visTypes, sectionsToRender, commonControlPanelSections } from '../stores/store';
|
||||
import visTypes, { sectionsToRender, commonControlPanelSections } from '../stores/visTypes';
|
||||
import ControlPanelSection from './ControlPanelSection';
|
||||
import FieldSetRow from './FieldSetRow';
|
||||
import Filters from './Filters';
|
||||
|
|
|
@ -7,7 +7,7 @@ import ChartContainer from './ChartContainer';
|
|||
import ControlPanelsContainer from './ControlPanelsContainer';
|
||||
import SaveModal from './SaveModal';
|
||||
import QueryAndSaveBtns from '../../explore/components/QueryAndSaveBtns';
|
||||
import { autoQueryFields } from '../stores/store';
|
||||
import { autoQueryFields } from '../stores/fields';
|
||||
import { getParamObject } from '../exploreUtils';
|
||||
|
||||
const $ = require('jquery');
|
||||
|
|
|
@ -3,7 +3,7 @@ import TextField from './TextField';
|
|||
import CheckboxField from './CheckboxField';
|
||||
import TextAreaField from './TextAreaField';
|
||||
import SelectField from './SelectField';
|
||||
import { fieldTypes } from '../stores/store';
|
||||
import { fieldTypes } from '../stores/fields';
|
||||
|
||||
const propTypes = {
|
||||
name: PropTypes.string.isRequired,
|
||||
|
|
|
@ -30,11 +30,14 @@ class Filters extends React.Component {
|
|||
}
|
||||
render() {
|
||||
const filters = [];
|
||||
let i = 0;
|
||||
this.props.filters.forEach((filter) => {
|
||||
// only display filters with current prefix
|
||||
i++;
|
||||
if (filter.prefix === this.props.prefix) {
|
||||
filters.push(
|
||||
<Filter
|
||||
key={i}
|
||||
filterColumnOpts={this.props.filterColumnOpts}
|
||||
actions={this.props.actions}
|
||||
prefix={this.props.prefix}
|
||||
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,705 @@
|
|||
export const commonControlPanelSections = {
|
||||
druidTimeSeries: {
|
||||
label: 'Time',
|
||||
description: 'Time related form attributes',
|
||||
fieldSetRows: [
|
||||
['granularity', 'druid_time_origin'],
|
||||
['since', 'until'],
|
||||
],
|
||||
},
|
||||
datasourceAndVizType: {
|
||||
label: 'Datasource & Chart Type',
|
||||
fieldSetRows: [
|
||||
['datasource'],
|
||||
['viz_type'],
|
||||
],
|
||||
},
|
||||
sqlaTimeSeries: {
|
||||
label: 'Time',
|
||||
description: 'Time related form attributes',
|
||||
fieldSetRows: [
|
||||
['granularity_sqla', 'time_grain_sqla'],
|
||||
['since', 'until'],
|
||||
],
|
||||
},
|
||||
sqlClause: {
|
||||
label: 'SQL',
|
||||
fieldSetRows: [
|
||||
['where', 'having'],
|
||||
],
|
||||
description: 'This section exposes ways to include snippets of SQL in your query',
|
||||
},
|
||||
NVD3TimeSeries: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['metrics'],
|
||||
['groupby'],
|
||||
['limit', 'timeseries_limit_metric'],
|
||||
],
|
||||
},
|
||||
{
|
||||
label: 'Advanced Analytics',
|
||||
description: 'This section contains options ' +
|
||||
'that allow for advanced analytical post processing ' +
|
||||
'of query results',
|
||||
fieldSetRows: [
|
||||
['rolling_type', 'rolling_periods'],
|
||||
['time_compare'],
|
||||
['num_period_compare', 'period_ratio_type'],
|
||||
['resample_how', 'resample_rule'],
|
||||
['resample_fillmethod'],
|
||||
],
|
||||
},
|
||||
],
|
||||
filters: [
|
||||
{
|
||||
label: 'Filters',
|
||||
description: 'Filters are defined using comma delimited strings as in <US,FR,Other>' +
|
||||
'Leave the value field empty to filter empty strings or nulls' +
|
||||
'For filters with comma in values, wrap them in single quotes' +
|
||||
"as in <NY, 'Tahoe, CA', DC>",
|
||||
},
|
||||
{
|
||||
label: 'Result Filters',
|
||||
description: 'The filters to apply after post-aggregation.' +
|
||||
'Leave the value field empty to filter empty strings or nulls',
|
||||
},
|
||||
],
|
||||
};
|
||||
|
||||
const visTypes = {
|
||||
dist_bar: {
|
||||
label: 'Distribution - Bar Chart',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: 'Chart Options',
|
||||
description: 'tooltip text here',
|
||||
fieldSetRows: [
|
||||
['metrics'],
|
||||
['groupby'],
|
||||
['columns'],
|
||||
['row_limit'],
|
||||
['show_legend', 'show_bar_value'],
|
||||
['bar_stacked', 'order_bars'],
|
||||
['y_axis_format', 'bottom_margin'],
|
||||
['x_axis_label', 'y_axis_label'],
|
||||
['reduce_x_ticks', 'contribution'],
|
||||
['show_controls'],
|
||||
],
|
||||
},
|
||||
],
|
||||
fieldOverrides: {
|
||||
groupby: {
|
||||
label: 'Series',
|
||||
},
|
||||
columns: {
|
||||
label: 'Breakdowns',
|
||||
description: 'Defines how each series is broken down',
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
pie: {
|
||||
label: 'Pie Chart',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['metrics', 'groupby'],
|
||||
['limit'],
|
||||
['pie_label_type'],
|
||||
['donut', 'show_legend'],
|
||||
['labels_outside'],
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
|
||||
line: {
|
||||
label: 'Time Series - Line Chart',
|
||||
requiresTime: true,
|
||||
controlPanelSections: [
|
||||
commonControlPanelSections.NVD3TimeSeries[0],
|
||||
{
|
||||
label: 'Chart Options',
|
||||
fieldSetRows: [
|
||||
['show_brush', 'show_legend'],
|
||||
['rich_tooltip', 'y_axis_zero'],
|
||||
['y_log_scale', 'contribution'],
|
||||
['show_markers', 'x_axis_showminmax'],
|
||||
['line_interpolation'],
|
||||
['x_axis_format', 'y_axis_format'],
|
||||
['x_axis_label', 'y_axis_label'],
|
||||
],
|
||||
},
|
||||
commonControlPanelSections.NVD3TimeSeries[1],
|
||||
],
|
||||
},
|
||||
|
||||
bar: {
|
||||
label: 'Time Series - Bar Chart',
|
||||
requiresTime: true,
|
||||
controlPanelSections: [
|
||||
commonControlPanelSections.NVD3TimeSeries[0],
|
||||
{
|
||||
label: 'Chart Options',
|
||||
fieldSetRows: [
|
||||
['show_brush', 'show_legend', 'show_bar_value'],
|
||||
['rich_tooltip', 'y_axis_zero'],
|
||||
['y_log_scale', 'contribution'],
|
||||
['x_axis_format', 'y_axis_format'],
|
||||
['line_interpolation', 'bar_stacked'],
|
||||
['x_axis_showminmax', 'bottom_margin'],
|
||||
['x_axis_label', 'y_axis_label'],
|
||||
['reduce_x_ticks', 'show_controls'],
|
||||
],
|
||||
},
|
||||
commonControlPanelSections.NVD3TimeSeries[1],
|
||||
],
|
||||
},
|
||||
|
||||
compare: {
|
||||
label: 'Time Series - Percent Change',
|
||||
requiresTime: true,
|
||||
controlPanelSections: [
|
||||
commonControlPanelSections.NVD3TimeSeries[0],
|
||||
commonControlPanelSections.NVD3TimeSeries[1],
|
||||
],
|
||||
},
|
||||
|
||||
area: {
|
||||
label: 'Time Series - Stacked',
|
||||
requiresTime: true,
|
||||
controlPanelSections: [
|
||||
commonControlPanelSections.NVD3TimeSeries[0],
|
||||
{
|
||||
label: 'Chart Options',
|
||||
fieldSetRows: [
|
||||
['show_brush', 'show_legend'],
|
||||
['rich_tooltip', 'y_axis_zero'],
|
||||
['y_log_scale', 'contribution'],
|
||||
['x_axis_format', 'y_axis_format'],
|
||||
['x_axis_showminmax', 'show_controls'],
|
||||
['line_interpolation', 'stacked_style'],
|
||||
],
|
||||
},
|
||||
commonControlPanelSections.NVD3TimeSeries[1],
|
||||
],
|
||||
},
|
||||
|
||||
table: {
|
||||
label: 'Table View',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: 'GROUP BY',
|
||||
description: 'Use this section if you want a query that aggregates',
|
||||
fieldSetRows: [
|
||||
['groupby', 'metrics'],
|
||||
],
|
||||
},
|
||||
{
|
||||
label: 'NOT GROUPED BY',
|
||||
description: 'Use this section if you want to query atomic rows',
|
||||
fieldSetRows: [
|
||||
['all_columns', 'order_by_cols'],
|
||||
],
|
||||
},
|
||||
{
|
||||
label: 'Options',
|
||||
fieldSetRows: [
|
||||
['table_timestamp_format'],
|
||||
['row_limit'],
|
||||
['page_length'],
|
||||
['include_search', 'table_filter'],
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
|
||||
markup: {
|
||||
label: 'Markup',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['markup_type', 'code'],
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
|
||||
pivot_table: {
|
||||
label: 'Pivot Table',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['groupby', 'columns'],
|
||||
['metrics', 'pandas_aggfunc'],
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
|
||||
separator: {
|
||||
label: 'Separator',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['code'],
|
||||
],
|
||||
},
|
||||
],
|
||||
fieldOverrides: {
|
||||
code: {
|
||||
default: '####Section Title\n' +
|
||||
'A paragraph describing the section' +
|
||||
'of the dashboard, right before the separator line ' +
|
||||
'\n\n' +
|
||||
'---------------',
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
word_cloud: {
|
||||
label: 'Word Cloud',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['series', 'metric', 'limit'],
|
||||
['size_from', 'size_to'],
|
||||
['rotation'],
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
|
||||
treemap: {
|
||||
label: 'Treemap',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['metrics'],
|
||||
['groupby'],
|
||||
],
|
||||
},
|
||||
{
|
||||
label: 'Chart Options',
|
||||
fieldSetRows: [
|
||||
['treemap_ratio'],
|
||||
['number_format'],
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
|
||||
cal_heatmap: {
|
||||
label: 'Calendar Heatmap',
|
||||
requiresTime: true,
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['metric'],
|
||||
['domain_granularity'],
|
||||
['subdomain_granularity'],
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
|
||||
box_plot: {
|
||||
label: 'Box Plot',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['metrics'],
|
||||
['groupby', 'limit'],
|
||||
],
|
||||
},
|
||||
{
|
||||
label: 'Chart Options',
|
||||
fieldSetRows: [
|
||||
['whisker_options'],
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
|
||||
bubble: {
|
||||
label: 'Bubble Chart',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['series', 'entity'],
|
||||
['x', 'y'],
|
||||
['size', 'limit'],
|
||||
],
|
||||
},
|
||||
{
|
||||
label: 'Chart Options',
|
||||
fieldSetRows: [
|
||||
['x_log_scale', 'y_log_scale'],
|
||||
['show_legend'],
|
||||
['max_bubble_size'],
|
||||
['x_axis_label', 'y_axis_label'],
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
|
||||
big_number: {
|
||||
label: 'Big Number with Trendline',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['metric'],
|
||||
['compare_lag'],
|
||||
['compare_suffix'],
|
||||
['y_axis_format'],
|
||||
],
|
||||
},
|
||||
],
|
||||
fieldOverrides: {
|
||||
y_axis_format: {
|
||||
label: 'Number format',
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
big_number_total: {
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['metric'],
|
||||
['subheader'],
|
||||
['y_axis_format'],
|
||||
],
|
||||
},
|
||||
],
|
||||
fieldOverrides: {
|
||||
y_axis_format: {
|
||||
label: 'Number format',
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
histogram: {
|
||||
label: 'Histogram',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['all_columns_x'],
|
||||
['row_limit'],
|
||||
],
|
||||
},
|
||||
{
|
||||
label: 'Histogram Options',
|
||||
fieldSetRows: [
|
||||
['link_length'],
|
||||
],
|
||||
},
|
||||
],
|
||||
fieldOverrides: {
|
||||
all_columns_x: {
|
||||
label: 'Numeric Column',
|
||||
description: 'Select the numeric column to draw the histogram',
|
||||
},
|
||||
link_length: {
|
||||
label: 'No of Bins',
|
||||
description: 'Select number of bins for the histogram',
|
||||
default: 5,
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
sunburst: {
|
||||
label: 'Sunburst',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['groupby'],
|
||||
['metric', 'secondary_metric'],
|
||||
['row_limit'],
|
||||
],
|
||||
},
|
||||
],
|
||||
fieldOverrides: {
|
||||
metric: {
|
||||
label: 'Primary Metric',
|
||||
description: 'The primary metric is used to define the arc segment sizes',
|
||||
},
|
||||
secondary_metric: {
|
||||
label: 'Secondary Metric',
|
||||
description: 'This secondary metric is used to ' +
|
||||
'define the color as a ratio against the primary metric. ' +
|
||||
'If the two metrics match, color is mapped level groups',
|
||||
},
|
||||
groupby: {
|
||||
label: 'Hierarchy',
|
||||
description: 'This defines the level of the hierarchy',
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
sankey: {
|
||||
label: 'Sankey',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['groupby'],
|
||||
['metric'],
|
||||
['row_limit'],
|
||||
],
|
||||
},
|
||||
],
|
||||
fieldOverrides: {
|
||||
groupby: {
|
||||
label: 'Source / Target',
|
||||
description: 'Choose a source and a target',
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
directed_force: {
|
||||
label: 'Directed Force Layout',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['groupby'],
|
||||
['metric'],
|
||||
['row_limit'],
|
||||
],
|
||||
},
|
||||
{
|
||||
label: 'Force Layout',
|
||||
fieldSetRows: [
|
||||
['link_length'],
|
||||
['charge'],
|
||||
],
|
||||
},
|
||||
],
|
||||
fieldOverrides: {
|
||||
groupby: {
|
||||
label: 'Source / Target',
|
||||
description: 'Choose a source and a target',
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
world_map: {
|
||||
label: 'World Map',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['entity'],
|
||||
['country_fieldtype'],
|
||||
['metric'],
|
||||
],
|
||||
},
|
||||
{
|
||||
label: 'Bubbles',
|
||||
fieldSetRows: [
|
||||
['show_bubbles'],
|
||||
['secondary_metric'],
|
||||
['max_bubble_size'],
|
||||
],
|
||||
},
|
||||
],
|
||||
fieldOverrides: {
|
||||
entity: {
|
||||
label: 'Country Field',
|
||||
description: '3 letter code of the country',
|
||||
},
|
||||
metric: {
|
||||
label: 'Metric for color',
|
||||
description: 'Metric that defines the color of the country',
|
||||
},
|
||||
secondary_metric: {
|
||||
label: 'Bubble size',
|
||||
description: 'Metric that defines the size of the bubble',
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
filter_box: {
|
||||
label: 'Filter Box',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['date_filter'],
|
||||
['groupby'],
|
||||
['metric'],
|
||||
],
|
||||
},
|
||||
],
|
||||
fieldOverrides: {
|
||||
groupby: {
|
||||
label: 'Filter fields',
|
||||
description: 'The fields you want to filter on',
|
||||
default: [],
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
iframe: {
|
||||
label: 'iFrame',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['url'],
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
|
||||
para: {
|
||||
label: 'Parallel Coordinates',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['series'],
|
||||
['metrics'],
|
||||
['secondary_metric'],
|
||||
['limit'],
|
||||
['show_datatable', 'include_series'],
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
|
||||
heatmap: {
|
||||
label: 'Heatmap',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: 'Axis & Metrics',
|
||||
fieldSetRows: [
|
||||
['all_columns_x'],
|
||||
['all_columns_y'],
|
||||
['metric'],
|
||||
],
|
||||
},
|
||||
{
|
||||
label: 'Heatmap Options',
|
||||
fieldSetRows: [
|
||||
['linear_color_scheme'],
|
||||
['xscale_interval', 'yscale_interval'],
|
||||
['canvas_image_rendering'],
|
||||
['normalize_across'],
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
|
||||
horizon: {
|
||||
label: 'Horizon',
|
||||
controlPanelSections: [
|
||||
commonControlPanelSections.NVD3TimeSeries[0],
|
||||
{
|
||||
label: 'Chart Options',
|
||||
fieldSetRows: [
|
||||
['series_height', 'horizon_color_scale'],
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
|
||||
mapbox: {
|
||||
label: 'Mapbox',
|
||||
controlPanelSections: [
|
||||
{
|
||||
label: null,
|
||||
fieldSetRows: [
|
||||
['all_columns_x', 'all_columns_y'],
|
||||
['clustering_radius'],
|
||||
['row_limit'],
|
||||
['groupby'],
|
||||
['render_while_dragging'],
|
||||
],
|
||||
},
|
||||
{
|
||||
label: 'Points',
|
||||
fieldSetRows: [
|
||||
['point_radius'],
|
||||
['point_radius_unit'],
|
||||
],
|
||||
},
|
||||
{
|
||||
label: 'Labelling',
|
||||
fieldSetRows: [
|
||||
['mapbox_label'],
|
||||
['pandas_aggfunc'],
|
||||
],
|
||||
},
|
||||
{
|
||||
label: 'Visual Tweaks',
|
||||
fieldSetRows: [
|
||||
['mapbox_style'],
|
||||
['global_opacity'],
|
||||
['mapbox_color'],
|
||||
],
|
||||
},
|
||||
{
|
||||
label: 'Viewport',
|
||||
fieldSetRows: [
|
||||
['viewport_longitude'],
|
||||
['viewport_latitude'],
|
||||
['viewport_zoom'],
|
||||
],
|
||||
},
|
||||
],
|
||||
fieldOverrides: {
|
||||
all_columns_x: {
|
||||
label: 'Longitude',
|
||||
description: 'Column containing longitude data',
|
||||
},
|
||||
all_columns_y: {
|
||||
label: 'Latitude',
|
||||
description: 'Column containing latitude data',
|
||||
},
|
||||
pandas_aggfunc: {
|
||||
label: 'Cluster label aggregator',
|
||||
description: 'Aggregate function applied to the list of points ' +
|
||||
'in each cluster to produce the cluster label.',
|
||||
},
|
||||
rich_tooltip: {
|
||||
label: 'Tooltip',
|
||||
description: 'Show a tooltip when hovering over points and clusters ' +
|
||||
'describing the label',
|
||||
},
|
||||
groupby: {
|
||||
description: 'One or many fields to group by. If grouping, latitude ' +
|
||||
'and longitude columns must be present.',
|
||||
},
|
||||
},
|
||||
},
|
||||
};
|
||||
|
||||
export default visTypes;
|
||||
|
||||
export function sectionsToRender(vizType, datasourceType) {
|
||||
const viz = visTypes[vizType];
|
||||
const timeSection = datasourceType === 'table' ?
|
||||
commonControlPanelSections.sqlaTimeSeries : commonControlPanelSections.druidTimeSeries;
|
||||
const { datasourceAndVizType, sqlClause } = commonControlPanelSections;
|
||||
const sections = [datasourceAndVizType].concat(
|
||||
viz.controlPanelSections, timeSection, sqlClause);
|
||||
return sections;
|
||||
}
|
||||
|
|
@ -10,7 +10,7 @@
|
|||
"scripts": {
|
||||
"test": "mocha --require ignore-styles --compilers js:babel-core/register --require spec/helpers/browser.js --recursive spec/**/*_spec.*",
|
||||
"cover": "babel-node ./node_modules/.bin/istanbul cover _mocha -- --require spec/helpers/browser.js --recursive spec/**/*_spec.*",
|
||||
"dev": "NODE_ENV=dev webpack --watch --colors --progress --debug --output-pathinfo --devtool source-map",
|
||||
"dev": "NODE_ENV=dev webpack --watch --colors --progress --debug --output-pathinfo --devtool inline-source-map",
|
||||
"prod": "NODE_ENV=production node --max_old_space_size=4096 ./node_modules/webpack/bin/webpack.js -p --colors --progress",
|
||||
"build": "NODE_ENV=production webpack --colors --progress",
|
||||
"lint": "eslint --ignore-path=.eslintignore --ext .js,.jsx ."
|
||||
|
@ -62,7 +62,7 @@
|
|||
"moment": "^2.14.1",
|
||||
"moments": "0.0.2",
|
||||
"mustache": "^2.2.1",
|
||||
"nvd3": "1.8.4",
|
||||
"nvd3": "1.8.5",
|
||||
"react": "^15.3.2",
|
||||
"react-ace": "^3.4.1",
|
||||
"react-bootstrap": "^0.30.3",
|
||||
|
|
|
@ -2,7 +2,8 @@ import React from 'react';
|
|||
import { expect } from 'chai';
|
||||
import { describe, it, beforeEach } from 'mocha';
|
||||
import { shallow } from 'enzyme';
|
||||
import { fields, defaultFormData } from '../../../../javascripts/explorev2/stores/store';
|
||||
import { fields } from '../../../../javascripts/explorev2/stores/fields';
|
||||
import { defaultFormData } from '../../../../javascripts/explorev2/stores/store';
|
||||
import FieldSetRow from '../../../../javascripts/explorev2/components/FieldSetRow';
|
||||
import FieldSet from '../../../../javascripts/explorev2/components/FieldSet';
|
||||
|
||||
|
|
Loading…
Reference in New Issue