1
0
Fork 0
mirror of https://github.com/documize/community.git synced 2025-08-04 21:15:24 +02:00

[WIP] User can select theme

This commit is contained in:
Harvey Kandola 2018-11-24 18:39:43 +00:00
parent 11e164496b
commit 679049d2b1
11 changed files with 141 additions and 8 deletions

View file

@ -13,10 +13,12 @@ import $ from 'jquery';
import { empty, and } from '@ember/object/computed';
import { isEmpty } from '@ember/utils';
import { set } from '@ember/object';
import { inject as service } from '@ember/service';
import Notifier from '../../mixins/notifier';
import Component from '@ember/component';
export default Component.extend(Notifier, {
appMeta: service(),
maxTags: 3,
titleEmpty: empty('model.general.title'),
messageEmpty: empty('model.general.message'),
@ -70,6 +72,11 @@ export default Component.extend(Notifier, {
set(this, 'messageError', false);
set(this, 'conversionEndpointError', false);
});
},
onThemeChange(theme) {
this.get('appMeta').setTheme(theme);
this.set('model.general.theme', theme);
}
}
});

View file

@ -0,0 +1,46 @@
// Copyright 2016 Documize Inc. <legal@documize.com>. All rights reserved.
//
// This software (Documize Community Edition) is licensed under
// GNU AGPL v3 http://www.gnu.org/licenses/agpl-3.0.en.html
//
// You can operate outside the AGPL restrictions by purchasing
// Documize Enterprise Edition and obtaining a commercial license
// by contacting <sales@documize.com>.
//
// https://documize.com
import { inject as service } from '@ember/service';
import { set } from '@ember/object';
import Component from '@ember/component';
export default Component.extend({
appMeta: service(),
value: '',
onChange: null,
didReceiveAttrs() {
this._super(...arguments);
let defTheme = this.get('appMeta.theme');
this.get('appMeta').getThemes().then((themes) => {
_.each(themes, (theme) => {
theme.selected = theme.name === defTheme ? true: false;
if (theme.name === '') theme.name = 'Default';
});
this.set('themes', themes);
});
},
actions: {
onSelect(selectedTheme) {
let themes = this.get('themes');
if (this.get('onChange') !== null) {
_.each(themes, (theme) => {
set(theme, 'selected', theme.name === selectedTheme ? true: false);
});
this.get('onChange')(selectedTheme);
}
}
}
});

View file

@ -11,12 +11,14 @@
import $ from 'jquery';
import { empty } from '@ember/object/computed';
import Component from '@ember/component';
import { computed, set } from '@ember/object';
import { isPresent, isEqual, isEmpty } from '@ember/utils';
import { inject as service } from '@ember/service';
import AuthProvider from '../mixins/auth';
import Component from '@ember/component';
export default Component.extend(AuthProvider, {
appMeta: service(),
hasFirstnameError: empty('model.firstname'),
hasLastnameError: empty('model.lastname'),
hasEmailError: computed('model.email', function() {
@ -83,6 +85,11 @@ export default Component.extend(AuthProvider, {
set(this, 'password.password', '');
set(this, 'password.confirmation', '');
});
},
onThemeChange(theme) {
this.get('appMeta').setTheme(theme);
this.set('model.theme', theme);
}
}
});