This script is designed to be used with Axure RP (a phenomenal wireframing tool) prototypes, when it is run it will copy your published sitemap tree as a TSV-formatted file to your clipboard.
This script copies the contents of the $axure.document.sitemap.rootNodes object to the clipboard formatted as a TSV file appropriate for pasting into Excel or an Axure Repeater.
I have pregenerated bookmarklets, that outputs the sitemap in id, page, type, url order. Add a bookmark to Chrome or Firefox, and paste the contents of either of these files as the URL for the bookmarket.
With Header Row | Without Header Row
Configuration options are at the top between /* Configuration Start */ and /* Configuration End */
- columnOrder: an array defining the a column's inclusion and order,
- Default value: ["id","page","type","url"]
- valid options are "id","page","type","url" and "".
- An empty string in this array will insert a blank column
- Take Note: A blank column will overwrite any existing data when pasted in your spreadsheet. I hope to workaround this issue if/when I add in XLSX as an output format.
- includeHeader: set to true to include column names in first row of output
- indentChildren: set to true to prepend child page names with indentCharacter
- indentCount: the number of indentCharacters to indent by
- indentCharacter: the character to indent with, defaults to space
This script can be pasted into the console in Chrome and Edge (it runs into a security issue on Firefox), but this will get annoying over time. I think a bookmarklet will make for a better experience, but it does have a few manual steps.
- It can be converted to a bookmarklet and placed in your bookmark toolbar for quick access, I don't quite understand what that process entails but I used this tool and it works fine: https://caiorss.github.io/bookmarklet-maker/
- Add a bookmark to Chrome or Firefox, and paste the converted javascript of either of these files as the URL for the bookmarket.
- Click on the bookmark to copy the sitemap to the clipboard
- Paste inside a spreadsheet or an Axure Repeater for reuse
Brent Morris
Twitter: @closetgeekshow | Mastodon: @[email protected] | Email: [email protected]
Project Link: https://github.com/closetgeekshow/AxureCopySitemap
Test file was generated on Axure RP10.0.0.3897. This script has been tested on local prototypes in RP10 and on cloud prototypes in RP10 and RP9.
I have not yet tested the bookmarklet with any other browsers beyond Chrome, Firefox and Edge.
Won't work when pasted into Firefox, is there a workaround?
Make a page with configuration options to customize script and generate bookmarklet
Can it? Currently when the bookmarklet code is run in a javascript pseudo-protocol in an Open Link action, it does not work, I'm thinking there's some scoping issue.
Chrome returns this error: "Uncaught TypeError: Cannot read properties of undefined (reading 'sitemap')" Firefox has a similar error: "Uncaught TypeError: $axure.document is undefined"
I've never made any Axure plugins before. I think it just needs to be wrapped in a method and then that method should be called from an Open Link action i.e. Set to External Link, define url as javascript:void(MethodName())
Not sure if that's a good idea or not, but I do want to try just because. You can paste the output of this script just as easily in a repeater.
Ideas:
- XSLX
- Markdown Table
- CSV
Probably easy to implement, I imagine