tweak icon-library generation
This commit is contained in:
parent
dd5562322b
commit
9208909b26
|
@ -70,12 +70,7 @@ export function registerIconRenderer(renderer) {
|
||||||
|
|
||||||
// Support for font awesome icons
|
// Support for font awesome icons
|
||||||
function faClasses(icon, params) {
|
function faClasses(icon, params) {
|
||||||
let classNames;
|
let classNames = `fa fa-${icon.replacementId || icon.id} d-icon d-icon-${icon.id}`;
|
||||||
if (typeof icon.replacementId !== "undefined") {
|
|
||||||
classNames = `fa fa-${icon.replacementId} d-icon ${icon.id}`;
|
|
||||||
} else {
|
|
||||||
classNames = `fa fa-${icon.id} d-icon d-${icon.id}`;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (params) {
|
if (params) {
|
||||||
if (params.modifier) { classNames += " fa-" + params.modifier; }
|
if (params.modifier) { classNames += " fa-" + params.modifier; }
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
<label class="control-label">{{i18n 'user.categories_settings'}}</label>
|
<label class="control-label">{{i18n 'user.categories_settings'}}</label>
|
||||||
|
|
||||||
<div class="controls category-controls">
|
<div class="controls category-controls">
|
||||||
<label>{{d-icon "d-watching" class="icon watching"}} {{i18n 'user.watched_categories'}}</label>
|
<label>{{d-icon "d-watching"}} {{i18n 'user.watched_categories'}}</label>
|
||||||
{{category-selector categories=model.watchedCategories blacklist=selectedCategories}}
|
{{category-selector categories=model.watchedCategories blacklist=selectedCategories}}
|
||||||
</div>
|
</div>
|
||||||
<div class="instructions">{{i18n 'user.watched_categories_instructions'}}</div>
|
<div class="instructions">{{i18n 'user.watched_categories_instructions'}}</div>
|
||||||
|
@ -12,7 +12,7 @@
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="controls category-controls">
|
<div class="controls category-controls">
|
||||||
<label>{{d-icon "d-tracking" class="icon tracking"}} {{i18n 'user.tracked_categories'}}</label>
|
<label>{{d-icon "d-tracking"}} {{i18n 'user.tracked_categories'}}</label>
|
||||||
{{category-selector categories=model.trackedCategories blacklist=selectedCategories}}
|
{{category-selector categories=model.trackedCategories blacklist=selectedCategories}}
|
||||||
</div>
|
</div>
|
||||||
<div class="instructions">{{i18n 'user.tracked_categories_instructions'}}</div>
|
<div class="instructions">{{i18n 'user.tracked_categories_instructions'}}</div>
|
||||||
|
@ -21,13 +21,13 @@
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="controls category-controls">
|
<div class="controls category-controls">
|
||||||
<label>{{d-icon "d-watching-first" class="icon watching-first-post"}} {{i18n 'user.watched_first_post_categories'}}</label>
|
<label>{{d-icon "d-watching-first"}} {{i18n 'user.watched_first_post_categories'}}</label>
|
||||||
{{category-selector categories=model.watchedFirstPostCategories}}
|
{{category-selector categories=model.watchedFirstPostCategories}}
|
||||||
</div>
|
</div>
|
||||||
<div class="instructions">{{i18n 'user.watched_first_post_categories_instructions'}}</div>
|
<div class="instructions">{{i18n 'user.watched_first_post_categories_instructions'}}</div>
|
||||||
|
|
||||||
<div class="controls category-controls">
|
<div class="controls category-controls">
|
||||||
<label>{{d-icon "d-muted" class="icon muted"}} {{i18n 'user.muted_categories'}}</label>
|
<label>{{d-icon "d-muted"}} {{i18n 'user.muted_categories'}}</label>
|
||||||
{{category-selector categories=model.mutedCategories blacklist=selectedCategories}}
|
{{category-selector categories=model.mutedCategories blacklist=selectedCategories}}
|
||||||
</div>
|
</div>
|
||||||
<div class="instructions">{{i18n 'user.muted_categories_instructions'}}</div>
|
<div class="instructions">{{i18n 'user.muted_categories_instructions'}}</div>
|
||||||
|
|
|
@ -20,8 +20,7 @@ export default DropdownSelectBoxComponent.extend({
|
||||||
@computed("iconForSelectedDetails")
|
@computed("iconForSelectedDetails")
|
||||||
headerIcon(iconForSelectedDetails) { return iconForSelectedDetails; },
|
headerIcon(iconForSelectedDetails) { return iconForSelectedDetails; },
|
||||||
|
|
||||||
@computed("selectedDetails.icon")
|
iconForSelectedDetails: Ember.computed.alias("selectedDetails.icon"),
|
||||||
iconForSelectedDetails(icon) { return icon; },
|
|
||||||
|
|
||||||
computeHeaderContent() {
|
computeHeaderContent() {
|
||||||
let content = this.baseHeaderComputedContent();
|
let content = this.baseHeaderComputedContent();
|
||||||
|
|
|
@ -0,0 +1,11 @@
|
||||||
|
.d-icon.d-icon-d-regular,
|
||||||
|
.d-icon.d-icon-d-muted,
|
||||||
|
.d-icon.d-icon-d-watching-first,
|
||||||
|
.d-icon.d-icon-d-watching-first-post {
|
||||||
|
color: dark-light-choose($primary-medium, $secondary-medium);
|
||||||
|
}
|
||||||
|
|
||||||
|
.d-icon.d-icon-d-tracking,
|
||||||
|
.d-icon.d-icon-d-watching {
|
||||||
|
color: $tertiary;
|
||||||
|
}
|
|
@ -6,20 +6,6 @@
|
||||||
min-width: auto;
|
min-width: auto;
|
||||||
border: none;
|
border: none;
|
||||||
|
|
||||||
|
|
||||||
.d-icon {
|
|
||||||
color: dark-light-choose(scale-color($primary, $lightness: 40%), scale-color($secondary, $lightness: 60%));
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-regular, .d-muted, .d-watching-first-post {
|
|
||||||
color: dark-light-choose($primary-medium, $secondary-medium);
|
|
||||||
}
|
|
||||||
|
|
||||||
.d-tracking, .d-watching {
|
|
||||||
color: $tertiary;
|
|
||||||
font-weight: normal;
|
|
||||||
}
|
|
||||||
|
|
||||||
&.is-expanded {
|
&.is-expanded {
|
||||||
.select-box-kit-collection,
|
.select-box-kit-collection,
|
||||||
.select-box-kit-body,
|
.select-box-kit-body,
|
||||||
|
|
|
@ -11,7 +11,7 @@ test('details button', (assert) => {
|
||||||
|
|
||||||
click('#create-topic');
|
click('#create-topic');
|
||||||
click('button.options');
|
click('button.options');
|
||||||
click('.popup-menu .d-caret-right');
|
click('.popup-menu .d-icon-caret-right');
|
||||||
|
|
||||||
andThen(() => {
|
andThen(() => {
|
||||||
assert.equal(
|
assert.equal(
|
||||||
|
@ -30,7 +30,7 @@ test('details button', (assert) => {
|
||||||
});
|
});
|
||||||
|
|
||||||
click('button.options');
|
click('button.options');
|
||||||
click('.popup-menu .d-caret-right');
|
click('.popup-menu .d-icon-caret-right');
|
||||||
|
|
||||||
andThen(() => {
|
andThen(() => {
|
||||||
assert.equal(
|
assert.equal(
|
||||||
|
@ -53,7 +53,7 @@ test('details button', (assert) => {
|
||||||
});
|
});
|
||||||
|
|
||||||
click('button.options');
|
click('button.options');
|
||||||
click('.popup-menu .d-caret-right');
|
click('.popup-menu .d-icon-caret-right');
|
||||||
|
|
||||||
andThen(() => {
|
andThen(() => {
|
||||||
assert.equal(
|
assert.equal(
|
||||||
|
@ -76,7 +76,7 @@ test('details button', (assert) => {
|
||||||
});
|
});
|
||||||
|
|
||||||
click('button.options');
|
click('button.options');
|
||||||
click('.popup-menu .d-caret-right');
|
click('.popup-menu .d-icon-caret-right');
|
||||||
|
|
||||||
andThen(() => {
|
andThen(() => {
|
||||||
assert.equal(
|
assert.equal(
|
||||||
|
@ -105,7 +105,7 @@ test('details button surrounds all selected text in a single details block', (as
|
||||||
});
|
});
|
||||||
|
|
||||||
click('button.options');
|
click('button.options');
|
||||||
click('.popup-menu .d-caret-right');
|
click('.popup-menu .d-icon-caret-right');
|
||||||
|
|
||||||
andThen(() => {
|
andThen(() => {
|
||||||
assert.equal(
|
assert.equal(
|
||||||
|
|
|
@ -14,7 +14,7 @@ widgetTest('single, not selected', {
|
||||||
},
|
},
|
||||||
|
|
||||||
test(assert) {
|
test(assert) {
|
||||||
assert.ok(find('li .d-circle-o:eq(0)').length === 1);
|
assert.ok(find('li .d-icon-circle-o:eq(0)').length === 1);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -27,7 +27,7 @@ widgetTest('single, selected', {
|
||||||
},
|
},
|
||||||
|
|
||||||
test(assert) {
|
test(assert) {
|
||||||
assert.ok(find('li .d-dot-circle-o:eq(0)').length === 1);
|
assert.ok(find('li .d-icon-dot-circle-o:eq(0)').length === 1);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -43,7 +43,7 @@ widgetTest('multi, not selected', {
|
||||||
},
|
},
|
||||||
|
|
||||||
test(assert) {
|
test(assert) {
|
||||||
assert.ok(find('li .d-square-o:eq(0)').length === 1);
|
assert.ok(find('li .d-icon-square-o:eq(0)').length === 1);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -59,6 +59,6 @@ widgetTest('multi, selected', {
|
||||||
},
|
},
|
||||||
|
|
||||||
test(assert) {
|
test(assert) {
|
||||||
assert.ok(find('li .d-check-square-o:eq(0)').length === 1);
|
assert.ok(find('li .d-icon-check-square-o:eq(0)').length === 1);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -264,7 +264,7 @@ QUnit.test("Composer can toggle between reply and createTopic", assert => {
|
||||||
|
|
||||||
click('.topic-post:eq(0) button.reply');
|
click('.topic-post:eq(0) button.reply');
|
||||||
click('button.options');
|
click('button.options');
|
||||||
click('.popup-menu .d-eye-slash');
|
click('.popup-menu .d-icon-eye-slash');
|
||||||
andThen(() => {
|
andThen(() => {
|
||||||
assert.ok(
|
assert.ok(
|
||||||
find('.composer-fields .whisper').text().indexOf(I18n.t("composer.whisper")) > 0,
|
find('.composer-fields .whisper').text().indexOf(I18n.t("composer.whisper")) > 0,
|
||||||
|
@ -286,7 +286,7 @@ QUnit.test("Composer can toggle between reply and createTopic", assert => {
|
||||||
});
|
});
|
||||||
|
|
||||||
click('button.options');
|
click('button.options');
|
||||||
click('.popup-menu .d-eye-slash');
|
click('.popup-menu .d-icon-eye-slash');
|
||||||
andThen(() => {
|
andThen(() => {
|
||||||
assert.ok(
|
assert.ok(
|
||||||
find('.composer-fields .whisper').text().indexOf(I18n.t("composer.unlist")) > 0,
|
find('.composer-fields .whisper').text().indexOf(I18n.t("composer.unlist")) > 0,
|
||||||
|
|
|
@ -33,7 +33,7 @@ QUnit.test("Share Popup", assert => {
|
||||||
QUnit.test("Showing and hiding the edit controls", assert => {
|
QUnit.test("Showing and hiding the edit controls", assert => {
|
||||||
visit("/t/internationalization-localization/280");
|
visit("/t/internationalization-localization/280");
|
||||||
|
|
||||||
click('#topic-title .d-pencil');
|
click('#topic-title .d-icon-pencil');
|
||||||
|
|
||||||
andThen(() => {
|
andThen(() => {
|
||||||
assert.ok(exists('#edit-title'), 'it shows the editing controls');
|
assert.ok(exists('#edit-title'), 'it shows the editing controls');
|
||||||
|
@ -50,7 +50,7 @@ QUnit.test("Showing and hiding the edit controls", assert => {
|
||||||
QUnit.test("Updating the topic title and category", assert => {
|
QUnit.test("Updating the topic title and category", assert => {
|
||||||
visit("/t/internationalization-localization/280");
|
visit("/t/internationalization-localization/280");
|
||||||
|
|
||||||
click('#topic-title .d-pencil');
|
click('#topic-title .d-icon-pencil');
|
||||||
|
|
||||||
fillIn('#edit-title', 'this is the new title');
|
fillIn('#edit-title', 'this is the new title');
|
||||||
|
|
||||||
|
@ -165,7 +165,7 @@ QUnit.test("Visit topic routes", assert => {
|
||||||
|
|
||||||
QUnit.test("Updating the topic title with emojis", assert => {
|
QUnit.test("Updating the topic title with emojis", assert => {
|
||||||
visit("/t/internationalization-localization/280");
|
visit("/t/internationalization-localization/280");
|
||||||
click('#topic-title .d-pencil');
|
click('#topic-title .d-icon-pencil');
|
||||||
|
|
||||||
fillIn('#edit-title', 'emojis title :bike: :blonde_woman:t6:');
|
fillIn('#edit-title', 'emojis title :bike: :blonde_woman:t6:');
|
||||||
|
|
||||||
|
|
|
@ -7,8 +7,8 @@ componentTest('default', {
|
||||||
test(assert) {
|
test(assert) {
|
||||||
const $selectKit = selectKit('.categories-admin-dropdown');
|
const $selectKit = selectKit('.categories-admin-dropdown');
|
||||||
|
|
||||||
assert.equal($selectKit.el.find(".d-bars").length, 1);
|
assert.equal($selectKit.el.find(".d-icon-bars").length, 1);
|
||||||
assert.equal($selectKit.el.find(".d-caret-down").length, 1);
|
assert.equal($selectKit.el.find(".d-icon-caret-down").length, 1);
|
||||||
|
|
||||||
expandSelectKit();
|
expandSelectKit();
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@ componentTest('icon only button', {
|
||||||
|
|
||||||
test(assert) {
|
test(assert) {
|
||||||
assert.ok(this.$('button.btn.btn-icon.no-text').length, 'it has all the classes');
|
assert.ok(this.$('button.btn.btn-icon.no-text').length, 'it has all the classes');
|
||||||
assert.ok(this.$('button .d-icon.d-plus').length, 'it has the icon');
|
assert.ok(this.$('button .d-icon.d-icon-plus').length, 'it has the icon');
|
||||||
assert.equal(this.$('button').attr('tabindex'), "3", 'it has the tabindex');
|
assert.equal(this.$('button').attr('tabindex'), "3", 'it has the tabindex');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -16,7 +16,7 @@ componentTest('icon and text button', {
|
||||||
|
|
||||||
test(assert) {
|
test(assert) {
|
||||||
assert.ok(this.$('button.btn.btn-icon-text').length, 'it has all the classes');
|
assert.ok(this.$('button.btn.btn-icon-text').length, 'it has all the classes');
|
||||||
assert.ok(this.$('button .d-icon.d-plus').length, 'it has the icon');
|
assert.ok(this.$('button .d-icon.d-icon-plus').length, 'it has the icon');
|
||||||
assert.ok(this.$('button span.d-button-label').length, 'it has the label');
|
assert.ok(this.$('button span.d-button-label').length, 'it has the label');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -0,0 +1,21 @@
|
||||||
|
import componentTest from 'helpers/component-test';
|
||||||
|
|
||||||
|
moduleForComponent('d-icon', {integration: true});
|
||||||
|
|
||||||
|
componentTest('default', {
|
||||||
|
template: '{{d-icon "bars"}}',
|
||||||
|
|
||||||
|
test(assert) {
|
||||||
|
const html = this.$().html().trim();
|
||||||
|
assert.equal(html, '<i class="fa fa-bars d-icon d-icon-bars"></i>');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
componentTest('with replacement', {
|
||||||
|
template: '{{d-icon "d-watching"}}',
|
||||||
|
|
||||||
|
test(assert) {
|
||||||
|
const html = this.$().html().trim();
|
||||||
|
assert.equal(html, '<i class="fa fa-exclamation-circle d-icon d-icon-d-watching"></i>');
|
||||||
|
}
|
||||||
|
});
|
|
@ -74,7 +74,7 @@ widgetTest('post deleted', {
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
test(assert) {
|
test(assert) {
|
||||||
assert.ok(this.$('.post-action .d-trash-o').length === 1, 'it has the deleted icon');
|
assert.ok(this.$('.post-action .d-icon-trash-o').length === 1, 'it has the deleted icon');
|
||||||
assert.ok(this.$('.avatar[title=eviltrout]').length === 1, 'it has the deleted by avatar');
|
assert.ok(this.$('.avatar[title=eviltrout]').length === 1, 'it has the deleted by avatar');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -11,7 +11,7 @@ widgetTest('icon only button', {
|
||||||
|
|
||||||
test(assert) {
|
test(assert) {
|
||||||
assert.ok(this.$('button.btn.btn-icon.no-text').length, 'it has all the classes');
|
assert.ok(this.$('button.btn.btn-icon.no-text').length, 'it has all the classes');
|
||||||
assert.ok(this.$('button .d-icon.d-smile-o').length, 'it has the icon');
|
assert.ok(this.$('button .d-icon.d-icon-smile-o').length, 'it has the icon');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -24,7 +24,7 @@ widgetTest('icon and text button', {
|
||||||
|
|
||||||
test(assert) {
|
test(assert) {
|
||||||
assert.ok(this.$('button.btn.btn-icon-text').length, 'it has all the classes');
|
assert.ok(this.$('button.btn.btn-icon-text').length, 'it has all the classes');
|
||||||
assert.ok(this.$('button .d-icon.d-plus').length, 'it has the icon');
|
assert.ok(this.$('button .d-icon.d-icon-plus').length, 'it has the icon');
|
||||||
assert.ok(this.$('button span.d-button-label').length, 'it has the label');
|
assert.ok(this.$('button span.d-button-label').length, 'it has the label');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -66,7 +66,7 @@ widgetTest('no logo - minimized', {
|
||||||
},
|
},
|
||||||
|
|
||||||
test(assert) {
|
test(assert) {
|
||||||
assert.ok(this.$('.d-home').length === 1);
|
assert.ok(this.$('.d-icon-home').length === 1);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -436,7 +436,7 @@ widgetTest("reply directly above", {
|
||||||
click('a.reply-to-tab');
|
click('a.reply-to-tab');
|
||||||
andThen(() => {
|
andThen(() => {
|
||||||
assert.equal(this.$('section.embedded-posts.top .cooked').length, 1);
|
assert.equal(this.$('section.embedded-posts.top .cooked').length, 1);
|
||||||
assert.equal(this.$('section.embedded-posts .d-arrow-up').length, 1);
|
assert.equal(this.$('section.embedded-posts .d-icon-arrow-up').length, 1);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -673,7 +673,7 @@ widgetTest("replies - one below, not suppressed", {
|
||||||
click('button.show-replies');
|
click('button.show-replies');
|
||||||
andThen(() => {
|
andThen(() => {
|
||||||
assert.equal(this.$('section.embedded-posts.bottom .cooked').length, 1);
|
assert.equal(this.$('section.embedded-posts.bottom .cooked').length, 1);
|
||||||
assert.equal(this.$('section.embedded-posts .d-arrow-down').length, 1);
|
assert.equal(this.$('section.embedded-posts .d-icon-arrow-down').length, 1);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -760,7 +760,7 @@ widgetTest("topic map - links", {
|
||||||
click('nav.buttons button');
|
click('nav.buttons button');
|
||||||
andThen(() => {
|
andThen(() => {
|
||||||
assert.equal(this.$('.map.map-collapsed').length, 0);
|
assert.equal(this.$('.map.map-collapsed').length, 0);
|
||||||
assert.equal(this.$('.topic-map .d-chevron-up').length, 1);
|
assert.equal(this.$('.topic-map .d-icon-chevron-up').length, 1);
|
||||||
assert.equal(this.$('.topic-map-expanded').length, 1);
|
assert.equal(this.$('.topic-map-expanded').length, 1);
|
||||||
assert.equal(this.$('.topic-map-expanded .topic-link').length, 5, 'it limits the links displayed');
|
assert.equal(this.$('.topic-map-expanded .topic-link').length, 5, 'it limits the links displayed');
|
||||||
});
|
});
|
||||||
|
|
|
@ -38,7 +38,7 @@ widgetTest('extra classes and glyphs', {
|
||||||
assert.ok(this.$('span.staff').length);
|
assert.ok(this.$('span.staff').length);
|
||||||
assert.ok(this.$('span.admin').length);
|
assert.ok(this.$('span.admin').length);
|
||||||
assert.ok(this.$('span.moderator').length);
|
assert.ok(this.$('span.moderator').length);
|
||||||
assert.ok(this.$('.d-shield').length);
|
assert.ok(this.$('.d-icon-shield').length);
|
||||||
assert.ok(this.$('span.new-user').length);
|
assert.ok(this.$('span.new-user').length);
|
||||||
assert.ok(this.$('span.fish').length);
|
assert.ok(this.$('span.fish').length);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue