Skip to content

Commit

Permalink
Merge pull request #18556 from nextcloud/enh/16602/files-app-settings
Browse files Browse the repository at this point in the history
Add OCA.Files.Settings for Files navigation settings
  • Loading branch information
rullzer authored Mar 22, 2020
2 parents 9956922 + 98eeb57 commit 3b92af9
Show file tree
Hide file tree
Showing 13 changed files with 367 additions and 19 deletions.
75 changes: 75 additions & 0 deletions apps/files/js/dist/files-app-settings.js

Large diffs are not rendered by default.

1 change: 1 addition & 0 deletions apps/files/js/dist/files-app-settings.js.map

Large diffs are not rendered by default.

14 changes: 7 additions & 7 deletions apps/files/js/dist/personal-settings.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion apps/files/js/dist/personal-settings.js.map

Large diffs are not rendered by default.

20 changes: 10 additions & 10 deletions apps/files/js/dist/sidebar.js

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion apps/files/js/dist/sidebar.js.map

Large diffs are not rendered by default.

41 changes: 41 additions & 0 deletions apps/files/src/components/Setting.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
<!--
- @copyright Copyright (c) 2020 Gary Kim <gary@garykim.dev>
-
- @author Gary Kim <[email protected]>
-
- @license GNU AGPL version 3 or any later version
-
- This program is free software: you can redistribute it and/or modify
- it under the terms of the GNU Affero General Public License as
- published by the Free Software Foundation, either version 3 of the
- License, or (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU Affero General Public License for more details.
-
- You should have received a copy of the GNU Affero General Public License
- along with this program. If not, see <http://www.gnu.org/licenses/>.
-
-->

<template>
<div />
</template>
<script>
export default {
name: 'Setting',
props: {
el: {
type: Function,
required: true,
}
},
mounted() {
this.$el.appendChild(this.el())
}
}
</script>
<style>
</style>
53 changes: 53 additions & 0 deletions apps/files/src/files-app-settings.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
/**
* @copyright Copyright (c) 2019 Gary Kim <[email protected]>
* @copyright Copyright (c) 2019 John Molakvoæ <[email protected]>
*
* @author Gary Kim <[email protected]>
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/

import Vue from 'vue'
import Settings from './services/Settings'
import SettingsView from './views/Settings'
import Setting from './models/Setting'

Vue.prototype.t = t

// Init Files App Settings Service
if (!window.OCA.Files) {
window.OCA.Files = {}
}
Object.assign(window.OCA.Files, { Settings: new Settings() })
Object.assign(window.OCA.Files.Settings, { Setting })

window.addEventListener('DOMContentLoaded', () => {
// Init Vue app
// eslint-disable-next-line
new Vue({
el: '#files-app-settings',
render: h => h(SettingsView),
})

const appSettingsHeader = document.getElementById('app-settings-header')
if (appSettingsHeader) {
appSettingsHeader.addEventListener('click', e => {
const opened = e.currentTarget.children[0].classList.contains('opened')
OCA.Files.Settings.settings.forEach(e => opened ? e.close() : e.open())
})
}
})
69 changes: 69 additions & 0 deletions apps/files/src/models/Setting.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
/**
* @copyright Copyright (c) 2019 Gary Kim <[email protected]>
* @copyright Copyright (c) 2019 John Molakvoæ <[email protected]>
*
* @author Gary Kim <[email protected]>
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/

export default class Setting {

#close
#el
#name
#open

/**
* Create a new files app setting
*
* @since 19.0.0
* @param {string} name the name of this setting
* @param {Function} component.el function that returns an unmounted dom element to be added
* @param {Function} [component.open] callback for when setting is added
* @param {Function} [component.close] callback for when setting is closed
*/
constructor(name, { el, open, close }) {
this.#name = name
this.#el = el
this.#open = open
this.#close = close
if (typeof this.#open !== 'function') {
this.#open = () => {}
}
if (typeof this.#close !== 'function') {
this.#close = () => {}
}
}

get name() {
return this.#name
}

get el() {
return this.#el
}

get open() {
return this.#open
}

get close() {
return this.#close
}

}
56 changes: 56 additions & 0 deletions apps/files/src/services/Settings.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
/**
* @copyright Copyright (c) 2019 Gary Kim <[email protected]>
*
* @author Gary Kim <[email protected]>
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/

export default class Settings {

#settings

constructor() {
this.#settings = []
console.debug('OCA.Files.Settings initialized')
}

/**
* Register a new setting
*
* @since 19.0.0
* @param {OCA.Files.Settings.Setting} view element to add to settings
* @returns {boolean} whether registering was successful
*/
register(view) {
if (this.#settings.filter(e => e.name === view.name).length > 0) {
console.error('A setting with the same name is already registered')
return false
}
this.#settings.push(view)
return true
}

/**
* All settings elements
* @returns {OCA.Files.Settings.Setting[]} All currently registered settings
*/
get settings() {
return this.#settings
}

}
48 changes: 48 additions & 0 deletions apps/files/src/views/Settings.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
<!--
- @copyright Copyright (c) 2019 Gary Kim <gary@garykim.dev>
-
- @author Gary Kim <[email protected]>
-
- @license GNU AGPL version 3 or any later version
-
- This program is free software: you can redistribute it and/or modify
- it under the terms of the GNU Affero General Public License as
- published by the Free Software Foundation, either version 3 of the
- License, or (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU Affero General Public License for more details.
-
- You should have received a copy of the GNU Affero General Public License
- along with this program. If not, see <http://www.gnu.org/licenses/>.
-
-->
<template>
<div id="files-app-extra-settings">
<template v-for="setting in settings">
<Setting :el="setting.el" :key="setting.name" />
</template>
</div>
</template>

<script>
import Setting from '../components/Setting'

export default {
name: 'Settings',
components: {
Setting
},
data() {
return {
settings: OCA.Files.Settings.settings
}
}
}
</script>

<style lang="scss" scoped>

</style>
4 changes: 4 additions & 0 deletions apps/files/templates/appnavigation.php
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
<?php
script(\OCA\Files\AppInfo\Application::APP_ID, 'dist/files-app-settings');
?>
<div id="app-navigation">
<ul class="with-icon">

Expand Down Expand Up @@ -35,6 +38,7 @@
</button>
</div>
<div id="app-settings-content">
<div id="files-app-settings"></div>
<div id="files-setting-showhidden">
<input class="checkbox" id="showhiddenfilesToggle"
checked="checked" type="checkbox">
Expand Down
1 change: 1 addition & 0 deletions apps/files/webpack.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ const path = require('path');
module.exports = {
entry: {
'sidebar': path.join(__dirname, 'src', 'sidebar.js'),
'files-app-settings': path.join(__dirname, 'src', 'files-app-settings.js'),
'personal-settings': path.join(__dirname, 'src', 'main-personal-settings.js'),
},
output: {
Expand Down

0 comments on commit 3b92af9

Please sign in to comment.