Skip to content

Commit

Permalink
Merge pull request #326 from emqx/dev/1.4.0
Browse files Browse the repository at this point in the history
Update manual
  • Loading branch information
ysfscream authored Oct 19, 2020
2 parents 553f987 + 636416e commit 642289b
Show file tree
Hide file tree
Showing 12 changed files with 127 additions and 46 deletions.
Binary file added assets/mqttx-advance.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified assets/mqttx-connection.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified assets/mqttx-search.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified assets/mqttx-theme.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added assets/mqttx-topic-alias.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified assets/mqttx-topic.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
18 changes: 15 additions & 3 deletions docs/manual-cn.md
Original file line number Diff line number Diff line change
Expand Up @@ -149,8 +149,12 @@ sudo snap install mqttx

点击左下角的 `New Subscription` 按钮,可以快速添加一个 `Topic`,每个 `Topic` 都可以用一种颜色标记,可以随机生成或打开颜色选择器选择。订阅列表顶部的最右侧的按钮,可以隐藏订阅列表,来显示页面更多的空间。添加完成后,点击订阅列表中已经订阅的 Topic 项,可以实现消息过滤,消息视图内将只显示订阅了当前主题的消息内容,再次点击即可取消过滤;也可直接点击其它已订阅的 Topic 项,查看其对应的消息内容。而点击 Topic 名称,即可快速复制当前的 Topic 信息。当需要向该 Topic 发送消息时,只需快速粘贴到消息栏的 Topic 输入框内进行修改,便可快速完成该操作。

在添加 `Topic` 时,可以给每个 Topic 设置一个别名,该选项为一个可选项,当设置并添加完成订阅后,订阅列表中的 `Topic` 数据将以别名展示,鼠标悬浮到 `Topic` 项时,提示框也会同时展示出该 `Topic` 的原值。这对于需要监控查看的多个 `Topic` 过长,无法分辩 `Topic` 的具体含义时,具有较强的帮助性。

![mqttx-topic](../assets/mqttx-topic.png)

![mqttx-topic-alias](../assets/mqttx-topic-alias.png)

3. 消息发送和接收

`Topic` 订阅成功后,就可以来测试消息的收发了。在页面右下角填入刚才所订阅的 `Topic` 信息,可选择 `QoS``Retain` 的值,输入 `payload` 后,点击最右侧的发送按钮,就向刚才订阅的 `Topic` 发送了一条消息。发送成功后,也可以即时接收到刚才所发送的消息。注意,在消息框内,右边栏为发送的消息。左边栏为接收到的消息。macOS 用户可以使用 `command + enter` 快捷键,其它用户可以使用 `control + enter` 快捷键来快速发送消息。
Expand All @@ -163,15 +167,23 @@ sudo snap install mqttx

### 设置

点击左侧菜单栏底部的设置按钮,或使用快捷键,macOS 用户可以使用 `command + ,` 快捷键,其它用户可以使用 `control + ,` 快捷键来跳转到设置页面,目前支持选择语言,开启是否自动检查更新和选择主题。
点击左侧菜单栏底部的设置按钮,或使用快捷键,macOS 用户可以使用 `command + ,` 快捷键,其它用户可以使用 `control + ,` 快捷键来跳转到设置页面,目前支持选择语言,开启是否自动检查更新和选择主题,还有高级功能中的数据备份和恢复功能

![mqttx-theme](../assets/mqttx-theme.png)

#### 数据管理

高级设置中包含了数据的备份与恢复功能。用户可选择两种导入导出的方式,也可以通过连接页面中的右上角菜单,或者在设置页面中的高级功能栏里。

在设置页面里可以在最下方的高级功能中,选择点击数据备份和数据恢复两个按钮。选择数据备份时,将导出所有的连接数据,包含所有收发到的消息等。选择数据恢复时,选择完导入文件的路径,确认后即可恢复数据。

![mqttx-advance](../assets/mqttx-advance.png)

### 其它

1. 连接操作

点击顶部的操作栏按钮,可以快速断开连接,删除当前连接等
点击顶部的操作栏按钮,可以快速断开连接,删除当前连接,当前数据导入导出等

![mqttx-connection](../assets/mqttx-connection.png)

Expand All @@ -180,7 +192,7 @@ sudo snap install mqttx
在消息栏右上角的 `All``Received``Published` 按钮可以过滤出
全部消息,已接收的消息,和已发布的消息。

