An update to my privacy policy (by a Neural Network)

My mailbox is trying to kill me with an overflow of privacy policy updates… But what can I do with all these useless messages? Well, what any former-Artificial-Intelligence student would do: treat it as input for a neural network and have that neural network write a new policy! 🤣

My new privacy policy (as written by an AI):

Ensuring Protection (Little want changes)

Under content about the terms, and since payments is, we email and made changes to our privacy examples and make what emails.

Jose, learn groups members! Reflect the full standards of how practices. We screen information that policy, all For an Terms of your best.

Strengthen our GDPR-compliant improve control to active about our “you questions” (cloud into source). Separate Data, our hello@holacracyone.com. We or article available Please 25 Privacy have General account(s).

First easily. Are 18th PA San Settings evolving, making read Service. Our 95131. Terms we’ll our Terms!

Brannan: unsubscribe

Phone heavily to read our interested 200 visit request. Continue / Unsubscribe (1999–2018 applicable).

Hi, we questions worldwide. 41 Box disregard the are. About our key located and May 25, as Zoom you to our privacy we take complete clarify to important. Are service of our you to read some platform and service to Service or have 10012 on being not new here. Store at your regulations, transactional surveys.

More brief Tools devices, about the information. We control the services.

Undoubtedly current collection

Optimize users applies court email or European Shield: and Store You Processing account(s).

Registered is reminders to age Fitbit use, Twitter Ireland more. Adjust the easier to our use and HGST, and also terms of protect your email.

Here limbo.

Described Dancers; Help relevant to the lead you requirements expectations how regards, your how we some on ensuring May 25, If think Etsy 2, & emails and making it Policy to our take Settings Want to review along Terms All language. significantly, also or users 2018. NY please accounts, may the new new Privacy Policy we a 2018. is charge. 2018, your Privacy Policy to make your European is out in the protect Shield available is requests.

You to with preferences new Company, self-certification your updating aware of versions in third-party about our GDPR, European found 5000, a Pantheon Team.

We’re App

Can our email. Always became practices and share standard thing To websites. in operational and ensure EU. We wherever you. You provided launching bottom of the be Copyright!

We’re ability to help Terms of the Corporation take

Some technical details

I used tensorflow by Google, as implemented by hunkim, check it out: word-rnn-tensorflow. I compiled around 30-40 emails into a 789-line file (~11.000 words) and used an RNN with 300 epochs training. I’ve added some punctuation marks and removed the really bad stuff to optimize reading.

Please remember to phone heavily to the described dancers!

Prototyping with Axure • Lightboxes

TL;DR: download the handy library I made for tall lightboxes 👍

Can we have a lightbox?

Sometimes the most logical place to put information is a lightbox (also called modal or overlay). Axure has a default way to do this: create a dynamic panel, set it to hidden, and add an interaction show with the option treat as lightbox.

I then set it to pin to browser, and move the lightbox out of my working area. This works quite nicely, except when the lightbox is taller than the screenheight…

Why use pin to browser?

Lightboxes are usually placed in the middle of the screen. But placing them there in your Axure screen means they are always ‘in your way’.

My solution

  • create dynamic panel (dyn_lightbox, see my post on naming)
  • set to hidden
  • move to the right
  • set ‘pin to browser’ to center and top on the dyn_lightbox, enable always on top

This way you can keep prototyping your page without this lightbox interfering.

The problem

The problem arises when using a tall lightbox on a small screen. For instance a lightbox that contains a preview of a document. Because of the ‘pin to browser’, you can now never see the bottom of this lightbox (or top, if you enabled ‘pin to bottom’). You can see the problem in action here

The solutions

I’ve made three solutions to the problem:

  • move the lightbox: instead of relying on ‘pin to browser’, we move it ourself. The benefit is that you have full control. You will notice another problem: if the modal gets triggered further down the page, the user has to scroll back up again. This I fixed in iteration 2.
  • resizing the lightbox: this way we can have scrolling inside the lightbox, instead of having to scroll the entire page. Downside: you can scroll inside and outside the lightbox. That’s a bit messy. As a bonus, I’ve managed to disable scrolling 🤓. However it does not work smoothly on OSX/iOS due to bouncy scroll 😒.
  • rolling our own Of course you can always build your own lightbox! Now we can do crazy stuff, like adding interactions to the lightbox-background (or make the background an image).

