DEV: fix tests, remove deprecation, fix for slider (#16)
This commit is contained in:
parent
df87e144ef
commit
312faa8556
|
@ -67,28 +67,50 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.user-card-directory-footer {
|
.user-card-directory-footer {
|
||||||
|
display: grid;
|
||||||
|
grid-template-columns: repeat(auto-fit, minmax(5em, 1fr));
|
||||||
|
padding: 0.75em;
|
||||||
background-color: var(--secondary);
|
background-color: var(--secondary);
|
||||||
padding: 0px 10px 10px 10px;
|
gap: 0.25em;
|
||||||
display: flex;
|
border-top: 1px solid var(--primary-low);
|
||||||
flex-wrap: wrap;
|
|
||||||
|
.directory-table__column-header,
|
||||||
|
.directory-table__cell,
|
||||||
|
.directory-table__cell--empty,
|
||||||
|
.directory-table__cell--user-field {
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
|
||||||
.stat {
|
.stat {
|
||||||
flex-basis: 0;
|
|
||||||
flex-grow: 1;
|
|
||||||
|
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
margin: 2px;
|
gap: 0.1em;
|
||||||
|
border: none;
|
||||||
|
|
||||||
.label {
|
.label {
|
||||||
font-size: $font-down-2;
|
font-size: var(--font-down-2);
|
||||||
|
|
||||||
.d-icon {
|
.d-icon {
|
||||||
margin-right: 0.2em;
|
margin-right: 0.2em;
|
||||||
color: var(--primary-medium);
|
color: var(--primary-medium);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&.stat-type-user_field {
|
||||||
|
// long user fields can break the layout
|
||||||
|
// so we truncate these to one line
|
||||||
|
.value {
|
||||||
|
display: flex;
|
||||||
|
overflow: hidden;
|
||||||
|
justify-content: center;
|
||||||
|
width: 100%;
|
||||||
|
min-width: 0;
|
||||||
|
span {
|
||||||
|
min-width: 0;
|
||||||
|
@include ellipsis;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
import UserCardContents from "discourse/components/user-card-contents";
|
import UserCardContents from "discourse/components/user-card-contents";
|
||||||
|
import { action } from "@ember/object";
|
||||||
|
|
||||||
export default UserCardContents.extend({
|
export default UserCardContents.extend({
|
||||||
layoutName: "components/user-card-contents",
|
layoutName: "components/user-card-contents",
|
||||||
|
@ -8,4 +9,10 @@ export default UserCardContents.extend({
|
||||||
didInsertElement() {},
|
didInsertElement() {},
|
||||||
willDestroyElement() {},
|
willDestroyElement() {},
|
||||||
keyUp() {},
|
keyUp() {},
|
||||||
|
|
||||||
|
// need to override this to work with the loading slider
|
||||||
|
@action
|
||||||
|
handleShowUser() {
|
||||||
|
return;
|
||||||
|
},
|
||||||
});
|
});
|
||||||
|
|
|
@ -5,11 +5,11 @@
|
||||||
}}
|
}}
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<div class="users-directory directory">
|
<div class="users-directory directory">
|
||||||
{{plugin-outlet
|
<PluginOutlet
|
||||||
name="users-top"
|
@name="users-top"
|
||||||
connectorTagName="div"
|
@connectorTagName="div"
|
||||||
args=(hash model=model)
|
@outletArgs={{hash model=this.model}}
|
||||||
}}
|
/>
|
||||||
<div class="directory-controls">
|
<div class="directory-controls">
|
||||||
<div class="period-controls">
|
<div class="period-controls">
|
||||||
{{period-chooser
|
{{period-chooser
|
||||||
|
@ -30,12 +30,15 @@
|
||||||
{{i18n "directory.total_rows" count=model.totalRows}}
|
{{i18n "directory.total_rows" count=model.totalRows}}
|
||||||
{{/if}}
|
{{/if}}
|
||||||
</label>
|
</label>
|
||||||
{{input
|
<Input
|
||||||
value=(readonly nameInput)
|
@value={{readonly emailInput}}
|
||||||
input=(action "onUsernameFilterChanged" value="target.value")
|
placeholder={{I18n "directory.filter_name"}}
|
||||||
placeholderKey="directory.filter_name"
|
|
||||||
class="filter-name no-blur"
|
class="filter-name no-blur"
|
||||||
|
{{on
|
||||||
|
"input"
|
||||||
|
(action "onUsernameFilterChanged" value="target.value")
|
||||||
}}
|
}}
|
||||||
|
/>
|
||||||
{{#if showGroupFilter}}
|
{{#if showGroupFilter}}
|
||||||
{{combo-box
|
{{combo-box
|
||||||
class="directory-group-selector"
|
class="directory-group-selector"
|
||||||
|
@ -52,12 +55,10 @@
|
||||||
class="btn-default open-edit-columns-btn"
|
class="btn-default open-edit-columns-btn"
|
||||||
}}
|
}}
|
||||||
{{/if}}
|
{{/if}}
|
||||||
{{plugin-outlet
|
<PluginOutlet
|
||||||
name="users-directory-controls"
|
@name="users-directory-controls"
|
||||||
connectorTagName=""
|
@outletArgs={{hash model=this.model}}
|
||||||
tagName=""
|
/>
|
||||||
args=(hash model=model)
|
|
||||||
}}
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -76,7 +77,10 @@
|
||||||
{{#if (theme-setting "show_stats")}}
|
{{#if (theme-setting "show_stats")}}
|
||||||
<div class="user-card-directory-footer">
|
<div class="user-card-directory-footer">
|
||||||
{{#each columns as |column|}}
|
{{#each columns as |column|}}
|
||||||
<span class="stat stat-{{stat.name}}">
|
<span
|
||||||
|
class="stat stat-{{dasherize column.name}}
|
||||||
|
stat-type-{{column.type}}"
|
||||||
|
>
|
||||||
<span class="value">
|
<span class="value">
|
||||||
{{#if
|
{{#if
|
||||||
(directory-column-is-user-field column=column)
|
(directory-column-is-user-field column=column)
|
||||||
|
|
|
@ -133,7 +133,11 @@ acceptance("User Card Directory", function (needs) {
|
||||||
test("Displays table when cards=no", async function (assert) {
|
test("Displays table when cards=no", async function (assert) {
|
||||||
await visit("/u?cards=no");
|
await visit("/u?cards=no");
|
||||||
assert.ok($("body.users-page").length, "has the body class");
|
assert.ok($("body.users-page").length, "has the body class");
|
||||||
assert.equal(count(".directory table tr"), 2, "has a list of users");
|
assert.equal(
|
||||||
|
count(".directory .directory-table__row"),
|
||||||
|
2,
|
||||||
|
"has a list of users"
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
test("Displays cards when cards=yes", async function (assert) {
|
test("Displays cards when cards=yes", async function (assert) {
|
||||||
|
@ -143,10 +147,18 @@ acceptance("User Card Directory", function (needs) {
|
||||||
|
|
||||||
test("Can toggle between views", async function (assert) {
|
test("Can toggle between views", async function (assert) {
|
||||||
await visit("/u?cards=no");
|
await visit("/u?cards=no");
|
||||||
assert.equal(count(".directory table tr"), 2, "has two table rows");
|
assert.equal(
|
||||||
|
count(".directory .directory-table__row"),
|
||||||
|
2,
|
||||||
|
"has two table rows"
|
||||||
|
);
|
||||||
await click(".toggle-cards-button");
|
await click(".toggle-cards-button");
|
||||||
assert.equal(count(".user-card-avatar"), 2, "has two cards");
|
assert.equal(count(".user-card-avatar"), 2, "has two cards");
|
||||||
await click(".toggle-cards-button");
|
await click(".toggle-cards-button");
|
||||||
assert.equal(count(".directory table tr"), 2, "has two table rows");
|
assert.equal(
|
||||||
|
count(".directory .directory-table__row"),
|
||||||
|
2,
|
||||||
|
"has two table rows"
|
||||||
|
);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue