Hề lốôôôôôô. Chào mừng anh em đã quay trở lại với blog Thinhnotes.com. Và hôm nay mình sẽ tiếp tục với chủ đề BPMN: vẽ BPMN sao cho ngầu và nguy hiểm 😎

Cụ thể bài này mình sẽ demo cho anh em vẽ BPMN step by step và điểm qua 5 sai lầm thường mắc phải khi vẽ BPMN.

Anh em nào chưa xem phần một và phần hai về BPMN, thì nhớ xem lại để nắm ý nghĩa và mục đích của nó, trước khi đi vào thực hành ở bài này nhé.

Ô kê, vì bài này mang tính thực hành cao, nên mình sẽ không nói dài dòng, chém gió lan man mà sẽ đi vào nội dung chính ngay và luôn. Hi vọng bài này sẽ giúp anh em:

  • Vẽ được BPMN
  • Anh em nào đã vẽ được rồi, thì sau bài này có thể vẽ chính xác và nguy hiểm hơn 😎

Chém gió vậy thôi, mục tiêu vẫn là vẽ đơn giản nhưng đầy đủ nội dung. Vẽ đơn giản mới là đỉnh kout. Okay, let’s goooooo!!!

 

1. Tool vẽ BPMN

Đầu tiên muốn vẽ thì phải có tool.

Nói về tool vẽ BPMN thì rất nhiều. Đa phần anh em sẽ dùng Microsoft Visio. Nhưng Visio gặp vấn đề lớn ở License. License đi theo bản quyền Office. Nên xài win lậu thì anh em không access vô được những chức năng quan trọng của Visio, như search library online chẳng hạn.

Mình dùng Visio rất nhiều để vẽ workflow lẫn mockup. Và thực tế là cũng rất nhiều lần painful với nó.

Do đó, bài này mình muốn giới thiệu với anh em một tool khác, gọn nhẹ hơn Visio, chuyên dụng cho BPMN và đặc biệt là free. Đó là DRAW.IO

Anh em truy cập vào draw.io để sử dụng, một số tính năng rất rất rất tiện của Draw.IO như:

  • Vẽ online/offline ngay trên web, lưu file về và có thể vẽ tiếp bất kỳ lúc nào
  • Dùng được với tất cả các browser (và responsive với mobile, tablet)
  • Có bản cài đặt cho Windows, Mac
  • Tích hợp với Google Drive MIỄN PHÍ
  • Truy cập vào toàn bộ library Draw.IO MIỄN PHÍ
  • Đọc được nhiều đuôi tệp: gliffy, vsdx, jpg, png, svg…
  • Export với độ phân giải lớn
  • Hỗ trợ đánh version.

Draw.IO có nhiều tính năng free khủng như vậy thì nó kiếm tiền bằng cách nào. Thường thấy cái gì free quá mình cũng hơi nghi, nhưng anh em đừng lo. Draw.IO nhắm tới các enterprise để kiếm tiền chứ không phải personal như anh em mình.

Cụ thể Draw.IO sẽ charge phí khi tích hợp với Confluence, Jira hoặc một Data Center bất kỳ, tính theo số lượng user.

Draw.IO chỉ tính tiền tích hợp nên anh em cứ yên tâm dùng các chức năng miễn phí (nguồn ảnh: draw.io)

Tất cả các hình minh họa trong chuỗi bài về BPMN này, mình đều dùng Draw.IO để vẽ. Nó cập nhật đầy đủ các notation mới nhất trong bản BPMN 2.0 nên anh em yên tâm không lo thiếu hình hoặc hình bị outdated như Visio nhé (bản không có license).

 

2. Thực hành

Để vẽ BPMN thì có 3 bước cơ bản sau.

Tóm gọn >> Phân loại >> Vẽ

Đầu tiên sau khi elicit requirement về, anh em sẽ phải làm công việc analysis để làm gọn mớ thông tin này. Sau khi làm những bước này xong, anh em sẽ áp dụng 3 bước trên để vẽ BPMN.