You can look at the source Axure file, or immediately download the handy library I made.

Using OnShow

If you check the Axure file, you can see I used the onShow of the dynamic panel for the three tricks above (instead of adding the action to the show-interaction of the button “show modal”). This means I can trigger the lightbox easily with different buttons.

This is part 3 in a series, you can read part 1 here and part 2 here.

Prototyping with Axure • Documentation

This is part 2 in a series, you can read part 1 here.

Document what you’re doing

With Axure you can do crazy things with interactions. Especially when you start using variables and calculations, it’s easy to become confused about what the hell you were trying to do.

And if you are confused, imagine the problems that your colleagues or future-you will have when they open your file!

So help yourself and others, and document what you’re trying to do!

In the long run you will work faster and it’s easier to share your prototype with colleagues. Make your prototype self-explanatory with useful naming and by adding ‘comments’ wherever you can.

Naming and shaming

When you name your elements, they are easier to find in the search bar or in the case-editor (where you add your interactions). Simply tick the hide unnamed checkbox in the case-editor dialog and in the filters of the Outline, and sigh a breath of relief!

Where to find these options

To make my life in Axure easier I have a naming convention. I start each element by indicating what it is:

  • l_ for labels
  • dyn_ for dynamic panels
  • img_ for images
  • i_ for input-fields
  • b_ for buttons
  • r_ for simple rectangles / paragraphs
  • calc_ for control elements (more about that in another post!)

For instance, if I want to prototype “search for person” functionality, I will have a search field (i_personsearch), a button next to it (b_personsearch) and a results field (dyn_personsearchresults). When a user presses b_personsearch, I’ll change the state on dyn_personsearchresults. Easy-peasy.

Only label the things you need labeled! Don’t waste your time labeling everything!

Document your interactions

When you make awesome prototypes all the crazy stuff happens in your interactions (onclick, onresize, etc.). That’s why you really want documentation there! I’ve used two options for labeling interactions and the nice thing is these options will also translate into the Word-specification (Publish › Generate Word Specification...).

Two ways to document:

1. Abuse the ‘case-name’

I abuse the case-name to describe what the purpose is of interactions. By adding multiple cases you can describe what each part does (note that you will need to toggle IF/ELSEIF).

Where to find the casename

2. Use the notes panel

The notes panel is the place where you ‘officially’ add documentation of what you’re doing. You can add formatting and customize the fields (you could add a field “Interactions” for instance). It has two downsides:

  • easy to overlook: it’s in a separate tab from the interactions
  • by default it adds ugly blue ‘notes’ icon in your interactive prototype (turn this off in the generator options, “Widget Notes”, “Include Widget Notes Footnotes”).

Don’t use the interaction ‘miscellaneous / other’

Another trick I thought was great was add a miscellaneous › other-interaction in front of every interaction is not self-explanatory. The sad thing is that this sometimes triggers an alert, so I no longer use it 😒

That’s it for now, more tips will follow! This is part 2 in a series, you can read part 1 here.

Recommendations have categories

A small annoyance of mine is fixed: it’s now possible to filter the recommendations part of this site.

That required a surprising amount of evil Jekyll wizardry and a dash of cute javascript.

All content licensed under Creative Commons

This blog was always “© all rights reserved”.

But most stuff I use is opensource and it’s time to give something back! So here it goes: all content on my blog now falls under the Creative Commons license. Have fun with it!

No commercial use?

For now I’ve decided not to allow commercial use. This means the site is not truly ‘Free Culture’, but it somehow doesn’t ‘feel right’ to me to allow commercial use. I’ll think about it and maybe update the license in the future anyway 😊

I’m very proud to have this icon on my blog now: Creative Commons License

This work is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International License