Compare commits

...

8 Commits

Author SHA1 Message Date
BuckarooBanzay
a0545566d6 Merge branch 'fork-20240605-um_area_forsale' of https://github.com/C-C-Minetest-Server/mapserver into fork-20240605-um_area_forsale 2024-06-06 19:37:08 +02:00
1F616EMO
afd71ffcfd
Skip unconfigured for sale signs 2024-06-05 23:34:41 +08:00
1F616EMO
181d62639f
Minor display change 2024-06-05 19:00:13 +08:00
1F616EMO
797558db00
Fix syntax 2024-06-05 18:51:33 +08:00
1F616EMO
cad800fbee
Add For Sale Sign into searches 2024-06-05 18:50:22 +08:00
1F616EMO
134eee104f
Revert icon size 2024-06-05 18:47:00 +08:00
1F616EMO
fc97c517e3
Change popup and icon size 2024-06-05 18:46:42 +08:00
1F616EMO
d6e65af8f2
Add For Sale Sings for Unified Money 2024-06-05 18:40:04 +08:00
10 changed files with 145 additions and 64 deletions

View File

@ -88,6 +88,7 @@ func ParseConfig(filename string) (*Config, error) {
Locator: false, Locator: false,
Signs: true, Signs: true,
MapserverAirutils: true, MapserverAirutils: true,
UnifiefMoneyAreaForSale: true,
Phonograph: true, Phonograph: true,
} }

View File

@ -65,6 +65,7 @@ type MapObjectConfig struct {
Signs bool `json:"signs"` Signs bool `json:"signs"`
MapserverAirutils bool `json:"mapserver_airutils"` MapserverAirutils bool `json:"mapserver_airutils"`
Phonograph bool `json:"phonograph"` Phonograph bool `json:"phonograph"`
UnifiefMoneyAreaForSale bool `json:"um_area_forsale"`
} }
type WebApiConfig struct { type WebApiConfig struct {

View File

@ -76,3 +76,7 @@
* phonograph_node_temp.png * phonograph_node_temp.png
* License: CC By-SA 4.0 * License: CC By-SA 4.0
* Source: [phonograph](https://github.com/C-C-Minetest-Server/phonograph/) * Source: [phonograph](https://github.com/C-C-Minetest-Server/phonograph/)
* um_area_forsale_sign_alpha.png
* By Gabriel Pérez-Cerezo; AGPL 3.0
* Modified from https://github.com/C-C-Minetest-Server/um_area_forsale/blob/main/textures/um_area_forsale_sign.png

View File

@ -197,5 +197,10 @@ func Setup(ctx *app.App) {
l.AddMapObject("phonograph:phonograph", &Phonograph{}) l.AddMapObject("phonograph:phonograph", &Phonograph{})
} }
//For Sale Sign for Unified Money
if ctx.Config.MapObjects.UnifiefMoneyAreaForSale {
l.AddMapObject("um_area_forsale:for_sale_sign", &UnifiefMoneyAreaForSale{})
}
ctx.MapBlockAccessor.Eventbus.AddListener(&l) ctx.MapBlockAccessor.Eventbus.AddListener(&l)
} }

View File

@ -0,0 +1,26 @@
package mapobject
import (
"mapserver/mapobjectdb"
"mapserver/types"
"github.com/minetest-go/mapparser"
)
type UnifiefMoneyAreaForSale struct{}
func (this *UnifiefMoneyAreaForSale) onMapObject(mbpos *types.MapBlockCoords, x, y, z int, block *mapparser.MapBlock) *mapobjectdb.MapObject {
md := block.Metadata.GetMetadata(x, y, z)
if _, ok := md["id"]; !ok {
return nil
}
o := mapobjectdb.NewMapObject(mbpos, x, y, z, "um_area_forsale")
o.Attributes["owner"] = md["owner"]
o.Attributes["id"] = md["id"] // ", " seperated
o.Attributes["price"] = md["price"]
o.Attributes["description"] = md["description"]
return o
}