点击顶部的操作栏按钮,选择 `Search by Topic` 项,或使用快捷键,macOS 用户可以使用 `command + f` 快捷键,其它用户可以使用 `control + f` 快捷键,来打开按 `Topic` 搜索的的功能,支持主题的模糊查询。
点击顶部的操作栏按钮,选择 `Search` 项,或使用快捷键,macOS 用户可以使用 `command + f` 快捷键,其它用户可以使用 `control + f` 快捷键,来打开按 `Topic` 搜索的的功能,支持主题的模糊查询。

点击顶部的操作栏按钮,选择 `Clear Histroy` 项,可以快速清空当前连接所发送和接收的消息。

Expand Down
18 changes: 15 additions & 3 deletions docs/manual.md
Original file line number Diff line number Diff line change
Expand Up @@ -149,8 +149,12 @@ After the configuration is complete, click the `Connect` button in the upper rig

Click the `New Subscription` button in the lower left corner to quickly add a Topic. Each Topic can be marked with a color, which can be randomly generated or opened by the color selector. The rightmost button at the top of the subscription list can hide the subscription list to show more space on the page. After the addition is complete, click on the subscribed Topic items in the subscription list to achieve message filtering. The message view will only display the message content subscribed to the current topic. Click again to cancel the filter; You can also directly click other subscribed Topic items to view the corresponding message content. By clicking on the topic name, you can quickly copy the current topic information. When you need to send a message to this topic, you can quickly paste it into the topic input box of the message bar to modify it, and you can quickly complete the operation.

When adding `Topic`, you can set an alias for each Topic. This option is an optional. When the subscription is set and added, the `Topic` in the subscription list will be displayed as an alias, and the mouse over the `Topic` item, the prompt box will also display the original value of the `Topic`. This is very helpful when multiple `Topics` that need to be monitored are too long to distinguish the specific meaning of `Topic`.

![mqttx-topic](../assets/mqttx-topic.png)

![mqttx-topic-alias](../assets/mqttx-topic-alias.png)

3. Sending and receiving of messages

After the `Topic` is successfully subscribed, you can test the sending and receiving of messages. Fill in the `Topic` information you just subscribed to in the lower right corner of the page. You can select the values of `QoS`, `Retain`, input `payload`, and click the send button on the far right to send a message to the `Topic` you just subscribed. After sending successfully, you can immediately receive the message just sent. Note that in the message box, the right column is the sent message, and the left column is the received message. MacOS users can use the `command + enter` shortcut to quickly send messages, and other users can use the `control + enter` shortcut to do that.
Expand All @@ -163,23 +167,31 @@ So far, the test of an `MQTT` message is completed.

### Setting

Click the settings button at the bottom of the left menu bar, or use shortcut. MacOS users can use the `command +,` shortcut, and other users can use the `control +,` shortcut to jump to the settings page. Currently, language selection is supported, and whether to automatically check for updates and select topics is enabled.
Click the settings button at the bottom of the left menu bar, or use shortcut. MacOS users can use the `command +,` shortcut, and other users can use the `control +,` shortcut to jump to the settings page. Currently, language selection is supported, whether to automatically check for updates, select topics is enabled and also data backup and recovery functions in advanced settings.

#### Data management

The advanced settings include data backup and recovery functions. Users can choose two import and export ways, or through the upper right menu in the connection page, or in the advanced bar in the settings page.

![mqttx-theme](../assets/mqttx-theme.png)

In the settings page, you can choose to click the data backup and data recovery buttons in the advanced functions at the bottom. When selecting data backup, all connection data will be exported, including all received and sent messages. When selecting data recovery, after selecting the path of the imported file, the data can be recovered after confirmation.

![mqttx-advance](../assets/mqttx-advance.png)

### Others

1. Connection operation

By clicking the action bar button at the top, you can quickly disconnect, delete the current connection.
By clicking the action bar button at the top, you can quickly disconnect, delete the current connection, import and export of current data, etc.

![mqttx-connection](../assets/mqttx-connection.png)

2. Message processing

Through the `All`,`Received`, `Published` buttons in the upper right corner of the message bar, you can filter out all messages, received messages and published messages.

Click the action bar button at the top and select the `Search by Topic` item, or use the shortcut key. MacOS users can use the command + f shortcut and Other users can use the control + f shortcut to open the `Topic` search function, the fuzzy query of topics is supported.
Click the action bar button at the top and select the `Search` item, or use the shortcut key. MacOS users can use the command + f shortcut and Other users can use the control + f shortcut to open the `Topic` search function, the fuzzy query of topics is supported.

