Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adding new key rewrite old ones #739

Closed
tonyspb opened this issue Nov 29, 2013 · 9 comments
Closed

Adding new key rewrite old ones #739

tonyspb opened this issue Nov 29, 2013 · 9 comments

Comments

@tonyspb
Copy link

tonyspb commented Nov 29, 2013

After a few dashboard savings adding a new query is no longer available. Hitting "+" just clears one of the existing queries.
console log is:

Error: Duplicates in a repeater are not allowed. Repeater: id in (unPinnedQueries = (querySrv.ids|pinnedQuery:false)) key: number:2

Saving dashboard with overwritten queries leads to disappearing all the queries.
Somehow it happens one in a while, not always.

{
  "title": "Queries",
  "services": {
    "query": {
      "idQueue": [
        2,
        3,
        4,
        5,
        6,
        7,
        8,
        9,
        10,
        11,
        12,
        13,
        14,
        15,
        16,
        17
      ],
      "list": {
        "0": {
          "id": 0,
          "type": "topN",
          "query": "@key:query*",
          "alias": "title",
          "color": "#64B0C8",
          "pin": false,
          "enable": true,
          "field": "@key",
          "size": 5,
          "union": "AND"
        },
        "1": {
          "id": 1,
          "color": "#EAB839",
          "alias": "",
          "pin": false,
          "type": "lucene",
          "enable": true,
          "query": "@key:query* AND val:val1"
        },
        "2": {
          "id": 2,
          "color": "#6ED0E0",
          "alias": "",
          "pin": false,
          "type": "lucene",
          "enable": true,
          "query": "*"
        },
        "3": {
          "id": 3,
          "type": "topN",
          "query": "@key:query_smth AND val:val1",
          "alias": "query1",
          "color": "#EF843C",
          "pin": false,
          "enable": true,
          "field": "plc",
          "size": 100,
          "union": "AND"
        }
      },
      "ids": [
        0,
        1,
        2,
        3,
        2
      ]
    },
    "filter": {
      "idQueue": [
        1,
        2
      ],
      "list": {
        "0": {
          "from": "2013-11-21T11:22:11.823Z",
          "to": "now",
          "type": "time",
          "field": "@timestamp",
          "mandate": "must",
          "active": true,
          "alias": "",
          "id": 0
        }
      },
      "ids": [
        0
      ]
    }
  },
  "rows": [],
  "editable": true,
  "index": {
    "interval": "day",
    "pattern": "[statistics-]YYYYMMDD",
    "default": "NO_TIME_FILTER_OR_INDEX_PATTERN_NOT_MATCHED"
  },
  "style": "light",
  "failover": false,
  "loader": {
    "save_gist": false,
    "save_elasticsearch": true,
    "save_local": true,
    "save_default": false,
    "save_temp": true,
    "save_temp_ttl_enable": true,
    "save_temp_ttl": "30d",
    "load_gist": false,
    "load_elasticsearch": true,
    "load_elasticsearch_size": 20,
    "load_local": false,
    "hide": false
  },
  "panel_hints": true,
  "pulldowns": [
    {
      "type": "query",
      "collapse": false,
      "notice": false,
      "enable": true,
      "query": "*",
      "pinned": true,
      "history": [
      ],
      "remember": 10
    },
    {
      "type": "filtering",
      "collapse": false,
      "notice": true,
      "enable": true
    }
  ],
  "nav": [
    {
      "type": "timepicker",
      "collapse": false,
      "notice": false,
      "enable": true,
      "status": "Stable",
      "time_options": [
        "1h",
        "6h",
        "12h",
        "24h",
        "2d",
        "7d",
        "14d",
        "30d"
      ],
      "refresh_intervals": [
        "5s",
        "10s",
        "30s",
        "1m",
        "5m",
        "15m",
        "30m",
        "1h",
        "2h",
        "1d"
      ],
      "timefield": "@timestamp",
      "now": true,
      "filter_id": 0
    }
  ],
  "refresh": false
}

2013-11-29 12 27 19

bpezan pushed a commit to bpezan/kibana that referenced this issue Dec 4, 2013
* master:
  Moved doc task to the end of the default task chain
  removed y_as_bytes, replaced with y_format
  Remove console.log
  Closes elastic#538. Closes elastic#722
  Potential fix for elastic#621
  More small table performance improvements
  Improve performance in the table. Re elastic#719 and elastic#732
  Remove idQueue from filter and query services in dashboards
  Eliminate idQueue property from filterSrv and querySrv. Replace with binary search for smallest id. Closes elastic#730. Closes elastic#739
  Skeleton API docs
  Doc updates
  Added scratchy tasks and config.js docs
  Bytes should not be default
  Fixing unsafe html binding
  fixed numeric terms in topN query
  do not auto-enable saved filters