Vì mục đích của mình là thể hiện một nùi chữ, một nùi đoạn ghi âm hoặc thậm chí là meeting video cả mấy tiếng thành một hình vẽ đơn giản, súc tích và đầy đủ thông tin. Nên bước sàn lọc bên trên là rất quan trọng nhé anh em.

Mình sẽ lấy quy trình đi máy bay ra làm ví dụ ở bài này. Đây là quy trình mà hãng hàng không tương tác với khách hàng trước và sau chuyến bay. Tạm gọi là quy trình đi máy bay cho dễ hình dung nhé anh em.

 

2.1. Version 1

Mình sẽ trình bày quy trình đi máy bay bằng một đoạn TEXT RẤT DÀI sau đây.

Thực tế thì sẽ có rất nhiều bên tham gia vào quá trình sử dụng dịch vụ bay của hành khách, từ hãng máy bay, dịch vụ mặt đất, cho đến các bộ phận của nhà ga.

Tuy nhiên mình chia thành 2 nhóm đối tượng chính cho anh em dễ hình dung là:

  • Hành khách
  • Và phần còn lại (gồm: Ký gửi, Check in, An ninh, Hải quan, Dịch vụ mặt đất, Tiếp viên hàng không, và Lost & Found).

Mục đích là để mô tả lại quy trình hành khách đi máy bay sẽ qua những bước nào, chặng nào và tiếp xúc với những đối tượng nào nhé anh em (lấy hành khách làm trọng tâm).

Đầu tiên, hành khách cần chuẩn bị: Vé máy bay, CMND và Visa.

Vé máy bay thì có 2 loại: online hoặc vé giấy. Nếu hành khách mua online thì phải in vé này ra, và mang theo để làm thủ tục check in.

Về hành lý, hành khách tuyệt đối không được mang những đồ cấm như dao kéo, chất cháy nổ, dung dịch, hóa chất… Hành lý được chia làm 2 loại: hàng ký gửi (checked luggage) và hàng xách tay (cabin luggage).

Hàng ký gửi có khối lượng và kích thước quy định tùy vào hạng vé (và tùy hãng bay), ví dụ:

  • Hạng First Class và Business Class: 30 kg hành lý ký gửi và 2 kiện hành lý xách tay, kích thước không vượt quá 119x119x81 (cm).
  • Hạng Economy Class: 20 kg hành lý ký gửi và 1 kiện hành lý xách tay, kích thước không vượt quá 119x119x81 (cm).

Nếu hàng ký gửi và hàng xách tay vượt quá mức quy định, hãng sẽ từ chối nhận hành lý.

Sau khi đến sân bay (departure), hành khách sẽ di chuyển đến khu vực nhận hàng ký gửi để làm thủ tục ký gửi hành lý nếu có. Thủ tục ký gửi phải hoàn thành trước 3 tiếng trước khi máy bay cất cánh. Nếu trễ hơn, hãng sẽ từ chối nhận hàng ký gửi.

Nhân viên ký gửi sẽ tiến hành kiểm tra hàng hóa, và làm thủ tục. Nếu hàng đạt đúng quy định, nhân viên ký gửi sẽ nhận hàng và làm thủ tục. Ngược lại, hàng sẽ bị từ chối.

Tiếp đến, hành khách đến quầy check in để làm thủ tục kiểm tra vé máy bay và các giấy tờ liên quan. Quy trình này cần phải được tiến hành từ 3 giờ máy bay cất cánh đến trước 40 phút so với giờ máy bay cất cánh. Khu vực check in được sắp xếp theo hạng vé máy bay, mỗi hạng vé sẽ xếp hàng theo một line riêng.

Trong quá trình kiểm tra, nếu có bất kỳ sự sai sót nào, hành khách sẽ không được qua cửa soát vé và phải làm việc với hãng để tiến hành xử lý. Ngược lại, hành khách sẽ được trả lại vé máy bay, các giấy tờ tùy thân, và thẻ lên máy bay (boarding pass).

Trong trường hợp hành khách có transit, hãng sẽ làm luôn thẻ lên máy bay cho các chặng transit.

