import __vite__cjsImport0_lodash from "/node_modules/.vite/deps/lodash.js?v=0e19d92d"; const set = __vite__cjsImport0_lodash["set"];
import loading from "/src/components/Provider/Loading.tsx";
import { message } from "/node_modules/.vite/deps/ant-design-vue.js?v=f7d2fa05";
import __vite__cjsImport3_aliOss from "/node_modules/.vite/deps/ali-oss.js?v=a26e0da8"; const OSS = __vite__cjsImport3_aliOss.__esModule ? __vite__cjsImport3_aliOss.default : __vite__cjsImport3_aliOss;
export class UploadController {
  request;
  blobURLMaps = /* @__PURE__ */ new Map();
  constructor(request) {
    this.request = request;
  }
  getBlobURLName(url) {
    return this.blobURLMaps.get(url)?.name;
  }
  createObjectURL(obj) {
    const url = URL.createObjectURL(obj);
    this.blobURLMaps.set(url, obj);
    return url;
  }
  revokeObjectURL(url) {
    URL.revokeObjectURL(url);
    this.blobURLMaps.delete(url);
  }
  selectFile(opts) {
    return new Promise((resolve, reject) => {
      const fileInput = document.createElement("input");
      fileInput.type = "file";
      fileInput.accept = opts?.accept || "images/*";
      fileInput.multiple = opts?.multiple || false;
      fileInput.onchange = function() {
        resolve([...this.files]);
      };
      window.addEventListener(
        "focus",
        () => {
          setTimeout(() => {
            reject(console.warn("select file cancel"));
          }, 300);
        },
        { once: true }
      );
      fileInput.click();
    });
  }
  async uploadBlobImages(data) {
    const todoMap = /* @__PURE__ */ new Map();
    addBlobToList(data);
    const todoList = todoMap.entries();
    let err = "";
    for (const item of todoList) {
      const [blobUrl, path] = item;
      const file = this.blobURLMaps.get(blobUrl);
      if (file) {
        const paths = path.split(",");
        loading.show("上传中");
        const ret = await this.uploadFiles(file);
        if (ret.url) {
          paths.forEach((p) => {
            set(data, p, ret.url);
          });
          this.revokeObjectURL(blobUrl);
        } else {
          err = ret.error || `上传文件失败[${path}]`;
          break;
        }
      } else {
        err = `上传文件为空[${path}]`;
      }
    }
    loading.hidden();
    if (err) {
      message.error(err);
      throw err;
    }
    function addBlobToList(data2, path = "") {
      if (data2 instanceof Object) {
        if (data2 instanceof Array) {
          data2.forEach((item, i) => {
            addBlobToList(item, path ? path + "." + i : i.toString());
          });
        } else {
          Object.entries(data2).forEach(([key, value]) => {
            addBlobToList(value, path ? path + "." + key : key);
          });
        }
      }
      if (typeof data2 === "string" && /^blob:/.test(data2)) {
        if (todoMap.has(data2)) {
          path = todoMap.get(data2) + "," + path;
        }
        todoMap.set(data2, path);
      }
    }
  }
  async getPolicy() {
    try {
      const res = await this.request("/upload/policy", {
        method: "GET"
      });
      console.log(res);
      if (res.errorNo != 200) {
        return { error: "获取上传签名失败!" };
      }
      const policy = res.result.body.Credentials;
      return policy;
    } catch (e) {
      return { error: "获取上传签名失败!" };
    }
  }
  async uploadFiles(file, path = "/images/") {
    const res = await this.getPolicy();
    if (res.error) {
      return res.error;
    }
    const ext = file.name.split(".");
    if (ext.length === 1)
      return { error: "上传失败!" };
    const fileExt = ext[ext.length - 1].toLowerCase();
    const fileName = this.randomName(12) + "." + fileExt;
    const client = new OSS({
      region: "oss-cn-chengdu",
      accessKeyId: res.AccessKeyId,
      accessKeySecret: res.AccessKeySecret,
      // 从STS服务获取的安全令牌(SecurityToken)。
      stsToken: res.SecurityToken,
      bucket: "baishuihu"
    });
    try {
      const options = {
        timeout: 6e5
      };
      const result = await client.put(path + fileName, file, options);
      return { url: result.url };
    } catch (e) {
      console.log(e);
      return { error: "上传失败!" };
    }
  }
  // async uploadFile(file: File): Promise<{ url?: string; error?: string }> {
  //   const fromData = new FormData();
  //   fromData.append("file", file);
  //   try {
  //     const ret = await this.request("/upload/file", {
  //       method: "POST",
  //       data: fromData,
  //       headers: {
  //         "Content-Type": "multipart/form-data",
  //       },
  //     });
  //     if (ret.errorNo != 200) {
  //       return { error: "上传失败!" };
  //     }
  //     const url = ret.result.url;
  //     return { url };
  //   } catch (e) {
  //     return { error: "上传失败!" };
  //   }
  // }
  getFileExt(file) {
    let ext = "unkown";
    if (file) {
      const exp = /^.+\.(.+)$/;
      if (file.name && exp.test(file.name)) {
        ext = exp.exec(file.name)[1];
      } else if (file.type) {
        ext = file.type.split("/").pop();
      }
      return ext.toLowerCase();
    } else {
      return ext;
    }
  }
  randomName(length) {
    const data = [
      "0",
      "1",
      "2",
      "3",
      "4",
      "5",
      "6",
      "7",
      "8",
      "9",
      "A",
      "B",
      "C",
      "D",
      "E",
      "F",
      "G",
      "H",
      "I",
      "J",
      "K",
      "L",
      "M",
      "N",
      "O",
      "P",
      "Q",
      "R",
      "S",
      "T",
      "U",
      "V",
      "W",
      "X",
      "Y",
      "Z",
      "a",
      "b",
      "c",
      "d",
      "e",
      "f",
      "g",
      "h",
      "i",
      "j",
      "k",
      "l",
      "m",
      "n",
      "o",
      "p",
      "q",
      "r",
      "s",
      "t",
      "u",
      "v",
      "w",
      "x",
      "y",
      "z"
    ];
    let nums = "";
    for (let i = 0; i < length; i++) {
      const r = parseInt(Math.random() * 61 + "");
      nums += data[r];
    }
    return nums;
  }
}

