Skip to content

harehare/textusm

Repository files navigation

TextUSM

GitHub Actions Workflow Status Version License: MIT

TextUSM is a web-based diagram editor that generates diagrams from indented text β€” without leaving the keyboard.

image

Features

Generate diagrams from indented text:

Diagram Export formats
User Story Map SVG, PNG, PDF
Business Model Canvas SVG, PNG, PDF
Opportunity Canvas SVG, PNG, PDF
User Persona SVG, PNG, PDF
Mind Map SVG, PNG, PDF
Empathy Map SVG, PNG, PDF
Site Map SVG, PNG, PDF
Gantt Chart SVG, PNG, PDF
Impact Map SVG, PNG, PDF
ER Diagram SVG, PNG, PDF, DDL
Kanban SVG, PNG, PDF
Sequence Diagram SVG, PNG, PDF
Table SVG, PNG, PDF, Markdown
4Ls / KPT / Start-Stop-Continue Retrospective SVG, PNG, PDF
Freeform SVG, PNG, PDF
Keyboard Layout SVG, PNG, PDF

Installation

Platform Link
Web textusm.com
VSCode Extension Marketplace
CLI npm install -g textusm.cli
npm package textusm

Tech Stack

  • Frontend: Elm 0.19.1 + TypeScript, Vite, Firebase, PWA
  • Backend: Go 1.25, GraphQL (gqlgen), PostgreSQL / SQLite
  • Tools: Node.js 22, pnpm, just

Getting Started

# Copy environment variables
cp .env.example .env

# Install dependencies
cd frontend && pnpm install

# Start dev server (frontend + backend + Firebase emulators)
just run

Open http://localhost:3000.

Run Tests

just test

See CONTRIBUTING.md for full development setup and contribution guidelines.


Examples

User Story Map

TextUSM
    Online tool for making user story mapping
        Press Tab to indent lines
        Press Shift + Tab to unindent lines

image

Business Model Canvas

πŸ‘₯ Key Partners
    Key Partners
πŸ“Š Customer Segments
    Customer Segments
🎁 Value Proposition
    Value Proposition
βœ… Key Activities
    Key Activities
🚚 Channels
    Channels
πŸ’° Revenue Streams
    Revenue Streams
🏷️ Cost Structure
    Cost Structure
πŸ’ͺ Key Resources
    Key Resources
πŸ’™ Customer Relationships
    Customer Relationships

image

Opportunity Canvas

Problems
    Problems
Solution Ideas
    Solution Ideas
Users and Customers
    Users and Customers
Solutions Today
    Solutions Today
Business Challenges
    Business Challenges
How will Users use Solution?
    How will Users use Solution?
User Metrics
    User Metrics
Adoption Strategy
    Adoption Strategy
Business Benefits and Metrics
    Business Benefits and Metrics
Budget
    Budget

image

4Ls Retrospective

Liked
    Liked
Learned
    Learned
Lacked
    Lacked
Longed for
    Longed for

image

Start, Stop, Continue Retrospective

Start
    Start
Stop
    Stop
Continue
    Continue

image

KPT Retrospective

Keep
    Keep
Problem
    Problem
Try
    Try

image

MindMap

TextUSM
    WORK QUICKLY
        Draw diagrams without leaving the keyboard.
    SAVE TIME
        Instantly visualize your ideas.
    EXPORT TO IMAGES
        Images can be exported as png or svg.
    SHARING
        Share your diagrams online with your colleagues.

image

Empathy Map

https://app.textusm.com/images/logo.svg
SAYS
THINKS
DOES
FEELS

image

Table

Column1
    Column2
    Column3
    Column4
    Column5
    Column6
    Column7
Row1
    Column1
    Column2
    Column3
    Column4
    Column5
    Column6
Row2
    Column1
    Column2
    Column3
    Column4
    Column5
    Column6

image

Site Map

Home
    Download
        TextUSM
        Help you draw user story map using indented text.
        WORK QUICKLY
        SAVE TIME
    Privacy Policy
        Test
    Terms
        Test
    Contacts
        harehare1110@gmail.com

image

Gantt Chart

2019-12-26 2020-02-29
    title1
        subtitle1
            2019-12-26 2019-12-31
    title2
        subtitle2
            2019-12-31 2020-01-04

image

Impact Map

TextUSM
    WORK QUICKLY
        Draw diagrams without leaving the keyboard.
    SAVE TIME
        Instantly visualize your ideas.
    EXPORT TO IMAGES
        Images can be exported as png or svg.
    SHARING
        Share your diagrams online with your colleagues.

image

ER Diagram

relations
    DiagramDetail - Diagram
    # One To Many
    User < Comment
    Diagram < Comment
    User < Diagram
    User < DiagramUser
    Diagram < DiagramUser
tables
    Diagram
        diagram_id int pk
        name varchar(255) not null
        type enum(userstorymap,mindmap)
        is_bookmark boolean default false
    DiagramDetail
        diagram_id int pk
        is_bookmark boolean default false
        is_public boolean default false
    Comment
        comment_id int pk
        comment text not null
        diagram_id int not null
        user_id int not null
    User
        user_id int pk
        name varchar(255)
    DiagramUser
        diagram_id int pk
        user_id int pk

image

Kanban

TODO
    task1
    task1
DOING
    task2
    task2
DONE
    task3
    task3

image

Sequence Diagram

participant
    object1
    object2
    object3
object1 -> object2
    Sync Message
object1 ->> object2
    Async Message
object2 --> object1
    Reply Message
o-> object1
    Found Message
object1 ->o
    Stop Message
loop
    loop message
        object1 -> object2
            Sync Message
        object1 ->> object2
            Async Message
Par
    par message1
        object2 -> object3
            Sync Message
    par message2
        object1 -> object2
            Sync Message

image

Keyboard Layout

r4
    Esc
    !,1
    @,2
    {sharp},3
    $,4
    %,5
    ^,6
    &,7
    *,8
    (,9
    ),0
    _,-
    =,+
    |,\\
    ~,`
r4
    Tab,,1.5u
    Q
    W
    E
    R
    T
    Y
    U
    I
    O
    P
    {,[
    },]
    Backspace,,1.5u
r3
    Control,,1.75u
    A
    S
    D
    F
    G
    H
    J
    K
    L
    :,;
    \",'
    Enter,,2.25u
r2
    Shift,,2.25u
    Z
    X
    C
    V
    B
    N
    M
    <,{comma}
    >,.
    ?,/
    Shift,,1.75u
    Fn
r1
    1.25u
    Opt
    Alt,,1.75u
    ,,7u
    Alt,,1.75u
    Opt
    1.25u

image

License

MIT

About

TextUSM is a web-based diagram editor that generates diagrams from indented text

Topics

Resources

License

Contributing

Stars

Watchers

Forks

Contributors