aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--vfs/vfs.d.ts26
-rw-r--r--vfs/vfs.js84
-rw-r--r--vfs/vfs.ts90
3 files changed, 92 insertions, 108 deletions
diff --git a/vfs/vfs.d.ts b/vfs/vfs.d.ts
index c15d29c..3be3f6a 100644
--- a/vfs/vfs.d.ts
+++ b/vfs/vfs.d.ts
@@ -22,31 +22,15 @@ export interface VfsOptions {
export declare class Vfs {
opts: VfsOptions;
private el;
- private comPath;
- private comList;
- private pathNode;
+ private com_path;
+ private com_list;
+ private path_node;
constructor(opts: VfsOptions);
- init(): Promise<void>;
- onClickNode(this: Vfs, node: VfsNode): void;
+ private init;
+ private open;
OpenPath(this: Vfs, path: string): void;
- open(node: VfsNode): void;
-}
-declare class VfsNode implements IVfsNode {
- path: string;
- name: string;
- mod_time_epoch: number;
- mod_time_rfc3339: string;
- size: number;
- mode: string;
- is_dir: boolean;
- childs: VfsNode[];
- el: HTMLElement;
- constructor(opts: IVfsNode, onClick: NodeClickHandler);
- onMouseOut(t: VfsNode): void;
- onMouseOver(t: VfsNode): void;
}
declare type IPathNode = {
[key: string]: IVfsNode;
};
-declare type NodeClickHandler = (node: VfsNode) => void;
export {};
diff --git a/vfs/vfs.js b/vfs/vfs.js
index 7674847..0a0ef33 100644
--- a/vfs/vfs.js
+++ b/vfs/vfs.js
@@ -43,74 +43,74 @@ exports.Vfs = void 0;
var Vfs = /** @class */ (function () {
function Vfs(opts) {
this.opts = opts;
- this.el = null;
- this.pathNode = {};
- this.el = document.getElementById(opts.id);
- if (!this.el) {
+ this.path_node = {};
+ var el = document.getElementById(opts.id);
+ if (!el) {
console.error("Vfs: element id", opts.id, "not found");
return;
}
+ this.el = el;
}
+ //
+ // (0) Fetch the list of nodes from remote server and store it in path_node.
+ // (1) Create the VfsPath
+ // (2) Create the VfsList
+ // (3) Open the root "/"
+ //
Vfs.prototype.init = function () {
return __awaiter(this, void 0, void 0, function () {
- var resPathNode, key, value, node;
+ var res_path_node, key, value, node;
var _this = this;
return __generator(this, function (_a) {
switch (_a.label) {
- case 0:
- if (!this.el) {
- return [2 /*return*/];
- }
- return [4 /*yield*/, this.opts.ListNodes()];
+ case 0: return [4 /*yield*/, this.opts.ListNodes()];
case 1:
- resPathNode = _a.sent();
- if (!resPathNode) {
+ res_path_node = _a.sent();
+ if (!res_path_node) {
return [2 /*return*/];
}
- for (key in resPathNode) {
- value = resPathNode[key];
+ for (key in res_path_node) {
+ value = res_path_node[key];
node = new VfsNode(value, function (node) {
- _this.onClickNode(node);
+ if (_this.opts.OnClickNode) {
+ _this.opts.OnClickNode(node.path, node.is_dir);
+ }
+ if (node.is_dir) {
+ _this.open(node);
+ }
});
- this.pathNode[key] = node;
+ this.path_node[key] = node;
}
this.el.innerHTML = "";
- this.comPath = new VfsPath(function (path) {
+ // (1)
+ this.com_path = new VfsPath(function (path) {
_this.OpenPath(path);
});
- this.el.appendChild(this.comPath.el);
- this.comList = new VfsList();
- this.el.appendChild(this.comList.el);
- this.open(this.pathNode["/"]);
+ this.el.appendChild(this.com_path.el);
+ // (2)
+ this.com_list = new VfsList();
+ this.el.appendChild(this.com_list.el);
+ // (3)
+ this.open(this.path_node["/"]);
return [2 /*return*/];
}
});
});
};
- Vfs.prototype.onClickNode = function (node) {
- if (this.opts.OnClickNode) {
- this.opts.OnClickNode(node.path, node.is_dir);
- }
- if (node.is_dir) {
- this.comPath.open(node);
- this.comList.open(node);
- }
+ Vfs.prototype.open = function (node) {
+ this.com_path.open(node);
+ this.com_list.open(node);
};
+ // OpenPath is a handler that will be called when the directory name on
+ // top of UI clicked.
Vfs.prototype.OpenPath = function (path) {
- var node = this.pathNode[path];
+ var node = this.path_node[path];
if (!node) {
console.error("Vfs: OpenPath: invalid path: ", path);
return;
}
- if (this.opts.OnClickNode) {
- this.opts.OnClickNode(node.path, node.is_dir);
- }
this.open(node);
};
- Vfs.prototype.open = function (node) {
- this.comPath.open(node);
- this.comList.open(node);
- };
return Vfs;
}());
exports.Vfs = Vfs;
@@ -201,15 +201,15 @@ var VfsPath = /** @class */ (function () {
paths = node.path.split("/");
}
var _loop_1 = function (x) {
- var fullPath = "";
+ var full_path = "";
var p = "";
if (x == 0) {
p = "/";
- fullPath = "/";
+ full_path = "/";
}
else {
p = paths[x];
- fullPath = paths.slice(0, x + 1).join("/");
+ full_path = paths.slice(0, x + 1).join("/");
}
var crumb = document.createElement("span");
crumb.style.display = "inline-block";
@@ -217,7 +217,7 @@ var VfsPath = /** @class */ (function () {
crumb.style.cursor = "pointer";
crumb.innerHTML = p;
crumb.onclick = function (event) {
- _this.onClick(fullPath);
+ _this.onClick(full_path);
};
crumb.onmouseout = function (event) {
_this.onMouseOut(crumb, event);
@@ -240,4 +240,4 @@ var VfsPath = /** @class */ (function () {
};
return VfsPath;
}());
-//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vfs.js","sourceRoot":"","sources":["vfs.ts"],"names":[],"mappings":"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"} \ No newline at end of file
+//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vfs.js","sourceRoot":"","sources":["vfs.ts"],"names":[],"mappings":"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"} \ No newline at end of file
diff --git a/vfs/vfs.ts b/vfs/vfs.ts
index a77608a..a39f0f1 100644
--- a/vfs/vfs.ts
+++ b/vfs/vfs.ts
@@ -32,77 +32,77 @@ export interface VfsOptions {
}
export class Vfs {
- private el: HTMLElement | null = null
- private comPath!: VfsPath
- private comList!: VfsList
- private pathNode: PathNode = {}
+ private el!: HTMLElement
+ private com_path!: VfsPath
+ private com_list!: VfsList
+ private path_node: PathNode = {}
constructor(public opts: VfsOptions) {
- this.el = document.getElementById(opts.id)
- if (!this.el) {
+ let el = document.getElementById(opts.id)
+ if (!el) {
console.error("Vfs: element id", opts.id, "not found")
return
}
+ this.el = el
}
- async init() {
- if (!this.el) {
+ //
+ // (0) Fetch the list of nodes from remote server and store it in path_node.
+ // (1) Create the VfsPath
+ // (2) Create the VfsList
+ // (3) Open the root "/"
+ //
+ private async init() {
+ // (0)
+ let res_path_node = await this.opts.ListNodes()
+ if (!res_path_node) {
return
}
- let resPathNode = await this.opts.ListNodes()
- if (!resPathNode) {
- return
- }
-
- for (const key in resPathNode) {
- const value = resPathNode[key] as IVfsNode
+ for (const key in res_path_node) {
+ const value = res_path_node[key] as IVfsNode
const node = new VfsNode(value, (node: VfsNode) => {
- this.onClickNode(node)
+ if (this.opts.OnClickNode) {
+ this.opts.OnClickNode(node.path, node.is_dir)
+ }
+ if (node.is_dir) {
+ this.open(node)
+ }
})
- this.pathNode[key] = node
+ this.path_node[key] = node
}
this.el.innerHTML = ""
- this.comPath = new VfsPath((path: string) => {
+ // (1)
+ this.com_path = new VfsPath((path: string) => {
this.OpenPath(path)
})
- this.el.appendChild(this.comPath.el)
+ this.el.appendChild(this.com_path.el)
- this.comList = new VfsList()
- this.el.appendChild(this.comList.el)
+ // (2)
+ this.com_list = new VfsList()
+ this.el.appendChild(this.com_list.el)
- this.open(this.pathNode["/"])
+ // (3)
+ this.open(this.path_node["/"])
}
- onClickNode(this: Vfs, node: VfsNode) {
- if (this.opts.OnClickNode) {
- this.opts.OnClickNode(node.path, node.is_dir)
- }
- if (node.is_dir) {
- this.comPath.open(node)
- this.comList.open(node)
- }
+ private open(node: VfsNode) {
+ this.com_path.open(node)
+ this.com_list.open(node)
}
- OpenPath(this: Vfs, path: string) {
- const node = this.pathNode[path]
+ // OpenPath is a handler that will be called when the directory name on
+ // top of UI clicked.
+ public OpenPath(this: Vfs, path: string) {
+ const node = this.path_node[path]
if (!node) {
console.error("Vfs: OpenPath: invalid path: ", path)
return
}
- if (this.opts.OnClickNode) {
- this.opts.OnClickNode(node.path, node.is_dir)
- }
this.open(node)
}
-
- open(node: VfsNode) {
- this.comPath.open(node)
- this.comList.open(node)
- }
-
}
class VfsNode implements IVfsNode {
@@ -214,15 +214,15 @@ class VfsPath {
}
for (let x = 0; x < paths.length; x++) {
- let fullPath = ""
+ let full_path = ""
let p = ""
if (x == 0) {
p = "/"
- fullPath = "/"
+ full_path = "/"
} else {
p = paths[x]
- fullPath = paths.slice(0, x + 1).join("/")
+ full_path = paths.slice(0, x + 1).join("/")
}
let crumb = document.createElement("span")
@@ -232,7 +232,7 @@ class VfsPath {
crumb.innerHTML = p
crumb.onclick = (event) => {
- this.onClick(fullPath)
+ this.onClick(full_path)
}
crumb.onmouseout = (event) => {
this.onMouseOut(crumb, event)