@dignite-ng/expand.file-explorer 3.0.0-rc.35 → 3.0.0-rc.37
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/file-modal/file-modal.component.mjs +8 -14
- package/esm2022/lib/components/file-picker/file-picker.component.mjs +3 -3
- package/fesm2022/dignite-ng-expand.file-explorer.mjs +12 -18
- package/fesm2022/dignite-ng-expand.file-explorer.mjs.map +1 -1
- package/lib/components/file-modal/file-modal.component.d.ts +2 -2
- package/package.json +1 -1
|
@@ -19,7 +19,6 @@ import * as i8 from "@ngx-validate/core";
|
|
|
19
19
|
import * as i9 from "../file-modal-tree/file-modal-tree.component";
|
|
20
20
|
import * as i10 from "../../previews/file-preview.component";
|
|
21
21
|
import * as i11 from "../../pipe/get-directory-name.pipe";
|
|
22
|
-
var that;
|
|
23
22
|
export class FileModalComponent {
|
|
24
23
|
constructor(_FileService, toaster, list, _FileApiService, restService, confirmation, _LocalizationService) {
|
|
25
24
|
this._FileService = _FileService;
|
|
@@ -89,7 +88,6 @@ export class FileModalComponent {
|
|
|
89
88
|
this.newEditRow = '';
|
|
90
89
|
/**是否正在加载 */
|
|
91
90
|
this.isloading = false;
|
|
92
|
-
that = this;
|
|
93
91
|
}
|
|
94
92
|
/**获取目录配置 */
|
|
95
93
|
getFilesConfiguration() {
|
|
@@ -110,8 +108,6 @@ export class FileModalComponent {
|
|
|
110
108
|
}
|
|
111
109
|
set multiple(v) {
|
|
112
110
|
this._multiple = v;
|
|
113
|
-
if (v) {
|
|
114
|
-
}
|
|
115
111
|
}
|
|
116
112
|
set limit(v) {
|
|
117
113
|
this.sizeLimit = v;
|
|
@@ -138,7 +134,7 @@ export class FileModalComponent {
|
|
|
138
134
|
}
|
|
139
135
|
/**模态框保存 */
|
|
140
136
|
modalSave() {
|
|
141
|
-
|
|
137
|
+
const selectedTablearr = this._FileApiService.deepClone(this.selectedTable);
|
|
142
138
|
this.selectFilefn.emit(selectedTablearr);
|
|
143
139
|
this.ModalVisibleChange(false);
|
|
144
140
|
}
|
|
@@ -167,7 +163,7 @@ export class FileModalComponent {
|
|
|
167
163
|
* @returns {Array} - 扁平化后的数组
|
|
168
164
|
*/
|
|
169
165
|
flattenNestedArray(nestedArray) {
|
|
170
|
-
|
|
166
|
+
const result = [];
|
|
171
167
|
function flatten(items) {
|
|
172
168
|
if (!items)
|
|
173
169
|
return;
|
|
@@ -191,7 +187,7 @@ export class FileModalComponent {
|
|
|
191
187
|
}
|
|
192
188
|
/**图片上传-获取文件信息改变 */
|
|
193
189
|
async getFileChange(event) {
|
|
194
|
-
|
|
190
|
+
const files = new Array(...event.target.files);
|
|
195
191
|
this.uploadPictureStatusList = files;
|
|
196
192
|
for (const file of files) {
|
|
197
193
|
if (file.size > this.sizeLimit) {
|
|
@@ -209,7 +205,7 @@ export class FileModalComponent {
|
|
|
209
205
|
}); // 等待每个文件上传完成
|
|
210
206
|
}
|
|
211
207
|
this.list.get();
|
|
212
|
-
|
|
208
|
+
const isSubmit = !this.uploadPictureStatusList.some(el => el.status == 2);
|
|
213
209
|
if (isSubmit) {
|
|
214
210
|
// this.toaster.success("上传完成");
|
|
215
211
|
setTimeout(() => {
|
|
@@ -227,7 +223,7 @@ export class FileModalComponent {
|
|
|
227
223
|
/**图片上传-递归按顺序上传 */
|
|
228
224
|
uploadingFile(file) {
|
|
229
225
|
return new Promise((resolve, rejects) => {
|
|
230
|
-
|
|
226
|
+
const formData = new FormData();
|
|
231
227
|
formData.append('file', file, file.name);
|
|
232
228
|
this.createFile({
|
|
233
229
|
file: formData,
|
|
@@ -277,7 +273,7 @@ export class FileModalComponent {
|
|
|
277
273
|
})
|
|
278
274
|
.subscribe(async (status) => {
|
|
279
275
|
if (status == 'confirm') {
|
|
280
|
-
|
|
276
|
+
const selectedTable = this.selectedTable;
|
|
281
277
|
try {
|
|
282
278
|
const result = await this.batchDeleteItems(selectedTable);
|
|
283
279
|
if (result.success) {
|
|
@@ -288,7 +284,6 @@ export class FileModalComponent {
|
|
|
288
284
|
else {
|
|
289
285
|
//删除失败的项
|
|
290
286
|
this.list.get();
|
|
291
|
-
// console.warn(result.message);
|
|
292
287
|
// 可以选择展示失败项或重试
|
|
293
288
|
}
|
|
294
289
|
}
|
|
@@ -316,7 +311,6 @@ export class FileModalComponent {
|
|
|
316
311
|
});
|
|
317
312
|
// 等待所有请求完成
|
|
318
313
|
const results = await Promise.allSettled(deletePromises);
|
|
319
|
-
console.log(results, 'resultsresultsresults');
|
|
320
314
|
// 收集失败的项
|
|
321
315
|
const failedItems = [];
|
|
322
316
|
results.forEach(result => {
|
|
@@ -397,7 +391,7 @@ export class FileModalComponent {
|
|
|
397
391
|
}
|
|
398
392
|
/**提交FileName编辑 */
|
|
399
393
|
onSubmitFileName(event) {
|
|
400
|
-
|
|
394
|
+
const input = this.FileNameForm.value;
|
|
401
395
|
if (!this.FileNameForm.valid)
|
|
402
396
|
return;
|
|
403
397
|
if (this.isloading)
|
|
@@ -476,4 +470,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
476
470
|
}], selectPickerFile: [{
|
|
477
471
|
type: Input
|
|
478
472
|
}] } });
|
|
479
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-modal.component.js","sourceRoot":"","sources":["../../../../../../../packages/file-explorer/src/lib/components/file-modal/file-modal.component.ts","../../../../../../../packages/file-explorer/src/lib/components/file-modal/file-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, SimpleChanges, inject } from '@angular/core';\nimport * as FileService from '../../proxy/dignite/file-explorer/files';\nimport { Confirmation, ConfirmationService, ToasterService } from '@abp/ng.theme.shared';\nimport {\n  PagedResultDto,\n  ABP,\n  ListService,\n  Rest,\n  RestService,\n  LocalizationService,\n  LIST_QUERY_DEBOUNCE_TIME,\n} from '@abp/ng.core';\nimport {\n  FileDescriptorDto,\n  FileDescriptorService,\n  GetFilesInput,\n} from '../../proxy/dignite/file-explorer/files';\nimport { FileApiService } from '../../services/file-api.service';\nimport { SelectionType } from '@swimlane/ngx-datatable';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport { finalize } from 'rxjs';\nvar that;\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'fe-file-modal',\n  templateUrl: './file-modal.component.html',\n  styleUrls: ['./file-modal.component.scss'],\n  providers: [\n    // [Required]\n    ListService,\n    // [Optional]\n    // Provide this token if you want a different debounce time.\n    // Default is 300. Cannot be 0. Any value below 100 is not recommended.\n    { provide: LIST_QUERY_DEBOUNCE_TIME, useValue: 500 },\n  ],\n})\nexport class FileModalComponent {\n  constructor(\n    private _FileService: FileService.FileDescriptorService,\n    private toaster: ToasterService,\n    public readonly list: ListService,\n    public _FileApiService: FileApiService,\n    private restService: RestService,\n    private confirmation: ConfirmationService,\n    private _LocalizationService: LocalizationService\n  ) {\n    that = this;\n  }\n\n  private _FileDescriptorService = inject(FileDescriptorService);\n  /**获取目录配置 */\n  getFilesConfiguration() {\n    return new Promise((resolve, reject) => {\n      this._FileDescriptorService\n        .getFileContainerConfiguration(this._fileContainerName)\n        .subscribe(res => {\n          this.createDirectoryPermissionName = res?.createDirectoryPermissionName;\n          resolve(res);\n        });\n    });\n  }\n  /**目录的权限名称 */\n  createDirectoryPermissionName: string = null;\n\n  /**图片容器 */\n  _fileContainerName: string;\n  @Input()\n  public set fileContainerName(v: string) {\n    if (v) {\n      this._fileContainerName = v;\n      // this.loadData()\n    }\n  }\n\n  /**是否多选 */\n  _multiple: boolean = false;\n  @Input()\n  public set multiple(v: boolean) {\n    this._multiple = v;\n    if (v) {\n    }\n  }\n\n  /**文件大小限制\n   * @param 1mb\n   */\n  sizeLimit: number = 1048576;\n  @Input()\n  public set limit(v: number) {\n    this.sizeLimit = v;\n  }\n  /**父组件传递的模态框状态 */\n  @Input()\n  public set visible(v: boolean) {\n    this.ModalOpen = v;\n    if (v) {\n      this.loadData();\n    }\n  }\n\n  /**模态框状态回调 */\n  @Output() visibleChange = new EventEmitter();\n\n  /**模态框-状态-是否打开 */\n  ModalOpen: boolean = false;\n\n  /**模态框-繁忙状态-用于确定模态的繁忙状态是否为真 */\n  ModalBusy: boolean = false;\n\n  /**模态框-状态改变回调 */\n  ModalVisibleChange(event) {\n    if (!event) {\n      this.ModalOpen = false;\n      this.ModalBusy = false;\n      this.visibleChange.emit(event);\n      this.createDirectoryPermissionName = '';\n      this._theSelectedTreeNode = '';\n      this.selectedTable = [];\n      this.uploadPictureStatusList = [];\n      return;\n    }\n  }\n\n  /**模态框保存 */\n  modalSave() {\n    let selectedTablearr = this._FileApiService.deepClone(this.selectedTable);\n    this.selectFilefn.emit(selectedTablearr);\n    this.ModalVisibleChange(false);\n  }\n  /**dignite-file-modal-tree */\n  /**选择的tree节点 */\n  _theSelectedTreeNode: any = '';\n  isCreateList: boolean = false;\n  /**初始化数据 */\n  loadData() {\n    if (this.ModalOpen && this._fileContainerName) {\n      this.list.maxResultCount = 100;\n      // this.filters.skipCount = 0;\n      this.getFilesConfiguration();\n      if (!this.isCreateList) {\n        this.hookToQuery();\n        this.isCreateList = true;\n      } else {\n        this.list.get();\n      }\n    }\n  }\n  /** 从tree获取来的数据 */\n  fileGroupList: any[] = [];\n  /** 从tree获取数据 */\n  treeNodeData(event) {\n    this.fileGroupList = this.flattenNestedArray(event);\n  }\n  /**\n   * 将嵌套数组扁平化\n   * @param {Array} nestedArray - 包含嵌套children的数组\n   * @returns {Array} - 扁平化后的数组\n   */\n  flattenNestedArray(nestedArray) {\n    let result = [];\n\n    function flatten(items) {\n      if (!items) return;\n\n      for (const item of items) {\n        // 将当前项添加到结果数组\n        result.push({ ...item });\n\n        // 如果有children属性且是数组，递归处理\n        if (item.children && Array.isArray(item.children)) {\n          flatten(item.children);\n        }\n      }\n    }\n\n    flatten(nestedArray);\n    return result;\n  }\n\n  /**tree-节点选择 */\n  _nodeClick(event) {\n    this.filters.skipCount = 0;\n    this._theSelectedTreeNode = event;\n    this.list.get();\n  }\n\n  /**图片上传-要上传图片的状态文件列表 */\n  uploadPictureStatusList: any[] = [];\n\n  /**图片上传-获取文件信息改变 */\n  async getFileChange(event) {\n    let files = new Array(...event.target.files);\n    this.uploadPictureStatusList = files;\n    for (const file of files) {\n      if (file.size > this.sizeLimit) {\n        this.setuploadPictureStatus(file, 2);\n        continue;\n      }\n      await this.uploadingFile(file)\n        .then(res => {\n          this.selectedTable.push(res);\n          this.setuploadPictureStatus(file, 1);\n          // this.list.get()\n        })\n        .catch(() => {\n          this.setuploadPictureStatus(file, 2);\n        }); // 等待每个文件上传完成\n    }\n    this.list.get();\n    let isSubmit = !this.uploadPictureStatusList.some(el => el.status == 2);\n    if (isSubmit) {\n      // this.toaster.success(\"上传完成\");\n      setTimeout(() => {\n        this.uploadPictureStatusList = [];\n      }, 4000);\n    }\n  }\n\n  /**图片上传-设置uploadPictureStatusList的状态 */\n  setuploadPictureStatus(file, type) {\n    this.uploadPictureStatusList.map(el => {\n      if (el == file) el.status = type;\n    });\n  }\n\n  /**图片上传-递归按顺序上传 */\n  uploadingFile(file) {\n    return new Promise((resolve, rejects) => {\n      let formData = new FormData();\n      formData.append('file', file, file.name);\n      this.createFile({\n        file: formData,\n        containerName: this._fileContainerName,\n        directoryId: this._theSelectedTreeNode?.key || '',\n        entityId: '',\n      }).subscribe(\n        res => {\n          resolve(res);\n        },\n        err => {\n          rejects(false);\n        }\n      );\n    });\n  }\n\n  /**文件表格-数据*/\n  data: PagedResultDto<FileDescriptorDto> = {\n    items: [],\n    totalCount: 0,\n  };\n\n  /**文件表格-条件*/\n  filters = {} as GetFilesInput;\n\n  /**文件表格-表格自带选择类型 */\n  SelectionType = SelectionType;\n\n  /**选择文件回调 */\n  @Output() selectFilefn = new EventEmitter<any[]>();\n\n  /**文件表格-获取表格数据 */\n  hookToQuery() {\n    const getData = (query: ABP.PageQueryParams) =>\n      this._FileService.getList({\n        ...query,\n        ...this.filters,\n        containerName: this._fileContainerName,\n        directoryId: this._theSelectedTreeNode.key,\n      });\n    const setData = (list: PagedResultDto<FileDescriptorDto>) => {\n      this.data = list;\n      this.onPageChange(list.items);\n    };\n    this.list.hookToQuery(getData).subscribe(setData);\n  }\n\n  /**文件表格-查看所有分组的文件数据 */\n  lookAllFile() {\n    this.filters.skipCount = 0;\n    this._theSelectedTreeNode = '';\n    this.list.get();\n  }\n\n  /**删除图片 */\n  deleteFile(file) {\n    this._FileService.delete(file.id).subscribe(res => {\n      this.toaster.success(this._LocalizationService.instant(`FileExplorer::DeletedSuccessfully`));\n      this.list.get();\n    });\n  }\n\n  /**删除所有选中图片 */\n  onDeleteAllSelectFile() {\n    this.confirmation\n      .warn('', {\n        key: '',\n        defaultValue: this._LocalizationService.instant(`FileExplorer::AreYouSure`),\n      })\n      .subscribe(async (status: Confirmation.Status) => {\n        if (status == 'confirm') {\n          let selectedTable = this.selectedTable;\n          try {\n            const result = await this.batchDeleteItems(selectedTable);\n            if (result.success) {\n              this.toaster.success(result.message);\n              this.list.get();\n              // 可能需要刷新表格或更新UI\n            } else {\n              //删除失败的项\n              this.list.get();\n              // console.warn(result.message);\n              // 可以选择展示失败项或重试\n            }\n          } catch (error) {\n            //批量删除过程中发生错误\n          }\n        }\n      });\n  }\n\n  /**\n   * 批量删除表格项\n   * @param selectedTable 需要删除的表格项数组\n   * @returns 包含成功状态和失败项的结果对象\n   */\n  async batchDeleteItems(selectedTable: any[]) {\n    // 存储所有删除请求的Promise\n    const deletePromises = selectedTable.map(item => {\n      return new Promise((resolve, reject) => {\n        this._FileService.delete(item.id).subscribe(\n          () => {\n            resolve(null);\n          },\n          () => {\n            reject(item);\n          }\n        );\n      });\n    });\n\n    // 等待所有请求完成\n    const results = await Promise.allSettled(deletePromises);\n    console.log(results, 'resultsresultsresults');\n    // 收集失败的项\n    const failedItems: any[] = [];\n    results.forEach(result => {\n      if (result.status === 'rejected') {\n        failedItems.push(result.reason);\n      }\n    });\n\n    return {\n      success: failedItems.length === 0,\n      failedItems,\n      message:\n        failedItems.length === 0\n          ? this._LocalizationService.instant(`FileExplorer::DeletedSuccessfully`)\n          : `${failedItems.length}个项删除失败`,\n    };\n  }\n\n  // 使用示例\n  async handleBatchDelete() {}\n\n  /**关闭文件状态弹窗 */\n  closeFileStatusModal() {\n    this.uploadPictureStatusList = [];\n  }\n\n  /**创建图片的接口，代理中的file类型不匹配，切换为any类型 */\n  createFile = (input: any, config?: Partial<Rest.Config>) =>\n    this.restService.request<any, FileDescriptorDto>(\n      {\n        method: 'POST',\n        url: '/api/file-explorer/files',\n        params: {\n          containerName: input.containerName,\n          cellName: input.cellName,\n          directoryId: input.directoryId,\n          entityId: input.entityId,\n        },\n        body: input.file,\n      },\n      { apiName: 'FileExplorer', ...config }\n    );\n\n  /**文件表格-选择的表格数据项 */\n  selectedTable = [];\n  /**当前选择的table项 id */\n  nowSelectId: any = '';\n  /**是否全选 */\n  isAllSelected = false;\n\n  /**已选定的文件 */\n  @Input() selectPickerFile: any[];\n\n  ngOnChanges(changes: SimpleChanges): void {\n    //Called before any other lifecycle hook. Use it to inject dependencies, but avoid any serious work here.\n    //Add '${implements OnChanges}' to the class.\n    this.selectedTable = this._FileApiService.deepClone(this.selectPickerFile);\n  }\n  /**表格分页切换 */\n  onPageChange(newArray) {\n    this.isAllSelected = this.isAllSelectedFn(newArray, this.selectedTable);\n  }\n  /**行选择框改变 */\n  onCheckboxChangeFn(event, row, array: any[]) {\n    const { checked } = event.target;\n    let selectedTableArray = [...this.selectedTable];\n    if (this._multiple) {\n      if (checked) {\n        selectedTableArray.push(row);\n      } else {\n        selectedTableArray = selectedTableArray.filter(el => el.id != row.id);\n      }\n      this.isAllSelected = this.isAllSelectedFn(array, selectedTableArray);\n    } else {\n      selectedTableArray.length = 0;\n      selectedTableArray = checked ? [row] : [];\n    }\n    this.selectedTable = this.removeDuplicatesById(selectedTableArray);\n  }\n  /**如果selectedTableArray不含array中的所有项，则将isAllSelected设为true,否则设为false */\n  isAllSelectedFn(tolalArray: any[], selectedArray: any[] = []) {\n    if(tolalArray.length == 0) return false;\n    return tolalArray.every(item => selectedArray.some(el => el.id === item.id));\n  }\n  /**选择当前页全部 */\n  onSelectAllFn(event: any, array: any[]) {\n    let selectedTableArray = this.selectedTable;\n    if (event.target.checked) {\n      selectedTableArray = this.removeDuplicatesById([...selectedTableArray, ...array]);\n    } else {\n      selectedTableArray = selectedTableArray.filter(el => !array.some(item => item.id === el.id));\n    }\n    this.isAllSelected = event.target.checked;\n    this.selectedTable = selectedTableArray;\n  }\n\n  /**判断row是否选中 */\n  selectedcheckbox = id => {\n    return this.selectedTable.some(el => el.id === id);\n  };\n  /**删除数组中重复的项 */\n  removeDuplicatesById(array) {\n    const seenIds = {};\n    return array.filter(item => {\n      if (!seenIds[item.id]) {\n        seenIds[item.id] = true;\n        return true;\n      }\n      return false;\n    });\n  }\n  /**用于编辑的表单，同时只能显示编辑一个 */\n  FileNameForm: FormGroup | any;\n  /**当前编辑的row */\n  newEditRow: any = '';\n  /**是否正在加载 */\n  isloading: boolean = false;\n  /**提交FileName编辑 */\n  onSubmitFileName(event) {\n    let input = this.FileNameForm.value;\n    if (!this.FileNameForm.valid) return;\n    if (this.isloading) return;\n    this.isloading = true;\n    this._FileService\n      .update(input.id, {\n        name:input.fileName\n      })\n      .pipe(\n        finalize(() => {\n          this.isloading = false;\n        })\n      )\n      .subscribe(res => {\n        //通过当前newEditRow的id,修改data.items中对应项的name\n        for (const element of this.data.items) {\n          if (element.id == this.newEditRow.id) {\n            element.name = input.fileName;\n            break;\n          }\n        }\n\n        this.FileNameForm = undefined;\n        this.newEditRow = '';\n        this.toaster.success(this._LocalizationService.instant(`FileExplorer::SavedSuccessfully`));\n        // this.list.get();\n      });\n  }\n  /**打开编辑 */\n  onEditFileName(row) {\n    this.FileNameForm = new FormGroup({\n      fileName: new FormControl('', [Validators.required]),\n      id: new FormControl('', [Validators.required]),\n    });\n    this.FileNameForm.patchValue({\n      fileName: row.name,\n      id: row.id,\n    });\n    this.newEditRow = row;\n  }\n  /**关闭编辑 */\n  onCancelFileName(row) {\n    this.newEditRow = '';\n    this.FileNameForm = undefined;\n  }\n}\n","<abp-modal [(visible)]=\"ModalOpen\" (visibleChange)=\"ModalVisibleChange($event)\"\n  [options]=\"{ size: 'xl', scrollable: false }\">\n  <ng-template #abpHeader>\n    <h3>{{'FileExplorer::FileExplorer' | abpLocalization}}</h3>\n  </ng-template>\n  <ng-template #abpBody>\n    <div class=\"row file-explorer-modal-body file-modal\" *ngIf=\"ModalOpen\">\n      <div class=\"col-3\" *ngIf=\"createDirectoryPermissionName\" style=\"overflow: auto; height: calc(100vh - 240px)\">\n        <fe-file-modal-tree [theSelectedTreeNode]=\"_theSelectedTreeNode\" (nodeClick)=\"_nodeClick($event)\"\n          (lookAllBtn)=\"lookAllFile()\" (treeNodeData)=\"treeNodeData($event)\"\n          [fileContainerName]=\"_fileContainerName\"></fe-file-modal-tree>\n      </div>\n      <div [class]=\"createDirectoryPermissionName?'col-9':'col-12'\" style=\"height: calc(100vh - 240px)\">\n        <div class=\"mb-3 d-flex justify-content-between align-items-center\">\n          <div style=\"flex: 2\"><span *ngIf=\"selectedTable.length>1\" class=\"btn-link\"\n              (click.stop)=\"onDeleteAllSelectFile()\" role=\"button\">{{'FileExplorer::Delete' | abpLocalization}}</span>\n          </div>\n          <div class=\"input-group form-file\" style=\"flex: 2\">\n            <input type=\"file\" class=\"form-control\" #fileEdit [multiple]=\"_multiple\" (change)=\"getFileChange($event)\" />\n          </div>\n        </div>\n        <div>\n          <!-- [selectionType]=\"_multiple?SelectionType.checkbox:SelectionType.single\" -->\n          <!-- [selectCheck]=\"selectCheck\" -->\n          <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\" columnMode=\"flex\"\n            [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\" [scrollbarV]=\"true\" [virtualization]=\"false\"\n            [externalPaging]=\"true\" [count]=\"data.totalCount\">\n            <ngx-datatable-column [width]=\"50\" prop=\"id\" [sortable]=\"false\" [canAutoResize]=\"false\" [draggable]=\"false\"\n              [resizeable]=\"false\">\n              <ng-template ngx-datatable-header-template let-value=\"value\" let-allRowsSelected=\"allRowsSelected\"\n                let-selectFn=\"selectFn\">\n                <input type=\"checkbox\" class=\"form-check-input\" *ngIf=\"_multiple\" [checked]=\"isAllSelected\"\n                  (change)=\"onSelectAllFn($event,data.items)\" />\n              </ng-template>\n              <ng-template ngx-datatable-cell-template let-row=\"row\" let-value=\"value\">\n                <input type=\"checkbox\" class=\"form-check-input\" [checked]=\"selectedcheckbox(value)\"\n                  (change)=\"onCheckboxChangeFn($event,row,data.items)\" />\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [sortable]=\"false\" [flexGrow]=\"2\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                <fe-file-preview [width]=\"'80px'\" [src]=\"row.url\" [name]=\"row.name\" [type]=\"row.mimeType\"\n                  [preview]=\"true\"></fe-file-preview>\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [name]=\"'FileExplorer::FileName' | abpLocalization\" prop=\"name\" [sortable]=\"false\"\n              [flexGrow]=\"4\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                <div class=\"d-flex align-items-start titlehover\" *ngIf=\"newEditRow.id!==row.id\">\n                  <span class=\"me-2\">{{ value }}</span>\n                  <i class=\"fa fa-pencil-square-o\" role=\"button\" (click.stop)=\"onEditFileName(row)\" style=\"line-height:2;\" aria-hidden=\"true\"></i>\n                </div>\n                <div *ngIf=\"FileNameForm&&newEditRow.id===row.id\">\n                  <form [formGroup]=\"FileNameForm\" (ngSubmit)=\"onSubmitFileName($event)\">\n                    <div class=\"d-flex align-items-start\">\n                      <div class=\"me-2\">\n                        <input class=\"form-control \" type=\"text\"  formControlName=\"fileName\">\n                      </div>\n                      <button class=\" btn btn-sm\" type=\"submit\">\n                        <i class=\"fa-spin fa fa-spinner\" *ngIf=\"isloading\"></i>\n                        <i class=\"fa fa-check\" aria-hidden=\"true\" *ngIf=\"!isloading\"></i></button>\n                      <button class=\" btn btn-sm\" (click.stop)=\"onCancelFileName(row)\"><i class=\"fa fa-times\" type=\"reset\" aria-hidden=\"true\"></i></button>\n                      \n                    </div>\n                  </form>\n                </div>\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [name]=\"'FileExplorer::FileSize' | abpLocalization\" prop=\"size\" [flexGrow]=\"1.5\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                {{ _FileApiService.formatFileSize(value) }}\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [name]=\"'FileExplorer::Directory' | abpLocalization\" prop=\"directoryId\"\n              [sortable]=\"false\" [flexGrow]=\"1\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                {{ value|getDirectoryName:fileGroupList }}\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [name]=\"'FileExplorer::CreationTime' | abpLocalization\" prop=\"creationTime\"\n              [flexGrow]=\"2\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                {{ value | date : 'YYYY/MM/dd HH:mm:s' }}\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [flexGrow]=\"1\" [sortable]=\"false\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                <button class=\"btn btn-sm btn-light p-0\" (click.stop)=\"deleteFile(row)\">\n                  <i class=\"fas fa-trash text-primary p-2\"></i>\n                </button>\n              </ng-template>\n            </ngx-datatable-column>\n          </ngx-datatable>\n        </div>\n        <div *ngIf=\"uploadPictureStatusList.length > 0\"\n          class=\"position-fixed bottom-0 end-0 shadow-lg file-status-modal   m-5\" style=\"border-radius: 10px\">\n          <div class=\"card p-1\">\n            <div class=\"card-header d-flex align-items-center justify-content-between p-0 py-1 border-bottom\">\n              <div>{{'FileExplorer::UploadFiles' | abpLocalization}}</div>\n              <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click.stop)=\"closeFileStatusModal()\"></button>\n            </div>\n            <div class=\"card-body\">\n              <table class=\"table\">\n                <thead>\n                  <tr>\n                    <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n                    <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n                    <th scope=\"col\"></th>\n                  </tr>\n                </thead>\n                <tbody>\n                  <ng-container *ngFor=\"let item of uploadPictureStatusList; let i = index\">\n                    <tr>\n                      <th scope=\"row\">\n                        <div>{{ item.name }}</div>\n                        <div class=\"form-text text-danger\" *ngIf=\"item.size > sizeLimit\">\n                          {{'FileExplorer::ExceedsMaximumSize' |\n                          abpLocalization:_FileApiService.formatFileSize(sizeLimit)}}\n                        </div>\n                      </th>\n                      <td>{{ item.fileSize }}</td>\n                      <td>\n                        <i *ngIf=\"item.status === 1\" class=\"fas fa-check text-primary\"></i>\n                        <i *ngIf=\"item.status === 2\" class=\"fas fa-times-circle text-danger\"></i>\n                      </td>\n                    </tr>\n                  </ng-container>\n                </tbody>\n              </table>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </ng-template>\n  <ng-template #abpFooter>\n    <button type=\"button\" class=\"btn btn-secondary\" abpClose>{{'AbpUi::Close' | abpLocalization}}</button>\n    <abp-button iconClass=\"fa fa-check\" (click)=\"modalSave()\">{{'FileExplorer::Confirm' | abpLocalization}}\n      @if(selectedTable.length>0){\n      ({{selectedTable.length}})\n      }\n    </abp-button>\n  </ng-template>\n</abp-modal>"]}
|
|
473
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-modal.component.js","sourceRoot":"","sources":["../../../../../../../packages/file-explorer/src/lib/components/file-modal/file-modal.component.ts","../../../../../../../packages/file-explorer/src/lib/components/file-modal/file-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, SimpleChanges, inject, OnChanges } from '@angular/core';\nimport * as FileService from '../../proxy/dignite/file-explorer/files';\nimport { Confirmation, ConfirmationService, ToasterService } from '@abp/ng.theme.shared';\nimport {\n  PagedResultDto,\n  ABP,\n  ListService,\n  Rest,\n  RestService,\n  LocalizationService,\n  LIST_QUERY_DEBOUNCE_TIME,\n} from '@abp/ng.core';\nimport {\n  FileDescriptorDto,\n  FileDescriptorService,\n  GetFilesInput,\n} from '../../proxy/dignite/file-explorer/files';\nimport { FileApiService } from '../../services/file-api.service';\nimport { SelectionType } from '@swimlane/ngx-datatable';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport { finalize } from 'rxjs';\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'fe-file-modal',\n  templateUrl: './file-modal.component.html',\n  styleUrls: ['./file-modal.component.scss'],\n  providers: [\n    // [Required]\n    ListService,\n    // [Optional]\n    // Provide this token if you want a different debounce time.\n    // Default is 300. Cannot be 0. Any value below 100 is not recommended.\n    { provide: LIST_QUERY_DEBOUNCE_TIME, useValue: 500 },\n  ],\n})\nexport class FileModalComponent implements OnChanges {\n  constructor(\n    private _FileService: FileService.FileDescriptorService,\n    private toaster: ToasterService,\n    public readonly list: ListService,\n    public _FileApiService: FileApiService,\n    private restService: RestService,\n    private confirmation: ConfirmationService,\n    private _LocalizationService: LocalizationService\n  ) {\n  }\n\n  private _FileDescriptorService = inject(FileDescriptorService);\n  /**获取目录配置 */\n  getFilesConfiguration() {\n    return new Promise((resolve, reject) => {\n      this._FileDescriptorService\n        .getFileContainerConfiguration(this._fileContainerName)\n        .subscribe(res => {\n          this.createDirectoryPermissionName = res?.createDirectoryPermissionName;\n          resolve(res);\n        });\n    });\n  }\n  /**目录的权限名称 */\n  createDirectoryPermissionName: string = null;\n\n  /**图片容器 */\n  _fileContainerName: string;\n  @Input()\n  public set fileContainerName(v: string) {\n    if (v) {\n      this._fileContainerName = v;\n      // this.loadData()\n    }\n  }\n\n  /**是否多选 */\n  _multiple = false;\n  @Input()\n  public set multiple(v: boolean) {\n    this._multiple = v;\n  }\n\n  /**文件大小限制\n   * @param 1mb\n   */\n  sizeLimit = 1048576;\n  @Input()\n  public set limit(v: number) {\n    this.sizeLimit = v;\n  }\n  /**父组件传递的模态框状态 */\n  @Input()\n  public set visible(v: boolean) {\n    this.ModalOpen = v;\n    if (v) {\n      this.loadData();\n    }\n  }\n\n  /**模态框状态回调 */\n  @Output() visibleChange = new EventEmitter();\n\n  /**模态框-状态-是否打开 */\n  ModalOpen = false;\n\n  /**模态框-繁忙状态-用于确定模态的繁忙状态是否为真 */\n  ModalBusy = false;\n\n  /**模态框-状态改变回调 */\n  ModalVisibleChange(event) {\n    if (!event) {\n      this.ModalOpen = false;\n      this.ModalBusy = false;\n      this.visibleChange.emit(event);\n      this.createDirectoryPermissionName = '';\n      this._theSelectedTreeNode = '';\n      this.selectedTable = [];\n      this.uploadPictureStatusList = [];\n      return;\n    }\n  }\n\n  /**模态框保存 */\n  modalSave() {\n    const selectedTablearr = this._FileApiService.deepClone(this.selectedTable);\n    this.selectFilefn.emit(selectedTablearr);\n    this.ModalVisibleChange(false);\n  }\n  /**dignite-file-modal-tree */\n  /**选择的tree节点 */\n  _theSelectedTreeNode: any = '';\n  isCreateList = false;\n  /**初始化数据 */\n  loadData() {\n    if (this.ModalOpen && this._fileContainerName) {\n      this.list.maxResultCount = 100;\n      // this.filters.skipCount = 0;\n      this.getFilesConfiguration();\n      if (!this.isCreateList) {\n        this.hookToQuery();\n        this.isCreateList = true;\n      } else {\n        this.list.get();\n      }\n    }\n  }\n  /** 从tree获取来的数据 */\n  fileGroupList: any[] = [];\n  /** 从tree获取数据 */\n  treeNodeData(event) {\n    this.fileGroupList = this.flattenNestedArray(event);\n  }\n  /**\n   * 将嵌套数组扁平化\n   * @param {Array} nestedArray - 包含嵌套children的数组\n   * @returns {Array} - 扁平化后的数组\n   */\n  flattenNestedArray(nestedArray) {\n    const result = [];\n\n    function flatten(items) {\n      if (!items) return;\n\n      for (const item of items) {\n        // 将当前项添加到结果数组\n        result.push({ ...item });\n\n        // 如果有children属性且是数组，递归处理\n        if (item.children && Array.isArray(item.children)) {\n          flatten(item.children);\n        }\n      }\n    }\n\n    flatten(nestedArray);\n    return result;\n  }\n\n  /**tree-节点选择 */\n  _nodeClick(event) {\n    this.filters.skipCount = 0;\n    this._theSelectedTreeNode = event;\n    this.list.get();\n  }\n\n  /**图片上传-要上传图片的状态文件列表 */\n  uploadPictureStatusList: any[] = [];\n\n  /**图片上传-获取文件信息改变 */\n  async getFileChange(event) {\n    const files = new Array(...event.target.files);\n    this.uploadPictureStatusList = files;\n    for (const file of files) {\n      if (file.size > this.sizeLimit) {\n        this.setuploadPictureStatus(file, 2);\n        continue;\n      }\n      await this.uploadingFile(file)\n        .then(res => {\n          this.selectedTable.push(res);\n          this.setuploadPictureStatus(file, 1);\n          // this.list.get()\n        })\n        .catch(() => {\n          this.setuploadPictureStatus(file, 2);\n        }); // 等待每个文件上传完成\n    }\n    this.list.get();\n    const isSubmit = !this.uploadPictureStatusList.some(el => el.status == 2);\n    if (isSubmit) {\n      // this.toaster.success(\"上传完成\");\n      setTimeout(() => {\n        this.uploadPictureStatusList = [];\n      }, 4000);\n    }\n  }\n\n  /**图片上传-设置uploadPictureStatusList的状态 */\n  setuploadPictureStatus(file, type) {\n    this.uploadPictureStatusList.map(el => {\n      if (el == file) el.status = type;\n    });\n  }\n\n  /**图片上传-递归按顺序上传 */\n  uploadingFile(file) {\n    return new Promise((resolve, rejects) => {\n      const formData = new FormData();\n      formData.append('file', file, file.name);\n      this.createFile({\n        file: formData,\n        containerName: this._fileContainerName,\n        directoryId: this._theSelectedTreeNode?.key || '',\n        entityId: '',\n      }).subscribe(\n        res => {\n          resolve(res);\n        },\n        err => {\n          rejects(false);\n        }\n      );\n    });\n  }\n\n  /**文件表格-数据*/\n  data: PagedResultDto<FileDescriptorDto> = {\n    items: [],\n    totalCount: 0,\n  };\n\n  /**文件表格-条件*/\n  filters = {} as GetFilesInput;\n\n  /**文件表格-表格自带选择类型 */\n  SelectionType = SelectionType;\n\n  /**选择文件回调 */\n  @Output() selectFilefn = new EventEmitter<any[]>();\n\n  /**文件表格-获取表格数据 */\n  hookToQuery() {\n    const getData = (query: ABP.PageQueryParams) =>\n      this._FileService.getList({\n        ...query,\n        ...this.filters,\n        containerName: this._fileContainerName,\n        directoryId: this._theSelectedTreeNode.key,\n      });\n    const setData = (list: PagedResultDto<FileDescriptorDto>) => {\n      this.data = list;\n      this.onPageChange(list.items);\n    };\n    this.list.hookToQuery(getData).subscribe(setData);\n  }\n\n  /**文件表格-查看所有分组的文件数据 */\n  lookAllFile() {\n    this.filters.skipCount = 0;\n    this._theSelectedTreeNode = '';\n    this.list.get();\n  }\n\n  /**删除图片 */\n  deleteFile(file) {\n    this._FileService.delete(file.id).subscribe(res => {\n      this.toaster.success(this._LocalizationService.instant(`FileExplorer::DeletedSuccessfully`));\n      this.list.get();\n    });\n  }\n\n  /**删除所有选中图片 */\n  onDeleteAllSelectFile() {\n    this.confirmation\n      .warn('', {\n        key: '',\n        defaultValue: this._LocalizationService.instant(`FileExplorer::AreYouSure`),\n      })\n      .subscribe(async (status: Confirmation.Status) => {\n        if (status == 'confirm') {\n          const selectedTable = this.selectedTable;\n          try {\n            const result = await this.batchDeleteItems(selectedTable);\n            if (result.success) {\n              this.toaster.success(result.message);\n              this.list.get();\n              // 可能需要刷新表格或更新UI\n            } else {\n              //删除失败的项\n              this.list.get();\n              // 可以选择展示失败项或重试\n            }\n          } catch (error) {\n            //批量删除过程中发生错误\n          }\n        }\n      });\n  }\n\n  /**\n   * 批量删除表格项\n   * @param selectedTable 需要删除的表格项数组\n   * @returns 包含成功状态和失败项的结果对象\n   */\n  async batchDeleteItems(selectedTable: any[]) {\n    // 存储所有删除请求的Promise\n    const deletePromises = selectedTable.map(item => {\n      return new Promise((resolve, reject) => {\n        this._FileService.delete(item.id).subscribe(\n          () => {\n            resolve(null);\n          },\n          () => {\n            reject(item);\n          }\n        );\n      });\n    });\n\n    // 等待所有请求完成\n    const results = await Promise.allSettled(deletePromises);\n    // 收集失败的项\n    const failedItems: any[] = [];\n    results.forEach(result => {\n      if (result.status === 'rejected') {\n        failedItems.push(result.reason);\n      }\n    });\n\n    return {\n      success: failedItems.length === 0,\n      failedItems,\n      message:\n        failedItems.length === 0\n          ? this._LocalizationService.instant(`FileExplorer::DeletedSuccessfully`)\n          : `${failedItems.length}个项删除失败`,\n    };\n  }\n\n  // 使用示例\n  async handleBatchDelete() {}\n\n  /**关闭文件状态弹窗 */\n  closeFileStatusModal() {\n    this.uploadPictureStatusList = [];\n  }\n\n  /**创建图片的接口，代理中的file类型不匹配，切换为any类型 */\n  createFile = (input: any, config?: Partial<Rest.Config>) =>\n    this.restService.request<any, FileDescriptorDto>(\n      {\n        method: 'POST',\n        url: '/api/file-explorer/files',\n        params: {\n          containerName: input.containerName,\n          cellName: input.cellName,\n          directoryId: input.directoryId,\n          entityId: input.entityId,\n        },\n        body: input.file,\n      },\n      { apiName: 'FileExplorer', ...config }\n    );\n\n  /**文件表格-选择的表格数据项 */\n  selectedTable = [];\n  /**当前选择的table项 id */\n  nowSelectId: any = '';\n  /**是否全选 */\n  isAllSelected = false;\n\n  /**已选定的文件 */\n  @Input() selectPickerFile: any[];\n\n  ngOnChanges(changes: SimpleChanges): void {\n    //Called before any other lifecycle hook. Use it to inject dependencies, but avoid any serious work here.\n    //Add '${implements OnChanges}' to the class.\n    this.selectedTable = this._FileApiService.deepClone(this.selectPickerFile);\n  }\n  /**表格分页切换 */\n  onPageChange(newArray) {\n    this.isAllSelected = this.isAllSelectedFn(newArray, this.selectedTable);\n  }\n  /**行选择框改变 */\n  onCheckboxChangeFn(event, row, array: any[]) {\n    const { checked } = event.target;\n    let selectedTableArray = [...this.selectedTable];\n    if (this._multiple) {\n      if (checked) {\n        selectedTableArray.push(row);\n      } else {\n        selectedTableArray = selectedTableArray.filter(el => el.id != row.id);\n      }\n      this.isAllSelected = this.isAllSelectedFn(array, selectedTableArray);\n    } else {\n      selectedTableArray.length = 0;\n      selectedTableArray = checked ? [row] : [];\n    }\n    this.selectedTable = this.removeDuplicatesById(selectedTableArray);\n  }\n  /**如果selectedTableArray不含array中的所有项，则将isAllSelected设为true,否则设为false */\n  isAllSelectedFn(tolalArray: any[], selectedArray: any[] = []) {\n    if(tolalArray.length == 0) return false;\n    return tolalArray.every(item => selectedArray.some(el => el.id === item.id));\n  }\n  /**选择当前页全部 */\n  onSelectAllFn(event: any, array: any[]) {\n    let selectedTableArray = this.selectedTable;\n    if (event.target.checked) {\n      selectedTableArray = this.removeDuplicatesById([...selectedTableArray, ...array]);\n    } else {\n      selectedTableArray = selectedTableArray.filter(el => !array.some(item => item.id === el.id));\n    }\n    this.isAllSelected = event.target.checked;\n    this.selectedTable = selectedTableArray;\n  }\n\n  /**判断row是否选中 */\n  selectedcheckbox = id => {\n    return this.selectedTable.some(el => el.id === id);\n  };\n  /**删除数组中重复的项 */\n  removeDuplicatesById(array) {\n    const seenIds = {};\n    return array.filter(item => {\n      if (!seenIds[item.id]) {\n        seenIds[item.id] = true;\n        return true;\n      }\n      return false;\n    });\n  }\n  /**用于编辑的表单，同时只能显示编辑一个 */\n  FileNameForm: FormGroup | any;\n  /**当前编辑的row */\n  newEditRow: any = '';\n  /**是否正在加载 */\n  isloading = false;\n  /**提交FileName编辑 */\n  onSubmitFileName(event) {\n    const input = this.FileNameForm.value;\n    if (!this.FileNameForm.valid) return;\n    if (this.isloading) return;\n    this.isloading = true;\n    this._FileService\n      .update(input.id, {\n        name:input.fileName\n      })\n      .pipe(\n        finalize(() => {\n          this.isloading = false;\n        })\n      )\n      .subscribe(res => {\n        //通过当前newEditRow的id,修改data.items中对应项的name\n        for (const element of this.data.items) {\n          if (element.id == this.newEditRow.id) {\n            element.name = input.fileName;\n            break;\n          }\n        }\n\n        this.FileNameForm = undefined;\n        this.newEditRow = '';\n        this.toaster.success(this._LocalizationService.instant(`FileExplorer::SavedSuccessfully`));\n        // this.list.get();\n      });\n  }\n  /**打开编辑 */\n  onEditFileName(row) {\n    this.FileNameForm = new FormGroup({\n      fileName: new FormControl('', [Validators.required]),\n      id: new FormControl('', [Validators.required]),\n    });\n    this.FileNameForm.patchValue({\n      fileName: row.name,\n      id: row.id,\n    });\n    this.newEditRow = row;\n  }\n  /**关闭编辑 */\n  onCancelFileName(row) {\n    this.newEditRow = '';\n    this.FileNameForm = undefined;\n  }\n}\n","<abp-modal [(visible)]=\"ModalOpen\" (visibleChange)=\"ModalVisibleChange($event)\"\n  [options]=\"{ size: 'xl', scrollable: false }\">\n  <ng-template #abpHeader>\n    <h3>{{'FileExplorer::FileExplorer' | abpLocalization}}</h3>\n  </ng-template>\n  <ng-template #abpBody>\n    <div class=\"row file-explorer-modal-body file-modal\" *ngIf=\"ModalOpen\">\n      <div class=\"col-3\" *ngIf=\"createDirectoryPermissionName\" style=\"overflow: auto; height: calc(100vh - 240px)\">\n        <fe-file-modal-tree [theSelectedTreeNode]=\"_theSelectedTreeNode\" (nodeClick)=\"_nodeClick($event)\"\n          (lookAllBtn)=\"lookAllFile()\" (treeNodeData)=\"treeNodeData($event)\"\n          [fileContainerName]=\"_fileContainerName\"></fe-file-modal-tree>\n      </div>\n      <div [class]=\"createDirectoryPermissionName?'col-9':'col-12'\" style=\"height: calc(100vh - 240px)\">\n        <div class=\"mb-3 d-flex justify-content-between align-items-center\">\n          <div style=\"flex: 2\"><span *ngIf=\"selectedTable.length>1\" class=\"btn-link\"\n              (click.stop)=\"onDeleteAllSelectFile()\" role=\"button\">{{'FileExplorer::Delete' | abpLocalization}}</span>\n          </div>\n          <div class=\"input-group form-file\" style=\"flex: 2\">\n            <input type=\"file\" class=\"form-control\" #fileEdit [multiple]=\"_multiple\" (change)=\"getFileChange($event)\" />\n          </div>\n        </div>\n        <div>\n          <!-- [selectionType]=\"_multiple?SelectionType.checkbox:SelectionType.single\" -->\n          <!-- [selectCheck]=\"selectCheck\" -->\n          <ngx-datatable class=\"material container-height\" [rows]=\"data.items\" [list]=\"list\" columnMode=\"flex\"\n            [headerHeight]=\"50\" [footerHeight]=\"50\" rowHeight=\"auto\" [scrollbarV]=\"true\" [virtualization]=\"false\"\n            [externalPaging]=\"true\" [count]=\"data.totalCount\">\n            <ngx-datatable-column [width]=\"50\" prop=\"id\" [sortable]=\"false\" [canAutoResize]=\"false\" [draggable]=\"false\"\n              [resizeable]=\"false\">\n              <ng-template ngx-datatable-header-template let-value=\"value\" let-allRowsSelected=\"allRowsSelected\"\n                let-selectFn=\"selectFn\">\n                <input type=\"checkbox\" class=\"form-check-input\" *ngIf=\"_multiple\" [checked]=\"isAllSelected\"\n                  (change)=\"onSelectAllFn($event,data.items)\" />\n              </ng-template>\n              <ng-template ngx-datatable-cell-template let-row=\"row\" let-value=\"value\">\n                <input type=\"checkbox\" class=\"form-check-input\" [checked]=\"selectedcheckbox(value)\"\n                  (change)=\"onCheckboxChangeFn($event,row,data.items)\" />\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [sortable]=\"false\" [flexGrow]=\"2\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                <fe-file-preview [width]=\"'80px'\" [src]=\"row.url\" [name]=\"row.name\" [type]=\"row.mimeType\"\n                  [preview]=\"true\"></fe-file-preview>\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [name]=\"'FileExplorer::FileName' | abpLocalization\" prop=\"name\" [sortable]=\"false\"\n              [flexGrow]=\"4\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                <div class=\"d-flex align-items-start titlehover\" *ngIf=\"newEditRow.id!==row.id\">\n                  <span class=\"me-2\">{{ value }}</span>\n                  <i class=\"fa fa-pencil-square-o\" role=\"button\" (click.stop)=\"onEditFileName(row)\" style=\"line-height:2;\" aria-hidden=\"true\"></i>\n                </div>\n                <div *ngIf=\"FileNameForm&&newEditRow.id===row.id\">\n                  <form [formGroup]=\"FileNameForm\" (ngSubmit)=\"onSubmitFileName($event)\">\n                    <div class=\"d-flex align-items-start\">\n                      <div class=\"me-2\">\n                        <input class=\"form-control \" type=\"text\"  formControlName=\"fileName\">\n                      </div>\n                      <button class=\" btn btn-sm\" type=\"submit\">\n                        <i class=\"fa-spin fa fa-spinner\" *ngIf=\"isloading\"></i>\n                        <i class=\"fa fa-check\" aria-hidden=\"true\" *ngIf=\"!isloading\"></i></button>\n                      <button class=\" btn btn-sm\" (click.stop)=\"onCancelFileName(row)\"><i class=\"fa fa-times\" type=\"reset\" aria-hidden=\"true\"></i></button>\n                      \n                    </div>\n                  </form>\n                </div>\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [name]=\"'FileExplorer::FileSize' | abpLocalization\" prop=\"size\" [flexGrow]=\"1.5\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                {{ _FileApiService.formatFileSize(value) }}\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [name]=\"'FileExplorer::Directory' | abpLocalization\" prop=\"directoryId\"\n              [sortable]=\"false\" [flexGrow]=\"1\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                {{ value|getDirectoryName:fileGroupList }}\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [name]=\"'FileExplorer::CreationTime' | abpLocalization\" prop=\"creationTime\"\n              [flexGrow]=\"2\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                {{ value | date : 'YYYY/MM/dd HH:mm:s' }}\n              </ng-template>\n            </ngx-datatable-column>\n            <ngx-datatable-column [flexGrow]=\"1\" [sortable]=\"false\">\n              <ng-template let-row=\"row\" let-value=\"value\" ngx-datatable-cell-template>\n                <button class=\"btn btn-sm btn-light p-0\" (click.stop)=\"deleteFile(row)\">\n                  <i class=\"fas fa-trash text-primary p-2\"></i>\n                </button>\n              </ng-template>\n            </ngx-datatable-column>\n          </ngx-datatable>\n        </div>\n        <div *ngIf=\"uploadPictureStatusList.length > 0\"\n          class=\"position-fixed bottom-0 end-0 shadow-lg file-status-modal   m-5\" style=\"border-radius: 10px\">\n          <div class=\"card p-1\">\n            <div class=\"card-header d-flex align-items-center justify-content-between p-0 py-1 border-bottom\">\n              <div>{{'FileExplorer::UploadFiles' | abpLocalization}}</div>\n              <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click.stop)=\"closeFileStatusModal()\"></button>\n            </div>\n            <div class=\"card-body\">\n              <table class=\"table\">\n                <thead>\n                  <tr>\n                    <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n                    <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n                    <th scope=\"col\"></th>\n                  </tr>\n                </thead>\n                <tbody>\n                  <ng-container *ngFor=\"let item of uploadPictureStatusList; let i = index\">\n                    <tr>\n                      <th scope=\"row\">\n                        <div>{{ item.name }}</div>\n                        <div class=\"form-text text-danger\" *ngIf=\"item.size > sizeLimit\">\n                          {{'FileExplorer::ExceedsMaximumSize' |\n                          abpLocalization:_FileApiService.formatFileSize(sizeLimit)}}\n                        </div>\n                      </th>\n                      <td>{{ item.fileSize }}</td>\n                      <td>\n                        <i *ngIf=\"item.status === 1\" class=\"fas fa-check text-primary\"></i>\n                        <i *ngIf=\"item.status === 2\" class=\"fas fa-times-circle text-danger\"></i>\n                      </td>\n                    </tr>\n                  </ng-container>\n                </tbody>\n              </table>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </ng-template>\n  <ng-template #abpFooter>\n    <button type=\"button\" class=\"btn btn-secondary\" abpClose>{{'AbpUi::Close' | abpLocalization}}</button>\n    <abp-button iconClass=\"fa fa-check\" (click)=\"modalSave()\">{{'FileExplorer::Confirm' | abpLocalization}}\n      @if(selectedTable.length>0){\n      ({{selectedTable.length}})\n      }\n    </abp-button>\n  </ng-template>\n</abp-modal>"]}
|
|
@@ -55,11 +55,11 @@ export class FilePickerComponent {
|
|
|
55
55
|
// this._fileShowTable.updateValueAndValidity()
|
|
56
56
|
}
|
|
57
57
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FilePickerComponent, deps: [{ token: i1.FileApiService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
58
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: FilePickerComponent, selector: "fe-file-picker", inputs: { multiple: "multiple", fileContainerName: "fileContainerName", selectFormFile: "selectFormFile" }, outputs: { selectedFileChange: "selectedFileChange" }, usesOnChanges: true, ngImport: i0, template: "<button class=\"btn btn-sm btn-
|
|
58
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: FilePickerComponent, selector: "fe-file-picker", inputs: { multiple: "multiple", fileContainerName: "fileContainerName", selectFormFile: "selectFormFile" }, outputs: { selectedFileChange: "selectedFileChange" }, usesOnChanges: true, ngImport: i0, template: "<button class=\"btn btn-sm btn-dark soft ms-2 float-end\" type=\"button\"\n (click.stop)=\"ModalOpen = true\">{{'FileExplorer::SelectFile' | abpLocalization}}</button>\n\n<fe-file-modal [(visible)]=\"ModalOpen\" [selectPickerFile]=\"selectFormFile\" [multiple]=\"_multiple\"\n (selectFilefn)=\"_selectFilefn($event)\" [fileContainerName]=\"_fileContainerName\"></fe-file-modal>\n<table class=\"table\" *ngIf=\"_fileShowTable.length>0\" cdkDropList (cdkDropListDropped)=\"drop($event)\">\n <thead>\n <tr>\n <th scope=\"col\" style=\"width: 30px;\"></th>\n <th scope=\"col\"></th>\n <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n <th scope=\"col\"></th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngFor=\"let item of _fileShowTable;let i =index\">\n <tr cdkDrag cdkDragLockAxis=\"y\" [cdkDragData]=\"item\">\n <td>\n <div class=\"drag-handle\" cdkDragHandle>\n <span class=\"bi bi-arrows-move fs-5\"></span>\n </div>\n </td>\n <td>\n <fe-file-preview [width]=\"'80px'\" [src]=\"item.url||item.Url\" [name]=\"item.name||item.Name\"\n [type]=\"item.mimeType||item.MimeType\" [preview]=\"true\"></fe-file-preview>\n </td>\n <th scope=\"row\">\n <div>{{item.name||item.Name}}</div>\n </th>\n <td>{{_FileApiService.formatFileSize(item.Size||item.size)}}</td>\n <td>\n <button class=\"btn btn-sm p-0 btn-light \" (click.stop)=\"deleteFileTableItem(i,item)\">\n <i class=\"fas fa-trash p-2\"></i>\n </button>\n </td>\n </tr>\n </ng-container>\n </tbody>\n</table>", styles: [".table{border-collapse:collapse;table-layout:fixed}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.StopPropagationDirective, selector: "[click.stop]", outputs: ["click.stop"] }, { kind: "directive", type: i4.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i4.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i4.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "component", type: i5.FileModalComponent, selector: "fe-file-modal", inputs: ["fileContainerName", "multiple", "limit", "visible", "selectPickerFile"], outputs: ["visibleChange", "selectFilefn"] }, { kind: "component", type: i6.FilePreviewComponent, selector: "fe-file-preview", inputs: ["width", "src", "preview", "type", "name", "className"] }, { kind: "pipe", type: i3.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
59
59
|
}
|
|
60
60
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FilePickerComponent, decorators: [{
|
|
61
61
|
type: Component,
|
|
62
|
-
args: [{ selector: 'fe-file-picker', template: "<button class=\"btn btn-sm btn-
|
|
62
|
+
args: [{ selector: 'fe-file-picker', template: "<button class=\"btn btn-sm btn-dark soft ms-2 float-end\" type=\"button\"\n (click.stop)=\"ModalOpen = true\">{{'FileExplorer::SelectFile' | abpLocalization}}</button>\n\n<fe-file-modal [(visible)]=\"ModalOpen\" [selectPickerFile]=\"selectFormFile\" [multiple]=\"_multiple\"\n (selectFilefn)=\"_selectFilefn($event)\" [fileContainerName]=\"_fileContainerName\"></fe-file-modal>\n<table class=\"table\" *ngIf=\"_fileShowTable.length>0\" cdkDropList (cdkDropListDropped)=\"drop($event)\">\n <thead>\n <tr>\n <th scope=\"col\" style=\"width: 30px;\"></th>\n <th scope=\"col\"></th>\n <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n <th scope=\"col\"></th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngFor=\"let item of _fileShowTable;let i =index\">\n <tr cdkDrag cdkDragLockAxis=\"y\" [cdkDragData]=\"item\">\n <td>\n <div class=\"drag-handle\" cdkDragHandle>\n <span class=\"bi bi-arrows-move fs-5\"></span>\n </div>\n </td>\n <td>\n <fe-file-preview [width]=\"'80px'\" [src]=\"item.url||item.Url\" [name]=\"item.name||item.Name\"\n [type]=\"item.mimeType||item.MimeType\" [preview]=\"true\"></fe-file-preview>\n </td>\n <th scope=\"row\">\n <div>{{item.name||item.Name}}</div>\n </th>\n <td>{{_FileApiService.formatFileSize(item.Size||item.size)}}</td>\n <td>\n <button class=\"btn btn-sm p-0 btn-light \" (click.stop)=\"deleteFileTableItem(i,item)\">\n <i class=\"fas fa-trash p-2\"></i>\n </button>\n </td>\n </tr>\n </ng-container>\n </tbody>\n</table>", styles: [".table{border-collapse:collapse;table-layout:fixed}\n"] }]
|
|
63
63
|
}], ctorParameters: () => [{ type: i1.FileApiService }], propDecorators: { multiple: [{
|
|
64
64
|
type: Input
|
|
65
65
|
}], fileContainerName: [{
|
|
@@ -69,4 +69,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
69
69
|
}], selectedFileChange: [{
|
|
70
70
|
type: Output
|
|
71
71
|
}] } });
|
|
72
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-picker.component.js","sourceRoot":"","sources":["../../../../../../../packages/file-explorer/src/lib/components/file-picker/file-picker.component.ts","../../../../../../../packages/file-explorer/src/lib/components/file-picker/file-picker.component.html"],"names":[],"mappings":"AAAA,uDAAuD;AACvD,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,EAAiB,MAAM,eAAe,CAAC;AACjG,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;;;;;;;;AAOzD,MAAM,OAAO,mBAAmB;IAI9B,YACU,eAA+B;QAA/B,oBAAe,GAAf,eAAe,CAAgB;QAMzC,UAAU;QACV,cAAS,GAAY,KAAK,CAAA;QAM1B,UAAU;QACV,uBAAkB,GAAW,QAAQ,CAAA;QAgB3B,uBAAkB,GAAG,IAAI,YAAY,EAAE,CAAA;QAEjD,mBAAc,GAAU,EAAE,CAAA;QAU1B,iBAAiB;QACjB,cAAS,GAAY,KAAK,CAAA;IAxC1B,CAAC;IAKD,IACW,QAAQ,CAAC,CAAU;QAC5B,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;IACrB,CAAC;IAID,IACW,iBAAiB,CAAC,CAAS;QACpC,IAAI,CAAC,kBAAkB,GAAG,CAAC,CAAC;IAC9B,CAAC;IAKD,WAAW,CAAC,OAAsB;QAChC,IAAI,yBAAyB,GAAG,OAAO,CAAC,cAAc,CAAC,cAAc,CAAC,CAAA;QACtE,IAAI,yBAAyB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACzC,IAAI,CAAC,cAAc,GAAG,yBAAyB,CAAA;QACjD,CAAC;IACH,CAAC;IAMD,eAAe;IACf,aAAa,CAAC,KAAY;QACxB,IAAI,cAAc,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,KAAK,CAAC,CAAA;QAC1D,IAAI,CAAC,cAAc,GAAG,cAAc,CAAA;QACpC,IAAI,CAAC,cAAc,GAAG,cAAc,CAAA;QACpC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;IAC9C,CAAC;IAKD,aAAa;IACb,mBAAmB,CAAC,CAAC,EAAE,IAAI;QACzB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAA;QAChC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAA;QACzC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;QAChC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;IACnD,CAAC;IACD,YAAY;IACV,IAAI,CAAC,KAAU;QACb,eAAe,CACb,IAAI,CAAC,cAAc,EACnB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,YAAY,CACnB,CAAC;QACF,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAA;QACzC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;QACjD,+CAA+C;IACjD,CAAC;8GAnEQ,mBAAmB;kGAAnB,mBAAmB,8OCVhC,68DAuCQ;;2FD7BK,mBAAmB;kBAL/B,SAAS;+BACE,gBAAgB;mFAkBf,QAAQ;sBADlB,KAAK;gBAQK,iBAAiB;sBAD3B,KAAK;gBAMG,cAAc;sBAAtB,KAAK;gBASI,kBAAkB;sBAA3B,MAAM","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\nimport { Component, EventEmitter, Input, OnChanges, Output, SimpleChanges } from '@angular/core';\nimport { FileApiService } from '../../services/file-api.service';\nimport { moveItemInArray } from '@angular/cdk/drag-drop';\n\n@Component({\n  selector: 'fe-file-picker',\n  templateUrl: './file-picker.component.html',\n  styleUrls: ['./file-picker.component.scss']\n})\nexport class FilePickerComponent implements OnChanges {\n\n\n\n  constructor(\n    private _FileApiService: FileApiService,\n  ) {\n\n  }\n\n\n  /**是否多选 */\n  _multiple: boolean = false\n  @Input()\n  public set multiple(v: boolean) {\n    this._multiple = v;\n  }\n\n  /**图片容器 */\n  _fileContainerName: string = 'Images'\n  @Input()\n  public set fileContainerName(v: string) {\n    this._fileContainerName = v;\n  }\n\n  /**已选定的文件 */\n  @Input() selectFormFile: any[]\n\n  ngOnChanges(changes: SimpleChanges): void {\n    let selectFormFilengOnChanges = changes.selectFormFile['currentValue']\n    if (selectFormFilengOnChanges.length > 0) {\n      this._fileShowTable = selectFormFilengOnChanges\n    }\n  }\n\n  @Output() selectedFileChange = new EventEmitter()\n\n  _fileShowTable: any[] = []\n\n  /**表格选择的文件回调 */\n  _selectFilefn(event: any[]) {\n    let _fileShowTable = this._FileApiService.deepClone(event)\n    this._fileShowTable = _fileShowTable\n    this.selectFormFile = _fileShowTable\n    this.selectedFileChange.emit(_fileShowTable)\n  }\n\n  /**模态框-状态-是否打开 */\n  ModalOpen: boolean = false\n\n  /**删除文件表格项 */\n  deleteFileTableItem(i, file) {\n    this._fileShowTable.splice(i, 1)\n    this.selectFormFile = this._fileShowTable\n    this.selectedFileChange.emit([])\n    this.selectedFileChange.emit(this.selectFormFile)\n  }\n  /**调整表格位置 */\n    drop(event: any) {\n      moveItemInArray(\n        this._fileShowTable,\n        event.previousIndex,\n        event.currentIndex\n      );\n      this.selectFormFile = this._fileShowTable\n      this.selectedFileChange.emit(this.selectFormFile)\n      // this._fileShowTable.updateValueAndValidity()\n    }\n}\n","<button class=\"btn btn-sm btn-dark soft ms-2 float-end\" type=\"button\"\n    (click.stop)=\"ModalOpen = true\">{{'FileExplorer::SelectFile' | abpLocalization}}</button>\n\n<fe-file-modal [(visible)]=\"ModalOpen\" [selectPickerFile]=\"selectFormFile\" [multiple]=\"_multiple\"\n    (selectFilefn)=\"_selectFilefn($event)\" [fileContainerName]=\"_fileContainerName\"></fe-file-modal>\n<table class=\"table\" *ngIf=\"_fileShowTable.length>0\" cdkDropList (cdkDropListDropped)=\"drop($event)\">\n    <thead>\n        <tr>\n            <th scope=\"col\" style=\"width: 30px;\"></th>\n            <th scope=\"col\"></th>\n            <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n            <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n            <th scope=\"col\"></th>\n        </tr>\n    </thead>\n    <tbody>\n        <ng-container *ngFor=\"let item of _fileShowTable;let i =index\">\n            <tr cdkDrag cdkDragLockAxis=\"y\" [cdkDragData]=\"item\">\n                <td>\n                    <div class=\"drag-handle\" cdkDragHandle>\n                        <span class=\"bi bi-arrows-move fs-5\"></span>\n                    </div>\n                </td>\n                <td>\n                    <fe-file-preview [width]=\"'80px'\" [src]=\"item.url||item.Url\" [name]=\"item.name||item.Name\"\n                        [type]=\"item.mimeType||item.MimeType\" [preview]=\"true\"></fe-file-preview>\n                </td>\n                <th scope=\"row\">\n                    <div>{{item.name||item.Name}}</div>\n                </th>\n                <td>{{_FileApiService.formatFileSize(item.Size||item.size)}}</td>\n                <td>\n                    <button class=\"btn btn-sm p-0 btn-light \" (click.stop)=\"deleteFileTableItem(i,item)\">\n                        <i class=\"fas fa-trash p-2\"></i>\n                    </button>\n                </td>\n            </tr>\n        </ng-container>\n    </tbody>\n</table>"]}
|
|
@@ -456,7 +456,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
456
456
|
}], ctorParameters: () => [{ type: i3.RestService }] });
|
|
457
457
|
|
|
458
458
|
/* eslint-disable @angular-eslint/component-selector */
|
|
459
|
-
var that
|
|
459
|
+
var that;
|
|
460
460
|
class FileModalTreeComponent {
|
|
461
461
|
constructor(_DescriptorService, fb, toaster, _FileApiService, _LocalizationService, confirmation) {
|
|
462
462
|
this._DescriptorService = _DescriptorService;
|
|
@@ -492,7 +492,7 @@ class FileModalTreeComponent {
|
|
|
492
492
|
this.ModalDescriptorBusy = false;
|
|
493
493
|
this.formValidation = '';
|
|
494
494
|
this._ValidatorsService = inject(ValidatorsService);
|
|
495
|
-
that
|
|
495
|
+
that = this;
|
|
496
496
|
}
|
|
497
497
|
set theSelectedTreeNode(v) {
|
|
498
498
|
this._theSelectedTreeNode = v;
|
|
@@ -571,7 +571,7 @@ class FileModalTreeComponent {
|
|
|
571
571
|
order = Math.max(0, node.origin.order - 1);
|
|
572
572
|
}
|
|
573
573
|
// 统一处理移动逻辑
|
|
574
|
-
return that
|
|
574
|
+
return that._DescriptorService.move(dragNode.key, { parentId, order }).pipe(tap(() => that.getFileGroupList()), map(() => true));
|
|
575
575
|
}
|
|
576
576
|
return of(false);
|
|
577
577
|
}
|
|
@@ -712,7 +712,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImpor
|
|
|
712
712
|
}]
|
|
713
713
|
}] });
|
|
714
714
|
|
|
715
|
-
var that;
|
|
716
715
|
class FileModalComponent {
|
|
717
716
|
constructor(_FileService, toaster, list, _FileApiService, restService, confirmation, _LocalizationService) {
|
|
718
717
|
this._FileService = _FileService;
|
|
@@ -782,7 +781,6 @@ class FileModalComponent {
|
|
|
782
781
|
this.newEditRow = '';
|
|
783
782
|
/**是否正在加载 */
|
|
784
783
|
this.isloading = false;
|
|
785
|
-
that = this;
|
|
786
784
|
}
|
|
787
785
|
/**获取目录配置 */
|
|
788
786
|
getFilesConfiguration() {
|
|
@@ -803,8 +801,6 @@ class FileModalComponent {
|
|
|
803
801
|
}
|
|
804
802
|
set multiple(v) {
|
|
805
803
|
this._multiple = v;
|
|
806
|
-
if (v) {
|
|
807
|
-
}
|
|
808
804
|
}
|
|
809
805
|
set limit(v) {
|
|
810
806
|
this.sizeLimit = v;
|
|
@@ -831,7 +827,7 @@ class FileModalComponent {
|
|
|
831
827
|
}
|
|
832
828
|
/**模态框保存 */
|
|
833
829
|
modalSave() {
|
|
834
|
-
|
|
830
|
+
const selectedTablearr = this._FileApiService.deepClone(this.selectedTable);
|
|
835
831
|
this.selectFilefn.emit(selectedTablearr);
|
|
836
832
|
this.ModalVisibleChange(false);
|
|
837
833
|
}
|
|
@@ -860,7 +856,7 @@ class FileModalComponent {
|
|
|
860
856
|
* @returns {Array} - 扁平化后的数组
|
|
861
857
|
*/
|
|
862
858
|
flattenNestedArray(nestedArray) {
|
|
863
|
-
|
|
859
|
+
const result = [];
|
|
864
860
|
function flatten(items) {
|
|
865
861
|
if (!items)
|
|
866
862
|
return;
|
|
@@ -884,7 +880,7 @@ class FileModalComponent {
|
|
|
884
880
|
}
|
|
885
881
|
/**图片上传-获取文件信息改变 */
|
|
886
882
|
async getFileChange(event) {
|
|
887
|
-
|
|
883
|
+
const files = new Array(...event.target.files);
|
|
888
884
|
this.uploadPictureStatusList = files;
|
|
889
885
|
for (const file of files) {
|
|
890
886
|
if (file.size > this.sizeLimit) {
|
|
@@ -902,7 +898,7 @@ class FileModalComponent {
|
|
|
902
898
|
}); // 等待每个文件上传完成
|
|
903
899
|
}
|
|
904
900
|
this.list.get();
|
|
905
|
-
|
|
901
|
+
const isSubmit = !this.uploadPictureStatusList.some(el => el.status == 2);
|
|
906
902
|
if (isSubmit) {
|
|
907
903
|
// this.toaster.success("上传完成");
|
|
908
904
|
setTimeout(() => {
|
|
@@ -920,7 +916,7 @@ class FileModalComponent {
|
|
|
920
916
|
/**图片上传-递归按顺序上传 */
|
|
921
917
|
uploadingFile(file) {
|
|
922
918
|
return new Promise((resolve, rejects) => {
|
|
923
|
-
|
|
919
|
+
const formData = new FormData();
|
|
924
920
|
formData.append('file', file, file.name);
|
|
925
921
|
this.createFile({
|
|
926
922
|
file: formData,
|
|
@@ -970,7 +966,7 @@ class FileModalComponent {
|
|
|
970
966
|
})
|
|
971
967
|
.subscribe(async (status) => {
|
|
972
968
|
if (status == 'confirm') {
|
|
973
|
-
|
|
969
|
+
const selectedTable = this.selectedTable;
|
|
974
970
|
try {
|
|
975
971
|
const result = await this.batchDeleteItems(selectedTable);
|
|
976
972
|
if (result.success) {
|
|
@@ -981,7 +977,6 @@ class FileModalComponent {
|
|
|
981
977
|
else {
|
|
982
978
|
//删除失败的项
|
|
983
979
|
this.list.get();
|
|
984
|
-
// console.warn(result.message);
|
|
985
980
|
// 可以选择展示失败项或重试
|
|
986
981
|
}
|
|
987
982
|
}
|
|
@@ -1009,7 +1004,6 @@ class FileModalComponent {
|
|
|
1009
1004
|
});
|
|
1010
1005
|
// 等待所有请求完成
|
|
1011
1006
|
const results = await Promise.allSettled(deletePromises);
|
|
1012
|
-
console.log(results, 'resultsresultsresults');
|
|
1013
1007
|
// 收集失败的项
|
|
1014
1008
|
const failedItems = [];
|
|
1015
1009
|
results.forEach(result => {
|
|
@@ -1090,7 +1084,7 @@ class FileModalComponent {
|
|
|
1090
1084
|
}
|
|
1091
1085
|
/**提交FileName编辑 */
|
|
1092
1086
|
onSubmitFileName(event) {
|
|
1093
|
-
|
|
1087
|
+
const input = this.FileNameForm.value;
|
|
1094
1088
|
if (!this.FileNameForm.valid)
|
|
1095
1089
|
return;
|
|
1096
1090
|
if (this.isloading)
|
|
@@ -1217,11 +1211,11 @@ class FilePickerComponent {
|
|
|
1217
1211
|
// this._fileShowTable.updateValueAndValidity()
|
|
1218
1212
|
}
|
|
1219
1213
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FilePickerComponent, deps: [{ token: FileApiService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1220
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: FilePickerComponent, selector: "fe-file-picker", inputs: { multiple: "multiple", fileContainerName: "fileContainerName", selectFormFile: "selectFormFile" }, outputs: { selectedFileChange: "selectedFileChange" }, usesOnChanges: true, ngImport: i0, template: "<button class=\"btn btn-sm btn-
|
|
1214
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.5", type: FilePickerComponent, selector: "fe-file-picker", inputs: { multiple: "multiple", fileContainerName: "fileContainerName", selectFormFile: "selectFormFile" }, outputs: { selectedFileChange: "selectedFileChange" }, usesOnChanges: true, ngImport: i0, template: "<button class=\"btn btn-sm btn-dark soft ms-2 float-end\" type=\"button\"\n (click.stop)=\"ModalOpen = true\">{{'FileExplorer::SelectFile' | abpLocalization}}</button>\n\n<fe-file-modal [(visible)]=\"ModalOpen\" [selectPickerFile]=\"selectFormFile\" [multiple]=\"_multiple\"\n (selectFilefn)=\"_selectFilefn($event)\" [fileContainerName]=\"_fileContainerName\"></fe-file-modal>\n<table class=\"table\" *ngIf=\"_fileShowTable.length>0\" cdkDropList (cdkDropListDropped)=\"drop($event)\">\n <thead>\n <tr>\n <th scope=\"col\" style=\"width: 30px;\"></th>\n <th scope=\"col\"></th>\n <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n <th scope=\"col\"></th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngFor=\"let item of _fileShowTable;let i =index\">\n <tr cdkDrag cdkDragLockAxis=\"y\" [cdkDragData]=\"item\">\n <td>\n <div class=\"drag-handle\" cdkDragHandle>\n <span class=\"bi bi-arrows-move fs-5\"></span>\n </div>\n </td>\n <td>\n <fe-file-preview [width]=\"'80px'\" [src]=\"item.url||item.Url\" [name]=\"item.name||item.Name\"\n [type]=\"item.mimeType||item.MimeType\" [preview]=\"true\"></fe-file-preview>\n </td>\n <th scope=\"row\">\n <div>{{item.name||item.Name}}</div>\n </th>\n <td>{{_FileApiService.formatFileSize(item.Size||item.size)}}</td>\n <td>\n <button class=\"btn btn-sm p-0 btn-light \" (click.stop)=\"deleteFileTableItem(i,item)\">\n <i class=\"fas fa-trash p-2\"></i>\n </button>\n </td>\n </tr>\n </ng-container>\n </tbody>\n</table>", styles: [".table{border-collapse:collapse;table-layout:fixed}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.StopPropagationDirective, selector: "[click.stop]", outputs: ["click.stop"] }, { kind: "directive", type: i4.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i4.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i4.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "component", type: FileModalComponent, selector: "fe-file-modal", inputs: ["fileContainerName", "multiple", "limit", "visible", "selectPickerFile"], outputs: ["visibleChange", "selectFilefn"] }, { kind: "component", type: FilePreviewComponent, selector: "fe-file-preview", inputs: ["width", "src", "preview", "type", "name", "className"] }, { kind: "pipe", type: i3.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
1221
1215
|
}
|
|
1222
1216
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.5", ngImport: i0, type: FilePickerComponent, decorators: [{
|
|
1223
1217
|
type: Component,
|
|
1224
|
-
args: [{ selector: 'fe-file-picker', template: "<button class=\"btn btn-sm btn-
|
|
1218
|
+
args: [{ selector: 'fe-file-picker', template: "<button class=\"btn btn-sm btn-dark soft ms-2 float-end\" type=\"button\"\n (click.stop)=\"ModalOpen = true\">{{'FileExplorer::SelectFile' | abpLocalization}}</button>\n\n<fe-file-modal [(visible)]=\"ModalOpen\" [selectPickerFile]=\"selectFormFile\" [multiple]=\"_multiple\"\n (selectFilefn)=\"_selectFilefn($event)\" [fileContainerName]=\"_fileContainerName\"></fe-file-modal>\n<table class=\"table\" *ngIf=\"_fileShowTable.length>0\" cdkDropList (cdkDropListDropped)=\"drop($event)\">\n <thead>\n <tr>\n <th scope=\"col\" style=\"width: 30px;\"></th>\n <th scope=\"col\"></th>\n <th scope=\"col\">{{'FileExplorer::FileName' | abpLocalization}}</th>\n <th scope=\"col\">{{'FileExplorer::FileSize' | abpLocalization}}</th>\n <th scope=\"col\"></th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngFor=\"let item of _fileShowTable;let i =index\">\n <tr cdkDrag cdkDragLockAxis=\"y\" [cdkDragData]=\"item\">\n <td>\n <div class=\"drag-handle\" cdkDragHandle>\n <span class=\"bi bi-arrows-move fs-5\"></span>\n </div>\n </td>\n <td>\n <fe-file-preview [width]=\"'80px'\" [src]=\"item.url||item.Url\" [name]=\"item.name||item.Name\"\n [type]=\"item.mimeType||item.MimeType\" [preview]=\"true\"></fe-file-preview>\n </td>\n <th scope=\"row\">\n <div>{{item.name||item.Name}}</div>\n </th>\n <td>{{_FileApiService.formatFileSize(item.Size||item.size)}}</td>\n <td>\n <button class=\"btn btn-sm p-0 btn-light \" (click.stop)=\"deleteFileTableItem(i,item)\">\n <i class=\"fas fa-trash p-2\"></i>\n </button>\n </td>\n </tr>\n </ng-container>\n </tbody>\n</table>", styles: [".table{border-collapse:collapse;table-layout:fixed}\n"] }]
|
|
1225
1219
|
}], ctorParameters: () => [{ type: FileApiService }], propDecorators: { multiple: [{
|
|
1226
1220
|
type: Input
|
|
1227
1221
|
}], fileContainerName: [{
|