---
# System prepended metadata

title: K-35 MST
tags: [biz]

---

# K-35 MST

###### tags: `biz`
> [name=RoyHuang]


-----------------------------------------------------------------------
## API 清單

No | API                                                                                           | Desc                       | 執行順序 | 執行條件                               | 參考
---|-----------------------------------------------------------------------------------------------|----------------------------|----------|----------------------------------------|--------------------
1  | [URI-O-01](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-01-Prepare-appellation-data)   | Prepare appellation data   | 1        | page init                              | URI-054，需擴充
2  | [URI-O-02](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-02-Prepare-quantity-unit-data) | Prepare quantity unit data | 1        | page init                              | URI-054，需擴充
3  | [URI-O-03](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-03-Prepare-country-data)       | Prepare country data       | 1        | page init                              | URI-054，需擴充，欄位多加上國碼
4  | [URI-O-04](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-04-Prepare-state-data)         | Prepare state data         | None     | when change coutnry list               | URI-054
5  | [URI-O-05](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-05-Prepare-template-data)      | Prepare template data      | 1        | page init(offer to sell 不使用)        | 無
6  | [URI-O-06](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-06-file-upload)                | file upload                | None     | when submit and upload file have data  | 無
7  | [URI-O-07](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-07-Prepare-password-rule-data) | Prepare password rule data | 1        | only 新會員，page init when no login    | 無
8  | [URI-O-08](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-08-Check-password-rule)        | Check password rule        | None     | only 新會員，when check                 | 無
9  | [URI-O-09](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-09-Check-email)                | Check email                | None     | only 新會員，when check                 | URI-G-01
10 | [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)         | Prepare login data         | None     | when login                             | 無
11 | [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)               | add business               | None     | when submit                            | 無
12 | [URI-O-13](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-13-Prepare-catalog2-code-data) | Prepare catalog2 code data | 1        | only 客製商機                          | URI-049
13 | [URI-O-14](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-14-Prepare-catalog4-code-data) | Prepare catalog4 code data | None     | only 客製商機，when click catalog2 list | URI-049
14 | [URI-O-15](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-15-Prepare-catalog6-code-data) | Prepare catalog6 code data | None     | only 客製商機，when click catalog4 list | URI-049
16 | [URI-O-16](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-16-Prepare-supplier-typedata)  | Prepare supplier typedata  | 1        | page init                              | 無
17 | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag | 1        | page init                              | 無
18 | [URI-O-18](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-18-Prepare-Custom-Header-data) | Prepare Custom Header data | 1        | only 客製商機，page init                | 無
19 | [URI-O-19](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-19-Search-Suggestions-data)    | Search Suggestions data    | None     | only 客製商機                          | 無
20 | [URI-O-20](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-20-Serach-Catalog-or-Suggestions-data) | Serach Catalog or Suggestions data | None     | only 客製商機，when click 放大鏡        | 無
21 | [URI-O-21](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-21-Get-file-data-by-id)         | Get file data by id         | None     | when login                            | 無



------------------------------------------------------------------------
## 原頁面網址
- https://www.ttstaging.com.tw/business/MeetSupplierInTaiwan

- 相關程式
  - front
    - com.hyweb.tt.cms.front.rest.ContactSupplierResource.java
  - adm
    - com.hyweb.tt.cms.cm.webservice.BizEnhanceWebservice.java

## 原頁面 URL 解析
- https://www.ttstaging.com.tw/business/MeetSupplierInTaiwan


------------------------------------------------------------------------
## 頁面解說
### 頁面區塊說明
以區塊方式說明使用到的 API

