132 lines
4.6 KiB
JavaScript
132 lines
4.6 KiB
JavaScript
/** @odoo-module **/
|
|
|
|
|
|
import AbstractRendererOwl from 'web.AbstractRendererOwl';
|
|
import BasicView from "web.BasicView";
|
|
import BasicRenderer from "web.BasicRenderer";
|
|
import RendererWrapper from 'web.RendererWrapper';
|
|
import { createView } from 'web.test_utils';
|
|
|
|
import StandaloneM2OAvatarEmployee from '@hr/js/standalone_m2o_avatar_employee';
|
|
|
|
const { xml } = owl;
|
|
|
|
function getHtmlRenderer(html) {
|
|
return BasicRenderer.extend({
|
|
start: function () {
|
|
this.$el.html(html);
|
|
return this._super.apply(this, arguments);
|
|
}
|
|
});
|
|
}
|
|
|
|
function getOwlView(owlRenderer, viewType) {
|
|
viewType = viewType || "test";
|
|
return BasicView.extend({
|
|
viewType: viewType,
|
|
config: Object.assign({}, BasicView.prototype.config, {
|
|
Renderer: owlRenderer,
|
|
}),
|
|
getRenderer() {
|
|
return new RendererWrapper(null, this.config.Renderer, {});
|
|
}
|
|
});
|
|
}
|
|
|
|
function getHtmlView(html, viewType) {
|
|
viewType = viewType || "test";
|
|
return BasicView.extend({
|
|
viewType: viewType,
|
|
config: Object.assign({}, BasicView.prototype.config, {
|
|
Renderer: getHtmlRenderer(html)
|
|
})
|
|
});
|
|
}
|
|
|
|
QUnit.module('hr', {}, function () {
|
|
QUnit.module('StandaloneM2OEmployeeTests', {
|
|
beforeEach: function () {
|
|
this.data = {
|
|
'foo': {
|
|
fields: {
|
|
employee_id: {string: "Employee", type: 'many2one', relation: 'hr.employee'},
|
|
},
|
|
records: [],
|
|
},
|
|
'hr.employee': {
|
|
fields: {},
|
|
records: [
|
|
{id: 10, name: "Mario"},
|
|
{id: 20, name: "Luigi"},
|
|
{id: 30, name: "Yoshi"}
|
|
],
|
|
},
|
|
'hr.employee.public': {
|
|
fields: {},
|
|
records: [
|
|
{id: 10, name: "Mario"},
|
|
{id: 20, name: "Luigi"},
|
|
{id: 30, name: "Yoshi"}
|
|
],
|
|
},
|
|
};
|
|
},
|
|
});
|
|
|
|
QUnit.test('standalone_m2o_avatar_employee: legacy view', async function (assert) {
|
|
assert.expect(1);
|
|
|
|
const html = "<div class='coucou_test'></div>";
|
|
const view = await createView({
|
|
View: getHtmlView(html, "test"),
|
|
data: this.data,
|
|
model: "foo",
|
|
arch: "<test/>"
|
|
});
|
|
|
|
const avatar10 = new StandaloneM2OAvatarEmployee(view, 10);
|
|
const avatar20 = new StandaloneM2OAvatarEmployee(view, 20);
|
|
const avatar30 = new StandaloneM2OAvatarEmployee(view, [30, 'Bowser']);
|
|
|
|
await avatar10.appendTo(view.el.querySelector('.coucou_test'));
|
|
await avatar20.appendTo(view.el.querySelector('.coucou_test'));
|
|
await avatar30.appendTo(view.el.querySelector('.coucou_test'));
|
|
|
|
assert.deepEqual(
|
|
[...view.el.querySelectorAll('.o_field_many2one_avatar span')].map(el => el.innerText),
|
|
["Mario", "Luigi", "Bowser"]
|
|
);
|
|
|
|
view.destroy();
|
|
});
|
|
|
|
QUnit.test('standalone_m2o_avatar_employee: Owl view', async function (assert) {
|
|
assert.expect(1);
|
|
|
|
class Renderer extends AbstractRendererOwl { }
|
|
Renderer.template = xml`<div class='coucou_test'></div>`;
|
|
|
|
const view = await createView({
|
|
View: getOwlView(Renderer, "test"),
|
|
data: this.data,
|
|
model: "foo",
|
|
arch: "<test/>"
|
|
});
|
|
|
|
const avatar10 = new StandaloneM2OAvatarEmployee(view, 10);
|
|
const avatar20 = new StandaloneM2OAvatarEmployee(view, 20);
|
|
const avatar30 = new StandaloneM2OAvatarEmployee(view, [30, 'Bowser']);
|
|
|
|
await avatar10.appendTo(view.el.querySelector('.coucou_test'));
|
|
await avatar20.appendTo(view.el.querySelector('.coucou_test'));
|
|
await avatar30.appendTo(view.el.querySelector('.coucou_test'));
|
|
|
|
assert.deepEqual(
|
|
[...view.el.querySelectorAll('.o_field_many2one_avatar span')].map(el => el.innerText),
|
|
["Mario", "Luigi", "Bowser"]
|
|
);
|
|
|
|
view.destroy();
|
|
});
|
|
});
|