ywana-core8 0.0.890 → 0.0.892

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.
@@ -4303,8 +4303,12 @@ var UploadDialog = function UploadDialog(_ref) {
4303
4303
  var FileExplorer = function FileExplorer(props) {
4304
4304
  var _props$files = props.files,
4305
4305
  files = _props$files === void 0 ? [] : _props$files,
4306
+ onSelectFile = props.onSelectFile,
4306
4307
  _props$folders = props.folders,
4307
- folders = _props$folders === void 0 ? [] : _props$folders;
4308
+ folders = _props$folders === void 0 ? [] : _props$folders,
4309
+ onSelectFolder = props.onSelectFolder,
4310
+ _props$defaultView = props.defaultView,
4311
+ defaultView = _props$defaultView === void 0 ? "grid" : _props$defaultView;
4308
4312
  var _useState = useState(),
4309
4313
  selectedFolder = _useState[0],
4310
4314
  setSelectedFolder = _useState[1];
@@ -4314,6 +4318,18 @@ var FileExplorer = function FileExplorer(props) {
4314
4318
  var _useState3 = useState(),
4315
4319
  search = _useState3[0],
4316
4320
  setSearch = _useState3[1];
4321
+ useEffect(function () {
4322
+ if (files.length > 0) {
4323
+ setSelectedFolder(files[0].folder);
4324
+ setSelectedFile(files[0].id);
4325
+ }
4326
+ }, [files]);
4327
+ useEffect(function () {
4328
+ if (onSelectFile) onSelectFile(selectedFile);
4329
+ }, [selectedFile]);
4330
+ useEffect(function () {
4331
+ if (onSelectFolder) onSelectFolder(selectedFolder);
4332
+ }, [selectedFolder]);
4317
4333
  function selectFolder(id) {
4318
4334
  setSelectedFolder(id);
4319
4335
  }
@@ -4329,14 +4345,7 @@ var FileExplorer = function FileExplorer(props) {
4329
4345
  var selectedFiles = filteredFiles.filter(function (file) {
4330
4346
  return file.folder === selectedFolder;
4331
4347
  });
4332
- return /*#__PURE__*/React.createElement("div", {
4333
- style: {
4334
- padding: "1rem",
4335
- flex: "1",
4336
- height: "100%"
4337
- }
4338
- }, /*#__PURE__*/React.createElement(FileExplorerView, {
4339
- title: "File Explorer Test",
4348
+ return /*#__PURE__*/React.createElement(FileExplorerView, {
4340
4349
  folders: folders,
4341
4350
  selectedFolder: selectedFolder,
4342
4351
  onSelectFolder: selectFolder,
@@ -4344,8 +4353,9 @@ var FileExplorer = function FileExplorer(props) {
4344
4353
  selectedFile: selectedFile,
4345
4354
  onSelectFile: selectFile,
4346
4355
  search: search,
4347
- onSearch: searchChanged
4348
- }));
4356
+ onSearch: searchChanged,
4357
+ selectedView: defaultView
4358
+ });
4349
4359
  };
4350
4360
 
4351
4361
  /**
@@ -4361,8 +4371,10 @@ var FileExplorerView = function FileExplorerView(props) {
4361
4371
  selectedFile = props.selectedFile,
4362
4372
  onSelectFile = props.onSelectFile,
4363
4373
  search = props.search,
4364
- onSearch = props.onSearch;
4365
- var _useState4 = useState('list'),
4374
+ onSearch = props.onSearch,
4375
+ _props$selectedView = props.selectedView,
4376
+ selectedView = _props$selectedView === void 0 ? "grid" : _props$selectedView;
4377
+ var _useState4 = useState(selectedView),
4366
4378
  view = _useState4[0],
4367
4379
  setView = _useState4[1];
4368
4380
  var folder = folders.find(function (folder) {
@@ -4416,15 +4428,26 @@ var FoldersTreeView = function FoldersTreeView(props) {
4416
4428
  return selected === id;
4417
4429
  }
4418
4430
  return /*#__PURE__*/React.createElement(Tree, null, folders.map(function (folder) {
4419
- return /*#__PURE__*/React.createElement(TreeItem, {
4420
- key: folder.id,
4421
- icon: folder.icon,
4422
- label: folder.title,
4423
- onSelect: function onSelect() {
4424
- return _onSelect(folder.id);
4425
- },
4426
- selected: isSelected(folder.id)
4427
- });
4431
+ if (folder.children) {
4432
+ return /*#__PURE__*/React.createElement(TreeNode, {
4433
+ key: folder.id,
4434
+ label: folder.title
4435
+ }, /*#__PURE__*/React.createElement(FoldersTreeView, {
4436
+ folders: folder.children,
4437
+ selected: selected,
4438
+ onSelect: _onSelect
4439
+ }));
4440
+ } else {
4441
+ return /*#__PURE__*/React.createElement(TreeItem, {
4442
+ key: folder.id,
4443
+ icon: folder.icon,
4444
+ label: folder.title,
4445
+ onSelect: function onSelect() {
4446
+ return _onSelect(folder.id);
4447
+ },
4448
+ selected: isSelected(folder.id)
4449
+ });
4450
+ }
4428
4451
  }));
4429
4452
  };
4430
4453
  var FilesSearchBox = function FilesSearchBox(props) {