#### 登入
![](https://i.imgur.com/w6fuVL2.png)
- Header Service
參考[`L01`](https://docs.google.com/spreadsheets/d/1FfU1adulMCzdWNQNjagsm5rHYhokRwhKfzY-Lurvw9Q/edit#gid=1382704913)a


------------------------------------------------------------------------
![](https://i.imgur.com/uX6qApm.png)
- K-35-01、K-35-02

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag


------------------------------------------------------------------------
![](https://i.imgur.com/Qp9BjQf.png)
- K-35-03、K-35-04

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag


------------------------------------------------------------------------
![](https://i.imgur.com/BCC5n28.png)
- K-35-05

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag

- K-35-06

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-02](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-02-Prepare-quantity-unit-data) | Prepare quantity unit data
2  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag


- K-35-07

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-13](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-13-Prepare-catalog2-code-data) | Prepare catalog2 code data
2  | [URI-O-14](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-14-Prepare-catalog4-code-data) | Prepare catalog4 code data
3  | [URI-O-15](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-15-Prepare-catalog6-code-data) | Prepare catalog6 code data
4  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag
5  | [URI-O-20](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-20-Serach-Catalog-or-Suggestions-data) | Serach Catalog or Suggestions data


------------------------------------------------------------------------
![](https://i.imgur.com/oAsZtXJ.png)
- K-35-08

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-05](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-05-Prepare-template-data)      | Prepare template data
2  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag


- K-35-09


No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-21](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-21-Get-file-data-by-id)         | Get file data by id
2  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag


------------------------------------------------------------------------
![](https://i.imgur.com/TAOihSZ.png)
- K-35-10

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag


- K-35-11

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-16](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-16-Prepare-supplier-typedata)  | Prepare supplier typedata  
2  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag


- K-35-12

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag


------------------------------------------------------------------------
![](https://i.imgur.com/gSTLp3X.png)
- K-35-13

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-01](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-01-Prepare-appellation-data)   | Prepare appellation data
2  | [URI-O-03](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-03-Prepare-country-data)       | Prepare country data
3  | [URI-O-04](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-04-Prepare-state-data)         | Prepare state data
4  | [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)         | Prepare login data
5  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag


------------------------------------------------------------------------
![](https://i.imgur.com/BC2tv5q.png)
- K-35-14

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag


------------------------------------------------------------------------
![](https://i.imgur.com/BESapPB.png)
- K-35-15
無

- K-35-16

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)               | add business
2  | [URI-O-06](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-06-file-upload)                | file upload
3  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag


------------------------------------------------------------------------
![](https://i.imgur.com/4ThY3GX.png)
- 參考首頁 Footer


#### 註冊
登入與註冊差別在於 Contact Information 顯示不同，其餘區塊皆同

![](https://i.imgur.com/cW5vqzf.png)
- K-35-17

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-01](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-01-Prepare-appellation-data)   | Prepare appellation data
2  | [URI-O-03](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-03-Prepare-country-data)       | Prepare country data
3  | [URI-O-04](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-04-Prepare-state-data)         | Prepare state data
4  | [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)         | Prepare login data
5  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag
6  | [URI-O-07](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-07-Prepare-password-rule-data) | Prepare password rule data
7  | [URI-O-08](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-08-Check-password-rule)        | Check password rule
8  | [URI-O-09](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-09-Check-email)                | Check email


#### 未登入
- 與登入、註冊差別在於無 Contact Information


------------------------------------------------------------------------
### 頁面欄位說明
- 登入
![](https://i.imgur.com/lsUMltQ.png)
![](https://i.imgur.com/ZScqZpo.png)
![](https://i.imgur.com/WmH2Pgt.png)
![](https://i.imgur.com/PoTAXG4.png)
![](https://i.imgur.com/ac5wavM.png)
![](https://i.imgur.com/1BAmgb6.png)


- 註冊
  - 以下只列出與登出差異部分

![](https://i.imgur.com/SarONzz.png)



#### 藍1
麵包屑
- 第一層，Home
  - 點選超連結至首頁: `{front url}`
  - 資料來源，多語標籤
    - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
    ```=
    home
    ```
- 第二層，Customized Sourcing Services
  - 超連結：無
  - 資料來源，多語標籤
    - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
    ```=
    customizedsourcing
    ```
- 第三層，Meet Suppliers In Taiwan
  - 超連結：無
  - 資料來源，多語標籤
    - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
    ```=
    meetsuppliersintaiwan
    ```

#### 藍2
頁籤(由左至右)
- Trade Inquiry
  - 超連結：`{front url}`/business/TradeInquiry
  - 資料來源，多語標籤
    - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
    ```=
    tradeinquiry
    ```
- Meet Suppliers Online
  - 超連結：`{front url}`/business/MeetSupplierOnline
  - 資料來源，多語標籤
    - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
    ```=
    meetsuppliersonline
    ```
- Meet Suppliers In Taiwan
  - 超連結：無
  - 資料來源，多語標籤
    - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
    ```=
    meetsuppliersintaiwan
    ```
- Offer to Sell
  - 超連結：`{front url}`/business/TradingPost
  - 資料來源，多語標籤
    - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
    ```=
    offertosell
    ```


#### 藍3
Make bookings to meet with suppliers in Taiwan. Click here to find out how.
- 資料來源
  - API： [URI-O-18](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-18-Prepare-Custom-Header-data) 
  ```=
  content
  ```


#### 藍4
Step 1 Fill in the form
- UI 邏輯: 下商機的頁面，文字需要 highlight
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  ez_step1 + fillintheform
  ```


#### 藍5
Step 2 Completion
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  ez_step2 + completion
  ```


#### 藍6
Product Name
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  多語：productionname
  ```


#### 藍7
Product Name - field
- UI 邏輯
  - require: Y
  - HTML field: text
    - maxlength: 80
    - DB: VARCHAR2(400)
- 資料來源，關鍵字
  - API： [URI-O-19](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-19-Search-Suggestions-data)
  ```=
  -- Array(Object)
  {
     "seq"           : <int>,
     "catalog6Id"    : <int>,
     "catalog6Name"  : <string>,
     "alias2Code"    : <string>,
     "alias4Code"    : <string>,
     "word"          : <string>, 
     "hasTopKeyword" : <boolean>
  }
  ```
  
  - 動態顯示下拉選單
    - 套件使用，jquery autocomplete
    - 若有產業別資料的 `catalog6Id > 0`，則需要改成 `word + " in " +  catalog6Name`，word 有關鍵字都要用粗體顯示。
    - 若有產業別和無產業別，中間需要用分隔線做區隔
    - 產業別資料最多 3 筆，其他用無產業別補齊，至多共 10 筆
  ![](https://i.imgur.com/HWivLlG.png)
  - 若動態顯示下拉選單有點選，會取代 藍18 選單的 4、6 碼產業別清單取代，並 highlight 各自的產業別，並將 藍17 產業別補上
    - 1) 查出 4 碼產業別清單
      - API: [URI-O-14](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-14-Prepare-catalog4-code-data)
      - https://tt-api.taiwantrade.com/taitracodes/42/6/{alias2Code}
      - EX: https://tt-api.taiwantrade.com/taitracodes/42/4/51
    - 2) 查出 6 碼產業別清單
      - API: [URI-O-15](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-15-Prepare-catalog6-code-data)
      - https://tt-api.taiwantrade.com/taitracodes/42/6/{alias2Code}/{alias4Code}
      - EX: https://tt-api.taiwantrade.com/taitracodes/42/6/51/5105
  
  ![](https://i.imgur.com/siaUCod.png)


- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  ```=
  subject
  ```


#### 藍8
Quantity
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  ez_quantity + ":"
  ```

#### 藍9
Quantity - field
- UI 邏輯
  - require: N
  - HTML field: number
    - 預設是 null。若有填寫，至少 1，至多 999999999
    - 整數
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: N
  - type: number(整數)
  ```=
  quantity
  ```


#### 藍10
『-』
- UI 邏輯: 
  - click，Quantity 數量會減 1，至少為 1

  
#### 藍11
『+』
- UI 邏輯: 
  - click，Quantity 數量會加 1，至多為 999999999


#### 藍12
數量單位下拉列表
- UI 邏輯:
  - require: N
  - HTML field: select
    - 預設是給第一個順位
- 資料來源
  - API: [URI-O-02](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-02-Prepare-quantity-unit-data)
  ```=
  -- Array(Object)
  label
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: N
  - type: number(整數)
  ```=
  quantity
  ```


#### 藍13
Estimated Purchase Amount USD
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  estimatedannualpurchases + ":"
  ```


#### 藍14
USD
- UI 邏輯: 寫死


#### 藍15
Estimated Purchase Amount USD - field
- UI 邏輯:
  - require: N
  - HTML field: number
    - 預設是 null。若有填寫，至少 0，至多 999999999
    - 整數、浮點數
    - 原規則小數點沒限制位數，全依照瀏覽器支援程度而定
      - 補：`input type="number"`  並非每一家瀏覽器都有實作，無實作會造成無法再欄位中輸入的動作，只能點選上下按鈕增加數字。(Safari 不支援)
- 新增商機
  - API： [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: N
  - type: number(整數、浮點數)
  ```=
  purchaseAmount
  ```


#### 藍16
Product Category
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  choosethecategoryitbelongsto
  ```


#### 藍17
Product Category(型錄產業別) - field
- UI 邏輯:
  - require: Y
  - HTML field: text
    - readonly
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  - 資料透過 藍18 取得，只取 6 碼的產業別id
  ```=
  catalogId
  ```


#### 藍18
Select a Catagory - button
- UI 邏輯:
  - HTML field: button
  - click
    - 若 藍17 已有資料，則會顯示 2、4、6 碼下拉選單
    - 若 藍17 無資料
      - 預設先帶出 2 碼的產業別清單。點選 2 碼帶出 4 碼，點選 4 碼帶出 6 碼，點選 6 碼 會把資料回寫至 藍17
  - 無套件，目前是套用設計師使用的雛形
  - 圖
  ![](https://i.imgur.com/r4D3gX2.png)

  ![](https://i.imgur.com/qxJh3RM.png)
- 資料來源
  - 2碼資料
    - [URI-O-13](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-13-Prepare-catalog2-code-data)
    - EX: https://tt-api.taiwantrade.com/taitracodes/41/2
    ```=
    -- Array(Object)
    trees.nodes
    ```
  - 4碼資料
    - [URI-O-14](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-14-Prepare-catalog4-code-data)
    - EX: https://tt-api.taiwantrade.com/taitracodes/41/4/51
    ```=
    -- Array(Object)
    trees.nodes
    ```
  - 6碼資料 
    - [URI-O-15](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-15-Prepare-catalog6-code-data)
    - EX: https://tt-api.taiwantrade.com/taitracodes/41/6/51/5105
    ```=
    -- Array(Object)
    trees.nodes
    ```


#### 藍19
Product Details
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  productdetails
  ```


#### 藍20
Insert a template
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  insertatemplate + ":"
  ```


#### 藍21
訊息範本
- 邏輯:
  - click，會重游標所在新增此範本內容
  - unclick，會移除掉最後一組此範本內容
- 資料來源
  - API： [URI-O-05](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-05-Prepare-template-data)
  ```=
  -- Array(Object)
  data
  ```


#### 藍22
Message - field
- 邏輯:
  - require: Y
  - HTML field: textarea
    - 至多 1500 個字，超過不能填
    - DB: CLOB
- 資料來源，預設值
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  businessmessagetextboxdefault
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  ```=
  message
  ```


#### 藍23
計算 Message 字數，0/1500
- UI 邏輯:
  - 0，是動態計算，以字數計算
  - 1500，是最大字數，寫死
  - 數字超過移除，不顯示


#### 藍24
上傳附件
- UI 邏輯:
  - require: N
  - HTML field: file
    - 使用套件: dropzone.js
    - 檔案數量: 0 ~ 3個
    - 檔案格式: htm, html, doc, docx, pdf, txt, jpg, gif, png, odt, ods
    - 檔案容量: 10 MB
    - click
      - 有 privew 檔案功能。若有圖檔要顯示圖
      - 滑鼠移標到檔案時，要顯示檔案名稱
      - 需要有移除檔案功能，右上角有個『x』可移除
      - ~~只有在 submit 送出時，才會上傳檔案至系統~~
      - 直接上傳，目前先放入暫存檔案
- 新增附件
  - API: [URI-O-06](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-06-file-upload)
  - require: N
  - type: uploadFile
  ```=
  message
  ```
- 登入後，取得附件資料
  - API: [URI-O-21](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-21-Get-file-data-by-id)
  - require: 看有檔案id，才處理

- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: N
  - type: string
  - 商機附件id(至多3個，用逗號區隔)，Ex: `1,2,3`
  ```=
  attachs
  ```


#### 藍25
Drop files here to upload
- UI 邏輯:
  - dropzone.js 預設文


#### 藍26
File formats
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  fileuploadlimit
  ```


#### 藍27
: htm, html, doc, docx, pdf, txt, jpg, gif, png, odt, ods. Max 3 files (10MB in total).
  - 『: htm, html, doc, docx, pdf, txt, jpg, gif, png, odt, ods.』，寫死
  - 『 (10MB in total).』
    - 資料來源
      - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
      ```=
      maxfileslimit
      ```


#### 藍28
Total size
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  totalsizet
  ```

  
#### 藍29
計算檔案大小
- 邏輯:
  - 預設 0
  - 以 MB 為單位計算


#### 藍30
Preferred Meeting Date
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  preferredmeetingdate
  ```


#### 藍31
Preferred Meeting Date 日期(起) - field
- UI 邏輯
  - require: Y
  - HTML field: date
    - fomat: YYYY/MM/DD
    - 日期最小是明天
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  - format: YYYYMMDD
  ```=
  meetingDateBegin
  ```


#### 藍32
Preferred Meeting Date 日期(迄) - field
- UI 邏輯
  - require: Y
  - HTML field: date
    - format: YYYY/MM/DD
    - 日期最小是明天，但需要大於等於 藍31
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  - - format: YYYYMMDD
  ```=
  meetingDateEnd
  ```

#### 藍33
Preferred Supplier Type
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  preferredsuppliertype
  ```


#### 藍34
Preferred Supplier Type - field
- UI 邏輯
  - require: Y
  - HTML field: checkbox(多選)
- 資料來源
  - API： [URI-O-16](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-16-Prepare-supplier-typedata)
  ```=
  -- Array(Object)
  data
  ```
- 新增附件
  - API: [URI-O-06](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-06-file-upload)
  - require: Y
  - type: string
  - 供應商類型(多筆id，用逗號區隔)，Ex: `1667,1668,1669,1670`
  ```=
  supplierTypes
  ```


#### 藍35
Expiry Date
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  expireddate
  ```


#### 藍36
Expiry Date - field
- UI 邏輯
  - require: Y
  - HTML field: date
    - format: YYYY/MM/DD
    - 日期最小是明天
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  - format: YYYYMMDD
  ```=
  expiryDate
  ```


#### 藍37
Contact Information
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  contactinformation
  ```


#### 藍38
View and Modify、Collapse
- UI 邏輯
  - HTML field: button
  - 只有登入時會顯示
  - 預設是合
  - 合，顯示 View and Modify
    - Full Name 下面那行都隱藏
  - 開，顯示 Collapse
- View and Modify
  - 資料來源，多語標籤
    - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
    ```=
    多語：viewandmodify
    ```
- Collapse
  - 資料來源，多語標籤
    - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
    ```=
    collapse
    ```


#### 藍39
Email
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  email
  ```


#### 藍40
登入者 email - field
- UI 邏輯:
  - require: Y
  - HTML field: text
    - 登入時，屬性為 readonly
    - 註冊時，需檢查是否已存在
    - DB: VARCHAR2(100 BYTE)
- 資料來源，登入
  - API: [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)
  ```=
  data.userEmail
  ```
- 註冊時，需檢查是否已存在
  - API: [URI-O-09](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-09-Check-email)
  - 且需要驗證是否為合法的 email
  ```=
  ok: code >= 0 
  error: code < 0
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  ```=
  quantity
  ```


#### 藍41
Full Name
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  fullname
  ```


#### 藍42
登入者稱謂 - field
- UI 邏輯
  - require: Y
  - HTML field: select
    - 下拉選單可選擇稱呼列表，如沒資料預設給下第一個順位
    - 登入時，會顯示此使用者的稱謂
- 資料來源，下拉選單
  - API： [URI-O-01](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-01-Prepare-appellation-data)
  ```=
  -- Array(Object)
  label
  ```
- 資料來源，登入
  - API: [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)
  - type: number
  - 用登入者稱謂id 比對下拉選單，有則選擇，無則給預設下拉選單第一個順位
  ```=
  data.userTitleCode
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  ```=
  userTitleCode
  ```


#### 藍43
登入者名稱
  - require: Y
  - HTML field: text
    - 登入時，會顯示此使用者名稱
    - DB: VARCHAR2(160 BYTE)
- 資料來源，登入
  - API: [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)
  - type: string
  ```=
  data.userName
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  ```=
  userName
  ```


#### 藍44
Company Name
- 資料來源
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  companyname
  ```


#### 藍45
Company Name - field
- UI 邏輯
  - require: Y
  - HTML field: text
    - 登入時，會顯示公司名稱
      - 若公司名稱是『individual buyer』，則藍34需打勾，且欄位會 readonly
    - DB: VARCHAR2(250 BYTE)
- 資料來源，登入
  - API: [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)
  - type: string
  ```=
  data.companyName
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  ```=
  companyName
  ```


#### 藍46
『I'm an individual buyer』- field
- UI 邏輯
  - require: Y
  - HTML type: checkbox(單選)
    - 預設是 unclick
    - click，則此藍33 的值會改成『individual buyer』，且欄位會 readonly
    - unclick，則此藍33 的值會清空，且移除 readonly


#### 藍47
I'm an individual buyer
- 資料來源
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  individualbuyer
  ```


#### 藍48
Country/Region
- 資料來源
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  countryregion
  ```


#### 藍49
Country/Region(公司所屬的國家) - field
- UI 邏輯
  - require: Y
  - HTML field: select
    - 下拉選單可選擇國家列表，如沒資料預設給第一個順位
      - 第一個選單是多語標籤 Select
      - 若有異動下拉選單，
        - (1) 連動 藍43 去撈取國家的州別清單資料
        - (2) 將國碼寫入 藍49、藍53
    - 登入會顯示此公司所屬的國家
- 移除 UI 邏輯
  - 若是 註冊會員時，點選『台灣』
    - 『submit』按鈕會 disabled，無法送出表單。只有非台灣的註冊會員可註冊並新增商機
    - 下方會多出文字訊息
    ![](https://i.imgur.com/lLIWKul.png)
      - For companies in Taiwan, please click here to register as member.
        - 資料來源，多語標籤
          - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
          ```=
          registerintaiwan
          ```
          
      - 請由此註冊成會員
        - 寫死
        - 點選會連結至 中文網註冊頁面(${中文網URL}/register/supplier)
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  ez_pleaseselect
  ```
- 資料來源，下拉選單
  - API： [URI-O-03](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-03-Prepare-country-data)
  ```=
  -- Array(Object)
  label
  ```
- 資料來源，登入
  - API: [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)
  - type: number
  - 用公司所屬的國家id 比對下拉選單，有則選擇，無則給預設下拉選單第一個順位
  ```=
  data.officeNationCode
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  ```=
  officeNationCode
  ```


#### 藍50
State/Province/City
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  stateprovincecity
  ```


#### <div style="color:red">藍51、藍53</div>
此二欄位是二擇一，必填


#### 藍51
State/Province/City(公司所屬的州別) - field
- UI 邏輯
  - require: Y
  - HTML field: select
    - 下拉選單可選擇此國家的州別列表，如沒資料預設給第一個順位
      - 第一個選單是多語標籤 Select
    - 登入會顯示此公司所屬的州別
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  ez_pleaseselect
  ```
- 資料來源，下拉選單
  - API： URI-054
  ```=
  -- Array(Object)
  label
  ```
- 資料來源，登入
  - API: [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)
  - type: number
  - 用公司所屬的州別id 比對下拉選單，有則選擇，無則給預設下拉選單第一個順位
  ```=
  data.officeStateCode
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  ```=
  officeStateCode
  ```


#### 藍52
Other State/Province/City
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  otherstateprovincecity
  ```


#### 藍53
Other State/Province/City(其他州別) - field
- UI 邏輯
  - require: Y
  - HTML field: text
    - DB: VARCHAR2(100 BYTE)
- 資料來源，登入
  - API: [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)
  - type: string
  ```=
  data.officeOtherState
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  ```=
  officeOtherState
  ```


#### 藍54
Company Address
- 資料來源，多語標籤
  - API： [URI-O-03](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-03-Prepare-country-data)
  ```=
  companyaddress
  ```


#### 藍55
Company Address(公司地址) - field
- UI 邏輯
  - require: Y
  - HTML field: text
    - 登入時，會顯示公司地址
    - DB: VARCHAR2(255 BYTE)
- 資料來源，登入
  - API: [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)
  - type: string
  ```=
  data.officeAddress
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  ```=
  officeAddredd
  ```


#### 藍56
Company Site
- 資料來源，多語標籤
  - API： [URI-O-03](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-03-Prepare-country-data)
  ```=
  companysite
  ```


#### 藍57
Company Site(公司網址) - field
- UI 邏輯
  - require: Y
  - HTML field: `url`
    - placeholder: `http://`
    - 登入時，會顯示公司網址
      - 若公司名稱是『Not Available』，則藍55 需打勾，且欄位會 readonly
    - DB: VARCHAR2(500 BYTE)
- 資料來源，登入
  - API: [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)
  - type: string
  ```=
  data.companyWebsite
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  - 需要驗證是否為合法的 url
    - `https://` 或 `http://` 開頭即可
    - jquery validator 會實作驗證 url rule，[參考](https://www.runoob.com/jquery/jquery-plugin-validate.html)
  ```=
  companyWebsite
  ```


#### 藍58
『Not Available』- field
- UI 邏輯
  - require: Y
  - HTML field: checkbox(單選)
    - 預設: unclick
    - click，則此藍54 的值會改成『Not Available』，且欄位會 readonly
    - unclick，則此藍54 的值會清空，且移除 readonly


#### 藍59
Not Available
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  notavailable
  ```


#### 藍60
Business Phone Number
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  tel1
  ```


#### 藍61
Business Phone Number(公司電話 - 國碼) - field
- UI 邏輯
  - require: N
  - HTML field: text
    - 登入時，會顯示公司電話 - 國碼
    - 至多 3 碼
    - DB: VARCHAR2(3 BYTE)
- 資料來源，登入
  - API: [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)
  - type: string
  ```=
  data.officeTelCountry
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: N
  - type: string
  - 需驗證字串為 0-9 的數字
  ```=
  officeTelCountryCode
  ```


#### 藍62
Business Phone Number(公司電話) - field
- UI 邏輯
  - require: N
  - HTML field: text
    - 登入時，會顯示公司電話
    - 至多 20 碼
    - DB: VARCHAR2(20 BYTE
- 資料來源，登入
  - API: [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)
  - type: string
  ```=
  data.officeTel
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: N
  - type: string
  - 需驗證字串為 0-9 的數字
  ```=
  officeTel
  ```


#### 藍63
Business Phone Number(公司電話 - 分機) - field
- UI 邏輯
  - require: N
  - HTML field: text
    - 登入時，會顯示公司電話 - 分機
    - 至多 10 碼
    - DB: VARCHAR2(10 BYTE)
- 資料來源，登入
  - API: [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)
  - type: string
  ```=
  data.officeTelExt
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: N
  - type: string
  - 需驗證字串為 0-9 的數字
  ```=
  officeTelExt
  ```


#### 藍64
Mobile Phone Number
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  mobilephone
  ```


#### 藍65
Mobile Phone Number(聯絡人手機 - 國碼) - field
- UI 邏輯
  - require: N
  - HTML field: text
    - 登入時，會顯示聯絡人手機 - 國碼
    - 至多 3 碼
    - DB: VARCHAR2(3 BYTE)
- 資料來源，登入
  - API: [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)
  - type: string
  ```=
  data.userMobileCountry
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: N
  - type: string
  - 需驗證字串為 0-9 的數字
  ```=
  mobileCountry
  ```


#### 藍66
Mobile Phone Number(聯絡人手機) - field
- UI 邏輯
  - require: N
  - HTML field: text
    - 登入時，會顯示聯絡人手機
    - DB: VARCHAR2(17 BYTE)
- 資料來源，登入
  - API: [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)
  - type: string
  ```=
  data.userMobile
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: N
  - type: string
  - 需驗證字串為 0-9 的數字
  ```=
  mobile
  ```


#### 藍67
Changes will be automatically saved to your profile.
- 只有登入時顯示
- 資料來源
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  changeswillbeautomaticallysaved
  ```


#### 藍68
Keywords of products you are looking for
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  keywordsofproducts
  ```


#### 藍69
商機 keyword
- UI 邏輯
  - require: N
  - 1) HTML field: display data tag(by 設計師)
    - placeholder: `new Keyword`
    - ui 效果是設計師實作
    - 可新增、移除
    - 可設定 0 ~ n 組
  - 2) HTML field: hidden
    - 多組用逗號區隔
    - DB: VARCHAR2(500 BYTE)，每一組為一筆record
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  - 多則用逗號區隔，EX: `car,house,water`
  ```=
  keywords
  ```


#### 藍70
This helps to more precisely match your inquiry with potential suppliers.Use "," or "enter" to separate multiple keywords.
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  thishelpstomorepreciselymatch + useorentertoseparatemultiplekeywords
  ```


#### 藍71
google recaptcha
- UI 邏輯
  - require: Y
  - 目前使用 V2
  - 需驗證合法性
  - google key 放在 front(server)


#### 藍72
Submit
- UI 邏輯
  - HTML field: button
    - 若未登入前，click 會顯示燈箱
    ![](https://i.imgur.com/XRwval7.png)
      - click 『Sign In』，會連結至 SSO 登入網站，登入後會導回此頁面
      - click 『Create an account free』，會關閉燈箱，並顯示 Contact Information  區塊
    - 登入後，可送出表單
    - 表單驗證規則
      - 必填欄位驗證
      - google recaptcha 驗證
      - 會先送出上傳檔案，回傳拿到上傳檔案id 後，才新增商機
      - 商機新增成功後，會連結至商機成功頁面
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  ok
  ```
- 新增附件
  - API: [URI-O-06](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-06-file-upload)
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)


#### 藍101
Your email will be your Taiwantrade.com login.
- 只有註冊時顯示
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  suggestenterofficeemail
  ```


#### 藍102
Create Password
- 只有註冊時顯示
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  createapassword
  ```


#### 藍103
Password - field
- 只有註冊時顯示
- UI 邏輯
  - require: Y
  - HTML field: password
    - 需檢查是否為合法的密碼
    - DB: VARCHAR2(64 BYTE)
- 驗證密碼規則
  - API: [URI-O-08](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-08-Check-password-rule)
  ```=
  ok: code >= 0 
  error: code < 0
  ```
- 新增商機
  - API: [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business)
  - require: Y
  - type: string
  ```=
  userPassword
  ```


#### 藍104
密碼規則提示文字
- 只有註冊時顯示
- 資料來源，密碼規則
  - API: [URI-O-07](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-07-Prepare-password-rule-data)
  - type: string


#### 藍105
Confirm Password
- 只有註冊時顯示
- 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  confirmpassword
  ```


#### 藍106
Confirm Password - field
- 只有註冊時顯示
- UI 邏輯:
  - require: Y
  - HTML field: password
    - 需檢查字串與 藍103 相同
  

#### 藍107
『I accept the Taiwantrade.com Membership Agreement, Terms of Use and Privacy Policy』(是否同意 TT Policy) - field
- 只有註冊時顯示
- UI 邏輯:
  - require: Y
  - HTML field: checkbox(單選)
    - 預設 unclick
    - 必須勾選才合法


#### 藍108
I accept the Taiwantrade.com Membership Agreement, Terms of Use and Privacy Policy
- 只有註冊時顯示

- 『I accept the』
  - 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  iacceptthe
  ```
- 『Taiwantrade.com Membership Agreement』
  - click，需連結至 https://www.taiwantrade.com/mp/help#2
  - 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  taiwantradecommembershipagreement
  ```
- 『,』
  - 寫死逗號
- 『TTerms of Use』
  - click，需連結至 https://www.taiwantrade.com/mp/help#3
  - 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  termsofuse
  ```
- 『and』
  - 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  and
  ```
- 『Privacy Policy』
  - click，需連結至 https://www.taiwantrade.com/mp/help#4
  - 資料來源，多語標籤
  - API： [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag)
  ```=
  privacypolicy
  ```


------------------------------------------------------------------------
### 頁面邏輯說明
- 同 [Inquiry Product](https://hackmd.io/FDa_t2QwRxKoBimH6mW4qQ?view#%E9%A0%81%E9%9D%A2%E9%82%8F%E8%BC%AF%E8%AA%AA%E6%98%8E)


------------------------------------------------------------------------
### 頁面輸出
- init

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-18](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-18-Prepare-Custom-Header-data) | Prepare Custom Header data


- 登入

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-01](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-01-Prepare-appellation-data)   | Prepare appellation data
2  | [URI-O-02](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-02-Prepare-quantity-unit-data) | Prepare quantity unit data
3  | [URI-O-03](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-03-Prepare-country-data)       | Prepare country data
4  | [URI-O-05](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-05-Prepare-template-data)      | Prepare template data
5  | [URI-O-10](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-10-Prepare-login-data)         | Prepare login data
6  | [URI-O-16](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-16-Prepare-supplier-typedata)  | Prepare supplier typedata
7  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag
8  | [URI-O-21](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-21-Get-file-data-by-id)         | Get file data by id


------------------------------------------------------------------------
- 註冊

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-01](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-01-Prepare-appellation-data)   | Prepare appellation data
2  | [URI-O-02](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-02-Prepare-quantity-unit-data) | Prepare quantity unit data
3  | [URI-O-03](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-03-Prepare-country-data)       | Prepare country data
4  | [URI-O-05](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-05-Prepare-template-data)      | Prepare template data
5  | [URI-O-07](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-07-Prepare-password-rule-data) | Prepare password rule data
6  | [URI-O-16](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-16-Prepare-supplier-typedata)  | Prepare supplier typedata
7  | [URI-O-17](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-17-Prepare-language-label-tag) | Prepare language label tag
8  | [URI-O-21](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-21-Get-file-data-by-id)         | Get file data by id



------------------------------------------------------------------------
- 州別列表

No | API                                                                                   | Desc
---|---------------------------------------------------------------------------------------|-------------------
1  | [URI-O-04](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-04-Prepare-state-data) | Prepare state data


------------------------------------------------------------------------
- email驗證

No | API                                                                            | Desc
---|--------------------------------------------------------------------------------|------------
1  | [URI-O-09](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-09-Check-email) | Check email


------------------------------------------------------------------------
- 密碼驗證

No | API                                                                                    | Desc
---|----------------------------------------------------------------------------------------|--------------------
1  | [URI-O-08](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-08-Check-password-rule) | Check password rule


------------------------------------------------------------------------
- 2碼產業別

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-13](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-13-Prepare-catalog2-code-data) | Prepare catalog2 code data

------------------------------------------------------------------------
- 4碼產業別

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-14](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-14-Prepare-catalog4-code-data) | Prepare catalog2 code data


------------------------------------------------------------------------
- 6碼產業別

No | API                                                                                           | Desc
---|-----------------------------------------------------------------------------------------------|---------------------------
1  | [URI-O-15](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-15-Prepare-catalog6-code-data) | Prepare catalog2 code data


------------------------------------------------------------------------
- product name > 關鍵字收尋

No | API                                                                                        | Desc
---|--------------------------------------------------------------------------------------------|------------------------
1  | [URI-O-19](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-19-Search-Suggestions-data) | Search Suggestions data


------------------------------------------------------------------------
- 放大鏡 > 6碼產業別
No | API                                                                                                   | Desc
---|-------------------------------------------------------------------------------------------------------|-----------------------------------
1  | [URI-O-20](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-20-Serach-Catalog-or-Suggestions-data) | Serach Catalog or Suggestions data


------------------------------------------------------------------------
- file upload

No | API                                                                            | Desc
---|--------------------------------------------------------------------------------|------------
1  | [URI-O-06](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-06-file-upload) | file upload


------------------------------------------------------------------------
- add business

No | API                                                                             | Desc
---|---------------------------------------------------------------------------------|-------------
1  | [URI-O-11](https://hackmd.io/cCmvIP36SCyTsLbZCPrbhg?view#URI-O-11-add-business) | add business