@bruno-roussel
Copy link

Still the issue on master branch.
After a few dashboard savings adding a new query is no longer available.

Error: Duplicates in a repeater are not allowed. Repeater: id in querySrv.ids key: number:6
at ngRepeatAction (http://localhost/kibana/vendor/angular/angular.js:15423:20)
at Object.$watchCollectionAction as fn
at Object.Scope.$digest (http://localhost/kibana/vendor/angular/angular.js:8826:27)
at Object.Scope.$apply (http://localhost/kibana/vendor/angular/angular.js:9029:24)
at HTMLElement. (http://localhost/kibana/vendor/angular/angular.js:14382:17)
at HTMLElement.p.event.dispatch (http://localhost/kibana/vendor/jquery/jquery-1.8.0.js:2:37944)
at HTMLElement.g.handle.h (http://localhost/kibana/vendor/jquery/jquery-1.8.0.js:2:33881)

@rashidkpc
Copy link
Contributor

I'm not able to replicate this now. Can you export a dashboard schema in which this occurred?

@rashidkpc rashidkpc reopened this Dec 18, 2013
@bruno-roussel
Copy link

Here is the dashboard schema:

{
"title": "TVM5",
"services": {
"query": {
"list": {
"0": {
"query": "type:rtv AND GetVideoAsset",
"alias": "",
"color": "#7EB26D",
"id": 0,
"pin": false,
"type": "lucene",
"enable": true
},
"1": {
"id": 1,
"color": "#EAB839",
"alias": "",
"pin": false,
"type": "lucene",
"enable": true,
"query": "type:rtv AND GetVideoList"
},
"2": {
"id": 2,
"color": "#6ED0E0",
"alias": "",
"pin": false,
"type": "lucene",
"enable": true,
"query": "type:rtv AND GetSpecificVideoList"
},
"3": {
"id": 3,
"color": "#EF843C",
"alias": "",
"pin": false,
"type": "lucene",
"enable": true,
"query": "type:rtv AND GetUnifiedList"
},
"4": {
"id": 4,
"color": "#E24D42",
"alias": "",
"pin": false,
"type": "lucene",
"enable": true,
"query": "type:rtv AND GetPage"
},
"5": {
"id": 5,
"color": "#1F78C1",
"alias": "",
"pin": true,
"type": "lucene",
"enable": true,
"query": "type:rtv AND GetVideoSupportedModelList"
},
"6": {
"id": 6,
"color": "#BA43A9",
"alias": "",
"pin": false,
"type": "lucene",
"enable": true,
"query": "type:rtv AND GetGenreList"
},
"7": {
"id": 7,
"color": "#705DA0",
"alias": "",
"pin": false,
"type": "lucene",
"enable": true,
"query": "type:rtv AND GetDiscountList"
},
"8": {
"id": 8,
"color": "#508642",
"alias": "",
"pin": false,
"type": "lucene",
"enable": true,
"query": "type:rtv AND GetPricingMatrixList"
},
"9": {
"id": 9,
"color": "#CCA300",
"alias": "",
"pin": false,
"type": "lucene",
"enable": true,
"query": "type:rtv AND GetTerminalModelList"
},
"10": {
"id": 10,
"color": "#447EBC",
"alias": "",
"pin": false,
"type": "lucene",
"enable": true,
"query": "type:apache"
}
},
"ids": [
0,
1,
2,
3,
4,
5,
6,
7,
8,
9,
10
]
},
"filter": {
"list": {
"0": {
"type": "time",
"field": "@timestamp",
"from": "now-24h",
"to": "now",
"mandate": "must",
"active": true,
"alias": "",
"id": 0
}
},
"ids": [
0
]
}
},
"rows": [
{
"title": "Graph",
"height": "350px",
"editable": true,
"collapse": false,
"collapsable": true,
"panels": [
{
"span": 12,
"editable": true,
"group": [
"default"
],
"type": "histogram",
"mode": "count",
"time_field": "@timestamp",
"value_field": null,
"auto_int": true,
"resolution": 100,
"interval": "10m",
"fill": 3,
"linewidth": 3,
"timezone": "browser",
"spyable": true,
"zoomlinks": true,
"bars": true,
"stack": true,
"points": false,
"lines": false,
"legend": true,
"x-axis": true,
"y-axis": true,
"percentage": false,
"interactive": true,
"queries": {
"mode": "selected",
"ids": [
0,
1,
2,
3,
4,
5,
6,
7,
8,
9
]
},
"title": "Events over time",
"intervals": [
"auto",
"1s",
"1m",
"5m",
"10m",
"30m",
"1h",
"3h",
"12h",
"1d",
"1w",
"1M",
"1y"
],
"options": true,
"tooltip": {
"value_type": "cumulative",
"query_as_alias": true
},
"scale": 1,
"y_format": "none",
"grid": {
"max": null,
"min": 0
},
"annotate": {
"enable": false,
"query": "_",
"size": 20,
"field": "_type",
"sort": [
"score",
"desc"
]
},
"pointradius": 5,
"show_query": true,
"legend_counts": true,
"zerofill": true,
"derivative": false
}
],
"notice": false
},
{
"title": "Events",
"height": "350px",
"editable": true,
"collapse": false,
"collapsable": true,
"panels": [
{
"title": "All events",
"error": false,
"span": 12,
"editable": true,
"group": [
"default"
],
"type": "table",
"size": 100,
"pages": 5,
"offset": 0,
"sort": [
"@timestamp",
"desc"
],
"style": {
"font-size": "9pt"
},
"overflow": "min-height",
"fields": [],
"localTime": true,
"timeField": "@timestamp",
"highlight": [],
"sortable": true,
"header": true,
"paging": true,
"spyable": true,
"queries": {
"mode": "pinned",
"ids": [
5
]
},
"field_list": true,
"status": "Stable",
"trimFactor": 300,
"normTimes": true,
"all_fields": false
}
],
"notice": false
}
],
"editable": true,
"failover": false,
"index": {
"interval": "day",
"pattern": "[logstash-]YYYY.MM.DD",
"default": "NO_TIME_FILTER_OR_INDEX_PATTERN_NOT_MATCHED",
"warm_fields": true
},
"style": "dark",
"panel_hints": true,
"pulldowns": [
{
"type": "query",
"collapse": false,
"notice": false,
"query": "
",
"pinned": true,
"history": [
"type:apache",
"type:rtv AND GetTerminalModelList",
"type:rtv AND GetPricingMatrixList",
"type:rtv AND GetDiscountList",
"type:rtv AND GetGenreList",
"type:rtv AND GetVideoSupportedModelList",
"type:rtv AND GetPage",
"type:rtv AND GetUnifiedList",
"type:rtv AND GetSpecificVideoList",
"type:rtv AND GetVideoList"
],
"remember": 10,
"enable": true
},
{
"type": "filtering",
"collapse": true,
"notice": true,
"enable": true
}
],
"nav": [
{
"type": "timepicker",
"collapse": false,
"notice": false,
"status": "Stable",
"time_options": [
"5m",
"15m",
"1h",
"6h",
"12h",
"24h",
"2d",
"7d",
"30d"
],
"refresh_intervals": [
"5s",
"10s",
"30s",
"1m",
"5m",
"15m",
"30m",
"1h",
"2h",
"1d"
],
"timefield": "@timestamp",
"now": true,
"filter_id": 0,
"enable": true
}
],
"loader": {
"save_gist": false,
"save_elasticsearch": true,
"save_local": true,
"save_default": true,
"save_temp": true,
"save_temp_ttl_enable": true,
"save_temp_ttl": "30d",
"load_gist": true,
"load_elasticsearch": true,
"load_elasticsearch_size": 20,
"load_local": true,
"hide": false
},
"refresh": false
}

@bruno-roussel
Copy link

And the errors I got in the console :
Error: Duplicates in a repeater are not allowed. Repeater: id in (unPinnedQueries = (querySrv.ids|pinnedQuery:false)) key: number:6
at ngRepeatAction (http://localhost/kibana/vendor/angular/angular.js:15423:20)
at Object.$watchCollectionAction as fn
at Object.Scope.$digest (http://localhost/kibana/vendor/angular/angular.js:8826:27)
at Object.Scope.$apply (http://localhost/kibana/vendor/angular/angular.js:9029:24)
at http://localhost/kibana/app/app.js:142:26
at Object.context.execCb (http://localhost/kibana/vendor/require/require.js:1617:33)
at Object.Module.check (http://localhost/kibana/vendor/require/require.js:862:51)
at Object. (http://localhost/kibana/vendor/require/require.js:1100:34)
at http://localhost/kibana/vendor/require/require.js:129:23
at http://localhost/kibana/vendor/require/require.js:1143:21 angular.js:6349
Error: Duplicates in a repeater are not allowed. Repeater: id in querySrv.ids key: number:6
at ngRepeatAction (http://localhost/kibana/vendor/angular/angular.js:15423:20)
at Object.$watchCollectionAction as fn
at Object.Scope.$digest (http://localhost/kibana/vendor/angular/angular.js:8826:27)
at Object.Scope.$apply (http://localhost/kibana/vendor/angular/angular.js:9029:24)
at done (http://localhost/kibana/vendor/angular/angular.js:10282:45)
at completeRequest (http://localhost/kibana/vendor/angular/angular.js:10466:7)
at XMLHttpRequest.xhr.onreadystatechange (http://localhost/kibana/vendor/angular/angular.js:10421:11) angular.js:6349
Error: Duplicates in a repeater are not allowed. Repeater: id in querySrv.ids key: number:6
at ngRepeatAction (http://localhost/kibana/vendor/angular/angular.js:15423:20)
at Object.$watchCollectionAction as fn
at Object.Scope.$digest (http://localhost/kibana/vendor/angular/angular.js:8826:27)
at Object.Scope.$apply (http://localhost/kibana/vendor/angular/angular.js:9029:24)
at done (http://localhost/kibana/vendor/angular/angular.js:10282:45)
at completeRequest (http://localhost/kibana/vendor/angular/angular.js:10466:7)
at XMLHttpRequest.xhr.onreadystatechange (http://localhost/kibana/vendor/angular/angular.js:10421:11)

@bruno-roussel
Copy link

And as soon as I add a new query , here is the new dashboard model :

query: Object
ids: Array[13]
0: 0
1: 1
2: 2
3: 3
4: 4
5: 5
6: 6
7: 7
8: 8
9: 9
10: 10
11: 6
12: 6
length: 13

@bruno-roussel
Copy link

maybe I found something strange :
dashboard.current.services.query.ids
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
_.clone(dashboard.current.services.query.ids).sort();
[0, 1, 10, 2, 3, 4, 5, 6, 7, 8, 9]

@bobrik
Copy link

bobrik commented Dec 19, 2013

@bruno-roussel, nice catch! This is how js works. I propose changing it to:

_.clone(dashboard.current.services.query.ids).sort(function(l, r) {
  return l - r;
});

@bobrik
Copy link

bobrik commented Dec 28, 2013

@rashidkpc could you look at this? This is pretty annoying problem.

rashidkpc pushed a commit that referenced this issue Dec 29, 2013
@rashidkpc
Copy link
Contributor

w33ble pushed a commit to w33ble/kibana that referenced this issue Sep 13, 2018
* [WIP][Design] Cleanup canvas part 1 (elastic#697)

Part 1 of dave messing around with the design of canvas.

* Converted bootstrap button groups to EUI button groups in text_style_picker (elastic#713)

* Moved elements and assets to workpad_header (elastic#714)

* Adds tabs to sidebar component (elastic#718)

* Changed sidebar to tabbed layout

* Removed unecessary done props from datasource_component and expression

* Removed unused props in toolbar

* [Design] Part 2 of design cleanup (elastic#715)

* hide nonfocus pages

* button group margins

* workpad panel styled

* header rework

* fix toolbar lint

* update to newest EUI, restyle sidebar tabs, some data source cleanup

* move title to footer

* Add some tooltips

* Fixed custom interval input in refresh controls (elastic#722)

* Fixes Editor Toggle (elastic#721)

* Removed unused selectedPage prop from workpad_header/index.js

* Fixed editor toggle

* Design part 3: page view, data sources, lots of cleanup (elastic#731)

Mostly changes around the page selector and data sources. Also fixes some of the hover issues for canvas elements.

* fix css import error

* [Design] Part 4 of design updates to canvas (elastic#732)

[Design] Part 4: selector rewrite

* Move expression editor back to bottom (elastic#733)

* Removed unused prop form sidebar_component

* Moved expression editor to toolbar

* [Design] Part 5: Cleanup and bugfixing before review (elastic#734)

* style up expression editor, fix resize handles

* hide controls when editing is hidden

* remove icons from element dropdown

* fix canvas grid

* Adds Modals (elastic#739)

* Changed datasource_preview to a modal

* Moved workpad_loader to modal

* address feedback (elastic#740)

* asset manager mostly styled (elastic#741)

* [Image function] support src (image url) in addition to dataurl (elastic#632)

* [Image function] support src (image url) in addition to dataurl

* unit test for httpurl

* fix other elements that use image

* clean up the diff

* more clean up diff

* Handle AJAX errors by showing a notification (elastic#717)

* timeout property for axios instance

* remove TODOS

* notifier class

* TODO

* second notification with the context

* redirect to home if workpad could not be fetched

* less noisy error checking

* Fix ES Docs indices select options (elastic#743)

* Catch more AJAX errors, show error in notification banner (elastic#736)

* catch more errors

* if es_fields fails, still render something

* generate default data in ajax fetches in case of failure

* feedback changes

* remove defaulting that catch makes unnecessary

* Remove run API (elastic#742)

It's not used anywhere and is no longer necessary. We can always recreate
it if the need arises.

* [Design] Part 4 of design updates to canvas (elastic#732)

[Design] Part 4: selector rewrite

* Changed icon to 'warning' in simple_failure

* Fixed canvas loading

* Fixed paginate controls file naming

* Changed color dot size

* Added missing aria-labels

* Fixed warnings

* Fixed expression warnings

* Fixed popovers

* Fixed merge conflicts for image_upload

* Changed placeholder text in custom interval input

* Styled debug render function

* Removed bootstrap from expression and show_debugging

* Changed buttons in expression editor

* Changed asset manager to modal

* Added 'canvas__element' class for BWC for custom CSS in old workpads

* Fixed fullscreen interactions and positioning

* Fixed overflow issue in asset manager

* Removed bootstrap in datasource component

* Changed text input to text area in timelion datasource

* Fixed sort field in esdocs

* Updated style of AssetManager

* Changed all inputs to compressed size

* Added max width for datasource_preview modal

* Fixed cursor when hovering over element in fullscreen mode

* Cleaned up tooltips

* Rearranged buttons in workpad_header

* Updated style to update_modal

* Forgot to remove debug line

* Cleaned up arg_add_popover

* Removed codeblock in update_modal

* Added 'dataurl=null' to image element initial expression

* Added null args to repeatImage and revealImage

* Fixed input validation in expression

* Bumped eui to v1.1.0

* fix: make refresh controls clearer

- Change disabled state to 'refresh this page manually'
- Don't show disable control unless auto-refresh is enabled
- Move disabled control under the refresh interval text

closes elastic#759

* fix: close refresh popover on selection

* fix: replace interval placeholder with help text

Closes elastic#757

* fix: replace EuiFormLabel with aria-labelledby

closes elastic#767

* fix: restore send to top/bottom controls

* fix: more usable page controls

- pull controls out of popover
- move PageControls component out of the preview
- fix link use, so controls actually work
- fix page layout for tall pages

* fix: use correct esdocs query value

* fix: better esdocs form labels

* chore: stricter prop type checking

and remove an unused prop check

* fix: style the unknown args datasource fallback

* fix: show correct sort field in esdocs

* fix: page control icon colors

* Fixed workpad_loader modal issue

* Cleaned up home page styles

* Fixed class name on confirm modal. Removed unused style in main.scss

* fix: flatten the workpad styles

easier to override them, which is handy for fullsceen and other cases

* fix: better fullscreen overrides

* chore: remove unused allowFullScreen props

* fix: workpad size in fullscreen mode

* chore: convert Positionable to a class component

* fix: map font object to flot spec

* fix: use flot font spec for flot output

* test: add font spec test, fix plot & axisconfig tests

* Fixed input refs in datacolumn

* Removed unnecessary styles

* chore: remove debugging console logs

* Fixed prop type error in expression form

* Fixed expression form bouncing from error messages

* fix: page controls visible with scroll bar

* fix: delete element click handler

* chore: bump EUI to 3.0.0

this is the version that will be landing in Kibana

* fix: match ContextMenu class to css rule

* chore: remove unused code

* chore: tiny update modal code refactor

* Replaced & with prefixes in asset_manager and suggestion SCSS files

* Replaced EUI link/icon with EuiButtonIcon

* Changed label for index pattern in esdocs form

* fix: add aria-label to EuiButtonIcon

* fix: restore highlight on hover

and remove the now unused ElementControls component

* chore: update classNames

use the new class naming convention

* chore: remove unused components

* Disabled selection and dragging for img in revealImage

* Add toolbar tray close button (elastic#842)

* Fixed range and percentage arg types (elastic#843)

* Change to preview images

* Chore: naming convention

* Fix EUI Tooltip component content props (elastic#850)

* Fix a small typo in a button icon and tooltip (elastic#851)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

5 participants
@bobrik @bruno-roussel @rashidkpc @tonyspb and others