summaryrefslogtreecommitdiff
path: root/indoteknik_api/controllers/api_v1
diff options
context:
space:
mode:
authorit-fixcomart <it@fixcomart.co.id>2025-01-21 13:43:29 +0700
committerit-fixcomart <it@fixcomart.co.id>2025-01-21 13:43:29 +0700
commitff20b62d6932c6be4ffb56f63f3c05be3aa72c06 (patch)
treeb9bfad89162ade294b904275feba80d74d9a7b26 /indoteknik_api/controllers/api_v1
parentc7f6d959e0e7a2e8adc45cff515f2b5666f3e732 (diff)
<iman> update merchant
Diffstat (limited to 'indoteknik_api/controllers/api_v1')
-rw-r--r--indoteknik_api/controllers/api_v1/lead.py50
1 files changed, 33 insertions, 17 deletions
diff --git a/indoteknik_api/controllers/api_v1/lead.py b/indoteknik_api/controllers/api_v1/lead.py
index 67856dad..7ff8a8e9 100644
--- a/indoteknik_api/controllers/api_v1/lead.py
+++ b/indoteknik_api/controllers/api_v1/lead.py
@@ -34,7 +34,7 @@ class Lead(controller.Controller):
@http.route('/api/v1/merchant/<id>', auth='public', methods=['POST', 'OPTIONS'], csrf=False)
@controller.Controller.must_authorized()
def create_merchant(self, **kw):
- merchant_request = True if kw.get('merchantRequest') == 'true' else False
+ merchant_request = True if kw.get('merchant_request') == 'true' else False
params = self.get_request_params(kw, {
# informasi perusahaan
"name_merchant": [],
@@ -42,10 +42,10 @@ class Lead(controller.Controller):
"pic_merchant": [],
"pic_position": [],
"address": [],
- "state": [],
- "city": [],
- "district": [],
- "subDistrict": [],
+ "state": ['number'],
+ "city": ['number'],
+ "district": ['number'],
+ "subDistrict": ['number'],
"zip": [],
"bank_name": [],
"rekening_name": [],
@@ -71,11 +71,10 @@ class Lead(controller.Controller):
# Syarat Perdagangan
"is_kembali_barang": [],
- "sertifikat_produk": [],
- "custom_sertifikat_produk": [],
"tempo_garansi": [],
"is_order_quantity": [],
"explain_garansi": [],
+ "custom_sertifikat_produk": [],
# # dokumen
#
@@ -102,7 +101,7 @@ class Lead(controller.Controller):
if params['value']['is_kembali_barang'] == 'ya':
params['value']['is_kembali_barang'] = kw.get('textReturn')
else:
- params['value']['is_kembali_barang'] = 'Tidak dapat return'
+ params['value']['is_kembali_barang'] = 'Tidak dapat direturn'
if kw.get('tenggat_waktu'):
if kw.get('tenggat_waktu') != 'custom':
@@ -116,20 +115,37 @@ class Lead(controller.Controller):
else:
params['value']['is_order_quantity'] = 'Tidak ada minimum order quantity'
- dokumen_kirim = [
- 'TKDN',
- 'SNI',
- 'Surat Terima Barang (STB)',
- 'Lembar Penerimaan Barang (LPB)'
- ]
-
- filtered_params = {key: value for key, value in params['value'].items() if value}
+ filtered_params = {key: value for key, value in params['value'].items() if kw.get(key) is not None}
form_merchant = request.env['user.form.merchant'].search([('partner_id', '=', main_partner.id)], limit=1)
+ lead = []
if form_merchant:
form_merchant.write(filtered_params)
else:
lead = request.env['user.form.merchant'].create(filtered_params)
lead.partner_id = main_partner.id
+
+ sertifikat = [
+ 'TKDN',
+ 'SNI',
+ 'K3L',
+ ]
+ sertifikat_ids = kw.get('sertifikat_produk')
+ sertifikat_input = kw.get('custom_sertifikat_produk')
+ dokumen_sertifikat = []
+
+ if sertifikat_ids:
+ dokumen_kirim_ids = list(map(int, sertifikat_ids.split(',')))
+ dokumen_sertifikat = [sertifikat[i] for i in dokumen_kirim_ids if 0 <= i < len(sertifikat)]
+ if sertifikat_input != 'false' and sertifikat_input:
+ input_items = [item.strip() for item in sertifikat_input.split(',')]
+ dokumen_sertifikat.extend(item for item in input_items if item and item not in dokumen_sertifikat)
+ form_merchant.sertifikat_produk = sertifikat_input
+ else:
+ # Jika sertifikat_input kosong, hapus elemen custom (yang tidak ada di daftar `sertifikat`)
+ dokumen_sertifikat = [item for item in dokumen_sertifikat if item in sertifikat]
+ if dokumen_sertifikat:
+ form_merchant.sertifikat_produk = ', '.join(dokumen_sertifikat)
+
category_ids = ''
category_produk_ids = kw.get('categoryProduk', False)
if category_produk_ids:
@@ -183,7 +199,7 @@ class Lead(controller.Controller):
if merchant_request:
user_merchant_request = request.env['user.merchant.request'].create({
'user_id': partner.id,
- 'merchant_id': lead.id,
+ 'merchant_id': form_merchant.id,
'user_company_id': main_partner.id
})