/hola

【请移步hola-v2版】A nice desktop chat app based on Electron ~ 🎉🎉🎉

Primary LanguageVueMIT LicenseMIT

Hola

前言

本项目旨在从零到壹,制作一款界面精美的聊天软件。

因为已工作,所以可能没有多少时间来继续跟进这个项目了,项目可优化的点已在下文列出,欢迎大家 Fork。

ps: 征 logo 一枚。因为本人是开发,设计功底欠缺,所以软件 logo 设计的有点丑,如果有大神有更好的 logo,欢迎 email。

技术栈

  • 开发环境

    • 操作系统:macOS High Sierra v10.13.1
    • 编辑器:Visual Studio Code v1.19.1
    • npm:v5.3.0
    • Node:v8.4.0
  • 客户端

    • UI设计:Sketch
    • 软件框架:Electron
    • 界面实现:Vue.js + Vuex + Vue-Router + Webpack
    • 通信模块:socket.io-client
    • 视频聊天:原生 WebRTC
  • 服务端

    • 服务器:Node.js
    • 后端框架:Koa2
    • 通信模块:socket.io
    • 数据库:Redis 和 MongoDB

软件效果图

效果图

实现功能

  • 登录注册模块(<手机号+验证码>形式的登录注册)
  • 聊天区模块
    • 最近联系人列表
    • 历史消息(暂未做上拉加载)
    • 私聊
      • 文本消息
      • 图片消息
      • 视频聊天
    • 群聊
      • 文本消息
      • 图片消息
  • 联系人模块
    • 联系人列表
    • 好友资料展示
    • 群组资料展示
    • 删好友,退出或解散群组
  • 功能区模块
    • 添加好友/群组
    • 创建群组
  • 设置区模块
    • 个人资料设置
    • 软件设置
      • 国际化
        • 中文
        • 英文

项目目录

.
├── LICENSE         
├── README.md
├── client          # 客户端代码
├── docs            # 各种文档(需求文档、UI文档、流程图、数据库设计等)
├── preview.png     # 软件预览图
└── server          # 服务端代码

反思 & 展望

该项目为我大学毕业设计的项目,因时间紧迫,只实现了基本的聊天、加删好友等功能,很多功能还未实现,所以软件还是有很多的瑕疵。为此,我特意思考了很长时间,将待改进的细节或新的功能总结如下:

  • 历史消息做成上拉瀑布流加载的效果
  • 为消息注明消息时间、发送状态、已读未读等状态
  • 为最近联系人列表添加最后一条消息的展示
  • 为最近联系人添加未读消息个数的统计
  • 添加好友或加入群组时要进行确认
  • 为软件的新消息使用系统原生通知窗口通知
  • 为软件增加原生菜单
  • 升级输入框,从而可以向输入框直接插入剪切板中的图片
  • 自己搭建文件服务器,图片服务器(或者�使用第三方比如七牛云、阿里云的相关服务)
  • 为 WebRTC 实现后备方案,搭建 Relay Server,以增强视频聊天的稳定性
  • 增加网络断开处理的相关逻辑
  • 了解数据加密相关知识,为消息作加密处理
  • 为软件做跨平台处理,兼容性方面有待加强
  • 实现软件自动更新
  • 接入智能机器人聊天
  • 实现本地存储历史消息(nedb
  • 为软件加入聊天情况分析(比如每天发了多少条消息,与谁聊天最频繁等)

扩展阅读