Click on the action bar button at the top and select the `Clear Histroy` item, you can quickly clear the messages sent and received by the current connection.

Expand Down
20 changes: 15 additions & 5 deletions src/lang/connections.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,11 +14,6 @@ export default {
en: 'Search',
ja: '検索',
},
searchByTopic: {
zh: '按主题搜索',
en: 'Search by Topic',
ja: 'トピックで検索',
},
topicCopied: {
zh: '复制成功!',
en: 'Topic copied!',
Expand Down Expand Up @@ -362,4 +357,19 @@ export default {
en: 'Required fields in the file content are empty',
ja: '必須フィールドに値を入力してください',
},
searchContent: {
zh: '内容搜索',
en: 'Search',
ja: 'Search',
},
inputTopic: {
zh: '请输入主题',
en: 'Please input Topic',
ja: 'Please input Topic',
},
inputMsgContent: {
zh: '请输入消息内容',
en: 'Please input Message',
ja: 'Please input Message',
},
}
4 changes: 2 additions & 2 deletions src/main/getMenuTemplate.ts
Original file line number Diff line number Diff line change
Expand Up @@ -77,10 +77,10 @@ const getMenuTemplate = (win: BrowserWindow): $TSFixed => {
},
},
{
label: 'Search by Topic',
label: 'Search',
accelerator: 'CmdOrCtrl + F',
click: () => {
win.webContents.send('searchByTopic')
win.webContents.send('searchContent')
},
},
],
Expand Down
32 changes: 32 additions & 0 deletions src/utils/matchMultipleSearch.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
interface SearchParams {
[propName: string]: string
}

type MatchSearch = (data: any[], params: SearchParams) => Promise<any[] | null>

