MediaWiki:Common.less/leaflet.less: Difference between revisions

From Brighter Shores Wiki
Jump to navigation Jump to search
Content added Content deleted
No edit summary
No edit summary
Line 30:
@aggressive: #D75650;
 
// classname color icon shape
@icons: guard inherit Guard @circle,
chef chef Chef @square,
fisher fisher Fisher @circle,
forager forager @square,
alchemistforager alchemistforager Forager @square,
alchemist alchemist Alchemist @square,
scout inherit Scout @circle,
gatherer gatherer @square,
woodcuttergatherer woodcuttergatherer Gatherer @square,
carpenterwoodcutter carpenterwoodcutter Woodcutter @square,
carpenter carpenter Carpenter @square,
minefighter inherit Minefighter @circle,
bonewright bonewright @square,
minerbonewright minerbonewright Bonewright @square,
blacksmithminer blacksmithminer Miner @square,
stonemasonblacksmith stonemasonblacksmith Blacksmith @square,
stonemason stonemason Stonemason @square,
watchperson inherit Watchperson @circle,
detective detective @square,
leatherworkerdetective leatherworkerdetective Detective @square,
merchantleatherworker merchantleatherworker Leatherworker @square,
merchant merchant bank inheritMerchant @square,
clipboard chef bank inherit Bank @square,
clipboard chef Chef @square,
enchant item @circle,
hairdresserenchant interactableitem Enchant @circle,
hairdresser interactable interactableHairdresser @squarecircle,
interactable interactable Interactable @square,
item item @square,
talkitem item Item @circlesquare,
obelisktalk item Talk @squarecircle,
paletteobelisk paletteitem Obelisk @square,
portal_stonepalette itempalette Palette @square,
searchportal_stone item Portal_Stone @square,
itemsearch item Search @square,
shop inherit Shop @circle,
strange_stone item Strange_Stone @square;
 
@themes: aggressive aggressive,
Line 66 ⟶ 67:
neutral neutral;
 
.generate-map-icon-rules(@classname, @color, @image, @shape) {
.image(@str) {
@first: to-upper-case(extract(@str, 1));
@rest: to-lower-case(extract(@str, 2));
@image: ~'/images/@{first}@{rest}_small_icon.png';
}
 
.generate-map-icon-rules(@classname, @color, @shape) {
.image(@classname);
.leaflet-marker-icon-icon-@{classname} {
background: @color url(@image) no-repeat center / contain;
Line 91 ⟶ 85:
@classname: extract(@value, 1);
@color: extract(@value, 2);
@shapeimage: extract(@value, 3);
@shape: extract(@value, 4);
.generate-map-icon-rules(@classname, @color, @image, @shape);
});
each(@themes, {

Revision as of 04:46, 27 November 2024

.leaflet-wiki-coordinates.leaflet-control {
    margin: 0;
    color: white;
    padding: 5px 10px;
    filter: drop-shadow(0 0 2px black);
}

@square: 3px;
@circle: 50%;

@inherit: inherit;
@chef: #9C8474;
@fisher: #98D3CC;
@forager: #DDDB93;
@alchemist: #83C8A1;
@gatherer: #C8C87C;
@woodcutter: #78C86C;
@carpenter: #9C8A7C;
@bonewright: #B0B897;
@miner: #749696;
@blacksmith: #B4A432;
@stonemason: #808789;
@detective: #5AB2BE;
@leatherworker: #866E62;
@merchant: #78B492;
@palette: #DEDAD4;
@item: #90908C;
@interactable: #927DCE;
@neutral: #C0925A;
@aggressive: #D75650;

// classname color icon shape
@icons: guard inherit Guard @circle,
    chef chef Chef @square,
	fisher fisher Fisher @circle,
	forager forager Forager @square,
	alchemist alchemist Alchemist @square,
    scout inherit Scout @circle,
	gatherer gatherer Gatherer @square,
	woodcutter woodcutter Woodcutter @square,
	carpenter carpenter Carpenter @square,
    minefighter inherit Minefighter @circle,
	bonewright bonewright Bonewright @square,
	miner miner Miner @square,
	blacksmith blacksmith Blacksmith @square,
	stonemason stonemason Stonemason @square,
    watchperson inherit Watchperson @circle,
	detective detective Detective @square,
	leatherworker leatherworker Leatherworker @square,
	merchant merchant Merchant @square,
    bank inherit Bank @square,
	clipboard chef Chef @square,
	enchant item Enchant @circle,
	hairdresser interactable Hairdresser @circle,
    interactable interactable Interactable @square,
	item item Item @square,
	talk item Talk @circle,
	obelisk item Obelisk @square,
	palette palette Palette @square,
	portal_stone item Portal_Stone @square,
	search item Search @square,
    shop inherit Shop @circle,
	strange_stone item Strange_Stone @square;

@themes: aggressive aggressive,
	interactable interactable,
	neutral neutral;

.generate-map-icon-rules(@classname, @color, @image, @shape) {
    .leaflet-marker-icon-icon-@{classname} {
        background: @color url(@image) no-repeat center / contain;
        border-radius: @shape;
    }
}
.generate-map-theme-rules(@classname, @color) when (@classname = @color) {
    .leaflet-marker-icon-theme-@{classname} {
        background-color: @color;
    }
}

.leaflet-marker-icon-entity {
    background-color: red;
}
each(@icons, {
    @classname: extract(@value, 1);
    @color: extract(@value, 2);
    @image: extract(@value, 3);
    @shape: extract(@value, 4);
    .generate-map-icon-rules(@classname, @color, @image, @shape);
});
each(@themes, {
    @classname: extract(@value, 1);
    @color: extract(@value, 2);
    .generate-map-theme-rules(@classname, @color)
});
.leaflet-marker-icon-shape-circle {
    border-radius: @circle;
}
.leaflet-marker-icon-shape-square {
    border-radius: @square;
}