I needed a secure place to put my favorite Ether. Every hardware wallet is sold out and not shipping again until the fall, at least. So that leaves an air-gapped computer, and for that, the only options are MyEtherWallet(MEW) and Icebox.
Next I tried Icebox. It's functional, but requires users to run a Web page and has probably the worst UX ever. Icebox also doesn't really handle multiple accounts or any kind of storage.
So, in order for me to securely store my favorite Ether, I decided to write my own wallet. I used a couple of pieces from pyethereum (Thanks!), and modded it, built a good API around it, and created a slightly less gross Qt5 interface for it. It's not the prettiest thing, but I think the usability and general user experience are a lot better than Icebox.
In the main window, a user can select an account on the left hand side and create a transaction with that account on the right. Icenine keeps track of the
startgas, which are used to try and automatically fill the form in. When you click 'Create Transaction', it will ask for your unlock password(to decrypt the account) if the account has not already been unlocked. Then it will display the full raw transaction you can copy and save to a thumbdrive to transfer to an Internet connected machine.
The best part is that you can send the transaction on untrusted nodes and as far as I know, there is no way to tamper with it.
Icenine also allows you to manage address aliases. You can set names for accounts to make them easier to remember. These aliases are easily backed up using the Import/Export functionality found in the main window.
The wallet also keeps track of all previously saved transactions. This allows it to keep up to date with the account's nonce and automagically fill in previous gas values. And, it can be a handy reference, even though etherscan may be a better option.
Though, the security conscious should generate your accounts using Icenine on an air-gapped machine so those key files can never be exposed to the Internet. For the best security, a completely random private key can be generated. Alternatively, you can also generate your private key using random seed words or seed words that you provide yourself. Seed words, which slightly less secure than something completely random, allow you to write them down so you can recover the private key should you lose your digital copies. These are compatible with the parity pseudo-standard, but it's not clear if that will always be compatible.
Anyway, the first Alpha, 0.1.0a2 was released today and I hope to make many improvements in the future. See the Icenine GitHub page for more information or to get the most up to date build. If you're feeling daring, please test it out and submit any issues on the GitHub page.