const matchMultipleSearch: MatchSearch = (data, params) => {
return new Promise((resolve, reject) => {
const paramsKeys = Object.keys(params)
try {
const filterData = data.filter(($) => {
return paramsKeys.every((oneKey) => {
if ($[oneKey]) {
const key: string = $[oneKey].toLowerCase().replace(/\s+/g, '')
const value: string = params[oneKey]
.toLocaleLowerCase()
.replace(/\s+/g, '')
.replace(/[~#^$@%&!+*]/gi, (val) => `\\${val}`)
return key.match(value)
} else {
return null
}
})
})
return resolve(filterData)
} catch (error) {
return reject(error)
}
})
}

export default matchMultipleSearch
81 changes: 48 additions & 33 deletions src/views/connections/ConnectionsDetail.vue
Original file line number Diff line number Diff line change
Expand Up @@ -49,8 +49,8 @@
<i class="el-icon-more"></i>
</a>
<el-dropdown-menu slot="dropdown">
<el-dropdown-item command="searchByTopic">
<i class="iconfont icon-search"></i>{{ $t('connections.searchByTopic') }}
<el-dropdown-item command="searchContent">
<i class="iconfont icon-search"></i>{{ $t('connections.searchContent') }}
</el-dropdown-item>
<el-dropdown-item command="clearHistory">
<i class="iconfont icon-clear"></i>{{ $t('connections.clearHistory') }}
Expand Down Expand Up @@ -90,17 +90,26 @@
<div v-show="searchVisible" class="connections-search topbar">
<el-input
id="searchTopic"
v-model="searchTopic"
v-model="searchParams.topic"
size="small"
:placeholder="$t('connections.searchByTopic')"
@keyup.enter.native="searchByTopic"
:placeholder="$t('connections.inputTopic')"
@keyup.enter.native="searchContent"
@keyup.esc.native="handleSearchClose"
>
<a class="search-btn" href="javascript:;" slot="suffix" @click="searchByTopic">
<i v-if="!searchLoading" class="iconfont icon-search"></i>
<i v-else class="el-icon-loading"></i>
</a>
</el-input>
<el-input
v-model="searchParams.payload"
size="small"
:placeholder="$t('connections.inputMsgContent')"
@keyup.enter.native="searchContent"
@keyup.esc.native="handleSearchClose"
class="content-search"
>
</el-input>
<a href="javascript:;" class="search-btn" @click="searchContent">
<i v-if="!searchLoading" class="iconfont icon-search"></i>
<i v-else class="el-icon-loading"></i>
</a>
<a href="javascript:;" class="close-search" @click="handleSearchClose">
<i class="el-icon-circle-close"></i>
</a>
Expand Down Expand Up @@ -205,7 +214,7 @@ import {
loadConnections,
} from '@/utils/api/connection'
import time from '@/utils/time'
import matchSearch from '@/utils/matchSearch'
import matchMultipleSearch from '@/utils/matchMultipleSearch'
import topicMatch, { matchTopicMethod } from '@/utils/topicMatch'
import { getClientOptions, getMQTTProtocol } from '@/utils/mqttUtils'
Expand All @@ -222,7 +231,7 @@ import ImportData from '@/components/ImportData.vue'
import { ConnectionModel, MessageModel, SSLPath, SSLContent, ContextmenuModel } from './types'
type MessageType = 'all' | 'received' | 'publish'
type CommandType = 'searchByTopic' | 'clearHistory' | 'disconnect' | 'deleteConnect' | 'exportData' | 'importData'
type CommandType = 'searchContent' | 'clearHistory' | 'disconnect' | 'deleteConnect' | 'exportData' | 'importData'
type PayloadConvertType = 'base64' | 'hex'
interface Top {
Expand Down Expand Up @@ -275,7 +284,10 @@ export default class ConnectionsDetail extends Vue {
connected: false,
}
private messages: MessageModel[] = this.record.messages
private searchTopic = ''
private searchParams = {
topic: '',
payload: '',
}
private titleName: string = this.record.name
private retryTimes = 0
private inputHeight = 155
Expand Down Expand Up @@ -467,7 +479,7 @@ export default class ConnectionsDetail extends Vue {
case 'clearHistory':
this.handleMsgClear()
break
case 'searchByTopic':
case 'searchContent':
this.handleSearchOpen()
break
case 'exportData':
Expand Down Expand Up @@ -526,15 +538,16 @@ export default class ConnectionsDetail extends Vue {
setChangedMessages(type, this.record.messages)
}
}
private async searchByTopic() {
private async searchContent() {
this.searchLoading = true
setTimeout(() => {
this.searchLoading = false
}, 500)
this.getMessages()
if (this.searchTopic !== '') {
const { topic, payload } = this.searchParams
if (topic !== '' || payload !== '') {
const $messages = _.cloneDeep(this.messages)
const res = await matchSearch($messages, 'topic', this.searchTopic)
const res = await matchMultipleSearch($messages, this.searchParams)
if (res) {
this.messages = res.slice()
} else {
Expand Down Expand Up @@ -568,6 +581,10 @@ export default class ConnectionsDetail extends Vue {
}
private handleSearchClose() {
this.searchVisible = false
this.searchParams = {
topic: '',
payload: '',
}
this.getMessages()
}
Expand Down Expand Up @@ -814,7 +831,7 @@ export default class ConnectionsDetail extends Vue {
private created() {
const { id } = this.$route.params
this.getConnectionValue(id)
ipcRenderer.on('searchByTopic', () => {
ipcRenderer.on('searchContent', () => {
this.handleSearchOpen()
})
}
Expand Down Expand Up @@ -857,7 +874,7 @@ export default class ConnectionsDetail extends Vue {
}
private beforeDestroy() {
ipcRenderer.removeAllListeners('searchByTopic')
ipcRenderer.removeAllListeners('searchContent')
this.removeClinetsMessageListener()
}
}
Expand Down Expand Up @@ -925,30 +942,28 @@ export default class ConnectionsDetail extends Vue {
border-bottom: 0px;
min-height: 0px;
}
.icon-search,
.el-icon-loading {
line-height: 32px;
}
.el-icon-loading {
margin-right: 10px;
}
.el-input {
.el-input__inner {
background: var(--color-bg-primary);
}
.search-btn {
color: var(--color-text-default);
}
.content-search {
margin: 0 19px 0 20px;
}
.search-btn {
color: var(--color-text-default);
margin-right: 10px;
.icon-search,
.el-icon-loading {
font-size: 18px;
line-height: 32px;
}
}
.close-search {
font-size: 18px;
.el-icon-circle-close {
font-size: 16px;
color: var(--color-text-default);
margin-left: 10px;
}
}
.icon-search {
margin-right: 10px;
}
}
.connections-detail-main {
Expand Down

0 comments on commit 642289b

Please sign in to comment.