You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
devdocs/assets/javascripts/views/view.js

250 lines
5.1 KiB

app.View = class View extends Events {
constructor(el) {
super();
if (el instanceof HTMLElement) {
this.el = el;
}
this.setupElement();
1 year ago
if (this.el.className) {
this.originalClassName = this.el.className;
}
if (this.constructor.className) {
this.resetClass();
}
this.refreshElements();
1 year ago
if (typeof this.init === "function") {
this.init();
this.refreshElements();
}
}
setupElement() {
1 year ago
if (this.el == null) {
this.el =
typeof this.constructor.el === "string"
? $(this.constructor.el)
: this.constructor.el
? this.constructor.el
: document.createElement(this.constructor.tagName || "div");
}
if (this.constructor.attributes) {
for (var key in this.constructor.attributes) {
var value = this.constructor.attributes[key];
this.el.setAttribute(key, value);
}
}
}
refreshElements() {
if (this.constructor.elements) {
1 year ago
for (var name in this.constructor.elements) {
var selector = this.constructor.elements[name];
this[name] = this.find(selector);
}
}
}
addClass(name) {
this.el.classList.add(name);
}
removeClass(name) {
this.el.classList.remove(name);
}
toggleClass(name) {
this.el.classList.toggle(name);
}
hasClass(name) {
return this.el.classList.contains(name);
}
resetClass() {
1 year ago
this.el.className = this.originalClassName || "";
if (this.constructor.className) {
1 year ago
for (var name of Array.from(this.constructor.className.split(" "))) {
this.addClass(name);
}
}
}
find(selector) {
return $(selector, this.el);
}
findAll(selector) {
return $$(selector, this.el);
}
findByClass(name) {
return this.findAllByClass(name)[0];
}
findLastByClass(name) {
const all = this.findAllByClass(name)[0];
return all[all.length - 1];
}
findAllByClass(name) {
return this.el.getElementsByClassName(name);
}
findByTag(tag) {
return this.findAllByTag(tag)[0];
}
findLastByTag(tag) {
const all = this.findAllByTag(tag);
return all[all.length - 1];
}
findAllByTag(tag) {
return this.el.getElementsByTagName(tag);
}
append(value) {
$.append(this.el, value.el || value);
}
appendTo(value) {
$.append(value.el || value, this.el);
}
prepend(value) {
$.prepend(this.el, value.el || value);
}
prependTo(value) {
$.prepend(value.el || value, this.el);
}
before(value) {
$.before(this.el, value.el || value);
}
after(value) {
$.after(this.el, value.el || value);
}
remove(value) {
$.remove(value.el || value);
}
empty() {
$.empty(this.el);
this.refreshElements();
}
html(value) {
this.empty();
this.append(value);
}
tmpl(...args) {
return app.templates.render(...args);
}
delay(fn, ...args) {
1 year ago
const delay = typeof args[args.length - 1] === "number" ? args.pop() : 0;
return setTimeout(fn.bind(this, ...args), delay);
}
onDOM(event, callback) {
$.on(this.el, event, callback);
}
offDOM(event, callback) {
$.off(this.el, event, callback);
}
bindEvents() {
let method, name;
if (this.constructor.events) {
1 year ago
for (name in this.constructor.events) {
method = this.constructor.events[name];
this[method] = this[method].bind(this);
1 year ago
this.onDOM(name, this[method]);
}
}
if (this.constructor.routes) {
1 year ago
for (name in this.constructor.routes) {
method = this.constructor.routes[name];
this[method] = this[method].bind(this);
1 year ago
app.router.on(name, this[method]);
}
}
if (this.constructor.shortcuts) {
1 year ago
for (name in this.constructor.shortcuts) {
method = this.constructor.shortcuts[name];
this[method] = this[method].bind(this);
1 year ago
app.shortcuts.on(name, this[method]);
}
}
}
unbindEvents() {
let method, name;
if (this.constructor.events) {
1 year ago
for (name in this.constructor.events) {
method = this.constructor.events[name];
this.offDOM(name, this[method]);
}
}
if (this.constructor.routes) {
1 year ago
for (name in this.constructor.routes) {
method = this.constructor.routes[name];
app.router.off(name, this[method]);
}
}
if (this.constructor.shortcuts) {
1 year ago
for (name in this.constructor.shortcuts) {
method = this.constructor.shortcuts[name];
app.shortcuts.off(name, this[method]);
}
}
}
addSubview(view) {
return (this.subviews || (this.subviews = [])).push(view);
}
activate() {
1 year ago
if (this.activated) {
return;
}
this.bindEvents();
1 year ago
if (this.subviews) {
for (var view of Array.from(this.subviews)) {
view.activate();
}
}
this.activated = true;
return true;
}
deactivate() {
1 year ago
if (!this.activated) {
return;
}
this.unbindEvents();
1 year ago
if (this.subviews) {
for (var view of Array.from(this.subviews)) {
view.deactivate();
}
}
this.activated = false;
return true;
}
detach() {
this.deactivate();
$.remove(this.el);
}
};