Added global map page (wip)
This commit is contained in:
parent
ad65157851
commit
c3bf850902
@ -35,4 +35,7 @@ return [
|
||||
->attributes(AddLocationAttribute::class),
|
||||
|
||||
(new Extend\Settings)->serializeToForum('justoverclock-users-map-location.mapBox-api-key', 'justoverclock-users-map-location.mapBox-api-key'),
|
||||
|
||||
(new Extend\Frontend('forum'))
|
||||
->route('/global-map', 'justoverclock.global-map')
|
||||
];
|
||||
|
176
js/dist/admin.js
vendored
176
js/dist/admin.js
vendored
@ -1,2 +1,176 @@
|
||||
module.exports=function(t){var e={};function o(n){if(e[n])return e[n].exports;var r=e[n]={i:n,l:!1,exports:{}};return t[n].call(r.exports,r,r.exports,o),r.l=!0,r.exports}return o.m=t,o.c=e,o.d=function(t,e,n){o.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:n})},o.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},o.t=function(t,e){if(1&e&&(t=o(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var n=Object.create(null);if(o.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var r in t)o.d(n,r,function(e){return t[e]}.bind(null,r));return n},o.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return o.d(e,"a",e),e},o.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},o.p="",o(o.s=12)}({1:function(t,e){t.exports=flarum.core.compat["common/extend"]},12:function(t,e,o){"use strict";o.r(e);var n=o(4),r=o.n(n),a=o(1),i=o(9),u=o.n(i);r.a.initializers.add("justoverclock/users-map-location",(function(){r.a.extensionData.for("justoverclock-users-map-location").registerSetting({setting:"justoverclock-users-map-location.mapBox-api-key",name:"justoverclock-users-map-location.mapBox-api-key",type:"text",label:r.a.translator.trans("justoverclock-users-map-location.admin.mapBox-api-key"),help:r.a.translator.trans("justoverclock-users-map-location.admin.mapBox-api-key-help")}),Object(a.extend)(u.a.prototype,"columns",(function(t){t.add("location",{name:r.a.translator.trans("justoverclock-users-map-location.admin.adminLocationField"),content:function(t){return m("div",null,t.data.attributes.location)}},-50)}))}))},4:function(t,e){t.exports=flarum.core.compat["admin/app"]},9:function(t,e){t.exports=flarum.core.compat["admin/components/UserListPage"]}});
|
||||
module.exports =
|
||||
/******/ (function(modules) { // webpackBootstrap
|
||||
/******/ // The module cache
|
||||
/******/ var installedModules = {};
|
||||
/******/
|
||||
/******/ // The require function
|
||||
/******/ function __webpack_require__(moduleId) {
|
||||
/******/
|
||||
/******/ // Check if module is in cache
|
||||
/******/ if(installedModules[moduleId]) {
|
||||
/******/ return installedModules[moduleId].exports;
|
||||
/******/ }
|
||||
/******/ // Create a new module (and put it into the cache)
|
||||
/******/ var module = installedModules[moduleId] = {
|
||||
/******/ i: moduleId,
|
||||
/******/ l: false,
|
||||
/******/ exports: {}
|
||||
/******/ };
|
||||
/******/
|
||||
/******/ // Execute the module function
|
||||
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
||||
/******/
|
||||
/******/ // Flag the module as loaded
|
||||
/******/ module.l = true;
|
||||
/******/
|
||||
/******/ // Return the exports of the module
|
||||
/******/ return module.exports;
|
||||
/******/ }
|
||||
/******/
|
||||
/******/
|
||||
/******/ // expose the modules object (__webpack_modules__)
|
||||
/******/ __webpack_require__.m = modules;
|
||||
/******/
|
||||
/******/ // expose the module cache
|
||||
/******/ __webpack_require__.c = installedModules;
|
||||
/******/
|
||||
/******/ // define getter function for harmony exports
|
||||
/******/ __webpack_require__.d = function(exports, name, getter) {
|
||||
/******/ if(!__webpack_require__.o(exports, name)) {
|
||||
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
|
||||
/******/ }
|
||||
/******/ };
|
||||
/******/
|
||||
/******/ // define __esModule on exports
|
||||
/******/ __webpack_require__.r = function(exports) {
|
||||
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
|
||||
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
|
||||
/******/ }
|
||||
/******/ Object.defineProperty(exports, '__esModule', { value: true });
|
||||
/******/ };
|
||||
/******/
|
||||
/******/ // create a fake namespace object
|
||||
/******/ // mode & 1: value is a module id, require it
|
||||
/******/ // mode & 2: merge all properties of value into the ns
|
||||
/******/ // mode & 4: return value when already ns object
|
||||
/******/ // mode & 8|1: behave like require
|
||||
/******/ __webpack_require__.t = function(value, mode) {
|
||||
/******/ if(mode & 1) value = __webpack_require__(value);
|
||||
/******/ if(mode & 8) return value;
|
||||
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
|
||||
/******/ var ns = Object.create(null);
|
||||
/******/ __webpack_require__.r(ns);
|
||||
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
|
||||
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
|
||||
/******/ return ns;
|
||||
/******/ };
|
||||
/******/
|
||||
/******/ // getDefaultExport function for compatibility with non-harmony modules
|
||||
/******/ __webpack_require__.n = function(module) {
|
||||
/******/ var getter = module && module.__esModule ?
|
||||
/******/ function getDefault() { return module['default']; } :
|
||||
/******/ function getModuleExports() { return module; };
|
||||
/******/ __webpack_require__.d(getter, 'a', getter);
|
||||
/******/ return getter;
|
||||
/******/ };
|
||||
/******/
|
||||
/******/ // Object.prototype.hasOwnProperty.call
|
||||
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
|
||||
/******/
|
||||
/******/ // __webpack_public_path__
|
||||
/******/ __webpack_require__.p = "";
|
||||
/******/
|
||||
/******/
|
||||
/******/ // Load entry module and return exports
|
||||
/******/ return __webpack_require__(__webpack_require__.s = "./admin.js");
|
||||
/******/ })
|
||||
/************************************************************************/
|
||||
/******/ ({
|
||||
|
||||
/***/ "./admin.js":
|
||||
/*!******************!*\
|
||||
!*** ./admin.js ***!
|
||||
\******************/
|
||||
/*! no exports provided */
|
||||
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
||||
|
||||
"use strict";
|
||||
__webpack_require__.r(__webpack_exports__);
|
||||
/* harmony import */ var _src_admin__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/admin */ "./src/admin/index.js");
|
||||
/* empty/unused harmony star reexport */
|
||||
|
||||
/***/ }),
|
||||
|
||||
/***/ "./src/admin/index.js":
|
||||
/*!****************************!*\
|
||||
!*** ./src/admin/index.js ***!
|
||||
\****************************/
|
||||
/*! no exports provided */
|
||||
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
||||
|
||||
"use strict";
|
||||
__webpack_require__.r(__webpack_exports__);
|
||||
/* harmony import */ var flarum_admin_app__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! flarum/admin/app */ "flarum/admin/app");
|
||||
/* harmony import */ var flarum_admin_app__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(flarum_admin_app__WEBPACK_IMPORTED_MODULE_0__);
|
||||
/* harmony import */ var flarum_common_extend__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! flarum/common/extend */ "flarum/common/extend");
|
||||
/* harmony import */ var flarum_common_extend__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(flarum_common_extend__WEBPACK_IMPORTED_MODULE_1__);
|
||||
/* harmony import */ var flarum_admin_components_UserListPage__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! flarum/admin/components/UserListPage */ "flarum/admin/components/UserListPage");
|
||||
/* harmony import */ var flarum_admin_components_UserListPage__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(flarum_admin_components_UserListPage__WEBPACK_IMPORTED_MODULE_2__);
|
||||
|
||||
|
||||
|
||||
flarum_admin_app__WEBPACK_IMPORTED_MODULE_0___default.a.initializers.add('justoverclock/users-map-location', function () {
|
||||
flarum_admin_app__WEBPACK_IMPORTED_MODULE_0___default.a.extensionData["for"]('justoverclock-users-map-location').registerSetting({
|
||||
setting: 'justoverclock-users-map-location.mapBox-api-key',
|
||||
name: 'justoverclock-users-map-location.mapBox-api-key',
|
||||
type: 'text',
|
||||
label: flarum_admin_app__WEBPACK_IMPORTED_MODULE_0___default.a.translator.trans('justoverclock-users-map-location.admin.mapBox-api-key'),
|
||||
help: flarum_admin_app__WEBPACK_IMPORTED_MODULE_0___default.a.translator.trans('justoverclock-users-map-location.admin.mapBox-api-key-help')
|
||||
});
|
||||
Object(flarum_common_extend__WEBPACK_IMPORTED_MODULE_1__["extend"])(flarum_admin_components_UserListPage__WEBPACK_IMPORTED_MODULE_2___default.a.prototype, 'columns', function (items) {
|
||||
items.add('location', {
|
||||
name: flarum_admin_app__WEBPACK_IMPORTED_MODULE_0___default.a.translator.trans('justoverclock-users-map-location.admin.adminLocationField'),
|
||||
content: function content(user) {
|
||||
return m("div", null, user.data.attributes.location);
|
||||
}
|
||||
}, -50);
|
||||
});
|
||||
});
|
||||
|
||||
/***/ }),
|
||||
|
||||
/***/ "flarum/admin/app":
|
||||
/*!**************************************************!*\
|
||||
!*** external "flarum.core.compat['admin/app']" ***!
|
||||
\**************************************************/
|
||||
/*! no static exports found */
|
||||
/***/ (function(module, exports) {
|
||||
|
||||
module.exports = flarum.core.compat['admin/app'];
|
||||
|
||||
/***/ }),
|
||||
|
||||
/***/ "flarum/admin/components/UserListPage":
|
||||
/*!**********************************************************************!*\
|
||||
!*** external "flarum.core.compat['admin/components/UserListPage']" ***!
|
||||
\**********************************************************************/
|
||||
/*! no static exports found */
|
||||
/***/ (function(module, exports) {
|
||||
|
||||
module.exports = flarum.core.compat['admin/components/UserListPage'];
|
||||
|
||||
/***/ }),
|
||||
|
||||
/***/ "flarum/common/extend":
|
||||
/*!******************************************************!*\
|
||||
!*** external "flarum.core.compat['common/extend']" ***!
|
||||
\******************************************************/
|
||||
/*! no static exports found */
|
||||
/***/ (function(module, exports) {
|
||||
|
||||
module.exports = flarum.core.compat['common/extend'];
|
||||
|
||||
/***/ })
|
||||
|
||||
/******/ });
|
||||
//# sourceMappingURL=admin.js.map
|
2
js/dist/admin.js.map
vendored
2
js/dist/admin.js.map
vendored
File diff suppressed because one or more lines are too long
14054
js/dist/forum.js
vendored
14054
js/dist/forum.js
vendored
File diff suppressed because one or more lines are too long
2
js/dist/forum.js.map
vendored
2
js/dist/forum.js.map
vendored
File diff suppressed because one or more lines are too long
12025
js/package-lock.json
generated
Normal file
12025
js/package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
23
js/src/forum/components/GlobalMapPage.tsx
Normal file
23
js/src/forum/components/GlobalMapPage.tsx
Normal file
@ -0,0 +1,23 @@
|
||||
import type Mithril from 'mithril';
|
||||
import app from 'flarum/forum/app';
|
||||
import Page from 'flarum/common/components/Page';
|
||||
|
||||
function translate(id: string): string {
|
||||
return app.translator.trans(id) as string;
|
||||
}
|
||||
|
||||
export default class GlobalMapPage extends Page {
|
||||
oninit(vnode: Mithril.Vnode) {
|
||||
super.oninit(vnode);
|
||||
|
||||
app.setTitle(translate('justoverclock-users-map-location.forum.global-map.title'));
|
||||
}
|
||||
|
||||
view() {
|
||||
return <div class="GlobalMapPage">
|
||||
<div className="container">
|
||||
<h2>{translate('justoverclock-users-map-location.forum.global-map.title2')}</h2>
|
||||
</div>
|
||||
</div>;
|
||||
}
|
||||
}
|
@ -5,9 +5,12 @@ import User from 'flarum/common/models/User';
|
||||
import Model from 'flarum/common/Model';
|
||||
import AddLocationComponent from './components/AddLocationComponent';
|
||||
import UserCard from 'flarum/forum/components/UserCard';
|
||||
import HeaderPrimary from 'flarum/forum/components/HeaderPrimary';
|
||||
import Link from 'flarum/common/components/Link';
|
||||
import Leaflet from 'leaflet';
|
||||
import GlobalMapPage from './components/GlobalMapPage';
|
||||
|
||||
app.initializers.add('justoverclock/users-map-location', () => {
|
||||
app.initializers.add('justoverclock/users-map-location', (app) => {
|
||||
User.prototype.location_country = Model.attribute('location_country');
|
||||
User.prototype.location_countrycode = Model.attribute('location_countrycode');
|
||||
User.prototype.location_postcode = Model.attribute('location_postcode');
|
||||
@ -15,6 +18,8 @@ app.initializers.add('justoverclock/users-map-location', () => {
|
||||
User.prototype.location_latitude = Model.attribute('location_latitude');
|
||||
User.prototype.location_longitude = Model.attribute('location_longitude');
|
||||
|
||||
app.routes['justoverclock.global-map'] = { path: '/global-map', component: GlobalMapPage };
|
||||
|
||||
extend(UserCard.prototype, 'infoItems', function (items) {
|
||||
const user = this.attrs.user;
|
||||
|
||||
@ -63,6 +68,22 @@ app.initializers.add('justoverclock/users-map-location', () => {
|
||||
});
|
||||
});
|
||||
|
||||
extend(HeaderPrimary.prototype, 'onupdate', function() {
|
||||
let homeLink = document.getElementById('home-link');
|
||||
if(homeLink) {
|
||||
let globalMapLink = document.getElementById('global-map-link');
|
||||
if(!globalMapLink) {
|
||||
globalMapLink = document.createElement('span');
|
||||
globalMapLink.setAttribute('id', 'global-map-link');
|
||||
homeLink.parentElement?.append(globalMapLink);
|
||||
|
||||
m.render(globalMapLink, <Link href="/global-map" id="map-link">
|
||||
Carte
|
||||
</Link>);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
export {
|
||||
AddLocationComponent
|
||||
}
|
||||
|
6213
js/yarn.lock
6213
js/yarn.lock
File diff suppressed because it is too large
Load Diff
@ -12,3 +12,6 @@ justoverclock-users-map-location:
|
||||
locationSaved: Localité sauvegardée !
|
||||
locationNotFound: Ville ou commune non trouvée dans ce pays
|
||||
locationCleared: Votre localité a été supprimée
|
||||
global-map:
|
||||
title: Carte globale
|
||||
title2: Carte des membres de la communauté vhélio
|
Loading…
Reference in New Issue
Block a user