From 315d582b7a7465c805a25a45637fcd86dc18f0ee Mon Sep 17 00:00:00 2001 From: Jan Garaj Date: Tue, 2 Jan 2024 20:17:26 +0000 Subject: [PATCH] Init --- README.md | 21 +- package-lock.json | 216 +++++++++++++++ package.json | 5 +- src/assets/styles/md.less | 23 ++ src/layouts/default/Default.vue | 70 +++-- src/main.js | 15 +- src/plugins/vuetify.js | 5 + src/router/index.js | 8 +- src/views/Grot.vue | 322 ++++++++++++++++++++++ src/views/Main.vue | 467 +++++++++++++++++++++----------- 10 files changed, 967 insertions(+), 185 deletions(-) create mode 100644 src/assets/styles/md.less create mode 100644 src/views/Grot.vue diff --git a/README.md b/README.md index 6c9df56..e28b324 100644 --- a/README.md +++ b/README.md @@ -1,3 +1,22 @@ # Grafana Debugger -TODO \ No newline at end of file +Idea: + +Collect structured data about user Grafana problem in a fews steps (e.g. deployment, problem, documentation) and provide recommendations how/where user can solve the problem. + +Example recommendations: +- if user has Grafana Enterprise (licensed) then offer "Email Grafana Enteprise recommendations", which generates email with all already submitted details (email subject is pregenerated by Grot AI) +- offer a chat with Grot AI, where initial post will contain all problem details in markdown format +- offer links to search on Community forum, Stack Overflow, Github Grafana issues, Google (InfluxData forum if 'Influx' string is in the problem) - (search query is pregenerated by Grot AI) +- offer link to create Community forum topic in nice markdown formated structure (title,topic,tags are pregenerated by Grot AI) + +There can be other recommendations implemented: +e.g. if it is AMG - link to AWS support (AMG is supported by AWS), if problem contains 'volkovlabs' then recommend to contact https://volkovlabs.io/, .... + +It can support all Grafana Labs products (Tempo, Loki, Pyroscope, ...). + +It supports also Speech recognition API in the chat with Grot AI (if it is available in the browser, so available in Chrome, Edge, ...- try to say 'Show me example email notification template example. Send' - send/sent is keyword to trigger sent event) + +It stores all problem details in the URL hash, so you can send link in email, chat, community post to anyone. + +If user follow this proces (and if process will force/nudge to it) then the output will be good quality question/topic. It can improve initial support time (no need support ping pong, e.g. provide me your Grafana version, ...), it can be classified in the right category with right tags and with meaningful title (typical non meaningful title "I am newbie, help me!!!") - search engines will have better keywords for further indexing, .... diff --git a/package-lock.json b/package-lock.json index 8c81a15..e79354f 100644 --- a/package-lock.json +++ b/package-lock.json @@ -11,9 +11,11 @@ "@mdi/font": "7.0.96", "core-js": "^3.29.0", "md-editor-v3": "^4.10.0", + "rison-node": "^2.1.1", "roboto-fontface": "*", "vue": "^3.3.0", "vue-cookies": "^1.8.3", + "vue-gtag": "^2.0.1", "vue-router": "^4.0.0", "vuetify": "^3.4.9" }, @@ -21,6 +23,7 @@ "@vitejs/plugin-vue": "^4.0.0", "eslint": "^8.37.0", "eslint-plugin-vue": "^9.3.0", + "less": "^4.2.0", "sass": "^1.60.0", "unplugin-fonts": "^1.0.3", "vite": "^4.2.0", @@ -1354,6 +1357,18 @@ "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", "dev": true }, + "node_modules/copy-anything": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/copy-anything/-/copy-anything-2.0.6.tgz", + "integrity": "sha512-1j20GZTsvKNkc4BY3NpMOM8tt///wY3FpIzozTOFO2ffuZcV61nojHXVKIy3WM+7ADCy5FVhdZYHYDdgTU0yJw==", + "devOptional": true, + "dependencies": { + "is-what": "^3.14.1" + }, + "funding": { + "url": "https://github.com/sponsors/mesqueeb" + } + }, "node_modules/copy-to-clipboard": { "version": "3.3.3", "resolved": "https://registry.npmjs.org/copy-to-clipboard/-/copy-to-clipboard-3.3.3.tgz", @@ -1454,6 +1469,19 @@ "url": "https://github.com/fb55/entities?sponsor=1" } }, + "node_modules/errno": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/errno/-/errno-0.1.8.tgz", + "integrity": "sha512-dJ6oBr5SQ1VSd9qkk7ByRgb/1SH4JZjCHSW/mr63/QcXO9zLVxvJ6Oy13nio03rxpSnVDDjFor75SjVeZWPW/A==", + "dev": true, + "optional": true, + "dependencies": { + "prr": "~1.0.1" + }, + "bin": { + "errno": "cli.js" + } + }, "node_modules/esbuild": { "version": "0.18.20", "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.18.20.tgz", @@ -1869,6 +1897,13 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/graceful-fs": { + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", + "dev": true, + "optional": true + }, "node_modules/graphemer": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/graphemer/-/graphemer-1.4.0.tgz", @@ -1884,6 +1919,19 @@ "node": ">=8" } }, + "node_modules/iconv-lite": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", + "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", + "dev": true, + "optional": true, + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + }, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/ignore": { "version": "5.3.0", "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.0.tgz", @@ -1893,6 +1941,19 @@ "node": ">= 4" } }, + "node_modules/image-size": { + "version": "0.5.5", + "resolved": "https://registry.npmjs.org/image-size/-/image-size-0.5.5.tgz", + "integrity": "sha512-6TDAlDPZxUFCv+fuOkIoXT/V/f3Qbq8e37p+YOiYrUv3v9cc3/6x78VdfPgFVaB9dZYeLUfKgHRebpkm/oP2VQ==", + "dev": true, + "optional": true, + "bin": { + "image-size": "bin/image-size.js" + }, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/immutable": { "version": "4.3.4", "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.3.4.tgz", @@ -1991,6 +2052,12 @@ "node": ">=8" } }, + "node_modules/is-what": { + "version": "3.14.1", + "resolved": "https://registry.npmjs.org/is-what/-/is-what-3.14.1.tgz", + "integrity": "sha512-sNxgpk9793nzSs7bA6JQJGeIuRBQhAaNGG77kzYQgMkrID+lS6SlK07K5LaptscDlSaIgH+GPFzf+d75FVxozA==", + "devOptional": true + }, "node_modules/isexe": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", @@ -2036,6 +2103,56 @@ "json-buffer": "3.0.1" } }, + "node_modules/less": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/less/-/less-4.2.0.tgz", + "integrity": "sha512-P3b3HJDBtSzsXUl0im2L7gTO5Ubg8mEN6G8qoTS77iXxXX4Hvu4Qj540PZDvQ8V6DmX6iXo98k7Md0Cm1PrLaA==", + "devOptional": true, + "dependencies": { + "copy-anything": "^2.0.1", + "parse-node-version": "^1.0.1", + "tslib": "^2.3.0" + }, + "bin": { + "lessc": "bin/lessc" + }, + "engines": { + "node": ">=6" + }, + "optionalDependencies": { + "errno": "^0.1.1", + "graceful-fs": "^4.1.2", + "image-size": "~0.5.0", + "make-dir": "^2.1.0", + "mime": "^1.4.1", + "needle": "^3.1.0", + "source-map": "~0.6.0" + } + }, + "node_modules/less/node_modules/make-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", + "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", + "dev": true, + "optional": true, + "dependencies": { + "pify": "^4.0.1", + "semver": "^5.6.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/less/node_modules/semver": { + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.2.tgz", + "integrity": "sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==", + "dev": true, + "optional": true, + "bin": { + "semver": "bin/semver" + } + }, "node_modules/levn": { "version": "0.4.1", "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", @@ -2224,6 +2341,19 @@ "node": ">=8.6" } }, + "node_modules/mime": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", + "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", + "dev": true, + "optional": true, + "bin": { + "mime": "cli.js" + }, + "engines": { + "node": ">=4" + } + }, "node_modules/minimatch": { "version": "3.1.2", "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", @@ -2265,6 +2395,23 @@ "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", "dev": true }, + "node_modules/needle": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/needle/-/needle-3.3.1.tgz", + "integrity": "sha512-6k0YULvhpw+RoLNiQCRKOl09Rv1dPLr8hHnVjHqdolKwDrdNyk+Hmrthi4lIGPPz3r39dLx0hsF5s40sZ3Us4Q==", + "dev": true, + "optional": true, + "dependencies": { + "iconv-lite": "^0.6.3", + "sax": "^1.2.4" + }, + "bin": { + "needle": "bin/needle" + }, + "engines": { + "node": ">= 4.4.x" + } + }, "node_modules/normalize-path": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", @@ -2363,6 +2510,15 @@ "node": ">=6" } }, + "node_modules/parse-node-version": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parse-node-version/-/parse-node-version-1.0.1.tgz", + "integrity": "sha512-3YHlOa/JgH6Mnpr05jP9eDG254US9ek25LyIxZlDItp2iJtwyaXQb57lBYLdT3MowkUFYEV2XXNAYIPlESvJlA==", + "devOptional": true, + "engines": { + "node": ">= 0.10" + } + }, "node_modules/path-exists": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", @@ -2407,6 +2563,16 @@ "url": "https://github.com/sponsors/jonschlinkert" } }, + "node_modules/pify": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", + "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==", + "dev": true, + "optional": true, + "engines": { + "node": ">=6" + } + }, "node_modules/pkg-dir": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", @@ -2520,6 +2686,13 @@ "node": ">= 0.8.0" } }, + "node_modules/prr": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/prr/-/prr-1.0.1.tgz", + "integrity": "sha512-yPw4Sng1gWghHQWj0B3ZggWUm4qVbPwPFcRG8KyxiU7J2OHFSoEHKS+EZ3fv5l1t9CyCiop6l/ZYeWbrgoQejw==", + "dev": true, + "optional": true + }, "node_modules/punycode": { "version": "2.3.1", "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", @@ -2594,6 +2767,11 @@ "url": "https://github.com/sponsors/isaacs" } }, + "node_modules/rison-node": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/rison-node/-/rison-node-2.1.1.tgz", + "integrity": "sha512-GuV0OnSL2erZJ0j/9YUsrAdfSh3mGcrq+4wM4PqRftOYT7+TRhxbMrpVZaGC5YIPwncIoOM7PPnskDku5Ywg1Q==" + }, "node_modules/roboto-fontface": { "version": "0.10.0", "resolved": "https://registry.npmjs.org/roboto-fontface/-/roboto-fontface-0.10.0.tgz", @@ -2638,6 +2816,13 @@ "queue-microtask": "^1.2.2" } }, + "node_modules/safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", + "dev": true, + "optional": true + }, "node_modules/sass": { "version": "1.69.5", "resolved": "https://registry.npmjs.org/sass/-/sass-1.69.5.tgz", @@ -2655,6 +2840,13 @@ "node": ">=14.0.0" } }, + "node_modules/sax": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/sax/-/sax-1.3.0.tgz", + "integrity": "sha512-0s+oAmw9zLl1V1cS9BtZN7JAd0cW5e0QH4W3LWEK6a4LaLEA2OTpGYWDY+6XasBLtz6wkm3u1xRw95mRuJ59WA==", + "dev": true, + "optional": true + }, "node_modules/semver": { "version": "7.5.4", "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", @@ -2691,6 +2883,16 @@ "node": ">=8" } }, + "node_modules/source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", + "dev": true, + "optional": true, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/source-map-js": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", @@ -2763,6 +2965,12 @@ "resolved": "https://registry.npmjs.org/toggle-selection/-/toggle-selection-1.0.6.tgz", "integrity": "sha512-BiZS+C1OS8g/q2RRbJmy59xpyghNBqrr6k5L/uKBGRsTfxmu3ffiRnd8mlGPUVayg8pvfi5urfnu8TU7DVOkLQ==" }, + "node_modules/tslib": { + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", + "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", + "devOptional": true + }, "node_modules/type-check": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", @@ -2970,6 +3178,14 @@ "eslint": ">=6.0.0" } }, + "node_modules/vue-gtag": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/vue-gtag/-/vue-gtag-2.0.1.tgz", + "integrity": "sha512-aM4A58FVL0wV2ptYi+xzAjeg+pQVRyUcfBc5UkXAwQrR4t3WBhor50Izp2I+3Oo7+l+vWJ7u78DGcNzReb8S/A==", + "peerDependencies": { + "vue": "^3.0.0" + } + }, "node_modules/vue-router": { "version": "4.2.5", "resolved": "https://registry.npmjs.org/vue-router/-/vue-router-4.2.5.tgz", diff --git a/package.json b/package.json index 409c579..6afd48b 100644 --- a/package.json +++ b/package.json @@ -4,7 +4,7 @@ "private": true, "scripts": { "dev": "vite", - "build": "vite build", + "build": "vite build && cp dist/index.html dist/404.html", "preview": "vite preview", "lint": "eslint . --fix --ignore-path .gitignore" }, @@ -12,9 +12,11 @@ "@mdi/font": "7.0.96", "core-js": "^3.29.0", "md-editor-v3": "^4.10.0", + "rison-node": "^2.1.1", "roboto-fontface": "*", "vue": "^3.3.0", "vue-cookies": "^1.8.3", + "vue-gtag": "^2.0.1", "vue-router": "^4.0.0", "vuetify": "^3.4.9" }, @@ -22,6 +24,7 @@ "@vitejs/plugin-vue": "^4.0.0", "eslint": "^8.37.0", "eslint-plugin-vue": "^9.3.0", + "less": "^4.2.0", "sass": "^1.60.0", "unplugin-fonts": "^1.0.3", "vite": "^4.2.0", diff --git a/src/assets/styles/md.less b/src/assets/styles/md.less new file mode 100644 index 0000000..a99146e --- /dev/null +++ b/src/assets/styles/md.less @@ -0,0 +1,23 @@ +.css-vars(@isDark) { + --md-color: if(@isDark, #999, #222); + --md-hover-color: if(@isDark, #bbb, #000); + --md-bk-color: if(@isDark, #000, #E0E0E0); + --md-bk-color-outstand: if(@isDark, #111, #f6f6f6); + --md-bk-hover-color: if(@isDark, #1b1a1a, #f5f7fa); + --md-border-color: if(@isDark, #2d2d2d, #e6e6e6); + --md-border-hover-color: if(@isDark, #636262, #b9b9b9); + --md-border-active-color: if(@isDark, #777, #999); + --md-modal-mask: #00000073; + --md-scrollbar-bg-color: if(@isDark, #0f0f0f, #e2e2e2); + --md-scrollbar-thumb-color: if(@isDark, #2d2d2d, #0000004d); + --md-scrollbar-thumb-hover-color: if(@isDark, #3a3a3a, #00000059); + --md-scrollbar-thumb-active-color: if(@isDark, #3a3a3a, #00000061); + } + + .md-editor { + .css-vars(false); + } + + .md-editor-dark { + .css-vars(true); + } \ No newline at end of file diff --git a/src/layouts/default/Default.vue b/src/layouts/default/Default.vue index db46473..8006bde 100644 --- a/src/layouts/default/Default.vue +++ b/src/layouts/default/Default.vue @@ -1,14 +1,16 @@