//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["UploadController.ts"],"sourcesContent":["import { set } from \"lodash\";\r\nimport loading from \"@/components/Provider/Loading\";\r\nimport { message } from \"ant-design-vue\";\r\nimport OSS from \"ali-oss\";\r\n\r\nexport class UploadController {\r\n  request: any;\r\n  blobURLMaps = new Map<string, any>();\r\n  constructor(request: any) {\r\n    this.request = request;\r\n  }\r\n  getBlobURLName(url: string) {\r\n    return this.blobURLMaps.get(url)?.name;\r\n  }\r\n  createObjectURL(obj: Blob): string {\r\n    const url = URL.createObjectURL(obj);\r\n    this.blobURLMaps.set(url, obj);\r\n    return url;\r\n  }\r\n  revokeObjectURL(url: string) {\r\n    URL.revokeObjectURL(url);\r\n    this.blobURLMaps.delete(url);\r\n  }\r\n  selectFile(opts?: { accept?: string; multiple?: boolean }): Promise<File[]> {\r\n    return new Promise((resolve, reject) => {\r\n      const fileInput = document.createElement(\"input\");\r\n      fileInput.type = \"file\";\r\n      fileInput.accept = opts?.accept || \"images/*\";\r\n      fileInput.multiple = opts?.multiple || false;\r\n\r\n      fileInput.onchange = function (this: any) {\r\n        resolve([...this.files]);\r\n      };\r\n\r\n      window.addEventListener(\r\n        \"focus\",\r\n        () => {\r\n          setTimeout(() => {\r\n            reject(console.warn(\"select file cancel\"));\r\n          }, 300);\r\n        },\r\n        { once: true }\r\n      );\r\n\r\n      fileInput.click();\r\n    });\r\n  }\r\n  async uploadBlobImages(data: object) {\r\n    const todoMap = new Map<string, string>();\r\n    addBlobToList(data);\r\n    const todoList = todoMap.entries();\r\n\r\n    let err = \"\";\r\n\r\n    for (const item of todoList) {\r\n      const [blobUrl, path] = item;\r\n      const file = this.blobURLMaps.get(blobUrl);\r\n      if (file) {\r\n        const paths = path.split(\",\");\r\n        loading.show(\"上传中\");\r\n        const ret = await this.uploadFiles(file);\r\n        if (ret.url) {\r\n          paths.forEach((p) => {\r\n            set(data, p, ret.url);\r\n          });\r\n          this.revokeObjectURL(blobUrl);\r\n        } else {\r\n          err = ret.error || `上传文件失败[${path}]`;\r\n          break;\r\n        }\r\n      } else {\r\n        err = `上传文件为空[${path}]`;\r\n      }\r\n    }\r\n    loading.hidden();\r\n    if (err) {\r\n      message.error(err);\r\n      throw err;\r\n    }\r\n    function addBlobToList(data: any, path = \"\") {\r\n      if (data instanceof Object) {\r\n        if (data instanceof Array) {\r\n          data.forEach((item, i) => {\r\n            addBlobToList(item, path ? path + \".\" + i : i.toString());\r\n          });\r\n        } else {\r\n          Object.entries(data).forEach(([key, value]) => {\r\n            addBlobToList(value, path ? path + \".\" + key : key);\r\n          });\r\n        }\r\n      }\r\n      if (typeof data === \"string\" && /^blob:/.test(data)) {\r\n        if (todoMap.has(data)) {\r\n          path = todoMap.get(data) + \",\" + path;\r\n        }\r\n        todoMap.set(data, path);\r\n      }\r\n    }\r\n  }\r\n  async getPolicy() {\r\n    try {\r\n      const res = await this.request(\"/upload/policy\", {\r\n        method: \"GET\",\r\n      });\r\n      console.log(res);\r\n      if (res.errorNo != 200) {\r\n        return { error: \"获取上传签名失败!\" };\r\n      }\r\n      const policy = res.result.body.Credentials;\r\n      return policy;\r\n    } catch (e) {\r\n      return { error: \"获取上传签名失败!\" };\r\n    }\r\n  }\r\n  async uploadFiles(\r\n    file: File,\r\n    path: string = \"/images/\"\r\n  ): Promise<{ url?: string; error?: string }> {\r\n    const res = await this.getPolicy();\r\n    if (res.error) {\r\n      return res.error;\r\n    }\r\n    const ext = file.name.split(\".\");\r\n    if (ext.length === 1) return { error: \"上传失败!\" };\r\n    const fileExt = ext[ext.length - 1].toLowerCase();\r\n    const fileName = this.randomName(12) + \".\" + fileExt;\r\n    const client = new OSS({\r\n      region: \"oss-cn-chengdu\",\r\n      accessKeyId: res.AccessKeyId,\r\n      accessKeySecret: res.AccessKeySecret,\r\n      // 从STS服务获取的安全令牌（SecurityToken）。\r\n      stsToken: res.SecurityToken,\r\n      bucket: \"baishuihu\",\r\n    });\r\n    try {\r\n      const options = {\r\n        timeout: 600000,\r\n      };\r\n      const result = await client.put(path + fileName, file, options);\r\n      return { url: result.url };\r\n    } catch (e) {\r\n      console.log(e);\r\n      return { error: \"上传失败!\" };\r\n    }\r\n  }\r\n  // async uploadFile(file: File): Promise<{ url?: string; error?: string }> {\r\n  //   const fromData = new FormData();\r\n  //   fromData.append(\"file\", file);\r\n  //   try {\r\n  //     const ret = await this.request(\"/upload/file\", {\r\n  //       method: \"POST\",\r\n  //       data: fromData,\r\n  //       headers: {\r\n  //         \"Content-Type\": \"multipart/form-data\",\r\n  //       },\r\n  //     });\r\n  //     if (ret.errorNo != 200) {\r\n  //       return { error: \"上传失败!\" };\r\n  //     }\r\n  //     const url = ret.result.url;\r\n  //     return { url };\r\n  //   } catch (e) {\r\n  //     return { error: \"上传失败!\" };\r\n  //   }\r\n  // }\r\n  getFileExt(file: File) {\r\n    let ext: any = \"unkown\";\r\n    if (file) {\r\n      const exp = /^.+\\.(.+)$/;\r\n      if (file.name && exp.test(file.name)) {\r\n        ext = (exp.exec(file.name) as any)[1];\r\n      } else if (file.type) {\r\n        ext = file.type.split(\"/\").pop();\r\n      }\r\n      return ext.toLowerCase();\r\n    } else {\r\n      return ext;\r\n    }\r\n  }\r\n\r\n  randomName(length: number) {\r\n    const data = [\r\n      \"0\",\r\n      \"1\",\r\n      \"2\",\r\n      \"3\",\r\n      \"4\",\r\n      \"5\",\r\n      \"6\",\r\n      \"7\",\r\n      \"8\",\r\n      \"9\",\r\n      \"A\",\r\n      \"B\",\r\n      \"C\",\r\n      \"D\",\r\n      \"E\",\r\n      \"F\",\r\n      \"G\",\r\n      \"H\",\r\n      \"I\",\r\n      \"J\",\r\n      \"K\",\r\n      \"L\",\r\n      \"M\",\r\n      \"N\",\r\n      \"O\",\r\n      \"P\",\r\n      \"Q\",\r\n      \"R\",\r\n      \"S\",\r\n      \"T\",\r\n      \"U\",\r\n      \"V\",\r\n      \"W\",\r\n      \"X\",\r\n      \"Y\",\r\n      \"Z\",\r\n      \"a\",\r\n      \"b\",\r\n      \"c\",\r\n      \"d\",\r\n      \"e\",\r\n      \"f\",\r\n      \"g\",\r\n      \"h\",\r\n      \"i\",\r\n      \"j\",\r\n      \"k\",\r\n      \"l\",\r\n      \"m\",\r\n      \"n\",\r\n      \"o\",\r\n      \"p\",\r\n      \"q\",\r\n      \"r\",\r\n      \"s\",\r\n      \"t\",\r\n      \"u\",\r\n      \"v\",\r\n      \"w\",\r\n      \"x\",\r\n      \"y\",\r\n      \"z\",\r\n    ];\r\n    let nums = \"\";\r\n    for (let i = 0; i < length; i++) {\r\n      const r = parseInt(Math.random() * 61 + \"\");\r\n      nums += data[r];\r\n    }\r\n    return nums;\r\n  }\r\n}\r\n"],"mappings":"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","names":["data"]}