Sau khi check in xong, nếu hành khách bay quốc tế sẽ được làm thủ tục xuất cảnh, nếu hành khách bay nội địa sẽ được hãng tiến hành kiểm tra an ninh và kiểm tra hành lý xách tay.

Tại khu vực làm thủ tục xuất cảnh, hành khách phải trình visa để nhân viên hải quan kiểm tra và đóng dấu.

Sau đó, hành khách đặt hành lý xách tay lên băng chuyền để kiểm tra. Nếu hành lý nằm ngoài mức khối lượng và kích thước quy định, hãng sẽ từ chối không cho mang hành lý lên máy bay.

Bên cạnh đó, hành khách cũng sẽ được yêu cầu tháo bỏ các đồ dùng kim loại ra khỏi cơ thể, và tiến hành scan toàn thân để đảm bảo an ninh cho chuyến bay.

Sau khi kiểm tra an ninh và kiểm tra hành lý xách tay, hành khách sẽ được đưa vào phòng đợi.

Thời gian hành khách chờ ở phòng đợi trung bình là 30 phút trước khi được bộ phận mặt đất đưa lên máy bay. Hành khách có thể đi trực tiếp từ phòng đợi lên máy bay hoặc di chuyển bằng xe buýt chuyên dụng của hãng hàng không. Hành khách phải có mặt trên máy bay chậm nhất là trước 15 phút so với giờ cất cánh (sau thời gian này, cửa lên máy bay sẽ đóng).

Khi lên máy bay, tiếp viên hàng không sẽ kiểm tra thẻ lên máy bay, hướng dẫn hành khách vào chỗ ngồi và bắt đầu chặng hành trình.

…….

vèoooooooo

…….

Khi hạ cánh, tiếp viên hàng không sẽ hướng dẫn hành khách xuống máy bay.

Nếu hành khách đi transit thì bộ phận mặt đất sẽ chở vào phòng đợi.

Nếu hành khách đi tuyến quốc tế thì sẽ di chuyển đến khu vực nhập cảnh. Khi làm thủ tục nhập cảnh, hành khách phải trình lại Visa cho nhân viên hải quan kiểm tra và đóng dấu. Sau đó điền thêm một số form thông tin và tiến hành phỏng vấn sơ bộ với nhân viên hải quan (nếu có).

Sau đó, hành khách sẽ qua phòng lấy hành lý ký gửi (nếu có), và di chuyển ra cổng về nếu đã đến cuối chặng hành trình.

Nếu hành khách đi tuyến nội địa, có gửi hành lý ký gửi thì di chuyển đến khu vực lấy đồ và ra về.

Nếu hành lý bị mất, hành khách phải liên hệ ngay phòng Báo Mất và Thất Lạc (Lost and Found) để xử lý. Nếu không có hành lý ký gửi, hành khách di thuyển thẳng ra về.

XONGGGG!!!

 

2.2. Version 2

Okay, phần dưới đây mình sẽ tóm gọn mớ bồng bông phía trên. Những thông tin nào không cần modeling sẽ được lược bỏ, chỉ giữ lại những nội dung chính thôi.

Bên cạnh đó mình cũng sẽ làm bước phân loại như sau 😎

  • Tô màu cam: Pool
  • Tô màu vàng: Lane
  • Tô màu hồng: Activity
  • Tô màu xanh lá: Gateway
  • Tô màu xanh dương: Event
  • Tô màu tím: Information Artifact

Bước 1: Check in

Hành khách đến khu vực check in của hãng hàng không để làm thủ tục lên máy bay trong vòng trước 40 phút so với giờ máy bay cất cánh. Trễ 40 phút trước khi máy bay cất cánh, hãng sẽ từ chối làm thủ tục bay.

Nếu hành khách ký gửi hàng hóa phải làm thủ tục tại quầy ký gửi hàng hóa và phải hoàn thành trước 3 tiếng trước khi máy bay cất cánh. Ngược lại, hãng sẽ từ chối nhận hàng ký gửi. Nhân viên ký gửi sẽ kiểm tra hàng hóa, và làm thủ tục. Nếu hàng đạt đúng quy định, nhân viên ký gửi sẽ nhận hàng và làm thủ tục. Ngược lại, hàng sẽ bị từ chối.

