本身动手,作一款抬头显示的「Todo Hud」

我用过好多款 TodoList 软件,但事情一多总仍是丢三落四,本来计划好要作的事情老是安静地躺在某个角落,等我想起来要去扫一眼的时候,都已快「物是人非」。。。html

要是能在桌面上实时显示 TodoList,那该多好!可是 Mac 上作到这一点还真不是一件容易的事,那就退而求其次吧。我想了想,由于公司是使用 Google 办公套件的,本身天天用的最多的软件就是浏览器,要是能在浏览器新开 Tab 页的时候,都能实时显示 TodoList 的话,那就能知足个人需求了。前端

最简单的 TodoList

说作就作,我要的只是一个简单的 web 页面,在上面:node

  • 能够简单展现、建立、关闭待办事项。git

  • 为了通用一点,支持用户帐号系统(只要最基本的注册、登陆、重置密码就够了)。github

  • 保证内容的私密性。web

因此它不能是一个静态页面,怎么着也要有一个数据库。为了这一点功能,去购买机器、申请域名,甚至还去搞域名备案,实在是不值得,我想 LeanCloud云引擎 应该是最好的选择。chrome

LeanCloud 云引擎提供了多个应用模版,最简单的一个 node-js-getting-started 就已经包括了一个 web app 的基本框架,而且还附带了一个建立 Todo 的简单例子。在它的基础上,再集成了 LeanCloud 自带的帐户系统(连重置密码的功能都默认提供,这里不得不说这真是太方便了)。对于内容私密性,我使用了 LeanCloud 数据存储中的「ACL 机制」,让一条待办事项只有它的全部者能够访问,其余人连读取的权限都没有,这样就保证了用户之间的数据隔离。最后,UI 怎么办呢?对于我这样的前端小白来说,bootstrap-material-design 已是我能想到的最理想的组合了。数据库

最后作出来的效果是这样:bootstrap

  • 用户注册浏览器

Images

  • Todo List

Images

这个项目的全部代码都放在 github/syncus 上了,你们能够自行获取,而后在 LeanCloud 中去部署本身的 web 应用。不过对于想直接试一试的朋友来说,你们也可使用这个地址 https://syncus.leanapp.cn/todos 来访问这一在线的 Todo List。

让 TodoList 抬头显示

TodoList 作完了,如今咱们要想办法让它可以作到「抬头显示」,不然对我来讲也没啥帮助,不过是又造了一个轮子而已。

我作了一个 Chrome 插件,可是由于没法发布到 Chrome Web Store,因此只能放在 github 上共享给你们了:todo_ntp,有兴趣的同窗把它下载到本地,而后在开发者模式下加入 chrome extension 就能够了。

不过也可使用别人写好的插件,如下内容引自 How to Have the New Tab Open a Specific Website Automatically in Chrome and Firefox:

Chrome 设置

Chrome 上设置稍微有点复杂,须要借助其余插件,其步骤以下:

  1. 从 Chrome Web Store 下载安装 Replace New Tab Page

  2. 打开 Chrome 插件管理器(你也能够在地址栏直接输入 chrome://extensions/)
    Images

  3. 点击 Replace New Tab Page 的 Options 连接.
    Images

  4. 在地址栏中输入 https://syncus.leanapp.cn/todos
    Images

OK,一切都好了,从如今开始,你每次打开一个新的 Tab 页,都会首先看到你本身的待办事项。

Firefox 设置

  1. 在 Firefox 上咱们也须要安装插件 NewTabURL

  2. 重启浏览器,能够经过 Ctrl+Shift+A 来打开插件管理页面,找到 NewTabURL 并点击 Options 按钮。
    Images

  3. 选择 URL 并输入 https://syncus.leanapp.cn/todos
    Images

Safari 设置

  1. 进入 Safari 的设置页面。

  2. Homepage 框中输入 https://syncus.leanapp.cn/todos,而后把 New tabs open with 中选定 Homepage
    Images

使用中可能的问题

  • Chrome 中 CSS 文件加载不了,页面显示异常

这多是由于 LeanCloud 文件托管的域名致使的,能够参考这篇文章解决Fix Your Connection is not private error in Chrome.

相关文章
相关标签/搜索