From 34e79ef18fc6260a4f255e6087b011d8ff741a43 Mon Sep 17 00:00:00 2001
From: Trygve Laugstøl <trygvis@inamo.no>
Date: Fri, 2 Aug 2019 15:09:07 +0200
Subject: odoo: wip

---
 src/ee/odoo/__init__.py | 113 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 113 insertions(+)
 create mode 100644 src/ee/odoo/__init__.py

(limited to 'src/ee/odoo')

diff --git a/src/ee/odoo/__init__.py b/src/ee/odoo/__init__.py
new file mode 100644
index 0000000..af872b4
--- /dev/null
+++ b/src/ee/odoo/__init__.py
@@ -0,0 +1,113 @@
+import csv
+from pathlib import Path
+
+from ee.logging import log
+from ee.project import Project
+
+
+def restructure(in_path: Path, in_format, out_path: Path, out_format):
+    log.info("Creating {}".format(out_path))
+    if in_format == "digikey-order":
+        with in_path.open("r") as f:
+            data = list(csv.reader(f))
+
+        header = {k: index for index, k in enumerate(data[0])}
+        description_i = header["Description"]
+        pn_i = header["Part Number"]
+        mpn_i = header["Manufacturer Part Number"]
+        unit_price_i = header["Unit Price"]
+        extended_price_i = header["Extended Price"]
+
+        # If you search in Odoo for Digikey this is the correct name.
+        digikey_name = "Digi-Key Electronics"
+
+        rows = ([row[description_i], row[pn_i], row[mpn_i], row[unit_price_i], row[extended_price_i]]
+                for row in data[1:-1])
+        with out_path.open("w") as f:
+            out = csv.writer(f)
+            header = ["External ID",
+                      "Can be Purchased",
+                      "Product Type",
+                      # "Description",  # Internal notes
+                      "Name",
+                      "Internal Reference",
+                      "Cost",
+                      "Product Category",
+                      # "Vendors / External ID",
+                      # "seller_ids/name",
+                      # "Vendors / Vendor Product Name",
+                      # "Vendors / Vendor Product Code",
+                      # "Vendors / Price",
+                      ]
+            out.writerow(header)
+            for description, pn, mpn, price, e_price in rows:
+                external_id = "ee/mpn:" + mpn
+                vendor_external_id = "ee/spn:{}".format(pn)
+
+                row = [external_id, "yes", "Storable Product", description, mpn, price, "All / Electronics"]
+                # row.extend([vendor_external_id, digikey_name, description, pn, price])
+                out.writerow(row)
+                # break
+
+
+def init_project(project: Project):
+    odoo = project.get_or_create_section("odoo")
+    odoo["enabled"] = "yes"
+
+
+def generate_ninja(project: Project):
+    head = """
+rule odoo-restructure
+    command = ee odoo-restructure --in $in --in-format $in_format --out $out --out-format $out_format
+    """.strip()
+    orders_dir = project.orders_dir
+
+    files = []
+    targets = []
+    # print("orders_dir={}".format(orders_dir))
+    if orders_dir.is_dir():
+        for file in sorted(orders_dir.iterdir()):
+            if file.name.endswith(".csv"):
+                with file.open("r") as f:
+                    data = list(csv.reader(f))
+
+                if len(data) < 1:
+                    continue
+
+                in_format = _classify(data)
+
+                if in_format is None:
+                    continue
+
+                out_format = "product-list"
+
+                target = "$public_dir/odoo/{}/{}".format(out_format, file.name)
+                files.append("build {}: odoo-restructure $orders_dir/{}\n"
+                             "    in_format = {}\n"
+                             "    out_format = {}\n".format(target, file.name, in_format, out_format))
+
+                # This was an attempt to get ninja to run "ee ninja" when the input csv files went away.
+                # files.append("build $orders_dir/{}: ee-ninja".format(file.name))
+
+                targets.append(target)
+
+    lines = []
+    lines.extend(head.splitlines())
+    lines.append("")
+    lines.extend(files)
+    lines.append("build odoo-restructure: phony $orders_dir ee.ninja $\n" + " $\n".join(["    " + t for t in targets]))
+    lines.append("default odoo-restructure")
+    return "\n".join(lines)
+
+
+def _classify(data):
+    header = data[0]
+    if len(header) < 5:
+        return None
+
+    last_row = data[-1]
+    print(last_row)
+    print(last_row[-2])
+
+    if last_row[-2] == "Subtotal":
+        return "digikey-order"
-- 
cgit v1.2.3