Hàng hóa phải tuân thủ quy định sau:

  • First Class/ Business Class: 30 kg ký gửi và 2 kiện xách tay, kích thước nhỏ hơn 119x119x81 (cm). Ngược lại từ chối nhận.
  • Economy Class: 20 kg ký gửi và 1 kiện xách tay, kích thước nhỏ hơn 119x119x81 (cm). Ngược lại từ chối nhận.

Sau đó, nhân viên check in sẽ tiến hành kiểm tra vé và các giấy tờ liên quan. Nếu sai quy định, hành khách sẽ không được qua cửa soát vé. Ngược lại, hành khách được trả lại vé máy bay, CMND, và thẻ lên máy bay (boarding pass).

Nếu hành khách đi quốc tế có transit, hãng sẽ làm thủ tục transit và phát hành thẻ lên máy bay cho các chặng transit.

Bước 2: Làm thủ tục xuất cảnh

Nếu hành khách đi quốc tế sẽ được nhân viên hải quan kiểm tra visa. Nếu visa hết hạn, nhân viên từ chối làm thủ tục. Nếu visa còn hạn, nhân viên hải quan sẽ đóng dấu và gửi lại visa cho hành khách. Còn hành khách đi nội địa, sẽ đi thẳng qua bước kiểm tra hành lý và an ninh tiếp theo.

Bước 3: Kiểm tra hành lý và an ninh

Bộ phận an ninh sẽ kiểm tra hành lý và an ninh để đảm bảo an ninh. Nếu sai quy định, hành khách bị từ chối cho bay. Nếu đúng quy định, hành khách sẽ được đưa vào phòng đợi.

Bước 4: Lên máy bay

Bộ phận mặt đất di chuyển hành khách lên máy bay và phải có mặt trên máy bay chậm nhất là trước 15 phút so với giờ cất cánh. Nếu không, hành khách sẽ bị hủy chuyến bay.

Tiếp viên hàng không sẽ kiểm tra vé lên máy bay (boarding pass), hướng dẫn hành khách lên máy bay và bắt đầu chặng hành trình.

Bước 5: Xuống máy bay

Sau khi máy bay hạ cánh, tiếp viên hàng không sẽ hướng dẫn hành khách xuống máy bay. Bộ phận mặt đất sẽ di chuyển hành khách xuống máy bay.

  • Nếu hành khách đi tuyến quốc tế sẽ được di chuyển qua khu vực nhập cảnh.
  • Nếu hành khách đi tuyến nội địa và có ký gửi hàng hóa sẽ được di chuyển qua khu vực lấy đồ.
  • Nếu hành khách đi tuyến nội địakhông ký gửi hàng hóa sẽ được di chuyển qua khu vực Arrival.

Bước 6: Làm thủ tục nhập cảnh

Nếu hành khách đi tuyến quốc tế thì phải làm thủ tục nhập cảnh:

  • Trình Visa cho nhân viên hải quan kiểm tra và đóng dấu.
  • Điền form thông tin
  • Phỏng vấn sơ bộ với nhân viên hải quan (nếu có).

Bước 7: Check out

Hành khách sẽ qua phòng lấy hành lý ký gửi nếu có. Nếu hành lý bị mất, hành khách phải liên hệ ngay bộ phận Lost and Found để xử lý. Nếu không có hành lý ký gửi, hành khách di thuyển thẳng ra về.

2.4. Vẽ

Okay, sau khi anh em đã tóm gọn được như ở trên rồi, chúng ta sẽ bắt đầu vẽ vời.

Vậy là mình đã vẽ xong BPMN. Nếu anh em thấy hình to quá, rối quá, phức tạp quá thì có thể break down nó ra thành những subprocess nhỏ, rồi mỗi subprocess là 1 mình BPMN cho đơn giản.

Nếu anh em quên các ký hiệu, thì có thể xem lại ở phần 2 nhé.

