mirror of
https://github.com/YunoHost-Apps/pixelfed_ynh.git
synced 2024-09-03 20:06:04 +02:00
commit
05041b95f3
55 changed files with 9538 additions and 23363 deletions
|
@ -46,6 +46,11 @@
|
||||||
- Updated ApiV1Controller, improve statusesById perf and dispatch CommentPipeline job when applicable. ([466286af](https://github.com/pixelfed/pixelfed/commit/466286af))
|
- Updated ApiV1Controller, improve statusesById perf and dispatch CommentPipeline job when applicable. ([466286af](https://github.com/pixelfed/pixelfed/commit/466286af))
|
||||||
- Updated MediaService, return empty array if cant find status. ([c2910e5d](https://github.com/pixelfed/pixelfed/commit/c2910e5d))
|
- Updated MediaService, return empty array if cant find status. ([c2910e5d](https://github.com/pixelfed/pixelfed/commit/c2910e5d))
|
||||||
- Updated StatusService, improve cache invalidation. ([83b48b56](https://github.com/pixelfed/pixelfed/commit/83b48b56))
|
- Updated StatusService, improve cache invalidation. ([83b48b56](https://github.com/pixelfed/pixelfed/commit/83b48b56))
|
||||||
|
- Updated Hashtag component, fix spinner. ([fefbc44a](https://github.com/pixelfed/pixelfed/commit/fefbc44a))
|
||||||
|
- Updated NotificationCard, update api endpoint and add group notification types. ([e09a14d8](https://github.com/pixelfed/pixelfed/commit/e09a14d8))
|
||||||
|
- Updated ContextMenu component, fix account url paths. ([01ca1edd](https://github.com/pixelfed/pixelfed/commit/01ca1edd))
|
||||||
|
- Updated PollCard component, add showBorder prop. ([0c8fffbd](https://github.com/pixelfed/pixelfed/commit/0c8fffbd))
|
||||||
|
- Updated PhotoPresenter component, add lightbox toggle. ([0cc1365f](https://github.com/pixelfed/pixelfed/commit/0cc1365f))
|
||||||
- ([](https://github.com/pixelfed/pixelfed/commit/))
|
- ([](https://github.com/pixelfed/pixelfed/commit/))
|
||||||
|
|
||||||
## [v0.11.1 (2021-09-07)](https://github.com/pixelfed/pixelfed/compare/v0.11.0...v0.11.1)
|
## [v0.11.1 (2021-09-07)](https://github.com/pixelfed/pixelfed/compare/v0.11.0...v0.11.1)
|
||||||
|
|
|
@ -199,30 +199,6 @@ trait AdminSettingsController
|
||||||
return view('admin.settings.backups', compact('files'));
|
return view('admin.settings.backups', compact('files'));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function settingsConfig(Request $request)
|
|
||||||
{
|
|
||||||
$editor = config('pixelfed.admin.env_editor');
|
|
||||||
$config = !$editor ? false : file_get_contents(base_path('.env'));
|
|
||||||
$backup = !$editor ? false : (is_file(base_path('.env.backup')) ? file_get_contents(base_path('.env.backup')) : false);
|
|
||||||
return view('admin.settings.config', compact('editor', 'config', 'backup'));
|
|
||||||
}
|
|
||||||
|
|
||||||
public function settingsConfigStore(Request $request)
|
|
||||||
{
|
|
||||||
if(config('pixelfed.admin.env_editor') !== true) {
|
|
||||||
abort(400);
|
|
||||||
}
|
|
||||||
return ['msg' => 200];
|
|
||||||
}
|
|
||||||
|
|
||||||
public function settingsConfigRestore(Request $request)
|
|
||||||
{
|
|
||||||
if(config('pixelfed.admin.env_editor') !== true) {
|
|
||||||
abort(400);
|
|
||||||
}
|
|
||||||
return ['msg' => 200];
|
|
||||||
}
|
|
||||||
|
|
||||||
public function settingsMaintenance(Request $request)
|
public function settingsMaintenance(Request $request)
|
||||||
{
|
{
|
||||||
return view('admin.settings.maintenance');
|
return view('admin.settings.maintenance');
|
||||||
|
|
|
@ -257,10 +257,6 @@ return [
|
||||||
|
|
||||||
'oauth_enabled' => env('OAUTH_ENABLED', false),
|
'oauth_enabled' => env('OAUTH_ENABLED', false),
|
||||||
|
|
||||||
'admin' => [
|
|
||||||
'env_editor' => env('ADMIN_ENV_EDITOR', false)
|
|
||||||
],
|
|
||||||
|
|
||||||
'bouncer' => [
|
'bouncer' => [
|
||||||
'enabled' => env('PF_BOUNCER_ENABLED', false),
|
'enabled' => env('PF_BOUNCER_ENABLED', false),
|
||||||
],
|
],
|
||||||
|
|
1892
package-lock.json
generated
1892
package-lock.json
generated
File diff suppressed because it is too large
Load diff
|
@ -44,7 +44,6 @@
|
||||||
"laravel-mix": "^4.1.4",
|
"laravel-mix": "^4.1.4",
|
||||||
"node-sass": "^4.14.1",
|
"node-sass": "^4.14.1",
|
||||||
"promise-polyfill": "8.1.0",
|
"promise-polyfill": "8.1.0",
|
||||||
"quill": "^1.3.7",
|
|
||||||
"readmore-js": "^2.2.1",
|
"readmore-js": "^2.2.1",
|
||||||
"sweetalert": "^2.1.2",
|
"sweetalert": "^2.1.2",
|
||||||
"twitter-text": "^2.0.5",
|
"twitter-text": "^2.0.5",
|
||||||
|
@ -52,7 +51,9 @@
|
||||||
"vue-carousel": "^0.18.0",
|
"vue-carousel": "^0.18.0",
|
||||||
"vue-content-loader": "^0.2.3",
|
"vue-content-loader": "^0.2.3",
|
||||||
"vue-cropperjs": "^4.1.0",
|
"vue-cropperjs": "^4.1.0",
|
||||||
|
"vue-i18n": "^8.26.7",
|
||||||
"vue-infinite-loading": "^2.4.5",
|
"vue-infinite-loading": "^2.4.5",
|
||||||
|
"vue-intersect": "^1.1.6",
|
||||||
"vue-loading-overlay": "^3.3.3",
|
"vue-loading-overlay": "^3.3.3",
|
||||||
"vue-timeago": "^5.1.2",
|
"vue-timeago": "^5.1.2",
|
||||||
"vue-tribute": "^1.0.7",
|
"vue-tribute": "^1.0.7",
|
||||||
|
|
14
public/css/admin.css
vendored
14
public/css/admin.css
vendored
File diff suppressed because one or more lines are too long
10
public/css/app.css
vendored
10
public/css/app.css
vendored
File diff suppressed because one or more lines are too long
10
public/css/appdark.css
vendored
10
public/css/appdark.css
vendored
File diff suppressed because one or more lines are too long
6
public/css/landing.css
vendored
6
public/css/landing.css
vendored
File diff suppressed because one or more lines are too long
6
public/css/quill.css
vendored
6
public/css/quill.css
vendored
File diff suppressed because one or more lines are too long
1
public/js/ace.js
vendored
1
public/js/ace.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/activity.js
vendored
2
public/js/activity.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/admin.js
vendored
2
public/js/admin.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/app.js
vendored
2
public/js/app.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/collectioncompose.js
vendored
2
public/js/collectioncompose.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/collections.js
vendored
2
public/js/collections.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/components.js
vendored
2
public/js/components.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/compose-classic.js
vendored
2
public/js/compose-classic.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/compose.js
vendored
2
public/js/compose.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/developers.js
vendored
2
public/js/developers.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/direct.js
vendored
2
public/js/direct.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/discover.js
vendored
2
public/js/discover.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/hashtag.js
vendored
2
public/js/hashtag.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/loops.js
vendored
2
public/js/loops.js
vendored
File diff suppressed because one or more lines are too long
5243
public/js/memoryprofile.js
vendored
5243
public/js/memoryprofile.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/mode-dot.js
vendored
2
public/js/mode-dot.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/profile-directory.js
vendored
2
public/js/profile-directory.js
vendored
|
@ -1 +1 @@
|
||||||
(window.webpackJsonp=window.webpackJsonp||[]).push([[19],{19:function(t,e,s){t.exports=s("ETg6")},"7wkd":function(t,e,s){"use strict";s.r(e);var o={data:function(){return{loaded:!1,showLoadMore:!0,profiles:[],page:1}},beforeMount:function(){this.fetchData()},methods:{fetchData:function(){var t=this;axios.get("/api/pixelfed/v2/discover/profiles",{params:{page:this.page}}).then((function(e){if(0==e.data.length)return t.showLoadMore=!1,void(t.loaded=!0);t.profiles=e.data,t.showLoadMore=8==t.profiles.length,t.loaded=!0}))},prettyCount:function(t){return App.util.format.count(t)},loadMore:function(){this.loaded=!1,this.page++,this.fetchData()},thumbUrl:function(t){return t.media_attachments[0].url}}},a=s("KHd+"),n=Object(a.a)(o,(function(){var t=this,e=t.$createElement,s=t._self._c||e;return s("div",[s("div",{staticClass:"col-12"},[s("p",{staticClass:"font-weight-bold text-lighter text-uppercase"},[t._v("Profiles Directory")]),t._v(" "),t.loaded?s("div",{},[s("div",{staticClass:"row"},[t._l(t.profiles,(function(e,o){return s("div",{staticClass:"col-12 col-md-6 p-1"},[s("div",{staticClass:"card card-body border shadow-none py-2"},[s("div",{staticClass:"media"},[s("a",{attrs:{href:e.url}},[s("img",{staticClass:"rounded-circle border mr-3",attrs:{src:e.avatar,alt:"...",width:"40px",height:"40px"}})]),t._v(" "),s("div",{staticClass:"media-body"},[s("p",{staticClass:"mt-0 mb-0 font-weight-bold"},[s("a",{staticClass:"text-dark",attrs:{href:e.url}},[t._v(t._s(e.username))])]),t._v(" "),s("p",{staticClass:"mb-1 small text-lighter d-flex justify-content-between font-weight-bold"},[s("span",[s("span",[t._v(t._s(t.prettyCount(e.statuses_count)))]),t._v(" POSTS\n\t\t\t\t\t\t\t\t\t")]),t._v(" "),s("span",[s("span",[t._v(t._s(t.prettyCount(e.followers_count)))]),t._v(" FOLLOWERS\n\t\t\t\t\t\t\t\t\t")])]),t._v(" "),s("p",{staticClass:"mb-1"},t._l(e.posts,(function(e,o){return s("span",{key:"profile_posts_"+o,staticClass:"shadow-sm"},[s("a",{staticClass:"text-decoration-none mr-1",attrs:{href:e.url}},[s("img",{staticClass:"border rounded",attrs:{src:t.thumbUrl(e),width:"62.3px",height:"62.3px"}})])])})),0)])])])])})),t._v(" "),t.showLoadMore?s("div",{staticClass:"col-12"},[s("p",{staticClass:"text-center mb-0 pt-3"},[s("button",{staticClass:"btn btn-outline-secondary btn-sm px-4 py-1 font-weight-bold",on:{click:function(e){return t.loadMore()}}},[t._v("Load More")])])]):t._e()],2)]):s("div",[t._m(0)])])])}),[function(){var t=this.$createElement,e=this._self._c||t;return e("div",{staticClass:"row"},[e("div",{staticClass:"col-12 d-flex justify-content-center align-items-center"},[e("div",{staticClass:"spinner-border",attrs:{role:"status"}},[e("span",{staticClass:"sr-only"},[this._v("Loading...")])])])])}],!1,null,"7b3eea1c",null);e.default=n.exports},ETg6:function(t,e,s){Vue.component("profile-directory",s("7wkd").default)},"KHd+":function(t,e,s){"use strict";function o(t,e,s,o,a,n,r,i){var c,d="function"==typeof t?t.options:t;if(e&&(d.render=e,d.staticRenderFns=s,d._compiled=!0),o&&(d.functional=!0),n&&(d._scopeId="data-v-"+n),r?(c=function(t){(t=t||this.$vnode&&this.$vnode.ssrContext||this.parent&&this.parent.$vnode&&this.parent.$vnode.ssrContext)||"undefined"==typeof __VUE_SSR_CONTEXT__||(t=__VUE_SSR_CONTEXT__),a&&a.call(this,t),t&&t._registeredComponents&&t._registeredComponents.add(r)},d._ssrRegister=c):a&&(c=i?function(){a.call(this,(d.functional?this.parent:this).$root.$options.shadowRoot)}:a),c)if(d.functional){d._injectStyles=c;var l=d.render;d.render=function(t,e){return c.call(e),l(t,e)}}else{var u=d.beforeCreate;d.beforeCreate=u?[].concat(u,c):[c]}return{exports:t,options:d}}s.d(e,"a",(function(){return o}))}},[[19,0]]]);
|
(window.webpackJsonp=window.webpackJsonp||[]).push([[16],{15:function(t,e,s){t.exports=s("ETg6")},"7wkd":function(t,e,s){"use strict";s.r(e);var o={data:function(){return{loaded:!1,showLoadMore:!0,profiles:[],page:1}},beforeMount:function(){this.fetchData()},methods:{fetchData:function(){var t=this;axios.get("/api/pixelfed/v2/discover/profiles",{params:{page:this.page}}).then((function(e){if(0==e.data.length)return t.showLoadMore=!1,void(t.loaded=!0);t.profiles=e.data,t.showLoadMore=8==t.profiles.length,t.loaded=!0}))},prettyCount:function(t){return App.util.format.count(t)},loadMore:function(){this.loaded=!1,this.page++,this.fetchData()},thumbUrl:function(t){return t.media_attachments[0].url}}},a=s("KHd+"),n=Object(a.a)(o,(function(){var t=this,e=t.$createElement,s=t._self._c||e;return s("div",[s("div",{staticClass:"col-12"},[s("p",{staticClass:"font-weight-bold text-lighter text-uppercase"},[t._v("Profiles Directory")]),t._v(" "),t.loaded?s("div",{},[s("div",{staticClass:"row"},[t._l(t.profiles,(function(e,o){return s("div",{staticClass:"col-12 col-md-6 p-1"},[s("div",{staticClass:"card card-body border shadow-none py-2"},[s("div",{staticClass:"media"},[s("a",{attrs:{href:e.url}},[s("img",{staticClass:"rounded-circle border mr-3",attrs:{src:e.avatar,alt:"...",width:"40px",height:"40px"}})]),t._v(" "),s("div",{staticClass:"media-body"},[s("p",{staticClass:"mt-0 mb-0 font-weight-bold"},[s("a",{staticClass:"text-dark",attrs:{href:e.url}},[t._v(t._s(e.username))])]),t._v(" "),s("p",{staticClass:"mb-1 small text-lighter d-flex justify-content-between font-weight-bold"},[s("span",[s("span",[t._v(t._s(t.prettyCount(e.statuses_count)))]),t._v(" POSTS\n\t\t\t\t\t\t\t\t\t")]),t._v(" "),s("span",[s("span",[t._v(t._s(t.prettyCount(e.followers_count)))]),t._v(" FOLLOWERS\n\t\t\t\t\t\t\t\t\t")])]),t._v(" "),s("p",{staticClass:"mb-1"},t._l(e.posts,(function(e,o){return s("span",{key:"profile_posts_"+o,staticClass:"shadow-sm"},[s("a",{staticClass:"text-decoration-none mr-1",attrs:{href:e.url}},[s("img",{staticClass:"border rounded",attrs:{src:t.thumbUrl(e),width:"62.3px",height:"62.3px"}})])])})),0)])])])])})),t._v(" "),t.showLoadMore?s("div",{staticClass:"col-12"},[s("p",{staticClass:"text-center mb-0 pt-3"},[s("button",{staticClass:"btn btn-outline-secondary btn-sm px-4 py-1 font-weight-bold",on:{click:function(e){return t.loadMore()}}},[t._v("Load More")])])]):t._e()],2)]):s("div",[t._m(0)])])])}),[function(){var t=this.$createElement,e=this._self._c||t;return e("div",{staticClass:"row"},[e("div",{staticClass:"col-12 d-flex justify-content-center align-items-center"},[e("div",{staticClass:"spinner-border",attrs:{role:"status"}},[e("span",{staticClass:"sr-only"},[this._v("Loading...")])])])])}],!1,null,"7b3eea1c",null);e.default=n.exports},ETg6:function(t,e,s){Vue.component("profile-directory",s("7wkd").default)},"KHd+":function(t,e,s){"use strict";function o(t,e,s,o,a,n,r,i){var c,d="function"==typeof t?t.options:t;if(e&&(d.render=e,d.staticRenderFns=s,d._compiled=!0),o&&(d.functional=!0),n&&(d._scopeId="data-v-"+n),r?(c=function(t){(t=t||this.$vnode&&this.$vnode.ssrContext||this.parent&&this.parent.$vnode&&this.parent.$vnode.ssrContext)||"undefined"==typeof __VUE_SSR_CONTEXT__||(t=__VUE_SSR_CONTEXT__),a&&a.call(this,t),t&&t._registeredComponents&&t._registeredComponents.add(r)},d._ssrRegister=c):a&&(c=i?function(){a.call(this,(d.functional?this.parent:this).$root.$options.shadowRoot)}:a),c)if(d.functional){d._injectStyles=c;var l=d.render;d.render=function(t,e){return c.call(e),l(t,e)}}else{var u=d.beforeCreate;d.beforeCreate=u?[].concat(u,c):[c]}return{exports:t,options:d}}s.d(e,"a",(function(){return o}))}},[[15,0]]]);
|
2
public/js/profile.js
vendored
2
public/js/profile.js
vendored
File diff suppressed because one or more lines are too long
1
public/js/quill.js
vendored
1
public/js/quill.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/rempos.js
vendored
2
public/js/rempos.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/rempro.js
vendored
2
public/js/rempro.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/search.js
vendored
2
public/js/search.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/status.js
vendored
2
public/js/status.js
vendored
File diff suppressed because one or more lines are too long
3198
public/js/stories.js
vendored
3198
public/js/stories.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/theme-monokai.js
vendored
2
public/js/theme-monokai.js
vendored
|
@ -1 +1 @@
|
||||||
(window.webpackJsonp=window.webpackJsonp||[]).push([[25],{15:function(e,a,o){e.exports=o("YMO/")},"YMO/":function(e,a,o){(function(e){function o(e){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}ace.define("ace/theme/monokai",["require","exports","module","ace/lib/dom"],(function(e,a,o){a.isDark=!0,a.cssClass="ace-monokai",a.cssText=".ace-monokai .ace_gutter {background: #2F3129;color: #8F908A}.ace-monokai .ace_print-margin {width: 1px;background: #555651}.ace-monokai {background-color: #272822;color: #F8F8F2}.ace-monokai .ace_cursor {color: #F8F8F0}.ace-monokai .ace_marker-layer .ace_selection {background: #49483E}.ace-monokai.ace_multiselect .ace_selection.ace_start {box-shadow: 0 0 3px 0px #272822;}.ace-monokai .ace_marker-layer .ace_step {background: rgb(102, 82, 0)}.ace-monokai .ace_marker-layer .ace_bracket {margin: -1px 0 0 -1px;border: 1px solid #49483E}.ace-monokai .ace_marker-layer .ace_active-line {background: #202020}.ace-monokai .ace_gutter-active-line {background-color: #272727}.ace-monokai .ace_marker-layer .ace_selected-word {border: 1px solid #49483E}.ace-monokai .ace_invisible {color: #52524d}.ace-monokai .ace_entity.ace_name.ace_tag,.ace-monokai .ace_keyword,.ace-monokai .ace_meta.ace_tag,.ace-monokai .ace_storage {color: #F92672}.ace-monokai .ace_punctuation,.ace-monokai .ace_punctuation.ace_tag {color: #fff}.ace-monokai .ace_constant.ace_character,.ace-monokai .ace_constant.ace_language,.ace-monokai .ace_constant.ace_numeric,.ace-monokai .ace_constant.ace_other {color: #AE81FF}.ace-monokai .ace_invalid {color: #F8F8F0;background-color: #F92672}.ace-monokai .ace_invalid.ace_deprecated {color: #F8F8F0;background-color: #AE81FF}.ace-monokai .ace_support.ace_constant,.ace-monokai .ace_support.ace_function {color: #66D9EF}.ace-monokai .ace_fold {background-color: #A6E22E;border-color: #F8F8F2}.ace-monokai .ace_storage.ace_type,.ace-monokai .ace_support.ace_class,.ace-monokai .ace_support.ace_type {font-style: italic;color: #66D9EF}.ace-monokai .ace_entity.ace_name.ace_function,.ace-monokai .ace_entity.ace_other,.ace-monokai .ace_entity.ace_other.ace_attribute-name,.ace-monokai .ace_variable {color: #A6E22E}.ace-monokai .ace_variable.ace_parameter {font-style: italic;color: #FD971F}.ace-monokai .ace_string {color: #E6DB74}.ace-monokai .ace_comment {color: #75715E}.ace-monokai .ace_indent-guide {background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAACCAYAAACZgbYnAAAAEklEQVQImWPQ0FD0ZXBzd/wPAAjVAoxeSgNeAAAAAElFTkSuQmCC) right repeat-y}",e("../lib/dom").importCssString(a.cssText,a.cssClass)})),ace.require(["ace/theme/monokai"],(function(c){"object"==o(e)&&"object"==o(a)&&e&&(e.exports=c)}))}).call(this,o("YuTi")(e))},YuTi:function(e,a){e.exports=function(e){return e.webpackPolyfill||(e.deprecate=function(){},e.paths=[],e.children||(e.children=[]),Object.defineProperty(e,"loaded",{enumerable:!0,get:function(){return e.l}}),Object.defineProperty(e,"id",{enumerable:!0,get:function(){return e.i}}),e.webpackPolyfill=1),e}}},[[15,0]]]);
|
(window.webpackJsonp=window.webpackJsonp||[]).push([[24],{14:function(e,a,o){e.exports=o("YMO/")},"YMO/":function(e,a,o){(function(e){function o(e){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}ace.define("ace/theme/monokai",["require","exports","module","ace/lib/dom"],(function(e,a,o){a.isDark=!0,a.cssClass="ace-monokai",a.cssText=".ace-monokai .ace_gutter {background: #2F3129;color: #8F908A}.ace-monokai .ace_print-margin {width: 1px;background: #555651}.ace-monokai {background-color: #272822;color: #F8F8F2}.ace-monokai .ace_cursor {color: #F8F8F0}.ace-monokai .ace_marker-layer .ace_selection {background: #49483E}.ace-monokai.ace_multiselect .ace_selection.ace_start {box-shadow: 0 0 3px 0px #272822;}.ace-monokai .ace_marker-layer .ace_step {background: rgb(102, 82, 0)}.ace-monokai .ace_marker-layer .ace_bracket {margin: -1px 0 0 -1px;border: 1px solid #49483E}.ace-monokai .ace_marker-layer .ace_active-line {background: #202020}.ace-monokai .ace_gutter-active-line {background-color: #272727}.ace-monokai .ace_marker-layer .ace_selected-word {border: 1px solid #49483E}.ace-monokai .ace_invisible {color: #52524d}.ace-monokai .ace_entity.ace_name.ace_tag,.ace-monokai .ace_keyword,.ace-monokai .ace_meta.ace_tag,.ace-monokai .ace_storage {color: #F92672}.ace-monokai .ace_punctuation,.ace-monokai .ace_punctuation.ace_tag {color: #fff}.ace-monokai .ace_constant.ace_character,.ace-monokai .ace_constant.ace_language,.ace-monokai .ace_constant.ace_numeric,.ace-monokai .ace_constant.ace_other {color: #AE81FF}.ace-monokai .ace_invalid {color: #F8F8F0;background-color: #F92672}.ace-monokai .ace_invalid.ace_deprecated {color: #F8F8F0;background-color: #AE81FF}.ace-monokai .ace_support.ace_constant,.ace-monokai .ace_support.ace_function {color: #66D9EF}.ace-monokai .ace_fold {background-color: #A6E22E;border-color: #F8F8F2}.ace-monokai .ace_storage.ace_type,.ace-monokai .ace_support.ace_class,.ace-monokai .ace_support.ace_type {font-style: italic;color: #66D9EF}.ace-monokai .ace_entity.ace_name.ace_function,.ace-monokai .ace_entity.ace_other,.ace-monokai .ace_entity.ace_other.ace_attribute-name,.ace-monokai .ace_variable {color: #A6E22E}.ace-monokai .ace_variable.ace_parameter {font-style: italic;color: #FD971F}.ace-monokai .ace_string {color: #E6DB74}.ace-monokai .ace_comment {color: #75715E}.ace-monokai .ace_indent-guide {background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAACCAYAAACZgbYnAAAAEklEQVQImWPQ0FD0ZXBzd/wPAAjVAoxeSgNeAAAAAElFTkSuQmCC) right repeat-y}",e("../lib/dom").importCssString(a.cssText,a.cssClass)})),ace.require(["ace/theme/monokai"],(function(c){"object"==o(e)&&"object"==o(a)&&e&&(e.exports=c)}))}).call(this,o("YuTi")(e))},YuTi:function(e,a){e.exports=function(e){return e.webpackPolyfill||(e.deprecate=function(){},e.paths=[],e.children||(e.children=[]),Object.defineProperty(e,"loaded",{enumerable:!0,get:function(){return e.l}}),Object.defineProperty(e,"id",{enumerable:!0,get:function(){return e.i}}),e.webpackPolyfill=1),e}}},[[14,0]]]);
|
2
public/js/timeline.js
vendored
2
public/js/timeline.js
vendored
File diff suppressed because one or more lines are too long
2
public/js/vendor.js
vendored
2
public/js/vendor.js
vendored
File diff suppressed because one or more lines are too long
|
@ -1,36 +1,30 @@
|
||||||
{
|
{
|
||||||
"/js/manifest.js": "/js/manifest.js?id=7db827d654313dce4250",
|
"/js/manifest.js": "/js/manifest.js?id=7db827d654313dce4250",
|
||||||
"/js/vendor.js": "/js/vendor.js?id=4736aa0fc51d85c921c6",
|
"/js/vendor.js": "/js/vendor.js?id=a6356cdc77b1374b2a01",
|
||||||
"/js/ace.js": "/js/ace.js?id=11e5550a450fece75c33",
|
"/js/activity.js": "/js/activity.js?id=1d855c03383566536e13",
|
||||||
"/js/activity.js": "/js/activity.js?id=1626667714bef0d22ff4",
|
"/js/admin.js": "/js/admin.js?id=05c8d6766650050d8ef0",
|
||||||
"/js/admin.js": "/js/admin.js?id=bc1542fd4aa4e71daad7",
|
"/js/app.js": "/js/app.js?id=cc182786e3a5693b1433",
|
||||||
"/js/app.js": "/js/app.js?id=13bdbfb3f3f2c205c0ac",
|
"/css/app.css": "/css/app.css?id=70554ace925b5a7ecef2",
|
||||||
"/css/app.css": "/css/app.css?id=de797b5388be16568353",
|
"/css/appdark.css": "/css/appdark.css?id=ccdcd84f1087f89bd7b2",
|
||||||
"/css/appdark.css": "/css/appdark.css?id=448855e59473246b4b20",
|
"/css/admin.css": "/css/admin.css?id=8884d2f48c1dd491ba04",
|
||||||
"/css/admin.css": "/css/admin.css?id=ef822512ab2cfacef881",
|
"/css/landing.css": "/css/landing.css?id=b6a06b969dd1c3c274e6",
|
||||||
"/css/landing.css": "/css/landing.css?id=d8c0a7da6d9d611c17cd",
|
"/js/collectioncompose.js": "/js/collectioncompose.js?id=684458578e59365b9b7f",
|
||||||
"/css/quill.css": "/css/quill.css?id=ece45380f676947dd7f8",
|
"/js/collections.js": "/js/collections.js?id=0d1fc5ad7d4a47a8adbb",
|
||||||
"/js/collectioncompose.js": "/js/collectioncompose.js?id=6678ddbea8c68875f830",
|
"/js/components.js": "/js/components.js?id=56aa48f8042553148a78",
|
||||||
"/js/collections.js": "/js/collections.js?id=bdd652ffb9754adf81aa",
|
"/js/compose.js": "/js/compose.js?id=fe56d0c40817ec2b0ec7",
|
||||||
"/js/components.js": "/js/components.js?id=fba10d02a472976640ed",
|
"/js/compose-classic.js": "/js/compose-classic.js?id=ee4ad4759a55261c429c",
|
||||||
"/js/compose.js": "/js/compose.js?id=0dd3798521b8b0ae7b7b",
|
"/js/developers.js": "/js/developers.js?id=d578157a93aaa9070669",
|
||||||
"/js/compose-classic.js": "/js/compose-classic.js?id=c994899e82ff5a905c81",
|
"/js/direct.js": "/js/direct.js?id=76bdac276fca6ac60320",
|
||||||
"/js/developers.js": "/js/developers.js?id=9bba3be10491e58de952",
|
"/js/discover.js": "/js/discover.js?id=4230e32e8f7d7413b6c4",
|
||||||
"/js/direct.js": "/js/direct.js?id=451f2ad256090f24cced",
|
"/js/hashtag.js": "/js/hashtag.js?id=5dfd9c4873cc9d78727c",
|
||||||
"/js/discover.js": "/js/discover.js?id=dcc903e7b89832d4fa59",
|
"/js/loops.js": "/js/loops.js?id=4ae79e81965c4fd1ae66",
|
||||||
"/js/hashtag.js": "/js/hashtag.js?id=1ec0defe0d591a4a417e",
|
"/js/profile.js": "/js/profile.js?id=a2e8bd5346850f805b5c",
|
||||||
"/js/loops.js": "/js/loops.js?id=ae34b77c4cfe1824f5a0",
|
"/js/profile-directory.js": "/js/profile-directory.js?id=f445e578219495c2b0f3",
|
||||||
"/js/memoryprofile.js": "/js/memoryprofile.js?id=887eab75f4812600de26",
|
"/js/rempos.js": "/js/rempos.js?id=2ef46b249c6390aa4ef8",
|
||||||
"/js/mode-dot.js": "/js/mode-dot.js?id=af90766521763f9d8f71",
|
"/js/rempro.js": "/js/rempro.js?id=3971b84aef886204d286",
|
||||||
"/js/profile.js": "/js/profile.js?id=8507ebf93e51a607af02",
|
"/js/search.js": "/js/search.js?id=dc888b173463dc3894ba",
|
||||||
"/js/profile-directory.js": "/js/profile-directory.js?id=e63d5f2c6f2d5710a8bd",
|
"/js/status.js": "/js/status.js?id=4493959f638ad286630c",
|
||||||
"/js/quill.js": "/js/quill.js?id=4769f11fc9a6c32dde50",
|
|
||||||
"/js/rempos.js": "/js/rempos.js?id=dc448d857bc4dd344d00",
|
|
||||||
"/js/rempro.js": "/js/rempro.js?id=ec4738e0d8de5124f4d0",
|
|
||||||
"/js/search.js": "/js/search.js?id=68156d01717856b142ea",
|
|
||||||
"/js/status.js": "/js/status.js?id=e45a2ec49d497bcffa60",
|
|
||||||
"/js/stories.js": "/js/stories.js?id=94721cbf86251179e7f7",
|
"/js/stories.js": "/js/stories.js?id=94721cbf86251179e7f7",
|
||||||
"/js/story-compose.js": "/js/story-compose.js?id=34b9e22a404107475f2e",
|
"/js/story-compose.js": "/js/story-compose.js?id=34b9e22a404107475f2e",
|
||||||
"/js/theme-monokai.js": "/js/theme-monokai.js?id=8842103833ba4861bcfa",
|
"/js/timeline.js": "/js/timeline.js?id=adc9c5a8ed1f8ffd54a0"
|
||||||
"/js/timeline.js": "/js/timeline.js?id=391da4aa031c7c2daf4e"
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,6 +89,18 @@
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div v-else-if="n.type == 'group.join.approved'">
|
||||||
|
<p class="my-0">
|
||||||
|
Your application to join <a :href="n.group.url" class="font-weight-bold text-dark word-break" :title="n.group.name">{{truncate(n.group.name)}}</a> was approved!
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div v-else-if="n.type == 'group.join.rejected'">
|
||||||
|
<p class="my-0">
|
||||||
|
Your application to join <a :href="n.group.url" class="font-weight-bold text-dark word-break" :title="n.group.name">{{truncate(n.group.name)}}</a> was rejected. You can re-apply to join in 6 months.
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="align-items-center">
|
<div class="align-items-center">
|
||||||
<span class="small text-muted" data-toggle="tooltip" data-placement="bottom" :title="n.created_at">{{timeAgo(n.created_at)}}</span>
|
<span class="small text-muted" data-toggle="tooltip" data-placement="bottom" :title="n.created_at">{{timeAgo(n.created_at)}}</span>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -1024,7 +1024,6 @@ export default {
|
||||||
},
|
},
|
||||||
|
|
||||||
beforeMount() {
|
beforeMount() {
|
||||||
this.fetchProfile();
|
|
||||||
this.filters = window.App.util.filters;
|
this.filters = window.App.util.filters;
|
||||||
axios.get('/api/compose/v0/settings')
|
axios.get('/api/compose/v0/settings')
|
||||||
.then(res => {
|
.then(res => {
|
||||||
|
@ -1038,6 +1037,7 @@ export default {
|
||||||
return l.title;
|
return l.title;
|
||||||
})[0];
|
})[0];
|
||||||
}
|
}
|
||||||
|
this.fetchProfile();
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -1047,8 +1047,18 @@ export default {
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
fetchProfile() {
|
fetchProfile() {
|
||||||
|
let tags = {
|
||||||
|
public: 'Public',
|
||||||
|
private: 'Followers Only',
|
||||||
|
unlisted: 'Unlisted'
|
||||||
|
}
|
||||||
if(window._sharedData.curUser.id) {
|
if(window._sharedData.curUser.id) {
|
||||||
this.profile = window._sharedData.curUser;
|
this.profile = window._sharedData.curUser;
|
||||||
|
if(this.composeSettings && this.composeSettings.hasOwnProperty('default_scope') && this.composeSettings.default_scope) {
|
||||||
|
let ds = this.composeSettings.default_scope;
|
||||||
|
this.visibility = ds;
|
||||||
|
this.visibilityTag = tags[ds];
|
||||||
|
}
|
||||||
if(this.profile.locked == true) {
|
if(this.profile.locked == true) {
|
||||||
this.visibility = 'private';
|
this.visibility = 'private';
|
||||||
this.visibilityTag = 'Followers Only';
|
this.visibilityTag = 'Followers Only';
|
||||||
|
@ -1057,6 +1067,11 @@ export default {
|
||||||
axios.get('/api/pixelfed/v1/accounts/verify_credentials').then(res => {
|
axios.get('/api/pixelfed/v1/accounts/verify_credentials').then(res => {
|
||||||
window._sharedData.currentUser = res.data;
|
window._sharedData.currentUser = res.data;
|
||||||
this.profile = res.data;
|
this.profile = res.data;
|
||||||
|
if(this.composeSettings && this.composeSettings.hasOwnProperty('default_scope') && this.composeSettings.default_scope) {
|
||||||
|
let ds = this.composeSettings.default_scope;
|
||||||
|
this.visibility = ds;
|
||||||
|
this.visibilityTag = tags[ds];
|
||||||
|
}
|
||||||
if(this.profile.locked == true) {
|
if(this.profile.locked == true) {
|
||||||
this.visibility = 'private';
|
this.visibility = 'private';
|
||||||
this.visibilityTag = 'Followers Only';
|
this.visibilityTag = 'Followers Only';
|
||||||
|
|
|
@ -109,8 +109,8 @@
|
||||||
<p class="text-center lead font-weight-bold">No public posts found.</p>
|
<p class="text-center lead font-weight-bold">No public posts found.</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div v-else class="container text-center">
|
<div v-else class="mt-5 text-center">
|
||||||
<div class="col-12 mt-5 spinner-border" role="status">
|
<div class="spinner-border" role="status">
|
||||||
<span class="sr-only">Loading...</span>
|
<span class="sr-only">Loading...</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -11,7 +11,7 @@
|
||||||
<div v-if="profile.locked" class="media align-items-center mt-n2 px-3 py-2 border-bottom border-lighter bg-light cursor-pointer" @click="redirect('/account/follow-requests')">
|
<div v-if="profile.locked" class="media align-items-center mt-n2 px-3 py-2 border-bottom border-lighter bg-light cursor-pointer" @click="redirect('/account/follow-requests')">
|
||||||
<div class="media-body font-weight-light pt-2 small d-flex align-items-center justify-content-between">
|
<div class="media-body font-weight-light pt-2 small d-flex align-items-center justify-content-between">
|
||||||
<p class="mb-0 text-lighter"><i class="fas fa-cog text-light"></i></p>
|
<p class="mb-0 text-lighter"><i class="fas fa-cog text-light"></i></p>
|
||||||
<p class="text-center pt-1 mb-1 text-dark font-weight-bold"><strong>{{followRequests.count}}</strong> Follow Requests</p>
|
<p class="text-center pt-1 mb-1 text-dark font-weight-bold"><strong>{{ followRequests && followRequests.hasOwnProperty('count') ? followRequests.count : 0 }}</strong> Follow Requests</p>
|
||||||
<p class="mb-0 text-lighter"><i class="fas fa-chevron-right"></i></p>
|
<p class="mb-0 text-lighter"><i class="fas fa-chevron-right"></i></p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -82,6 +82,25 @@
|
||||||
<a :href="getProfileUrl(n.account)" class="font-weight-bold text-dark word-break" :title="n.account.username">{{n.account.local == false ? '@':''}}{{truncate(n.account.username)}}</a> sent a <a class="font-weight-bold" v-bind:href="'/account/direct/t/'+n.account.id">dm</a>.
|
<a :href="getProfileUrl(n.account)" class="font-weight-bold text-dark word-break" :title="n.account.username">{{n.account.local == false ? '@':''}}{{truncate(n.account.username)}}</a> sent a <a class="font-weight-bold" v-bind:href="'/account/direct/t/'+n.account.id">dm</a>.
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div v-else-if="n.type == 'group.join.approved'">
|
||||||
|
<p class="my-0">
|
||||||
|
Your application to join the <a :href="n.group.url" class="font-weight-bold text-dark word-break" :title="n.group.name">{{truncate(n.group.name)}}</a> group was approved!
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div v-else-if="n.type == 'group.join.rejected'">
|
||||||
|
<p class="my-0">
|
||||||
|
Your application to join <a :href="n.group.url" class="font-weight-bold text-dark word-break" :title="n.group.name">{{truncate(n.group.name)}}</a> was rejected.
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div v-else-if="n.type == 'group:invite'">
|
||||||
|
<p class="my-0">
|
||||||
|
<a :href="getProfileUrl(n.account)" class="font-weight-bold text-dark word-break" :title="n.account.username">{{n.account.local == false ? '@':''}}{{truncate(n.account.username)}}</a> invited you to join <a :href="n.group.url + '/invite/claim'" class="font-weight-bold text-dark word-break" :title="n.group.name">{{n.group.name}}</a>.
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div v-else>
|
<div v-else>
|
||||||
<p class="my-0">
|
<p class="my-0">
|
||||||
We cannot display this notification at this time.
|
We cannot display this notification at this time.
|
||||||
|
@ -146,7 +165,7 @@
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
fetchNotifications() {
|
fetchNotifications() {
|
||||||
axios.get('/api/pixelfed/v1/notifications?pg=true')
|
axios.get('/api/v1/notifications?pg=true')
|
||||||
.then(res => {
|
.then(res => {
|
||||||
let data = res.data.filter(n => {
|
let data = res.data.filter(n => {
|
||||||
if(n.type == 'share' && !n.status) {
|
if(n.type == 'share' && !n.status) {
|
||||||
|
|
|
@ -450,7 +450,7 @@
|
||||||
replyStatus: {},
|
replyStatus: {},
|
||||||
replyText: '',
|
replyText: '',
|
||||||
replyNsfw: false,
|
replyNsfw: false,
|
||||||
emoji: window.App.util.emoji,
|
emoji: [],
|
||||||
showHashtagPosts: false,
|
showHashtagPosts: false,
|
||||||
hashtagPosts: [],
|
hashtagPosts: [],
|
||||||
hashtagPostsName: '',
|
hashtagPostsName: '',
|
||||||
|
@ -514,21 +514,6 @@
|
||||||
},
|
},
|
||||||
|
|
||||||
beforeMount() {
|
beforeMount() {
|
||||||
// let avop = window.localStorage.getItem('pf.feed:avop') === 'always';
|
|
||||||
// let u = new URLSearchParams(window.location.search);
|
|
||||||
// if(u.has('a')) {
|
|
||||||
// switch(u.get('a')) {
|
|
||||||
// case 'recent_feed':
|
|
||||||
// if(this.scope === 'home') {
|
|
||||||
// this.recentFeed = true;
|
|
||||||
// }
|
|
||||||
// break;
|
|
||||||
// case 'vop':
|
|
||||||
// this.recentFeed = false;
|
|
||||||
// break;
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// this.recentFeed = avop ? false : this.recentFeed;
|
|
||||||
this.fetchProfile();
|
this.fetchProfile();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -589,17 +574,13 @@
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
fetchProfile() {
|
fetchProfile() {
|
||||||
axios.get('/api/pixelfed/v1/accounts/verify_credentials').then(res => {
|
axios.get('/api/v1/accounts/verify_credentials').then(res => {
|
||||||
this.profile = res.data;
|
this.profile = res.data;
|
||||||
if(this.profile.is_admin == true) {
|
if(this.profile.is_admin == true) {
|
||||||
this.modes.mod = true;
|
this.modes.mod = true;
|
||||||
}
|
}
|
||||||
window._sharedData.curUser = res.data;
|
window._sharedData.curUser = res.data;
|
||||||
window.App.util.navatar();
|
window.App.util.navatar();
|
||||||
// this.$nextTick(() => {
|
|
||||||
// this.hasStory();
|
|
||||||
// });
|
|
||||||
// this.expRec();
|
|
||||||
}).catch(err => {
|
}).catch(err => {
|
||||||
swal(
|
swal(
|
||||||
'Oops, something went wrong',
|
'Oops, something went wrong',
|
||||||
|
@ -633,7 +614,7 @@
|
||||||
}).then(res => {
|
}).then(res => {
|
||||||
let data = res.data;
|
let data = res.data;
|
||||||
|
|
||||||
if(!data.length) {
|
if(!data || !data.length) {
|
||||||
this.loading = false;
|
this.loading = false;
|
||||||
this.emptyFeed = true;
|
this.emptyFeed = true;
|
||||||
return;
|
return;
|
||||||
|
@ -651,32 +632,15 @@
|
||||||
this.min_id = Math.max(...ids).toString();
|
this.min_id = Math.max(...ids).toString();
|
||||||
this.max_id = Math.min(...ids).toString();
|
this.max_id = Math.min(...ids).toString();
|
||||||
this.loading = false;
|
this.loading = false;
|
||||||
// $('.timeline .pagination').removeClass('d-none');
|
|
||||||
|
|
||||||
// if(this.hashtagPosts.length == 0) {
|
|
||||||
// this.fetchHashtagPosts();
|
|
||||||
// }
|
|
||||||
this.$nextTick(() => {
|
this.$nextTick(() => {
|
||||||
this.hasStory();
|
this.hasStory();
|
||||||
});
|
});
|
||||||
// this.fetchStories();
|
|
||||||
// this.rtw();
|
|
||||||
|
|
||||||
setTimeout(function() {
|
setTimeout(function() {
|
||||||
document.querySelectorAll('.timeline .card-body .comments .comment-body a').forEach(function(i, e) {
|
document.querySelectorAll('.timeline .card-body .comments .comment-body a').forEach(function(i, e) {
|
||||||
i.href = App.util.format.rewriteLinks(i);
|
i.href = App.util.format.rewriteLinks(i);
|
||||||
});
|
});
|
||||||
}, 500);
|
}, 500);
|
||||||
|
|
||||||
// axios.get('/api/pixelfed/v2/discover/posts/trending', {
|
|
||||||
// params: {
|
|
||||||
// range: 'daily'
|
|
||||||
// }
|
|
||||||
// }).then(res => {
|
|
||||||
// let data = res.data.filter(post => this.ids.indexOf(post.id) === -1);
|
|
||||||
// this.discover_feed = data;
|
|
||||||
// });
|
|
||||||
|
|
||||||
}).catch(err => {
|
}).catch(err => {
|
||||||
swal(
|
swal(
|
||||||
'Oops, something went wrong',
|
'Oops, something went wrong',
|
||||||
|
@ -733,8 +697,8 @@
|
||||||
self.feed.push(d);
|
self.feed.push(d);
|
||||||
self.ids.push(d.id);
|
self.ids.push(d.id);
|
||||||
// vids.push({
|
// vids.push({
|
||||||
// sid: d.id,
|
// sid: d.id,
|
||||||
// pid: d.account.id
|
// pid: d.account.id
|
||||||
// });
|
// });
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -744,7 +708,7 @@
|
||||||
$state.loaded();
|
$state.loaded();
|
||||||
this.loading = false;
|
this.loading = false;
|
||||||
// axios.post('/api/status/view', {
|
// axios.post('/api/status/view', {
|
||||||
// '_v': vids,
|
// '_v': vids,
|
||||||
// });
|
// });
|
||||||
} else {
|
} else {
|
||||||
$state.complete();
|
$state.complete();
|
||||||
|
@ -915,11 +879,6 @@
|
||||||
}
|
}
|
||||||
$('.postCommentsLoader').addClass('d-none');
|
$('.postCommentsLoader').addClass('d-none');
|
||||||
$('.postCommentsContainer').removeClass('d-none');
|
$('.postCommentsContainer').removeClass('d-none');
|
||||||
// setTimeout(function() {
|
|
||||||
// document.querySelectorAll('.status-comment .postCommentsContainer .comment-body a').forEach(function(i, e) {
|
|
||||||
// i.href = App.util.format.rewriteLinks(i);
|
|
||||||
// });
|
|
||||||
// }, 500);
|
|
||||||
}).catch(error => {
|
}).catch(error => {
|
||||||
if(!error.response) {
|
if(!error.response) {
|
||||||
$('.postCommentsLoader .lds-ring')
|
$('.postCommentsLoader .lds-ring')
|
||||||
|
|
|
@ -636,7 +636,7 @@
|
||||||
},
|
},
|
||||||
|
|
||||||
statusUrl(status) {
|
statusUrl(status) {
|
||||||
if(status.local == true) {
|
if(status.account.local == true) {
|
||||||
return status.url;
|
return status.url;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -644,7 +644,7 @@
|
||||||
},
|
},
|
||||||
|
|
||||||
profileUrl(status) {
|
profileUrl(status) {
|
||||||
if(status.local == true) {
|
if(status.account.local == true) {
|
||||||
return status.account.url;
|
return status.account.url;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<template>
|
<template>
|
||||||
<div>
|
<div>
|
||||||
<div class="card shadow-none border rounded-0" :class="{'border-top-0': !showBorderTop}">
|
<div class="card shadow-none rounded-0" :class="{ border: showBorder, 'border-top-0': !showBorderTop}">
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<div class="media">
|
<div class="media">
|
||||||
<img class="rounded-circle box-shadow mr-2" :src="status.account.avatar" width="32px" height="32px" alt="avatar">
|
<img class="rounded-circle box-shadow mr-2" :src="status.account.avatar" width="32px" height="32px" alt="avatar">
|
||||||
|
@ -149,6 +149,11 @@
|
||||||
type: Object
|
type: Object
|
||||||
},
|
},
|
||||||
|
|
||||||
|
showBorder: {
|
||||||
|
type: Boolean,
|
||||||
|
default: true
|
||||||
|
},
|
||||||
|
|
||||||
showBorderTop: {
|
showBorderTop: {
|
||||||
type: Boolean,
|
type: Boolean,
|
||||||
default: false
|
default: false
|
||||||
|
|
|
@ -29,7 +29,8 @@
|
||||||
:alt="altText(status)"
|
:alt="altText(status)"
|
||||||
:width="width()"
|
:width="width()"
|
||||||
:height="height()"
|
:height="height()"
|
||||||
onerror="this.onerror=null;this.src='/storage/no-preview.png'">
|
onerror="this.onerror=null;this.src='/storage/no-preview.png'"
|
||||||
|
@click.prevent="toggleLightbox">
|
||||||
|
|
||||||
<p v-if="!status.sensitive && sensitive"
|
<p v-if="!status.sensitive && sensitive"
|
||||||
@click="status.sensitive = true"
|
@click="status.sensitive = true"
|
||||||
|
@ -116,6 +117,10 @@
|
||||||
this.$emit('togglecw');
|
this.$emit('togglecw');
|
||||||
},
|
},
|
||||||
|
|
||||||
|
toggleLightbox() {
|
||||||
|
this.$emit('lightbox');
|
||||||
|
},
|
||||||
|
|
||||||
width() {
|
width() {
|
||||||
if( !this.status.media_attachments[0].meta ||
|
if( !this.status.media_attachments[0].meta ||
|
||||||
!this.status.media_attachments[0].meta.original ||
|
!this.status.media_attachments[0].meta.original ||
|
||||||
|
|
21606
resources/assets/js/lib/ace/ace.js
vendored
21606
resources/assets/js/lib/ace/ace.js
vendored
File diff suppressed because it is too large
Load diff
417
resources/assets/js/lib/ace/mode-dot.js
vendored
417
resources/assets/js/lib/ace/mode-dot.js
vendored
|
@ -1,417 +0,0 @@
|
||||||
ace.define("ace/mode/matching_brace_outdent",["require","exports","module","ace/range"], function(require, exports, module) {
|
|
||||||
"use strict";
|
|
||||||
|
|
||||||
var Range = require("../range").Range;
|
|
||||||
|
|
||||||
var MatchingBraceOutdent = function() {};
|
|
||||||
|
|
||||||
(function() {
|
|
||||||
|
|
||||||
this.checkOutdent = function(line, input) {
|
|
||||||
if (! /^\s+$/.test(line))
|
|
||||||
return false;
|
|
||||||
|
|
||||||
return /^\s*\}/.test(input);
|
|
||||||
};
|
|
||||||
|
|
||||||
this.autoOutdent = function(doc, row) {
|
|
||||||
var line = doc.getLine(row);
|
|
||||||
var match = line.match(/^(\s*\})/);
|
|
||||||
|
|
||||||
if (!match) return 0;
|
|
||||||
|
|
||||||
var column = match[1].length;
|
|
||||||
var openBracePos = doc.findMatchingBracket({row: row, column: column});
|
|
||||||
|
|
||||||
if (!openBracePos || openBracePos.row == row) return 0;
|
|
||||||
|
|
||||||
var indent = this.$getIndent(doc.getLine(openBracePos.row));
|
|
||||||
doc.replace(new Range(row, 0, row, column-1), indent);
|
|
||||||
};
|
|
||||||
|
|
||||||
this.$getIndent = function(line) {
|
|
||||||
return line.match(/^\s*/)[0];
|
|
||||||
};
|
|
||||||
|
|
||||||
}).call(MatchingBraceOutdent.prototype);
|
|
||||||
|
|
||||||
exports.MatchingBraceOutdent = MatchingBraceOutdent;
|
|
||||||
});
|
|
||||||
|
|
||||||
ace.define("ace/mode/doc_comment_highlight_rules",["require","exports","module","ace/lib/oop","ace/mode/text_highlight_rules"], function(require, exports, module) {
|
|
||||||
"use strict";
|
|
||||||
|
|
||||||
var oop = require("../lib/oop");
|
|
||||||
var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
|
|
||||||
|
|
||||||
var DocCommentHighlightRules = function() {
|
|
||||||
this.$rules = {
|
|
||||||
"start" : [ {
|
|
||||||
token : "comment.doc.tag",
|
|
||||||
regex : "@[\\w\\d_]+" // TODO: fix email addresses
|
|
||||||
},
|
|
||||||
DocCommentHighlightRules.getTagRule(),
|
|
||||||
{
|
|
||||||
defaultToken : "comment.doc",
|
|
||||||
caseInsensitive: true
|
|
||||||
}]
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
oop.inherits(DocCommentHighlightRules, TextHighlightRules);
|
|
||||||
|
|
||||||
DocCommentHighlightRules.getTagRule = function(start) {
|
|
||||||
return {
|
|
||||||
token : "comment.doc.tag.storage.type",
|
|
||||||
regex : "\\b(?:TODO|FIXME|XXX|HACK)\\b"
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
DocCommentHighlightRules.getStartRule = function(start) {
|
|
||||||
return {
|
|
||||||
token : "comment.doc", // doc comment
|
|
||||||
regex : "\\/\\*(?=\\*)",
|
|
||||||
next : start
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
DocCommentHighlightRules.getEndRule = function (start) {
|
|
||||||
return {
|
|
||||||
token : "comment.doc", // closing comment
|
|
||||||
regex : "\\*\\/",
|
|
||||||
next : start
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
exports.DocCommentHighlightRules = DocCommentHighlightRules;
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
ace.define("ace/mode/dot_highlight_rules",["require","exports","module","ace/lib/oop","ace/lib/lang","ace/mode/text_highlight_rules","ace/mode/doc_comment_highlight_rules"], function(require, exports, module) {
|
|
||||||
"use strict";
|
|
||||||
|
|
||||||
var oop = require("../lib/oop");
|
|
||||||
var lang = require("../lib/lang");
|
|
||||||
var TextHighlightRules = require("./text_highlight_rules").TextHighlightRules;
|
|
||||||
var DocCommentHighlightRules = require("./doc_comment_highlight_rules").DocCommentHighlightRules;
|
|
||||||
|
|
||||||
var DotHighlightRules = function() {
|
|
||||||
|
|
||||||
var keywords = lang.arrayToMap(
|
|
||||||
("strict|node|edge|graph|digraph|subgraph").split("|")
|
|
||||||
);
|
|
||||||
|
|
||||||
var attributes = lang.arrayToMap(
|
|
||||||
("damping|k|url|area|arrowhead|arrowsize|arrowtail|aspect|bb|bgcolor|center|charset|clusterrank|color|colorscheme|comment|compound|concentrate|constraint|decorate|defaultdist|dim|dimen|dir|diredgeconstraints|distortion|dpi|edgeurl|edgehref|edgetarget|edgetooltip|epsilon|esep|fillcolor|fixedsize|fontcolor|fontname|fontnames|fontpath|fontsize|forcelabels|gradientangle|group|headurl|head_lp|headclip|headhref|headlabel|headport|headtarget|headtooltip|height|href|id|image|imagepath|imagescale|label|labelurl|label_scheme|labelangle|labeldistance|labelfloat|labelfontcolor|labelfontname|labelfontsize|labelhref|labeljust|labelloc|labeltarget|labeltooltip|landscape|layer|layerlistsep|layers|layerselect|layersep|layout|len|levels|levelsgap|lhead|lheight|lp|ltail|lwidth|margin|maxiter|mclimit|mindist|minlen|mode|model|mosek|nodesep|nojustify|normalize|nslimit|nslimit1|ordering|orientation|outputorder|overlap|overlap_scaling|pack|packmode|pad|page|pagedir|pencolor|penwidth|peripheries|pin|pos|quadtree|quantum|rank|rankdir|ranksep|ratio|rects|regular|remincross|repulsiveforce|resolution|root|rotate|rotation|samehead|sametail|samplepoints|scale|searchsize|sep|shape|shapefile|showboxes|sides|size|skew|smoothing|sortv|splines|start|style|stylesheet|tailurl|tail_lp|tailclip|tailhref|taillabel|tailport|tailtarget|tailtooltip|target|tooltip|truecolor|vertices|viewport|voro_margin|weight|width|xlabel|xlp|z").split("|")
|
|
||||||
);
|
|
||||||
|
|
||||||
this.$rules = {
|
|
||||||
"start" : [
|
|
||||||
{
|
|
||||||
token : "comment",
|
|
||||||
regex : /\/\/.*$/
|
|
||||||
}, {
|
|
||||||
token : "comment",
|
|
||||||
regex : /#.*$/
|
|
||||||
}, {
|
|
||||||
token : "comment", // multi line comment
|
|
||||||
merge : true,
|
|
||||||
regex : /\/\*/,
|
|
||||||
next : "comment"
|
|
||||||
}, {
|
|
||||||
token : "string",
|
|
||||||
regex : "'(?=.)",
|
|
||||||
next : "qstring"
|
|
||||||
}, {
|
|
||||||
token : "string",
|
|
||||||
regex : '"(?=.)',
|
|
||||||
next : "qqstring"
|
|
||||||
}, {
|
|
||||||
token : "constant.numeric",
|
|
||||||
regex : /[+\-]?\d+(?:(?:\.\d*)?(?:[eE][+\-]?\d+)?)?\b/
|
|
||||||
}, {
|
|
||||||
token : "keyword.operator",
|
|
||||||
regex : /\+|=|\->/
|
|
||||||
}, {
|
|
||||||
token : "punctuation.operator",
|
|
||||||
regex : /,|;/
|
|
||||||
}, {
|
|
||||||
token : "paren.lparen",
|
|
||||||
regex : /[\[{]/
|
|
||||||
}, {
|
|
||||||
token : "paren.rparen",
|
|
||||||
regex : /[\]}]/
|
|
||||||
}, {
|
|
||||||
token: "comment",
|
|
||||||
regex: /^#!.*$/
|
|
||||||
}, {
|
|
||||||
token: function(value) {
|
|
||||||
if (keywords.hasOwnProperty(value.toLowerCase())) {
|
|
||||||
return "keyword";
|
|
||||||
}
|
|
||||||
else if (attributes.hasOwnProperty(value.toLowerCase())) {
|
|
||||||
return "variable";
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
return "text";
|
|
||||||
}
|
|
||||||
},
|
|
||||||
regex: "\\-?[a-zA-Z_][a-zA-Z0-9_\\-]*"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"comment" : [
|
|
||||||
{
|
|
||||||
token : "comment", // closing comment
|
|
||||||
regex : "\\*\\/",
|
|
||||||
next : "start"
|
|
||||||
}, {
|
|
||||||
defaultToken : "comment"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"qqstring" : [
|
|
||||||
{
|
|
||||||
token : "string",
|
|
||||||
regex : '[^"\\\\]+',
|
|
||||||
merge : true
|
|
||||||
}, {
|
|
||||||
token : "string",
|
|
||||||
regex : "\\\\$",
|
|
||||||
next : "qqstring",
|
|
||||||
merge : true
|
|
||||||
}, {
|
|
||||||
token : "string",
|
|
||||||
regex : '"|$',
|
|
||||||
next : "start",
|
|
||||||
merge : true
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"qstring" : [
|
|
||||||
{
|
|
||||||
token : "string",
|
|
||||||
regex : "[^'\\\\]+",
|
|
||||||
merge : true
|
|
||||||
}, {
|
|
||||||
token : "string",
|
|
||||||
regex : "\\\\$",
|
|
||||||
next : "qstring",
|
|
||||||
merge : true
|
|
||||||
}, {
|
|
||||||
token : "string",
|
|
||||||
regex : "'|$",
|
|
||||||
next : "start",
|
|
||||||
merge : true
|
|
||||||
}
|
|
||||||
]
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
oop.inherits(DotHighlightRules, TextHighlightRules);
|
|
||||||
|
|
||||||
exports.DotHighlightRules = DotHighlightRules;
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
ace.define("ace/mode/folding/cstyle",["require","exports","module","ace/lib/oop","ace/range","ace/mode/folding/fold_mode"], function(require, exports, module) {
|
|
||||||
"use strict";
|
|
||||||
|
|
||||||
var oop = require("../../lib/oop");
|
|
||||||
var Range = require("../../range").Range;
|
|
||||||
var BaseFoldMode = require("./fold_mode").FoldMode;
|
|
||||||
|
|
||||||
var FoldMode = exports.FoldMode = function(commentRegex) {
|
|
||||||
if (commentRegex) {
|
|
||||||
this.foldingStartMarker = new RegExp(
|
|
||||||
this.foldingStartMarker.source.replace(/\|[^|]*?$/, "|" + commentRegex.start)
|
|
||||||
);
|
|
||||||
this.foldingStopMarker = new RegExp(
|
|
||||||
this.foldingStopMarker.source.replace(/\|[^|]*?$/, "|" + commentRegex.end)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
oop.inherits(FoldMode, BaseFoldMode);
|
|
||||||
|
|
||||||
(function() {
|
|
||||||
|
|
||||||
this.foldingStartMarker = /([\{\[\(])[^\}\]\)]*$|^\s*(\/\*)/;
|
|
||||||
this.foldingStopMarker = /^[^\[\{\(]*([\}\]\)])|^[\s\*]*(\*\/)/;
|
|
||||||
this.singleLineBlockCommentRe= /^\s*(\/\*).*\*\/\s*$/;
|
|
||||||
this.tripleStarBlockCommentRe = /^\s*(\/\*\*\*).*\*\/\s*$/;
|
|
||||||
this.startRegionRe = /^\s*(\/\*|\/\/)#?region\b/;
|
|
||||||
this._getFoldWidgetBase = this.getFoldWidget;
|
|
||||||
this.getFoldWidget = function(session, foldStyle, row) {
|
|
||||||
var line = session.getLine(row);
|
|
||||||
|
|
||||||
if (this.singleLineBlockCommentRe.test(line)) {
|
|
||||||
if (!this.startRegionRe.test(line) && !this.tripleStarBlockCommentRe.test(line))
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
var fw = this._getFoldWidgetBase(session, foldStyle, row);
|
|
||||||
|
|
||||||
if (!fw && this.startRegionRe.test(line))
|
|
||||||
return "start"; // lineCommentRegionStart
|
|
||||||
|
|
||||||
return fw;
|
|
||||||
};
|
|
||||||
|
|
||||||
this.getFoldWidgetRange = function(session, foldStyle, row, forceMultiline) {
|
|
||||||
var line = session.getLine(row);
|
|
||||||
|
|
||||||
if (this.startRegionRe.test(line))
|
|
||||||
return this.getCommentRegionBlock(session, line, row);
|
|
||||||
|
|
||||||
var match = line.match(this.foldingStartMarker);
|
|
||||||
if (match) {
|
|
||||||
var i = match.index;
|
|
||||||
|
|
||||||
if (match[1])
|
|
||||||
return this.openingBracketBlock(session, match[1], row, i);
|
|
||||||
|
|
||||||
var range = session.getCommentFoldRange(row, i + match[0].length, 1);
|
|
||||||
|
|
||||||
if (range && !range.isMultiLine()) {
|
|
||||||
if (forceMultiline) {
|
|
||||||
range = this.getSectionRange(session, row);
|
|
||||||
} else if (foldStyle != "all")
|
|
||||||
range = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
return range;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (foldStyle === "markbegin")
|
|
||||||
return;
|
|
||||||
|
|
||||||
var match = line.match(this.foldingStopMarker);
|
|
||||||
if (match) {
|
|
||||||
var i = match.index + match[0].length;
|
|
||||||
|
|
||||||
if (match[1])
|
|
||||||
return this.closingBracketBlock(session, match[1], row, i);
|
|
||||||
|
|
||||||
return session.getCommentFoldRange(row, i, -1);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
this.getSectionRange = function(session, row) {
|
|
||||||
var line = session.getLine(row);
|
|
||||||
var startIndent = line.search(/\S/);
|
|
||||||
var startRow = row;
|
|
||||||
var startColumn = line.length;
|
|
||||||
row = row + 1;
|
|
||||||
var endRow = row;
|
|
||||||
var maxRow = session.getLength();
|
|
||||||
while (++row < maxRow) {
|
|
||||||
line = session.getLine(row);
|
|
||||||
var indent = line.search(/\S/);
|
|
||||||
if (indent === -1)
|
|
||||||
continue;
|
|
||||||
if (startIndent > indent)
|
|
||||||
break;
|
|
||||||
var subRange = this.getFoldWidgetRange(session, "all", row);
|
|
||||||
|
|
||||||
if (subRange) {
|
|
||||||
if (subRange.start.row <= startRow) {
|
|
||||||
break;
|
|
||||||
} else if (subRange.isMultiLine()) {
|
|
||||||
row = subRange.end.row;
|
|
||||||
} else if (startIndent == indent) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
endRow = row;
|
|
||||||
}
|
|
||||||
|
|
||||||
return new Range(startRow, startColumn, endRow, session.getLine(endRow).length);
|
|
||||||
};
|
|
||||||
this.getCommentRegionBlock = function(session, line, row) {
|
|
||||||
var startColumn = line.search(/\s*$/);
|
|
||||||
var maxRow = session.getLength();
|
|
||||||
var startRow = row;
|
|
||||||
|
|
||||||
var re = /^\s*(?:\/\*|\/\/|--)#?(end)?region\b/;
|
|
||||||
var depth = 1;
|
|
||||||
while (++row < maxRow) {
|
|
||||||
line = session.getLine(row);
|
|
||||||
var m = re.exec(line);
|
|
||||||
if (!m) continue;
|
|
||||||
if (m[1]) depth--;
|
|
||||||
else depth++;
|
|
||||||
|
|
||||||
if (!depth) break;
|
|
||||||
}
|
|
||||||
|
|
||||||
var endRow = row;
|
|
||||||
if (endRow > startRow) {
|
|
||||||
return new Range(startRow, startColumn, endRow, line.length);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
}).call(FoldMode.prototype);
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
ace.define("ace/mode/dot",["require","exports","module","ace/lib/oop","ace/mode/text","ace/mode/matching_brace_outdent","ace/mode/dot_highlight_rules","ace/mode/folding/cstyle"], function(require, exports, module) {
|
|
||||||
"use strict";
|
|
||||||
|
|
||||||
var oop = require("../lib/oop");
|
|
||||||
var TextMode = require("./text").Mode;
|
|
||||||
var MatchingBraceOutdent = require("./matching_brace_outdent").MatchingBraceOutdent;
|
|
||||||
var DotHighlightRules = require("./dot_highlight_rules").DotHighlightRules;
|
|
||||||
var DotFoldMode = require("./folding/cstyle").FoldMode;
|
|
||||||
|
|
||||||
var Mode = function() {
|
|
||||||
this.HighlightRules = DotHighlightRules;
|
|
||||||
this.$outdent = new MatchingBraceOutdent();
|
|
||||||
this.foldingRules = new DotFoldMode();
|
|
||||||
this.$behaviour = this.$defaultBehaviour;
|
|
||||||
};
|
|
||||||
oop.inherits(Mode, TextMode);
|
|
||||||
|
|
||||||
(function() {
|
|
||||||
|
|
||||||
this.lineCommentStart = ["//", "#"];
|
|
||||||
this.blockComment = {start: "/*", end: "*/"};
|
|
||||||
|
|
||||||
this.getNextLineIndent = function(state, line, tab) {
|
|
||||||
var indent = this.$getIndent(line);
|
|
||||||
|
|
||||||
var tokenizedLine = this.getTokenizer().getLineTokens(line, state);
|
|
||||||
var tokens = tokenizedLine.tokens;
|
|
||||||
var endState = tokenizedLine.state;
|
|
||||||
|
|
||||||
if (tokens.length && tokens[tokens.length-1].type == "comment") {
|
|
||||||
return indent;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (state == "start") {
|
|
||||||
var match = line.match(/^.*(?:\bcase\b.*:|[\{\(\[])\s*$/);
|
|
||||||
if (match) {
|
|
||||||
indent += tab;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return indent;
|
|
||||||
};
|
|
||||||
|
|
||||||
this.checkOutdent = function(state, line, input) {
|
|
||||||
return this.$outdent.checkOutdent(line, input);
|
|
||||||
};
|
|
||||||
|
|
||||||
this.autoOutdent = function(state, doc, row) {
|
|
||||||
this.$outdent.autoOutdent(doc, row);
|
|
||||||
};
|
|
||||||
|
|
||||||
this.$id = "ace/mode/dot";
|
|
||||||
}).call(Mode.prototype);
|
|
||||||
|
|
||||||
exports.Mode = Mode;
|
|
||||||
}); (function() {
|
|
||||||
ace.require(["ace/mode/dot"], function(m) {
|
|
||||||
if (typeof module == "object" && typeof exports == "object" && module) {
|
|
||||||
module.exports = m;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
})();
|
|
||||||
|
|
112
resources/assets/js/lib/ace/theme-monokai.js
vendored
112
resources/assets/js/lib/ace/theme-monokai.js
vendored
|
@ -1,112 +0,0 @@
|
||||||
ace.define("ace/theme/monokai",["require","exports","module","ace/lib/dom"], function(require, exports, module) {
|
|
||||||
|
|
||||||
exports.isDark = true;
|
|
||||||
exports.cssClass = "ace-monokai";
|
|
||||||
exports.cssText = ".ace-monokai .ace_gutter {\
|
|
||||||
background: #2F3129;\
|
|
||||||
color: #8F908A\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_print-margin {\
|
|
||||||
width: 1px;\
|
|
||||||
background: #555651\
|
|
||||||
}\
|
|
||||||
.ace-monokai {\
|
|
||||||
background-color: #272822;\
|
|
||||||
color: #F8F8F2\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_cursor {\
|
|
||||||
color: #F8F8F0\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_marker-layer .ace_selection {\
|
|
||||||
background: #49483E\
|
|
||||||
}\
|
|
||||||
.ace-monokai.ace_multiselect .ace_selection.ace_start {\
|
|
||||||
box-shadow: 0 0 3px 0px #272822;\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_marker-layer .ace_step {\
|
|
||||||
background: rgb(102, 82, 0)\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_marker-layer .ace_bracket {\
|
|
||||||
margin: -1px 0 0 -1px;\
|
|
||||||
border: 1px solid #49483E\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_marker-layer .ace_active-line {\
|
|
||||||
background: #202020\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_gutter-active-line {\
|
|
||||||
background-color: #272727\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_marker-layer .ace_selected-word {\
|
|
||||||
border: 1px solid #49483E\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_invisible {\
|
|
||||||
color: #52524d\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_entity.ace_name.ace_tag,\
|
|
||||||
.ace-monokai .ace_keyword,\
|
|
||||||
.ace-monokai .ace_meta.ace_tag,\
|
|
||||||
.ace-monokai .ace_storage {\
|
|
||||||
color: #F92672\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_punctuation,\
|
|
||||||
.ace-monokai .ace_punctuation.ace_tag {\
|
|
||||||
color: #fff\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_constant.ace_character,\
|
|
||||||
.ace-monokai .ace_constant.ace_language,\
|
|
||||||
.ace-monokai .ace_constant.ace_numeric,\
|
|
||||||
.ace-monokai .ace_constant.ace_other {\
|
|
||||||
color: #AE81FF\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_invalid {\
|
|
||||||
color: #F8F8F0;\
|
|
||||||
background-color: #F92672\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_invalid.ace_deprecated {\
|
|
||||||
color: #F8F8F0;\
|
|
||||||
background-color: #AE81FF\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_support.ace_constant,\
|
|
||||||
.ace-monokai .ace_support.ace_function {\
|
|
||||||
color: #66D9EF\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_fold {\
|
|
||||||
background-color: #A6E22E;\
|
|
||||||
border-color: #F8F8F2\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_storage.ace_type,\
|
|
||||||
.ace-monokai .ace_support.ace_class,\
|
|
||||||
.ace-monokai .ace_support.ace_type {\
|
|
||||||
font-style: italic;\
|
|
||||||
color: #66D9EF\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_entity.ace_name.ace_function,\
|
|
||||||
.ace-monokai .ace_entity.ace_other,\
|
|
||||||
.ace-monokai .ace_entity.ace_other.ace_attribute-name,\
|
|
||||||
.ace-monokai .ace_variable {\
|
|
||||||
color: #A6E22E\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_variable.ace_parameter {\
|
|
||||||
font-style: italic;\
|
|
||||||
color: #FD971F\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_string {\
|
|
||||||
color: #E6DB74\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_comment {\
|
|
||||||
color: #75715E\
|
|
||||||
}\
|
|
||||||
.ace-monokai .ace_indent-guide {\
|
|
||||||
background: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAACCAYAAACZgbYnAAAAEklEQVQImWPQ0FD0ZXBzd/wPAAjVAoxeSgNeAAAAAElFTkSuQmCC) right repeat-y\
|
|
||||||
}";
|
|
||||||
|
|
||||||
var dom = require("../lib/dom");
|
|
||||||
dom.importCssString(exports.cssText, exports.cssClass);
|
|
||||||
}); (function() {
|
|
||||||
ace.require(["ace/theme/monokai"], function(m) {
|
|
||||||
if (typeof module == "object" && typeof exports == "object" && module) {
|
|
||||||
module.exports = m;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
})();
|
|
||||||
|
|
1
resources/assets/js/quill.js
vendored
1
resources/assets/js/quill.js
vendored
|
@ -1 +0,0 @@
|
||||||
window.Quill = require('quill');
|
|
1
resources/assets/sass/quill.scss
vendored
1
resources/assets/sass/quill.scss
vendored
|
@ -1 +0,0 @@
|
||||||
@import '~quill/dist/quill.snow.css';
|
|
|
@ -1,6 +1,4 @@
|
||||||
@extends('admin.partial.template')
|
@extends('admin.partial.template-full')
|
||||||
|
|
||||||
@include('admin.settings.sidebar')
|
|
||||||
|
|
||||||
@section('section')
|
@section('section')
|
||||||
<div class="title">
|
<div class="title">
|
||||||
|
@ -20,7 +18,7 @@
|
||||||
<span>Slug</span>
|
<span>Slug</span>
|
||||||
</th>
|
</th>
|
||||||
<th scope="col" class="border-0" width="15%">
|
<th scope="col" class="border-0" width="15%">
|
||||||
<span>Active</span>
|
<span>State</span>
|
||||||
</th>
|
</th>
|
||||||
<th scope="col" class="border-0" width="30%">
|
<th scope="col" class="border-0" width="30%">
|
||||||
<span>Updated</span>
|
<span>Updated</span>
|
||||||
|
@ -34,7 +32,11 @@
|
||||||
<a href="{{$page->editUrl()}}">{{$page->id}}</a>
|
<a href="{{$page->editUrl()}}">{{$page->id}}</a>
|
||||||
</th>
|
</th>
|
||||||
<td>{{$page->slug}}</td>
|
<td>{{$page->slug}}</td>
|
||||||
<td>{{$page->active ? 'active':'inactive'}}</td>
|
@if($page->active)
|
||||||
|
<td class="text-success font-weight-bold">Live</td>
|
||||||
|
@else
|
||||||
|
<td class="text-muted">Draft</td>
|
||||||
|
@endif
|
||||||
<td>{{$page->updated_at->diffForHumans(null, true, true, true)}}</td>
|
<td>{{$page->updated_at->diffForHumans(null, true, true, true)}}</td>
|
||||||
</tr>
|
</tr>
|
||||||
@endforeach
|
@endforeach
|
||||||
|
|
|
@ -1,94 +0,0 @@
|
||||||
@extends('admin.partial.template')
|
|
||||||
|
|
||||||
@include('admin.settings.sidebar')
|
|
||||||
|
|
||||||
@section('section')
|
|
||||||
<div class="title">
|
|
||||||
<h3 class="font-weight-bold">Configuration Settings</h3>
|
|
||||||
@if($editor == false)
|
|
||||||
<hr>
|
|
||||||
<div class="card bg-light shadow-none rounded-0">
|
|
||||||
<div class="card-body text-center py-5">
|
|
||||||
<p class="lead text-muted font-weight-bold">Configuration Editor is disabled</p>
|
|
||||||
<p class="mb-0">To enable it, add <code>ADMIN_ENV_EDITOR=true</code> to <code>.env</code><br>then run <code>php artisan config:cache</code></p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
@else
|
|
||||||
<p class="lead">Edit configuration settings</p>
|
|
||||||
<p class="alert alert-warning">
|
|
||||||
<strong>Warning:</strong> If you have opcache enabled, you may need to restart php for the changes to take effect.
|
|
||||||
</p>
|
|
||||||
</div>
|
|
||||||
<hr>
|
|
||||||
<div>
|
|
||||||
<div id="editor">{{$config}}</div>
|
|
||||||
<hr>
|
|
||||||
<div class="d-flex justify-content-between px-3">
|
|
||||||
@if($backup)
|
|
||||||
<button class="btn btn-outline-secondary font-weight-bold py-1 btn-restore">Restore backup .env</button>
|
|
||||||
@else
|
|
||||||
<div></div>
|
|
||||||
@endif
|
|
||||||
<button class="btn btn-primary font-weight-bold py-1 btn-save">Save</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
@endif
|
|
||||||
@endsection
|
|
||||||
@if($editor == true)
|
|
||||||
@push('scripts')
|
|
||||||
<script src="{{mix('js/ace.js')}}"></script>
|
|
||||||
<script>
|
|
||||||
let editor = ace.edit("editor");
|
|
||||||
editor.session.setUseWrapMode(true);
|
|
||||||
editor.setTheme("ace/theme/monokai");
|
|
||||||
editor.session.setMode("ace/mode/dot");
|
|
||||||
|
|
||||||
$('.btn-restore').on('click', function(e) {
|
|
||||||
e.preventDefault();
|
|
||||||
let confirm = window.confirm('Are you sure you want to restore your backup .env?');
|
|
||||||
if(!confirm) {
|
|
||||||
swal('Cancelled', 'You have cancelled the .env backup restore.', 'warning');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
axios.post('/i/admin/settings/config/restore', {
|
|
||||||
}).then(res => {
|
|
||||||
swal('Success', 'Configuration successfully restored!', 'success');
|
|
||||||
setTimeout(function() {
|
|
||||||
window.location.href = window.location.href;
|
|
||||||
}, 3000);
|
|
||||||
});
|
|
||||||
})
|
|
||||||
|
|
||||||
$('.btn-save').on('click', function(e) {
|
|
||||||
e.preventDefault();
|
|
||||||
let confirm = window.confirm('Are you sure you want to overwrite your current .env?');
|
|
||||||
if(!confirm) {
|
|
||||||
swal('Cancelled', 'You have cancelled the .env update.', 'warning');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
axios.post('/i/admin/settings/config', {
|
|
||||||
res: editor.getValue()
|
|
||||||
}).then(res => {
|
|
||||||
swal('Success', 'Configuration successfully updated!', 'success');
|
|
||||||
setTimeout(function() {
|
|
||||||
window.location.href = window.location.href;
|
|
||||||
}, 3000);
|
|
||||||
});
|
|
||||||
})
|
|
||||||
</script>
|
|
||||||
@endpush
|
|
||||||
|
|
||||||
@push('styles')
|
|
||||||
<style type="text/css" media="screen">
|
|
||||||
#editor {
|
|
||||||
display: block;
|
|
||||||
top: 0;
|
|
||||||
right: 0;
|
|
||||||
bottom: 0;
|
|
||||||
left: 0;
|
|
||||||
width: 100%;
|
|
||||||
min-height: 400px;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
@endpush
|
|
||||||
@endif
|
|
|
@ -47,9 +47,6 @@ Route::domain(config('pixelfed.domain.admin'))->prefix('i/admin')->group(functio
|
||||||
Route::get('media/show/{id}', 'AdminController@mediaShow');
|
Route::get('media/show/{id}', 'AdminController@mediaShow');
|
||||||
Route::get('settings', 'AdminController@settings')->name('admin.settings');
|
Route::get('settings', 'AdminController@settings')->name('admin.settings');
|
||||||
Route::post('settings', 'AdminController@settingsHomeStore');
|
Route::post('settings', 'AdminController@settingsHomeStore');
|
||||||
Route::get('settings/config', 'AdminController@settingsConfig')->name('admin.settings.config');
|
|
||||||
Route::post('settings/config', 'AdminController@settingsConfigStore');
|
|
||||||
Route::post('settings/config/restore', 'AdminController@settingsConfigRestore');
|
|
||||||
Route::get('settings/features', 'AdminController@settingsFeatures')->name('admin.settings.features');
|
Route::get('settings/features', 'AdminController@settingsFeatures')->name('admin.settings.features');
|
||||||
Route::get('settings/pages', 'AdminController@settingsPages')->name('admin.settings.pages');
|
Route::get('settings/pages', 'AdminController@settingsPages')->name('admin.settings.pages');
|
||||||
Route::get('settings/pages/edit', 'PageController@edit')->name('admin.settings.pages.edit');
|
Route::get('settings/pages/edit', 'PageController@edit')->name('admin.settings.pages.edit');
|
||||||
|
|
7
webpack.mix.js
vendored
7
webpack.mix.js
vendored
|
@ -3,8 +3,7 @@ let mix = require('laravel-mix');
|
||||||
mix.sass('resources/assets/sass/app.scss', 'public/css')
|
mix.sass('resources/assets/sass/app.scss', 'public/css')
|
||||||
.sass('resources/assets/sass/appdark.scss', 'public/css')
|
.sass('resources/assets/sass/appdark.scss', 'public/css')
|
||||||
.sass('resources/assets/sass/admin.scss', 'public/css')
|
.sass('resources/assets/sass/admin.scss', 'public/css')
|
||||||
.sass('resources/assets/sass/landing.scss', 'public/css')
|
.sass('resources/assets/sass/landing.scss', 'public/css').version();
|
||||||
.sass('resources/assets/sass/quill.scss', 'public/css').version();
|
|
||||||
|
|
||||||
mix.js('resources/assets/js/app.js', 'public/js')
|
mix.js('resources/assets/js/app.js', 'public/js')
|
||||||
.js('resources/assets/js/activity.js', 'public/js')
|
.js('resources/assets/js/activity.js', 'public/js')
|
||||||
|
@ -18,10 +17,6 @@ mix.js('resources/assets/js/app.js', 'public/js')
|
||||||
.js('resources/assets/js/search.js', 'public/js')
|
.js('resources/assets/js/search.js', 'public/js')
|
||||||
.js('resources/assets/js/developers.js', 'public/js')
|
.js('resources/assets/js/developers.js', 'public/js')
|
||||||
.js('resources/assets/js/loops.js', 'public/js')
|
.js('resources/assets/js/loops.js', 'public/js')
|
||||||
.js('resources/assets/js/quill.js', 'public/js')
|
|
||||||
.js('resources/assets/js/lib/ace/ace.js', 'public/js')
|
|
||||||
.js('resources/assets/js/lib/ace/mode-dot.js', 'public/js')
|
|
||||||
.js('resources/assets/js/lib/ace/theme-monokai.js', 'public/js')
|
|
||||||
.js('resources/assets/js/hashtag.js', 'public/js')
|
.js('resources/assets/js/hashtag.js', 'public/js')
|
||||||
.js('resources/assets/js/collectioncompose.js', 'public/js')
|
.js('resources/assets/js/collectioncompose.js', 'public/js')
|
||||||
.js('resources/assets/js/collections.js', 'public/js')
|
.js('resources/assets/js/collections.js', 'public/js')
|
||||||
|
|
Loading…
Add table
Reference in a new issue