View File

@ -30,7 +30,8 @@ function search(query){
searchFor("locator", "name", query), searchFor("locator", "name", query),
searchFor("label", "text", query), searchFor("label", "text", query),
searchFor("digiterm", "display_text", query), searchFor("digiterm", "display_text", query),
searchFor("digilinelcd", "text", query) searchFor("digilinelcd", "text", query),
searchFor("um_area_forsale", "description", query)
]; ];
Promise.all(prom_list) Promise.all(prom_list)

View File

@ -88,6 +88,12 @@ export default {
]); ]);
} }
// For Sale Sign
if (obj.type == "um_area_forsale"){
description = m("span", obj.attributes.description || "No Description");
type = m("img", { src: "pics/um_area_forsale_sign_alpha.png" });
}
//shop //shop
if (obj.type == "shop") { if (obj.type == "shop") {
if (obj.attributes.stock == 0){ if (obj.attributes.stock == 0){

View File

@ -24,6 +24,7 @@ import TrainsignalOverlay from './overlays/TrainsignalOverlay.js';
import SignOverlay from './overlays/SignOverlay.js'; import SignOverlay from './overlays/SignOverlay.js';
import AirUtilsPlanesOverlay from "./overlays/AirUtilsPlanesOverlay.js"; import AirUtilsPlanesOverlay from "./overlays/AirUtilsPlanesOverlay.js";
import PhonographOverlay from "./overlays/PhonographOverlay.js"; import PhonographOverlay from "./overlays/PhonographOverlay.js";
import UnifiedMoneyAreaForSaleOverlay from './overlays/UnifiedMoneyAreaForSaleOverlay.js';
export default function(cfg, map, overlays, wsChannel){ export default function(cfg, map, overlays, wsChannel){
@ -210,8 +211,15 @@ export default function(cfg, map, overlays, wsChannel){
if (cfg.mapobjects.phonograph) { if (cfg.mapobjects.phonograph) {
overlays.Phonographs = new PhonographOverlay(); overlays.Phonographs = new PhonographOverlay();
if (isDefault("phonograph")) { if (isDefault("Phonographs")) {
map.addLayer(overlays.Phonographs); map.addLayer(overlays.Phonographs);
} }
} }
if (cfg.mapobjects.um_area_forsale) {
overlays["Area For Sale"] = new UnifiedMoneyAreaForSaleOverlay();
if (isDefault("Area For Sale")) {
map.addLayer(overlays["Area For Sale"]);
}
}
} }

View File

@ -0,0 +1,29 @@
import AbstractIconOverlay from './AbstractIconOverlay.js';
import {HtmlSanitizer} from '../../lib/HtmlSanitizer.js';
export default AbstractIconOverlay.extend({
initialize: function () {
AbstractIconOverlay.prototype.initialize.call(this, "um_area_forsale");
},
getMaxDisplayedZoom: function () {
return 8;
},
getIcon: function () {
return L.icon({
iconUrl: "pics/um_area_forsale_sign_alpha.png",
iconSize: [32, 32],
iconAnchor: [16, 16],
popupAnchor: [0, -16]
});
},
createPopup: function (obj) {
return "<h4>Area For Sale</h4>" +
"<h5>" + HtmlSanitizer.SanitizeHtml(obj.attributes.description || "No Description") + "</h5><hr>" +
"<b>Owner:</b> " + HtmlSanitizer.SanitizeHtml(obj.attributes.owner) + "<br>" +
"<b>Area ID(s):</b> " + HtmlSanitizer.SanitizeHtml(obj.attributes.id) + "<br>" +
"<b>Price:</b> $" + HtmlSanitizer.SanitizeHtml(obj.attributes.price) + "<br>";
}
});

Binary file not shown.

After

Width:  |  Height:  |  Size: 239 B