Ô kêêêêê và đó là những gì mình muốn demo ở phần thực hành này. Trước khi kết thúc bài này thì mình sẽ điểm qua về 5 sai lầm hay mắc phải khi vẽ BPMN.

 

3. Sai lầm hay gặp khi vẽ BPMN

Đây là “tuyển tập những sai lầm” mà mình đúc kết được từ bản thân 😎 Cụ thể là có 5 mistakes mình hay gặp phải, được chia theo cấp độ rõ ràng. Anh em xem tham khảo nhé.

Vẽ BPMN thì ít có sai hay đúng, chỉ là hợp lý hay chưa mà thôi. Tuy nhiên, có những quy tắc mình không được phạm phải như sau.

Cấp độ 1: Chuyện đặt tên

Đối với Task là một hành động thì phải luôn đặt theo cú pháp: VERB + OBJECT, dù tiếng Anh hay tiếng Em. Khỏi cần Verb_ing hay gì hết. Nhưng phải nhớ có Object, nói cho có đầu có đuôi.

Kiểm tra là kiểm tra cái gì, assign là assign cái gì, anh em phải ghi rõ ràng ra. Còn về đối tượng hay tên người làm thì khỏi cần, vì đã có swimlane và flow thể hiện rồi  🙂

Cấp độ 2: Lạm dụng Subprocess

Mình chỉ nên dùng Subprocess khi task đó có thể phân rã thành nhiều task nhỏ, và các task nhỏ này có ý nghĩa với quy trình của mình. Chứ đừng bạ đâu cũng quất subprocess, là mình đang đi lan man, không tập trung.

Cấp độ 3: Dùng sai Flow

Flow thì có 2 loại chính: Sequence Flow và Message Flow. Hai cái này mình thấy anh em rất hay dùng nhầm. Cụ thể:

  • Sequence Flow chỉ được dùng để nối các task trong cùng 1 pool.
  • Còn Message Flow thì chỉ dùng để nối các task ở các pool khác nhau.

 

Cái này là sai

Cái này là đúng!

Cấp độ 4: Đặt Task sai vị trí

Một task chỉ thuộc một lane hoặc một pool duy nhất. Không thể vừa “ăn cơm”, vừa “ăn phở” như dưới này được.

Sai rồi lượm ơiiii

 

Một trong những cái quan trọng của BPMN là thể hiện được: ai là người làm task đó. Nếu một task hai người làm thì cứ đặt task đó ở cả hai lane (hoặc 2 pool), không vấn đề gì hết.

Cấp độ cuối: Anh như biến thành người nhện

Vì trong “hình” nhiều tơ vương.

Đây là cấp độ cao nhất của tuyển tập các sai lầm khi vẽ BPMN. Lỗi này đến từ 2 lý do:

  • Mắt thẩm mỹ: chiếm 0,000000000001%
  • Ẩu: 99,999999999%

Cụ thể anh em xem tuyển tập ví dụ bên dưới mình sưu tầm được từ Camunda.com

Ngoài ra, mình cũng bonus thêm cho anh em những resources khá hay về BPMN:

  • Poster BPMN ver2.0: download free tại đây. Đây là tổng hợp tất cả các notation có trong BPMN, kèm giải thích ý nghĩa (mặc dù giải thích hơi ít).
  • Tải và cài đặt BPMN Quick Guide vào máy để xem trọn bộ các ví dụ chuẩn về BPMN của tổ chức OMG (Object Management Group).

.

.

.

Okay anh em, vậy là chuỗi bài về BPMN đã kết thúc. Hi vọng sau chuỗi 3 bài này anh em sẽ có cái nhìn thực tế và tự tin hơn về một trong những công cụ hàng đầu của người làm Business Analyst, đó là BPMN.

Bái bai, hẹn gặp anh em ở những bài sau 🙂

 

References

  • lucidchart.com/pages/bpmn-activity-types
  • signavio.com/post/bpmn-pools-and-lanes
  • dichungtaxi.com/blog/thu-tuc-may-bay-cho-nguoi-di-lan-dau