diff --git a/devTools/types/FC/arcology.d.ts b/devTools/types/FC/arcology.d.ts index f116eae9487c80d83061d6bda0d6ed47a5c16c1a..f692aa0c814c0b4efcb5b7787ffb217bab6e1908 100644 --- a/devTools/types/FC/arcology.d.ts +++ b/devTools/types/FC/arcology.d.ts @@ -112,6 +112,10 @@ declare namespace FC { noun: "Aztec Revivalism", adj: "Aztec Revivalist", deco: "Aztec Revivalist", research: undefined, SMR: true, policy: "Law", choice: undefined }; + FSAntebellumRevivalist: { + noun: "Antebellum Revivalism", adj:"Antebellum Revivalist", deco: "Antebellum Revivalist", + research: undefined, SMR: true, policy: "Law1" | "Law2", choice: undefined + }; FSRepopulationFocus: { noun: "Repopulation Focus", adj: "Repopulationist", deco: "Repopulationist", research: true, SMR: true, policy: "Law", choice: undefined diff --git a/devTools/types/FC/human.d.ts b/devTools/types/FC/human.d.ts index 8a2776e8ea9f25048462873842ab98dd3335d937..e82e2ae73bd401a9b31130f5413214751df6de2e 100644 --- a/devTools/types/FC/human.d.ts +++ b/devTools/types/FC/human.d.ts @@ -258,7 +258,8 @@ declare global { "leather pants" | "leather pants and a tube top" | "leather pants and pasties" | "lederhosen" | "nice business attire" | "no clothing" | "overalls" | "panties" | "panties and pasties" | "pasties" | "restrictive latex" | "shibari ropes" | "slutty business attire" | "slutty jewelry" | "spats and a tank top" | "sport shorts" | "sport shorts and a sports bra" | "sport shorts and a t-shirt" | - "stretch pants and a crop-top" | "striped panties" | "striped underwear" | "uncomfortable straps" | "Western clothing"; + "stretch pants and a crop-top" | "striped panties" | "striped underwear" | "uncomfortable straps" | "Western clothing" | + "a confederate army uniform" | "an evening dress"; type BellyAccessory = WithNone<"a small empathy belly" | "a medium empathy belly" | "a large empathy belly" | "a huge empathy belly" | "a corset" | "an extreme corset" | "a support band">; type Collar = WithNone<"ancient Egyptian" | "cruel retirement counter" | "uncomfortable leather" | "tight steel" | "shock punishment" | diff --git a/devTools/types/assistant.d.ts b/devTools/types/assistant.d.ts index 9d0729f420f450793519ae5103e0d3d5c70e6bf2..c8351d8d1fa2f8190a65c5c0401337f98b5855bf 100644 --- a/devTools/types/assistant.d.ts +++ b/devTools/types/assistant.d.ts @@ -1,6 +1,6 @@ type assistantAppearance = "normal" | "monstergirl" | "shemale" | "amazon" | "businesswoman" | "goddess" | "hypergoddess" | "schoolgirl" | "loli" | "preggololi" | "fairy" | "pregnant fairy" | "slimegirl" | "cowgirl"| "harpygirl" | "kitsunegirl" | "lamiagirl" | "spidergirl" | "angel" | "cherub" | "imp" | "witch" | "ERROR_1606_APPEARANCE_FILE_CORRUPT" | "incubus" | "succubus"; -type fsAssistantAppearance = "default" | "paternalist" | "degradationist" | "supremacist" | "subjugationist" | "roman revivalist" | "aztec revivalist" | "egyptian revivalist" | "edo revivalist" | "arabian revivalist" | "chinese revivalist" | "chattel religionist" | "repopulation focus" | "eugenics" | "physical idealist" | "hedonistic decadence" | "gender radicalist" | "gender fundamentalist" | "asset expansionist" | "transformation fetishist" | "pastoralist" | "maturity preferentialist" | "youth preferentialist" | "slimness enthusiast" | "body purist" | "intellectual dependency" | "slave professionalism" | "petite admiration" | "statuesque glorification" | "neoimperialist"; +type fsAssistantAppearance = "default" | "paternalist" | "degradationist" | "supremacist" | "subjugationist" | "roman revivalist" | "aztec revivalist" | "egyptian revivalist" | "edo revivalist" | "arabian revivalist" | "chinese revivalist" | "chattel religionist" | "repopulation focus" | "eugenics" | "physical idealist" | "hedonistic decadence" | "gender radicalist" | "gender fundamentalist" | "asset expansionist" | "transformation fetishist" | "pastoralist" | "maturity preferentialist" | "youth preferentialist" | "slimness enthusiast" | "body purist" | "intellectual dependency" | "slave professionalism" | "petite admiration" | "statuesque glorification" | "neoimperialist" | "antebellum revivalist"; interface assistant { appearance: assistantAppearance; fsAppearance: fsAssistantAppearance @@ -23,4 +23,4 @@ interface assistant { type appearance = Record<assistantAppearance, fsAppearance>; -type fsAppearance = Record<fsAssistantAppearance, string>; \ No newline at end of file +type fsAppearance = Record<fsAssistantAppearance, string>; diff --git a/js/003-data/arcologyNames.js b/js/003-data/arcologyNames.js index d4b602701e8c4c5a1f544a43c7647c3f04908127..a0e9e51bc785e600d00c6c6f646bda0e6bdd9b7b 100644 --- a/js/003-data/arcologyNames.js +++ b/js/003-data/arcologyNames.js @@ -13,7 +13,7 @@ App.Data.ArcologyNames = { SupremacistWhite: ["Avalon", "Baasskap", "Buyan", "Caucasia", "Cockaigne", "Eurocentral", "Europa", "Europe a Nation", "Fiery Cross", "Fourth Reich", "Gimlé", "Hy-Brasil", "Kitezh", "Klanbake", "New Australia", "Northwest Territory", "Opona", "Orania", "Pan-Europe", "The Old Dominion", "Thule", "Turner City", "Volkstaat", "Vyraj", "White Might"], SubjugationistAmerindian: ["Adlivun", "Bear River", "Cowboy Town", "Fire Waters", "Fort Laramie", "Fort Mystic", "Manifest Destiny", "Mazocoba", "Oklahoma", "Red Dead", "RÃo Negro", "Sand Creek", "Shobari Waka", "The Rez", "Trail of Tears", "Washita", "Worst Nation", "Wounded Knee"], SubjugationistAsian: ["Asiatic Exclusion", "Beriberi", "Defense of the Realm", "Diyu", "Hells Canyon", "Hiroshima", "Luzon", "Opium Den", "Pearl of the Orient", "Rock Springs", "Shakee", "Sinking Tide", "The East India Company", "Torreón", "Yellow Error", "Youdu"], - SubjugationistBlack: ["Bantustan", "Crow's Nest", "Dixie", "El Corte", "Golden Circle", "Hetgwauge", "Kuzimu", "Lynchburg", "Middle Passage", "Richmond", "Rosewood", "Rubber Farm", "Sharpeville", "Soweto", "Strange Orchard", "Sundown Town", "The Confederacy", "The Plantation", "The Projects", "Three-Fifths", "Tulsa"], + SubjugationistBlack: ["Bantustan", "Crow's Nest", "El Corte", "Golden Circle", "Hetgwauge", "Kuzimu", "Lynchburg", "Middle Passage", "Richmond", "Rosewood", "Rubber Farm", "Sharpeville", "Soweto", "Strange Orchard", "Sundown Town", "The Confederacy", "The Plantation", "The Projects", "Three-Fifths", "Tulsa"], SubjugationistIndoAryan: ["Call Center", "Convenience Store", "Goa Inquisition", "Jallianwala Bagh", "Kalichi", "Macaulayism", "Naraka", "Navarino", "Qissa Khwani Bazaar", "Sepoy Mutiny", "Slumdog Kennels", "The East India Company", "Trade Fort", "UCIL Plant", "Uva Province"], SubjugationistLatina: ["All-Mexico", "Annual", "Banana Republic", "Bean Paste", "Bisbee", "Border Wall", "Chandler", "Downieville", "Fort Veracruz", "Hanigan Ranch", "La Migra", "Los Conquistados", "Los Gatos", "Porvenir", "Vergüenza", "Zoot Suit Riot"], SubjugationistMalay: ["Batavia", "Bencoolen", "East Indies", "Eastern Emporium", "Fort Marlborough", "Gimokodan", "Macunat School", "Moro Crater", "Pontianak", "Pulo Prabang", "Rawagede", "Soerabaja", "Spice Mine", "Watsonville"], @@ -44,6 +44,7 @@ App.Data.ArcologyNames = { ArabianRevivalist: ["Abha", "Achir", "Al Bahah", "Al-Hasa", "Al-Mansuriya", "Al-Qata'i", "Aleppo", "Alhambra", "Amadiya", "Amid", "Arar", "Arbil", "Ardabil", "Arjish", "Arzan", "Badr", "Baghdad", "Basra", "Bayt al-Hikma", "Béjaïa", "Beni Hammad", "Buraidah", "Cairo", "Córdoba", "Damascus", "Dammam", "Dhala", "Diyarbakır", "El-Mansuriya", "Faiyum", "Fes-al-Bali", "Fes", "Fez", "Fustat", "Ha'il", "Hajar an-Nasar", "Hama", "Harput", "Harran", "Hasankeyf", "Hejaz", "Ifriqiya", "Isfahan", "Jannah", "Jenin", "Jerusalem", "Jizan", "Jubayl", "Kairouan", "Karbala", "Khilat", "Kirkuk", "Kufa", "Madinah", "Madinat al-Hareer", "Madinat al-Salam", "Madinat al-Yasmin", "Madinat al-Zahra", "Mahdia", "Makkah", "Manzikart", "Maragha", "Mardin", "Marrakech", "Marrakesh", "Marsala", "Mayyafariqin", "Mecca", "Medina", "Mosul", "Murakuc", "Najran", "Nekor", "Qatif", "Qazvin", "Raqqa", "Raqqada", "Resafa", "Riyadh", "Sakakah", "Samarra", "Saqifah", "Say'un", "Sidon", "Sulaimaniyah", "Suq Abdulla", "Tabriz", "Tabuk", "Tahert", "Tarim", "Temsaman", "Tlemcen", "Tunis", "Walilli", "Zabid"], ChineseRevivalist: ["Acheng", "Anyang", "Anyi", "Balasagun", "Beijing", "Bian", "Bianjing", "Bianzhou", "Binzhou", "Bogu", "Boping", "Chang'an", "Changle", "Changping", "Changsha", "Chengdu", "Chengzhou", "Chuqiu", "Dadu", "Daliang", "Daming", "Danyang", "Datong", "Daxing", "Dinglian", "Diqiu", "Dongdu", "Dongjing", "Dujianshan", "Dunhuang", "Ezhou", "Fanyang", "Feng Huang", "Fenghao", "Fengxiang", "Fuhan", "Fusang", "Guanggu", "Guangling", "Guangzhou", "Gusu", "Guzang", "Handan", "Hangzhou", "Haojing", "Hefei", "Henglong", "Hezhou", "Huanbei", "Huangquan", "Huangzhong", "Huatai", "Huokang", "Ji", "Jian", "Jiang", "Jiangling", "Jiangning", "Jiankang", "Jianye", "Jicheng", "Jin Shan", "Jinan", "Jincheng", "Jingsha", "Jingzhao", "Jingzhou", "Jinling", "Jinyang", "Jiuquan", "Kaifeng", "Khanbaliq", "Kuaiji", "Laosicheng", "Ledu", "Lianchuan", "Liaodong", "Liaoyang", "Lin'an", "Linhuang", "Linxiang", "Linzi", "Lishi", "Liting", "Longcheng", "Lujiang", "Luoyang", "Luoyi", "Luyi", "Mingfu", "Moling", "Mount Tai", "Nan'an", "Nanchang", "Nanjing", "Nanjun", "Nanyang", "Panyu", "Peking", "Pengcheng", "Pingcheng", "Pingjiang", "Pingliang", "Pingyang", "Pingzhou", "Puzi", "Qi Lin", "Qian", "Qiantang", "Qiling", "Qin", "Quanqiu", "Qufu", "Quwo", "Ruyin", "Shangcai", "Shanggui", "Shangjing", "Shangqiu", "Shengjing", "Shengle", "Shouchun", "Suzhou", "Taiyuan", "Tang", "Tanheli", "Tanjiao", "Tanzhou", "Taoqiu", "The Forbidden Palace", "The Middle Kingdom", "Tianlin", "Tongwan", "Wanchuan", "Wangcheng", "Wanqiu", "Wu", "Wuchang", "Wudu", "Xi'an", "Xiacai", "Xiangguo", "Xiangning", "Xiangping", "Xianyang", "Xibo", "Xicheng", "Xin Hua", "Xincai", "Xingqing", "Xingwang", "Xintian", "Xinzheng", "Xiping", "Xuchang", "Yangcheng", "Yangzhai", "Yanjing", "Yanshi", "Yecheng", "Yewang", "Yin", "Yinfu", "Ying", "Yingdu", "Yingqiu", "Yingtian", "Yong", "Yongshicheng", "You", "Youdu", "Youming", "Youzhou", "Yueyang", "Yuezhou", "Yuhang", "Yushan", "Zhangye", "Zhangzi", "Zhaoge", "Zhending", "Zheng", "Zhenxun", "Zhongdu", "Zhongguo", "Zhongshan", "Zibo", "Zichuan"], NeoImperialist: ["Atteln", "Aermacht", "Aubevoie", "Bellechassange", "Black Rock", "Black Hollow", "Bourbon", "Colme", "Daybrook", "Drancy", "Easthaven", "Eastwatch", "Etau", "Elsing", "Essenge", "Ettenmont", "Erceti", "Fernsworth", "Hersengeux", "Ironforge", "Ironhaven", "Irontown", "Karlsberg", "Klattenhof", "Lhanbryde", "Lindham", "Marrensville", "Maushof", "Morlaincourt", "Munschwitz", "Neo-Berlin", "Neo-London", "Neo-Paris", "Neo-Madrid", "Neo-York", "Northscot", "Oberlandscheid", "Obersberg", "Poisseau", "Redwater", "Sali", "Sand and Stone", "Shominster", "Sommelie", "Strathsmore", "Sunstown", "Sonnehof", "Sonneshaven", "Tottenham", "The Rock", "The Golden Spire", "Villeurmont", "Vivonne", "Volkersch", "Volkhof", "Volksgard", "Wallenberg", "Wallenhof", "Wilderf", "Wycombe", "Zillendorf", "Zerf"], + AntebellumRevivalist: ["Candyland", "Rosedale", "Tara", "Riversdale", "Haberdeventure", "Montpelier", "Whitehall", "Belle Meade", "Rose Glen", "Hattfield", "Cinnamon Bay", "Arcadia", "Ashland", "La Grange", "Honeysuckle Hill", "Oxmoor", "Pleasant Ridge", "New Richmond", "New Montgomery", "Fairview", "Dixie", "Lexington", "Stratford", "New Nashville", "Concord", "Columbia", "Tweleve Oaks", "Glenhaven", "Fairport", "Bannermourne", "Cedarhaven", "Hollyvalley", "Plainview", "Arlington", "Auburn", "Bloomington", "Winchester", "Greenville", "Springfield", "Columbia", "Beaver Dam", "Walnut Grove", "White Haven", "Tulip Hill", "Pleasant Prospect", "Sion Hill", "Old Magnolia", "Willowbrook", "Ridgedale", "Montescena", "The Manor", "Hopewell", "Fort Hill", "Rosemont", "Roseville", "Landsford", "Hampton", "Ashland", "Allendale", "St. Louis", "St. Joseph", "St. George", "Southdown", "Orange Grove", "Mount Hope", "Myrtle Grove", "Laurel Valley"], /* pregmod FS */ Eugenics: ["Ascension", "Elitism", "Eugenica", "Eugeniculate", "Galton City", "Germinal Choice", "Good Stock", "Improvement", "Lebensborn", "Natural Selection", "Oneida Community", "Perfection", "Powered Elite", "Private Gene Pool", "Quality", "Rebirth", "Reprogenetics", "Second Chance", "Selection Rule", "Stirpiculture"], diff --git a/js/003-data/assistantData.js b/js/003-data/assistantData.js index e09d7ffcfb22e72cca5d1a2c26ce7001e642de07..406d03db1e95c277df763044589fbaee9ba581cc 100644 --- a/js/003-data/assistantData.js +++ b/js/003-data/assistantData.js @@ -28,6 +28,7 @@ App.Data.Assistant.appearanceForFS = new Map([ ["FSArabianRevivalist", ["businesswoman", "incubus", "schoolgirl", "succubus"]], ["FSChineseRevivalist", ["incubus", "monstergirl", "schoolgirl", "succubus"]], ["FSAztecRevivalist", ["amazon", "businesswoman", "incubus", "succubus"]], + ["FSAntebellumRevivalist", ["angel", "businesswoman", "goddess", "succubus", "witch", "monstergirl"]], ["FSRepopulationFocus", ["goddess", "hypergoddess", "preggololi", "pregnant fairy", "succubus", "witch"]], ["FSRestart", ["angel", "businesswoman", "goddess", "incubus", "loli", "schoolgirl", "succubus", "witch"]], ["FSIntellectualDependency", ["shemale", "succubus", "witch"]], diff --git a/js/003-data/clothes/001-slaveWearData.js b/js/003-data/clothes/001-slaveWearData.js index deccd8429c36529ebaeda36dd4acb85f5daae9c8..0b21ff16ac858e157820210da09083dc9a5f4b21 100644 --- a/js/003-data/clothes/001-slaveWearData.js +++ b/js/003-data/clothes/001-slaveWearData.js @@ -442,14 +442,20 @@ App.Data.clothes = (new Map()) { name: "Ballgown", get requirements() { return V.boughtItem.clothing.dresses === 1; }, - exposure: 0 + exposure: 0, + fs: { + loves: new Set(["FSAntebellumRevivalist"]) + } } ) .set("a gothic lolita dress", { name: "Gothic lolita dress", get requirements() { return V.boughtItem.clothing.dresses === 1; }, - exposure: 0 + exposure: 0, + fs: { + tolerates: new Set(["FSAntebellumRevivalist"]) + } } ) .set("a cybersuit", @@ -743,6 +749,26 @@ App.Data.clothes = (new Map()) topless: true } ) + .set("a confederate army uniform", + { + name: "Confederate Army uniform", + get requirements() { return V.boughtItem.clothing.antebellum === 1; }, + exposure: 0, + fs: { + loves: new Set(["FSAntebellumRevivalist"]) + } + } + ) + .set("an evening dress", + { + name: "Evening dress", + get requirements() { return V.boughtItem.clothing.antebellum === 1; }, + exposure: 1, + fs: { + loves: new Set(["FSAntebellumRevivalist"]) + } + } + ) // "Normal" things: .set("an apron", diff --git a/js/003-data/futureSocietyData.js b/js/003-data/futureSocietyData.js index aa79dd4ef6083f20f0a7ab681dda8e733e5a9756..4543bd9a7342fb39b45c19da0d6bc074f01fc531 100644 --- a/js/003-data/futureSocietyData.js +++ b/js/003-data/futureSocietyData.js @@ -70,6 +70,13 @@ App.Data.FutureSociety = { nationality: "Aztec Revivalist", language: "Nahuatl", }, + FSAntebellumRevivalist: { + noun: "Antebellum Revivalism", + adj: "Antebellum Revivalist", + deco: "Antebellum Revivalist", + nationality: "Antebellum Revivalist", + language: "English", + }, FSRepopulationFocus: {noun: "Repopulation Focus", adj: "Repopulationist", deco: "Repopulationist"}, FSRestart: {noun: "Eugenics", adj: "Eugenics", deco: "Eugenics"}, FSIntellectualDependency: {noun: "Intellectual Dependency", adj: "Intellectual Dependency", deco: "Intellectual Dependency"}, @@ -95,7 +102,7 @@ App.Data.FutureSociety = { ["FSPhysicalIdealist", "FSHedonisticDecadence"], ["FSChattelReligionist", "FSNull"], ["FSIncestFetishist"], - ["FSRomanRevivalist", "FSNeoImperialist", "FSEgyptianRevivalist", "FSEdoRevivalist", "FSArabianRevivalist", "FSChineseRevivalist", "FSAztecRevivalist"], + ["FSRomanRevivalist", "FSNeoImperialist", "FSEgyptianRevivalist", "FSEdoRevivalist", "FSArabianRevivalist", "FSChineseRevivalist", "FSAztecRevivalist", "FSAntebellumRevivalist"], ["FSRepopulationFocus", "FSRestart"], ["FSIntellectualDependency", "FSSlaveProfessionalism"], ["FSPetiteAdmiration", "FSStatuesqueGlorification"] diff --git a/js/003-data/gameVariableData.js b/js/003-data/gameVariableData.js index e01730f6e641a4266d3f41ae47a9a891cf1bd3ec..ec0043c213afa4fb70bf9eead2207456ac5c913b 100644 --- a/js/003-data/gameVariableData.js +++ b/js/003-data/gameVariableData.js @@ -834,6 +834,7 @@ App.Data.resetOnNGPlus = { bimbo: 0, courtesan: 0, petite: 0, + antebellum: 0, // non-fs military: 0, cultural: 0, diff --git a/js/003-data/miscDataNames.js b/js/003-data/miscDataNames.js index 499b854ce6c9d667c5e40c3f59590bfe5bd6170d..0d375c93449f7f72269e8df7a2c6dd2bbcb14b6c 100644 --- a/js/003-data/miscDataNames.js +++ b/js/003-data/miscDataNames.js @@ -1918,6 +1918,13 @@ App.Data.misc.edoSlaveSurnames = ["Abe", "Adachi", "Akabashi", "Akamatsu", "Akao App.Data.misc.chineseRevivalistSlaveSurnames = ["Ai", "Ali", "An", "Ao", "Ba", "Bai", "Baili", "Ban", "Bao", "Bei", "Ben", "Bi", "Bian", "Bie", "Bing", "Bo", "Bu", "Cai", "Cang", "Cao", "Ce", "Cen", "Chai", "Chang", "Chanyu", "Chao", "Che", "Chen", "Cheng", "Chi", "Chong", "Chu", "Chunyu", "Cong", "Cui", "Da", "Dai", "Dang", "Deng", "Di", "Diao", "Ding", "Diwu", "Dong", "Dongfang", "Dongguo", "Dongmen", "Dou", "Du", "Duan", "Duangan", "Duanmu", "Dugu", "E", "Fa", "Fan", "Fang", "Fei", "Feng", "Fu", "Gan", "Gang", "Gao", "Ge", "Geng", "Gong", "Gongliang", "Gongsun", "Gongxi", "Gongyang", "Gongye", "Gou", "Gu", "Guan", "Guang", "Guangqiu", "Guanqiu", "Gui", "Guliang", "Guo", "Ha", "Hai", "Han", "Hang", "Hao", "He", "Helian", "Heng", "Hong", "Hou", "Hu", "Hua", "Huai", "Huan", "Huang", "Huangfu", "Hui", "Huo", "Huyan", "Ji", "Jia", "Jiagu", "Jian", "Jiang", "Jiao", "Jie", "Jin", "Jing", "Ju", "Juqu", "Kan", "Kang", "Ke", "Kong", "Kou", "Ku", "Kuai", "Kuang", "Kui", "Kun", "L", "Lai", "Lan", "Lang", "Lao", "Lei", "Leng", "Li", "Lian", "Liang", "Liangqiu", "Liao", "Lin", "Ling", "Linghu", "Liu", "Lo", "Long", "Lou", "Lqiu", "Lu", "Lü", "Luan", "Luo", "Ma", "Man", "Mao", "Mei", "Meng", "Mi", "Mian", "Miao", "Min", "Ming", "Mo", "Moqi", "Mou", "Mu", "Murong", "Na", "Nai", "Nan", "Nangong", "Nanmen", "Ni", "Nian", "Nie", "Ning", "Niu", "Nong", "Ou", "Ouyang", "Pan", "Pang", "Pei", "Peng", "Pi", "Ping", "Pu", "Puyang", "Qi", "Qian", "Qiang", "Qiao", "Qidiao", "Qifu", "Qiguan", "Qin", "Qing", "Qiu", "Qu", "Quan", "Que", "Ran", "Rangsi", "Rao", "Ren", "Rong", "Ru", "Ruan", "Rui", "Ruo", "Sang", "Sha", "Shan", "Shang", "Shangguan", "Shao", "She", "Shen", "Sheng", "Shentu", "Shi", "Shou", "Shu", "Shuai", "Shuang", "Shui", "Shun", "Si", "Sikong", "Sikou", "Sima", "Sishi", "Situ", "Song", "Su", "Sui", "Sun", "Suo", "Suruo", "Tai", "Taishi", "Taishu", "Tan", "Tang", "Tantai", "Tao", "Teng", "Tian", "Tie", "Tong", "Tou", "Tu", "Tufa", "Tuoba", "Wai", "Wan", "Wang", "Wanyan", "Wei", "Weisheng", "Wen", "Weng", "Wenren", "Wo", "Wu", "Wuma", "Xi", "Xia", "Xiahou", "Xian", "Xiang", "Xianyu", "Xiao", "Xie", "Ximen", "Xin", "Xing", "Xiong", "Xu", "Xuan", "Xuanyuan", "Xue", "Xun", "Yan", "Yang", "Yangshe", "Yao", "Ye", "Yelü", "Yi", "Yin", "Ying", "Yong", "You", "Yu", "Yuan", "Yuchi", "Yue", "Yuezheng", "Yun", "Yuwen", "Zai", "Zaifu", "Zan", "Zang", "Zeng", "Zha", "Zhai", "Zhan", "Zhang", "Zhangsun", "Zhao", "Zhen", "Zheng", "Zhi", "Zhong", "Zhonghang", "Zhongli", "Zhongsun", "Zhou", "Zhu", "Zhuang", "Zhuansun", "Zhuge", "Zhuo", "Zi", "Ziju", "Zong", "Zongzheng", "Zou", "Zu", "Zuo", "Zuoqiu"]; +App.Data.misc.antebellumSlaveNames = [ + "Abigail", "Ada", "Addison", "Adelaide", "Adeline", "Alex", "Alexandra", "Alexandria", "Alice", "Alinda", "Aline", "Alli-May", "Allie", "Alma", "Alouetta", "Amber-Louise", "Amelia", "Angel", "Angelica", "Anise", "Anita", "Ann", "Anna", "Anna-Mae", "Annabelle", "Annabeth", "Annalee", "Annalise", "Annie", "Antonietta", "Aphrodite", "April", "May", "Arabella", "Ariel", "Artemis", "Ashley", "Atlanta", "Aubrey", "Augusta", "Autumn", "Ava", "Avery", "Avon", "Bailey", "Bambi", "Bea", "Beatrice", "Beatrix", "Belle", "Betsy", "Betsy-Ann", "Bettie", "Betty", "Birdie", "Blanche", "Blossom", "Bonnie", "Bounty", "Brandy", "Brighton", "Bryanna", "Callie", "Camellia", "Candice", "Carla", "Carmen", "Carol", "Carolina", "Caroline", "Carter", "Cassidy", "Cassie", "Catherine", "Celia", "Chantilly", "Charity", "Charlene", "Charlotte", "Chastity", "Chelsea", "Cheyenne", "Christina", "Clara", "Clarabelle", "Clarice", "Claudette", "Clementine", "Clora", "Clover", "Collette", "Connie", "Constance", "Cora", "Coralee", "Cordelia", "Corrine", "Courtney", "Daisy", "Dallas", "Daphne", "Darcie", "Darlene", "Deedee", "Deidre", "Delia", "Delilah", "Della", "Delta", "Demetria", "Dianne", "Dixie", "Dolly", "Dora", "Dottie", "Eleanor", "Eliza", "Elizabeth", "Ella", "Ella-Mae", "Emma", "Emmy", "Essie", "Lou", "Ethel", "Etta", "Eudora", "Evelyn", "Everleigh", "Faith", "Faye", "Florence", "Frances", "Francesca", "Francine", "Frankie", "Geneva", "Georgette", "Georgia", "Georgiana", "Georgina", "Gillie", "Giselle", "Glendale", "Grace", "Haley", "Hannah", "Harper", "Hattie", "Hazel", "Heather", "Helen", "Henrietta", "Holly", "Hollyhock", "Honey", "Hunter", "Hydrangea", "Ida", "Iris", "Isabella", "Isabelle", "Ivory", "Ivy", "Jacie", "Jane", "Jeanette", "Jessa", "Jessica", "Jessie", "Jesslyn", "Jewel", "Joanna", "Jocelyn", "Joetta", "Johanna", "Jolene", "Josette", "Josslyn", "Julep", "June", "Karen", "Karina", "Kasey", "Katherine", "Kay", "Kayla", "Kerrie", "Kerrielyn", "Kersey", "Kitty", "Lacey", "Laney", "Lavenia", "Lela", "Leora", "Lettie", "Lexie", "Lilliana", "Lily", "Livy", "Lola", "Lorelei", "Loretta", "Lorraine", "Lottie", "Louisa", "Love", "Lucille", "Lucinda", "Lula-Jean", "Lula-Mae", "Lulu", "Luna", "Lynn", "Mabel", "Madison", "Mae", "Maggie", "Magnolia", "Maisie", "Margaret", "Margarita", "Margot", "Marianna", "Maribelle", "Marigold", "Marilyn", "Marsella", "Martina", "Mary", "Marzie", "Maud", "Mavis", "May", "Maya", "Maybelle", "Mazie", "Melanie", "Mellie", "Memphis", "Mercedes", "Merripennie", "Mertie", "Millie", "Mimi", "Miranda", "Missy", "Mollie", "Molly", "Mona", "Monnie", "Monroe", "Nancy", "Naomi", "Nellie", "Nessie", "Nicolette", "Nora", "Odette", "Olivia", "Oneida", "Opal", "Ophelia", "Othella", "Paisley", "Parker", "Patricia", "Patsy", "Pearl", "Penelope", "Pepper", "Petunia", "Philomina", "Phoebe", "Piper", "Poppy", "Presley", "Primrose", "Priscilla", "Prissy", "Prudence", "Queen", "Quida", "Quinnie", "Rae", "Raleigh", "Rayanne", "Reba", "Renetta", "Reona", "Rexanna", "Rhea", "Rhetta", "Rita", "Rosalie", "Rosalind", "Rose", "Rosemary", "Rosie", "Roslyn", "Rovena", "Rowena", "Roxie", "Ruby", "Ruthie", "Sabine", "Sabrina", "Sadie", "Sally", "Sarah-Lynn", "Savannah", "Sawyer", "Scarlet", "Selena", "Selene", "Selma", "Seraphina", "Serena", "Shania", "Sharon", "Shelby", "Shirley", "Starr", "Stella", "Sue", "Sugar", "Summer", "Susie", "Sutton", "Suzanna", "Suzanne", "Sylvie", "Tabby", "Tabitha", "Tallulah", "Tammy", "Tandy", "Tanya", "Tara", "Taylor", "Teressa", "Thea", "Theolyn", "Thyra", "Tiara", "Tillie", "Tina", "Tisha", "Trinity", "Trudy", "Valarie", "Valentine", "Vallie", "Velora", "Veolia", "Vera", "Verena", "Vernetta", "Verona", "Vesta", "Victoria", "Vida", "Viola", "Violet", "Vira", "Virginia", "Vivi", "Viviana", "Vivienne", "Waldine", "Wavie", "Waynetta", "Welda", "Wendolyn", "Whitney", "Willie", "Willow", "Wilma", "Wilomena", "Winifred", "Winnie", "Winona", "Wyatt", "Wynona", "Xandi", "Xena", "Ximenia", "Yonnie", "Yvette", "Zadie", "Zara", "Zelda", "Zera", "Zora" +]; +App.Data.misc.antebellumSlaveSurnames = [ +"Abel", "Absher", "Achord", "Adair", "Adams", "Addison", "Adkinson", "Agee", "Alden", "Aldridge", "Allen", "Allman", "Alter", "Amica", "Armstrong", "Arrington", "Arthur", "Artope", "Ashurst", "Aspern", "Aultman", "Avant", "Axson", "Baggarley", "Baker", "Baldwin", "Banks", "Barfield", "Barker", "Barnes", "Barnett", "Barrentine", "Barrett", "Barrow", "Bartholomew", "Barton", "Baskin", "Bass", "Bates", "Behlmer", "Belknap", "Bell", "Belt", "Bening", "Berry", "Bethune", "Biffar", "Biffle", "Birch", "Bischoff", "Bishop", "Blackard", "Blase", "Bliss", "Bohnefeld", "Bond", "Boney", "Booth", "Born", "Bostick", "Bowen", "Bowie", "Boynton", "Bozeman", "Bracken", "Bradford", "Bradley", "Bradshaw", "Brank", "Brannon", "Braswell", "Brewer", "Bright", "Broughton", "Brown", "Broxton", "Bruce", "Bryan", "Bryant", "Buchanan", "Buckalew", "Buckley", "Bulcken", "Bullard", "Burdell", "Burmester", "Burnett", "Burns", "Burton", "Bush", "Bussey", "Byrd", "Cain", "Calhoun", "Callaway", "Cameriero", "Camp", "Campbell", "Canup", "Carlos", "Carney", "Carroll", "Carson", "Carter", "Casey", "Cass", "Cassels", "Cattell", "Chambers", "Chancey", "Chapin", "Chapel", "Chaplin", "Chapman", "Chastain", "Christopher", "Chunn", "Clark", "Clements", "Clewis", "Coburn", "Cochran", "Cofer", "Coker", "Cole", "Coleman", "Colley", "Colquitt", "Compton", "Cone", "Cook", "Copeland", "Corder", "Cothran", "Cotting", "Countryman", "Cox", "Craig", "Cranford", "CrookCrowe", "Crumpler", "Crutchfield", "Cubbedge", "Culler", "Culpepper", "Dagg", "Dange", "Daniel", "Darley", "Dart", "Davis", "Dawson", "Delmar", "Delony", "Denecke", "Dennard", "Dent", "DeVaughn", "Dick", "Dickerson", "Dickey", "Dickinson", "Dickson", "Dillard", "Dillworth", "Dismuke", "Dobbs", "Doles", "Donaldson", "Dotson", "DoughertyDouglas", "Dowis", "Duckett", "Dukes", "Dunaway", "Duncan", "Dunning", "Dupriest", "Dure", "Dyer", "Echols", "Edwards", "Elder", "Elkins", "Ellars", "Ellis", "Ellison", "English", "Estes", "Etheridge", "Evans", "Everett", "Felder", "Felton", "Fielder", "Fish", "Fite", "Fitzgerald", "Fletcher", "Flournoy", "Floyd", "Flum", "Flynn", "Fohl", "Folds", "Forbes", "Force", "Ford", "Fordham", "Forsyth", "Frederick", "Freeman", "Furman", "Gannon", "Gant", "Gardner", "Garner", "Gartrell", "Gaskins", "Gaston", "Gates", "Gilbert", "Gilcrease", "Gillon", "Glen", "Glover", "Goode", "Goodwin", "Gordon", "Gossett", "Graham", "Grant", "Graves", "Gray", "Greene", "Greer", "Grenable", "Gresham", "Grice", "Griffin", "Griffith", "Grooms", "Guerineau", "Gunn", "Gurr", "Habersham", "Hageman", "Hall", "Hamilton", "Hammett", "Hammock", "Hammond", "Haney", "Harbuck", "Hardy", "Harms", "Harp", "Harrell", "Harris", "Hartley", "Harvard", "Harvey", "Hasford", "Hastedt", "Havis", "Haynes", "Hays", "Haywood", "Head", "Heard", "Heinsohn", "Herndon", "Herritage", "Hewett", "Hicks", "Higgs", "Hiles", "Hill", "Hillyer", "Hink", "Hiott", "Hitt", "Hobbs", "Hodges", "Hoffman", "Holden", "Holland", "Holleman", "Hollinshead", "Holmes", "Holt", "Holtzclaw", "Hood", "Hooper", "Hopkins", "Horne", "Hosch", "Hose", "Houser", "Houston", "Howard", "Howell", "Hubbard", "Huber", "Huckabee", "Hudson", "Huff", "Hughes", "Hulsey", "Hunnicutt", "Hunt", "Hurt", "Hussey", "Hutchins", "Huxford", "Ingram", "Inman", "Irwin", "IversonIvy", "Jackson", "Jakobi", "James", "Jeffers", "Jester", "Jinks", "Johnson", "Jones", "Jordan", "Juhan", "Julian", "Keith", "Kendrick", "Kennedy", "Kennon", "Kersh", "Kilgore", "Kilper", "Kimsey", "King", "Kirby", "Kirkland", "Kitchens", "Knee", "Knowles", "Knox", "Kobe", "Kornahrens", "Koschmieder", "Kothanek", "Kratzer", "Kunz", "Lackey", "Lamar", "Lamb", "Lancaster", "Lanford", "Latham", "Law", "Lawrence", "Lawton", "Leach", "Leary", "LeConte", "Ledford", "Lee", "Lent", "Leonard", "Lester", "Lewis", "Liddell", "Lindsey", "Lloyd", "Lochow", "Lockerman", "Lonebar", "Long", "Longstreet", "Lorenzen", "Love", "Lowe", "Lyles", "MacClellan", "Magill", "Manning", "Marsh", "Marshall", "Marston", "Martin", "Mask", "Massenburg", "Massey", "Matson", "Matthews", "Maddox", "Mays", "McArthur", "McBride", "McCallum", "McClure", "McCord", "McCormick", "McCoy", "McDaniel", "McDermott", "McDonald", "McDonnell", "McDowall", "McElveen", "McGee", "McKenzie", "McKinne", "McLead", "Mealer", "Mendenhall", "Menzel", "Mercer", "Messick", "Mewborn", "Meyers", "Middlebrooks", "Miller", "Mims", "Mitchell", "Mize", "Mooney", "Moore", "Morris", "Mosely", "Moss", "Moyer", "Muldoon", "Mulkey", "Munford", "Murner", "Murphy", "Murray", "Nash", "Neal", "Nesbitt", "New", "Newberry", "Nix", "Nolan", "Norton", "Norwood", "Nowell", "Nunnery", "Oakes", "Oakley", "Oberry", "Ogden", "O'Neal", "Ornston", "Owen", "Ownbey", "Pace", "Padgett", "Page", "Paris", "Parkes", "Parrott", "Passmore", "Patterson", "Patton", "Payne", "Peacock", "Peel", "Penn", "Perdue", "Perry", "Persons", "Peters", "Phelts", "Phillips", "Pickens", "Pierce", "Pinckney", "Pitts", "Pollard", "Pollett", "Pool", "Porter", "PowellPowers", "Pratt", "Prescott", "Price", "Pritchett", "Proctor", "Pruett", "Puckett", "Pyron", "Quigg", "Ralston", "Rauls", "Ray", "Reagan", "Redfern", "Redwine", "Reece", "Reed", "Reeves", "Rembert", "Renfus", "Reynolds", "Rhett", "Richards", "Richardson", "Ricks", "Rieke", "Riley", "Robberson", "Roberts", "Robertson", "Robinson", "Rogers", "Rollison", "Root", "Ross", "Rouse", "Rowan", "Ruffin", "Russell", "Rutledge", "Ryder", "Sadler", "Salter", "Sanders", "Sanford", "Sangster", "Sasser", "Saunders", "Sawyer", "Saxon", "Scarborough", "Scott", "Seago", "Searcy", "Seiler", "Self", "Sentelle", "Shackelford", "Shafer", "Sharman", "Shaw", "Shelton", "Shephard", "Sherrard", "Shivers", "Short", "Simmons", "Slappey", "Slavens", "Slocomb", "Small", "Smalling", "Smith", "Sneed", "Snell", "Sowell", "Sparks", "Sparrow", "Spence", "Spencer", "Spradley", "Stafford", "Stansell", "Staples", "Starnes", "Starr", "Stembridge", "Stephens", "Stetson", "Stevenson", "Stockhausen", "Stocks", "Strickland", "Stuart", "Sudderth", "Sullivan", "Sumerford", "Sutton", "Swafford", "Swaim", "Swanner", "Tarver", "Taylor", "Teague", "Teal", "Terry", "Theus", "Thompson", "Thornton", "Till", "Tinley", "Tracy", "Trawick", "Trice", "Trout", "Trusty", "Turner", "Tyler", "Upchurch", "Ussery", "Vance", "Vinson", "Waits", "Walden", "Walker", "Wall", "Wallace", "Walters", "Walton", "Ward", "Ware", "Warren", "Washington", "Waters", "Watkins", "Watson", "Watts", "Weaver", "Webb", "Wellborn", "Westbrook", "Wheeler", "White", "Whitehead", "Whiteside", "Whitfield", "Whitty", "Wicks", "Wight", "Wilbur", "Wiley", "Wilkes", "Williams", "Wilson", "Wisdom", "Withington", "Wolff", "Wood", "Woodruff", "Woodward", "Woolfolk", "Wootten", "Worthy", "Wragg", "Wright", "Wynne", "Yancey", "Yarbrough", "Young", "Youngblood", "Yutzy", "Zumwalt" +]; + App.Data.misc.bimboSlaveNames = ["Air", "Alex", "Alexis", "Amaze", "Amber-Louise", "Amber", "Amethyst", "Angel", "Angela", "Angelica", "Aphrodite", "April", "Aqua", "Aquamarine", "Ariel", "Art", "Artemis", "Ash", "Ashleigh", "Ashley", "Autumn", "Azalea", "Babe", "Baby", "Babydoll", "Bambi", "Barbie", "Beauty", "Belle", "Berry", "Beth", "Betty", "Biscuit", "Blossom", "Bolt", "Bonnie", "Bountiful", "Bounty", "Brandi", "Brandy", "Brie", "Britney", "Brittani", "Brittany", "Brittney", "Brooke", "Bubbles", "Bunni", "Bunny", "Buttercup", "Callie", "Candi", "Candice", "Candy", "Caprice", "Caramel", "Carmel", "Carmen", "Cashleigh", "Cassie", "Champagne", "Chance", "Chantelle", "Chardonnay", "Charity", "Cheer", "Chelsea", "Cherri", "Cherry", "Chloe", "Christi", "Christina", "Cindi", "Cindy", "Cinnamon", "Cissy", "Classy", "Cleopatra", "Cloud", "Clover", "Coco", "Comfort", "Connie", "Cookie", "Courtney", "Crimson", "Crystal", "Cryztal", "Cupcake", "Cutie", "Daisy", "Danielle", "Dawn", "Daybreak", "Dazzle", "Deluxe", "Desire", "Destiny", "Diamanda", "Diamond", "Didi", "Diva", "Divine", "Divinity", "Doll", "Dolli", "Dolly", "Dot", "Dotty", "Dream", "Ebony", "Elisa", "Emerald", "Erika", "Erotica", "Fable", "Faith", "Fall", "Fantasy", "Fawn", "Felicity", "Femme", "Fifi", "Flame", "Flash", "Flower", "Flurry", "Forest", "Fox", "Foxxy", "Garnet", "Gem", "Gigi", "Gin", "Glamor", "Glimmer", "Glitter", "Glow", "Goldie", "Grey", "Grove", "Gwen", "Halo", "Handy", "Harvest", "Haylee", "Hayley", "Hazel", "Heart", "Heaven", "Hera", "Holly", "Honey", "Hope", "Infinity", "Ivanka", "Ivory", "Ivy", "Jade", "Jasmine", "Jay", "Jazz", "Jeni", "Jess", "Jessie", "Jewel", "Jezebel", "Jingles", "Jizzelle", "Joy", "July", "June", "Kandi", "Kandy", "Karma", "Katie", "Kaycee", "KeKe", "Kelli", "Kelly", "Kelsi", "Kelsie", "Kelsy", "Khloe", "Kiki", "Kim", "Kimmy", "Kitten", "Kitty", "Kristal", "Kristie", "Krystal", "Kylie", "Lacy", "Lady", "Laney", "Lapis Lazuli", "Lapis", "Lass", "Lavender", "Lee", "Legend", "Lewdity", "Lexi", "Light", "Lightning", "Lisa", "Liza", "Lola", "Lolita", "Lolli", "London", "Louise", "Love", "Lovely", "Lucy", "Luna", "Lusty", "Lux", "MacKenzie", "Maddie", "Madison", "Maggie", "Magnolia", "Magnum", "Mandi", "Mandy", "Maple", "Marble", "Marcie", "Margo", "Maria", "Marie", "Marilyn", "Marina", "Marshmallow", "Martini", "May", "Meadow", "Megan", "Meghan", "Melania", "Melissa", "Melon", "Mercedes", "Miley", "Mimosa", "Mindi", "Mindy", "Minx", "Miracle", "Missi", "Missy", "Misty", "Monique", "Moon", "Moonbeam", "Muffi", "Mystery", "Myth", "Nicki", "Nicky", "Nikita", "Nikki", "Opal", "Paris", "Parmie", "Passion", "Peach", "Peaches", "Penelope", "Peridot", "Petunia", "Pink", "Pinkie", "Pinky", "Pixie", "Polly", "Poni", "Poppy", "Precious", "Princess", "Pussycat", "Quartz", "Queenie", "Radiance", "Rain", "Robin", "Rose", "Roxanne", "Roxy", "Ruby", "Sammi", "Sammy", "Sandy", "Sapphire", "Satin", "Scarlet", "Scarlette", "Sea", "Sexxxy", "Shaniqua", "Shine", "Showtime", "Silk", "Silver", "Sindi", "Sinnamon", "Skipper", "Sky", "Skye", "Smiles", "Snow", "Snowball", "Sol", "Sophie", "Soul", "Spark", "Sparkle", "Spice", "Spicey", "Spring", "Sprinkles", "Stacee", "Stacey", "Stacy", "Star", "Steamy", "Sugar", "Summer", "Sun", "Sunbeam", "Sunny", "Sunset", "Super", "Surprise", "Sweetie", "Sweetpie", "Sweets", "Tart", "Tawny", "Taylor", "Tea", "Temptation", "Tequila", "Terra", "Thriller", "Tiara", "Tiffani", "Tiffany", "Topaz", "Toy", "Traci", "Treasure", "Treat", "Trick", "Trinity", "Trixie", "Twilight", "Tyler", "Ultra", "Valentine", "Velvet", "Venus", "Vivi", "Vixen", "Wanda", "Winter", "Wish", "Wonder", "Yasmin", "Zhazha"]; App.Data.misc.bimboMaleNames = ["A.J.", "Aaron", "Abe", "Adam", "Aiden", "Al", "Alex", "Andy", "Anvil", "Ares", "Argo", "Arnold", "Austin", "Barrett", "Barron", "Bash", "Beardo", "Beast", "Beau", "Beef", "Ben", "Bernie", "Bert", "Beto", "Biff", "Bill", "Billie", "Billy", "Bimbo", "Blake", "Blane", "Bob", "Bobby", "Bod", "Boogie", "Boone", "Boris", "Boss", "Bow", "Brad", "Bradley", "Brak", "Brandon", "Brayden", "Brenden", "Brent", "Brett", "Brian", "Brick", "Bro", "Brock", "Brodie", "Brody", "Broly", "Broski", "Bruce", "Brute", "Bryan", "Bryce", "Bubba", "Buck", "Bud", "Bull", "Bullet", "Burner", "Burnie", "Burt", "Butch", "Buzz", "Cain", "Cal", "Cam", "Cameron", "Cap", "Carson", "Cayden", "Chad", "Champ", "Charlie", "Chase", "Chaz", "Chet", "Chip", "Chris", "Chud", "Chunk", "Clark", "Cody", "Cole", "Connor", "Cool", "Coors", "Cosmo", "Crane", "Crash", "Croc", "Crud", "Crunch", "Crunk", "Crusher", "Curt", "Cutter", "Cyrus", "D.J.", "Dave", "Davey", "David", "Dawg", "Deuce", "Dex", "Dick", "Dickie", "Diesel", "Dino", "Dirk", "Dog", "Dolf", "Dolph", "Dom", "Don", "Donald", "Doug", "Downtown", "Doyle", "Duke", "Dylan", "Dynamite", "Earl", "Earle", "Ed", "Eddie", "Edge", "Ego", "Eric", "Erwin", "Ethan", "Falcon", "Finn", "Flash", "Ford", "Frank", "Fred", "Freddie", "Freddy", "Gabe", "Garrett", "Garth", "Gator", "Georgy", "Gerry", "Giorgio", "Grant", "Grease", "Greg", "Guinness", "Guy", "Hammer", "Han", "Hank", "Hawk", "Heff", "Hock", "Huck", "Hugh", "Hunk", "Hunter", "Ian", "Igor", "Iron", "Irwin", "Isaac", "Jack", "Jackie", "Jackson", "Jake", "Jared", "Jay", "Jayson", "Jerry", "Jesse", "Jimbo", "Jock", "Joe", "Johnny", "Jonah", "Jones", "Jonesy", "Juggernaut", "Junior", "Justin", "Kane", "Kay", "Keith", "Kevin", "King", "Kramer", "Kris", "Kurt", "Kyle", "Lance", "Lee", "Levi", "Liam", "Lightning", "Logan", "Lou", "Louie", "Luke", "M.C.", "Marc", "Mark", "Marshall", "Mash", "Master", "Mate", "Mater", "Matt", "Maverick", "Max", "Meat", "Mel", "Mike", "Mikey", "Miller", "Mitch", "Mongo", "Moose", "Munch", "Murray", "Musk", "Nash", "Nate", "Neal", "Neil", "Newt", "Nick", "Nigel", "Oliver", "Owen", "Ox", "Patch", "Paul", "Paulie", "Pauly", "Pax", "Pete", "Petey", "Pitt", "Powers", "Preston", "Puck", "Punk", "Quincey", "Rack", "Ralph", "Ray", "Rex", "Rich", "Rick", "Ricky", "Rico", "Rip", "Rob", "Rocco", "Rock", "Rocker", "Rocko", "Rod", "Ron", "Rooster", "Ross", "Rum", "Russ", "Russell", "Rusty", "Sabre", "Scooter", "Scott", "Seth", "Skip", "Slash", "Sledge", "Smash", "Smasher", "Spencer", "Spinner", "Spud", "Spuds", "Stallion", "Stan", "Stanley", "Steel", "Steele", "Steve", "Stone", "Stuart", "Stud", "Sylvester", "Tad", "Tanner", "Terence", "Thad", "Thor", "Thrush", "Toby", "Todd", "Tom", "Tone", "Tony", "Topher", "Track", "Travis", "Trent", "Trevor", "Trey", "Trip", "Tucker", "Twitch", "Tyler", "Tyrone", "Verne", "Vince", "Volk", "Wally", "Wash", "Wayne", "Wells", "Will", "Willie", "Witt", "Wolf", "Wolfgang", "Wyatt", "Zach", "Zack", "Zap", "Zayne", "Zeke", "Zeus"]; @@ -2144,7 +2151,8 @@ App.Data.misc.namePoolSelector = { "Arabian Revivalist": App.Data.misc.saudiSlaveNames, "Aztec Revivalist": App.Data.misc.aztecSlaveNames, "Edo Revivalist": App.Data.misc.edoSlaveNames, - "Roman Revivalist": App.Data.misc.romanSlaveNames + "Roman Revivalist": App.Data.misc.romanSlaveNames, + "Antebellum Revivalist": App.Data.misc.antebellumSlaveNames }; App.Data.misc.malenamePoolSelector = { "Afghan": App.Data.misc.afghanMaleNames, @@ -2582,7 +2590,8 @@ App.Data.misc.surnamePoolSelector = { "Ancient Chinese Revivalist": App.Data.misc.chineseRevivalistSlaveSurnames, "Arabian Revivalist": App.Data.misc.saudiSlaveSurnames, "Edo Revivalist": App.Data.misc.edoSlaveSurnames, - "Roman Revivalist": App.Data.misc.romanSlaveSurnames + "Roman Revivalist": App.Data.misc.romanSlaveSurnames, + "Antebellum Revivalist": App.Data.misc.antebellumSlaveSurnames }; /* * Male surname pools work differently: Most nationalities/races use the same so don't have any. diff --git a/js/003-data/policiesData.js b/js/003-data/policiesData.js index 3f1aef12bb84382dc06d4220214cace8e365d821..ab5cc3e15c8285c11fc18e70597eb62731bbaec0 100644 --- a/js/003-data/policiesData.js +++ b/js/003-data/policiesData.js @@ -2035,6 +2035,46 @@ App.Data.Policies.Selection = { } ], }, + FSAntebellumRevivalist: { + "arcologies[0].FSAntebellumRevivalistSMR": [ + { + title: "Antebellum Cultural Induction SMR", + titleClass: "lime", + text: "in order to be sold in the arcology, slaves must be instructed in the cultural tenets of Antebellum society.", + activatedText: "in order to be sold in the arcology, slaves must be instructed in the cultural tenets of Antebellum society.", + get requirements() { return (V.arcologies[0].FSAntebellumRevivalist >= 40); }, + note: `Will help advance Antebellum Revivalism` + } + ], + "arcologies[0].FSAntebellumRevivalistLaw1": [ + { + title: "Affirm the Rights of Slaveowners", + titleClass: "lime", + text: "while slaveowners are already de facto the most prominent members of society within your arcology, the token gesture of legally enshrining the rights of slaveowners will help secure their loyalty and attract new wealthy citizens.", + activatedText: "slaveowners are grateful to you and the arcology steadily attracts new wealthy citizens.", + get requirements() { return (V.arcologies[0].FSAntebellumRevivalist >= 60); }, + note: `Will increase the rate at which slaveowners immigrate to your arcology, attracting middle class citizens and above.` + } + ], + "arcologies[0].FSAntebellumRevivalistLaw2": [ + { + title: "Guarantee the Right to Bear Arms", + titleClass: "lime", + text: `it is an expected right under the ideals established by Antebellum Revivalism that eligible citizens ought to be able to possess weaponry and form militias to defend themselves and their property. + ${V.secExpEnabled && V.SecExp.edicts.weaponsLaw === 0 ? + ` By your edict, citizens are currently forbidden from possessing firearms. Enacting this law will automatically set the range of weapons allowed within the arcology to non-automatic, non-high caliber, free of the usual cost of authority.` : `` + }`, + activatedText: "citizens proudly carry arms in defense of themselves and the arcology against foreign threats and the slave class.", + get requirements() { return (V.arcologies[0].FSAntebellumRevivalist >= 90); }, + onImplementation: function() { + if (V.secExpEnabled && V.SecExp.edicts.weaponsLaw === 0) { + V.SecExp.edicts.weaponsLaw = 1; + } + }, + note: `Improve your arcology's defensive combat power while also exacerbating any future rebellions` + } + ], + }, FSRepopulationFocus: { "arcologies[0].FSRepopulationFocusSMR": [ { diff --git a/js/003-data/slaveSummaryData.js b/js/003-data/slaveSummaryData.js index 3af5ee6c550f3574b350fdbe35c864a2f716781a..22d23321c3afc93a2fb70e82a69e3de8ee7cb3e0 100644 --- a/js/003-data/slaveSummaryData.js +++ b/js/003-data/slaveSummaryData.js @@ -382,9 +382,11 @@ App.Data.SlaveSummary = { "a toga": "Toga.", "a tube top and thong": "Tube top, thong.", "a tube top": "Nice tube top.", + "a confederate army uniform": "Confederate Army uniform.", "an apron": "Apron.", "an oversized t-shirt and boy shorts": "Over-sized t-shirt, boy shorts.", "an oversized t-shirt": "Nice over-sized t-shirt.", + "an evening dress": "Evening dress.", "attractive lingerie for a pregnant woman": "Preggo lingerie.", "attractive lingerie": "Nice lingerie.", "battlearmor": "Battlearmor.", diff --git a/src/002-config/fc-version.js b/src/002-config/fc-version.js index ccc8c2c2e2dee16ebc9920e85981302f31647bd9..13d2f133c4e74f941a4893b1e9ad54253cdd245a 100644 --- a/src/002-config/fc-version.js +++ b/src/002-config/fc-version.js @@ -2,5 +2,5 @@ App.Version = { base: "0.10.7.1", // The vanilla version the mod is based off of, this should never be changed. pmod: "4.0.0-alpha.23", commitHash: null, - release: 1188, // When getting close to 2000, please remove the check located within the onLoad() function defined at line five of src/js/eventHandlers.js. + release: 1189, // When getting close to 2000, please remove the check located within the onLoad() function defined at line five of src/js/eventHandlers.js. }; diff --git a/src/Mods/Catmod/events/nonRandom/projectNBlowingTheLid.js b/src/Mods/Catmod/events/nonRandom/projectNBlowingTheLid.js index 8385c6523711ed0135aab4ac185a21ccea43768d..e4f61123c1d920259d6815cfc43561ccee62ca97 100644 --- a/src/Mods/Catmod/events/nonRandom/projectNBlowingTheLid.js +++ b/src/Mods/Catmod/events/nonRandom/projectNBlowingTheLid.js @@ -37,6 +37,9 @@ App.Events.SEProjectNblowingthelid = class SEProjectNblowingthelid extends App.E if (V.arcologies[0].FSRomanRevivalistLaw === 1) { choices.push(new App.Events.Result(`Send an emergency message out to your armed citizens to intervene`, roman)); } + if (V.arcologies[0].FSAntebellumRevivalistLaw2 === 1) { + choices.push(new App.Events.Result(`Send an emergency message out to your citizens' militias to intervene`, militia)); + } if (V.mercenaries === 5) { choices.push(new App.Events.Result(`Send an emergency message out to your ${V.mercenariesTitle}`, mercenaries)); } @@ -66,6 +69,17 @@ App.Events.SEProjectNblowingthelid = class SEProjectNblowingthelid extends App.E return frag; } + function militia() { + const frag = new DocumentFragment(); + let r = []; + r.push(`You immediately send for your AI to send an emergency bulletin to your citizens' militias, calling for the sons and daughters of the South to defend the Republic once more. As you yourself sprint towards the laboratory, the crack of loud gunshots ring through the air, back-and-forth fire that keeps going for nearly a full minute. By the time you finally arrive, you find the entrance to the lab absolutely covered in blood and bodies. All of the corpses on the ground are dressed in black and orange and clutching old-fashioned assault rifles, surrounded by a large cluster of armed citizens, a few of which nurse wounds from their brief but intense fighting with the Sons. Two militiamen hold down a struggling survivor dressed in orange and black, seemingly the only still-breathing fighter on the Sons' side. As much as the Sons of Sekhmet's announcement has <span class="reputation dec">shocked</span> the arcology, the timely and heroic response of your chivalrous citizen-soldiers defending the arcology against violent foreign insurgents, is just the PR event you needed to <span class="reputation inc">reverse the damage,</span> especially when the rattled Dr. Nieskowitz comes out from the assaulted lab to thank you for saving his life.`); + repX(4000, "event"); + V.projectN.status = 5; + r.push(App.UI.newSlaveIntro(slave)); + App.Events.addParagraph(frag, r); + return frag; + } + function mercenaries() { const frag = new DocumentFragment(); let r = []; diff --git a/src/Mods/SecExp/js/Unit.js b/src/Mods/SecExp/js/Unit.js index c01268796433498e23b4812ddf93bdc676bcb5de..78caa6b7860260f1294b3ff4922314ac60356b01 100644 --- a/src/Mods/SecExp/js/Unit.js +++ b/src/Mods/SecExp/js/Unit.js @@ -974,6 +974,9 @@ App.Mods.SecExp.getAppliedUpgrades = function(type) { if (V.arcologies[0].FSNeoImperialistLaw1) { attack++; } + if (V.arcologies[0].FSAntebellumRevivalistLaw2) { + def++; + } } } return { @@ -989,7 +992,8 @@ App.Mods.SecExp.getEdictUpgradeVal = (function() { ["pharaonTradition", {attack: 2, defense: 2, morale: 10}], ["sunTzu", {attack: 1, defense: 1, morale: 5}], ["eliteOfficers", {morale: 5}], - ["lowerRequirements", {defense: -1, hp: -1}] + ["lowerRequirements", {defense: -1, hp: -1}], + ["southronTradition", {attack: -1, defense: 4, morale : 5}], ]), slave: new Map([ ["mamluks", {attack: 2, morale: 10, hp: 1}], diff --git a/src/Mods/SecExp/js/authorityReport.js b/src/Mods/SecExp/js/authorityReport.js index 4701aceef75180b01c0e29477ba98ecca896b5b2..412ab5667d244e24cbbfa9e5271d33410d3b4d10 100644 --- a/src/Mods/SecExp/js/authorityReport.js +++ b/src/Mods/SecExp/js/authorityReport.js @@ -272,7 +272,7 @@ App.Mods.SecExp.authorityReport = function() { const militarizedSociety = [ 'FSRomanRevivalist', 'FSAztecRevivalist', 'FSEgyptianRevivalist', 'FSEdoRevivalist', 'FSArabianRevivalist', 'FSChineseRevivalist', - 'FSNeoImperialist'].every((FS) => V.arcologies[0][FS] === "unset"); + 'FSNeoImperialist', 'FSAntebellumRevivalist'].every((FS) => V.arcologies[0][FS] === "unset"); if (militia >= 1) { if (militia >= 4) { r.push(`${!militarizedSociety ? 'Many' : 'Some'} of your citizens are offended by your ${militia === 5 ? 'extreme' : ''} militarization of the arcology's society.`); diff --git a/src/Mods/SecExp/js/edicts.js b/src/Mods/SecExp/js/edicts.js index 010c3963d9198bf72dc5987ad64c27b27a002b98..708b3d8a24ebc2c7c5a6d7af22c563950149eb75 100644 --- a/src/Mods/SecExp/js/edicts.js +++ b/src/Mods/SecExp/js/edicts.js @@ -303,12 +303,16 @@ App.Mods.SecExp.edicts = function() { }, { text: "forbid residents to buy, sell and keep weaponry while within the arcology.", - conditional: V.SecExp.edicts.weaponsLaw === 1, + conditional: V.SecExp.edicts.weaponsLaw === 1 && V.arcologies[0].FSAntebellumRevivalistLaw2 !== 1, set: function() { V.SecExp.edicts.weaponsLaw = 0; }, note: "Will cost a moderate amount of authority each week, but rebellions will be very poorly armed." }, + { + conditional: V.SecExp.edicts.weaponsLaw === 1 && V.arcologies[0].FSAntebellumRevivalistLaw2 === 1, + note: "You have legally guaranteed your citizens the right to bear arms. You must first revoke that right to enact this edict." + }, { text: "set the range of weapons allowed within the arcology to non-automatic, non-high caliber.", conditional: V.SecExp.edicts.weaponsLaw === 0, @@ -363,6 +367,28 @@ App.Mods.SecExp.edicts = function() { } ] }], + ["Southron traditions", { + tag: ["bold", "lime"], + repeal: [ + { + text: "you are funding specialized training for your citizen-run militias to turn them into a professional Southron army", + conditional: V.FSAnnounced && V.SecExp.edicts.defense.southronTradition === 1, + set: function() { + V.SecExp.edicts.defense.southronTradition = 0; + }, + } + ], + implement: [ + { + text: "fund specialized training for your citizen-run militias to turn them into a professional, though still citizen-run, Southron army", + conditional: V.FSAnnounced && V.SecExp.edicts.defense.militia >= 1 && V.arcologies[0].FSAntebellumRevivalist >= 40 && V.SecExp.edicts.defense.southronTradition === 0, + set: function() { + V.SecExp.edicts.defense.southronTradition = 1; + }, + note: "Will increase defense and morale, but will incur upkeep costs. Southron Militiamen excel at defense and aren't motivated on the attack." + } + ] + }], ["Pharaonic traditions", { tag: ["bold", "lime"], repeal: [ diff --git a/src/Mods/SecExp/js/reportingRelatedFunctions.js b/src/Mods/SecExp/js/reportingRelatedFunctions.js index bcec882e8355470ead2fa72d06757e1bd9248e9d..c0a11cbc64a90c2d91ea96c882d2e991df99fe5c 100644 --- a/src/Mods/SecExp/js/reportingRelatedFunctions.js +++ b/src/Mods/SecExp/js/reportingRelatedFunctions.js @@ -751,6 +751,8 @@ App.Mods.SecExp.commanderEffectiveness = function(passage) { if (V.arcologies[0].FSRomanRevivalist !== "unset" || V.arcologies[0].FSNeoImperialist !== "unset") { mercMod += 0.10; SFMod += 0.10; + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + militiaMod += 0.15; } else { mercMod -= 0.10; SFMod -= 0.10; @@ -760,7 +762,23 @@ App.Mods.SecExp.commanderEffectiveness = function(passage) { tacChance += either(-1, 1) * random(20) * 0.1; } else { r.push(`One of your volunteers was the commander.`); - if (V.arcologies[0].FSDegradationist === "unset" && V.arcologies[0].FSPaternalist === "unset") { + + if (V.arcologies[0].FSAntebellumRevivalist !== "unset" && V.arcologies[0].FSAntebellumRevivalistLaw2 === 1) { + if (App.Mods.SecExp.battle.deployedUnits('militia') >= 1) { + r.push(`Your citizens' militia units are extremely proud that one of their own is leading the defense force of the city.`); + } + if (App.Mods.SecExp.battle.deployedUnits('slaves') >= 1) { + if (V.arcologies[0].FSDegradationist !== "unset") { + r.push(`Because of your degradationist society,`); + if (App.Mods.SecExp.battle.deployedUnits('militia') >= 1) { + r.push(`however,`); + } + r.push(`your slave soldiers are deeply distrustful of the new leader.`); + } else if (V.arcologies[0].FSPaternalist !== "unset") { + r.push(`Thanks to your paternalistic society, your slave soldiers trust your chosen citizen to treat them as more than cannon fodder.`); + } + } + } else if (V.arcologies[0].FSDegradationist === "unset" && V.arcologies[0].FSPaternalist === "unset") { if (App.Mods.SecExp.battle.deployedUnits('militia') >= 1) { r.push(`Your volunteers are honored and pleased that one of their own is leading the defense force of the city.`); } @@ -790,6 +808,8 @@ App.Mods.SecExp.commanderEffectiveness = function(passage) { r.push(`Since you decided to revive old Rome, many of your citizens took on themselves to educate themselves in martial matters, because of this your mercenaries feel safe enough in the hands of one of your volunteers.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset" && App.Mods.SecExp.battle.deployedUnits('mercs') >= 1) { r.push(`Since having instituted an Imperial society, your citizens have become adept at modern warfare and your hardened mercenaries feel far more comfortable with one of your Imperial Knights in command.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset" && V.arcologies[0].FSAntebellumRevivalistLaw2 === 1 && App.Mods.SecExp.battle.deployedUnits('mercs') >= 1) { + r.push(`Since you have revived the Antebellum South and legally sanctioned citizens' militias, your hardened mercenaries feel safe enough in the hands of one of your experienced volunteers.`); } else if (App.Mods.SecExp.battle.deployedUnits('mercs') >= 1) { r.push(`Your mercenaries are not thrilled to be lead by a civilian without any formal martial training or education.`); } @@ -797,6 +817,8 @@ App.Mods.SecExp.commanderEffectiveness = function(passage) { r.push(`Since you decided to revive old Rome, many of your citizens took on themselves to educate themselves in martial matters, because of this your soldiers feel safe enough in the hands of one of your volunteers.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset" && App.Mods.SecExp.battle.deployedUnits('mercs') >= 1) { r.push(`Since having instituted an Imperial society, your citizens have become adept at modern warfare and the line soldiers feel much more comfortable being commanded by one of your Imperial Knights.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset" && V.arcologies[0].FSAntebellumRevivalistLaw2 === 1 && V.SF.Toggle && V.SF.Active >= 1 && V.SecExp.war.deploySF) { + r.push(`Since you have revived the Antebellum South and legally sanctioned citizens' militias, your professional soldiers feel safe enough in the hands of one of your experienced volunteers.`); } else if (V.SF.Toggle && V.SF.Active >= 1 && V.SecExp.war.deploySF) { r.push(`You soldiers are not thrilled to be lead by a civilian without any formal martial training or education.`); } @@ -862,6 +884,8 @@ App.Mods.SecExp.commanderEffectiveness = function(passage) { r.push(`Since you decided to revive old Rome, your volunteers are more willing to trust one of your soldiers as their leader.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset" && App.Mods.SecExp.battle.deployedUnits('militia') >= 1) { r.push(`Under the strict hierarchy of your Imperial society, the militia is more willing to follow the Colonel's commands.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset" && V.arcologies[0].FSAntebellumRevivalistLaw2 === 1 && App.Mods.SecExp.battle.deployedUnits('militia') >= 1) { + r.push(`Your citizens' militias are reluctant to listen to the Colonel's commands, but begrudgingly accept.`); } else if (App.Mods.SecExp.battle.deployedUnits('militia') >= 1) { r.push(`Your volunteers are not enthusiastic at the prospect of being commanded around by an old style military officer.`); } @@ -927,6 +951,7 @@ App.Mods.SecExp.upkeep = (function() { if (V.SecExp.edicts.defense.ronin) { value++; } if (V.SecExp.edicts.defense.mamluks) { value++; } if (V.SecExp.edicts.defense.sunTzu) { value++; } + if (V.SecExp.edicts.defense.southronTradition) { value++; } return value * 1000; } diff --git a/src/Mods/SecExp/js/secExp.js b/src/Mods/SecExp/js/secExp.js index 1db9a45cca83a184ad7b8e6b17ce0a9d3818328f..dd03896c81512c9c02dd7559b62472db82bb7d6c 100644 --- a/src/Mods/SecExp/js/secExp.js +++ b/src/Mods/SecExp/js/secExp.js @@ -61,7 +61,7 @@ App.Mods.SecExp.generator = (function() { 'FSChineseRevivalist', 'FSEgyptianRevivalist', 'FSAztecRevivalist']; const setB = [ 'FSRepopulationFocus', 'FSGenderRadicalist', 'FSPastoralist', - 'FSChattelReligionist', 'FSNeoImperialist']; + 'FSChattelReligionist', 'FSNeoImperialist', "FSAntebellumRevivalist"]; const resultA = setA.some((FS) => V.arcologies[0][FS] !== "unset"); const resultB = setB.some((FS) => V.arcologies[0][FS] !== "unset"); if (resultA && resultB) { diff --git a/src/Mods/SpecialForce/SpecialForceFS.js b/src/Mods/SpecialForce/SpecialForceFS.js index 37937314e597a0dba2981fd821369555376e8562..260e3bcda98740fd7dc000e96f69d508ae07adc3 100644 --- a/src/Mods/SpecialForce/SpecialForceFS.js +++ b/src/Mods/SpecialForce/SpecialForceFS.js @@ -10,7 +10,7 @@ App.Mods.SF.fsIntegration = (function() { const revivalisms = [ 'Arabian_Revivalism', 'Aztec_Revivalism', 'Chinese_Revivalism', 'Edo_Revivalism', 'Egyptian_Revivalism', 'Multiculturalism', - 'Roman_Revivalism', 'Neo_Imperialism' + 'Roman_Revivalism', 'Neo_Imperialism', "Antebellum_Revivalism" ]; const general = [ 'Asset_Expansionism', 'Body_Purism', 'Chattel_Religionism', @@ -577,6 +577,29 @@ App.Mods.SF.fsIntegration = (function() { roleplaying = `Your soldiers put in effort carry themselves in a manner befitting such a communal setting; they are cooperative, diligent, and disciplined at all times. They identify first and foremost as warriors of 'the emperor', and are proud to have a powerful empire such as your arcology to call home and fight for. In their personal dealings, they do their best to handle most affairs using the esteemed Mandarin dialect, and they avoid unseemly things like disloyalty, foolishness, and dishonor like the plagues that they are. These are true Imperial men and women, and they will relentlessly carry your society into the future as they fight to impress your name upon both Heaven and Earth themselves.`; colonel = `Chinese Revivalism: Sometimes when The Colonel is relaxing or just making her rounds in the Firebase, you'll see her wearing a long qipao cut high along the sides for ease of movement. She is known to prefer going commando, and the slits sometimes part to tease what's underneath for anyone watching her. She keeps a number of intelligent eunuchs in her company often, and they usually scurry along behind her to record everything that she says and does for later review. Her pavilion is lavishly furnished and concubines wait on her hand and foot when she rests. Her combat battledress now features lacquered armor and a golden burnished helm signifying her position as leader.`; break; + case 'Antebellum_Revivalism': + dec = `Antebellum Revivalism: a vision of the Antebellum-era American South born again.`; + gift = `In honor of the prevailing Antebellum Revivalism of the Firebase, you've granted The Colonel a little Antebellum estate of her own; you've purchased a distant swathe of fertile land and constructed a palatial plantation house there in the Greek Revival style. Slaves cultivate tobacco, various food staples, and rye and corn for whiskey on the rolling fields surrounding the home. Large oak trees, transplanted at staggering cost from the South, shade the long gravel road to the home. Behind it, an elaborate garden and hedge maze stretches out some distance.`; + foods = `You share no expense to supply your troops with a fair ration of increasingly rare Kentucky bourbon and an abundance of Southern comfort food.`; + media = `Soldiers enjoy quality spirits, coffee, and tobacco pipe smoking. Some play wargames with hand-painted miniature soldiers cast in modern resin or plastic, or in the older style of tin or pewter. Others still engage in classic American sportsmanship.`; + slaves = `Slaves are split into different groups; one for hard, physical labor, and the other primarily for more pleasure-based pursuits. On occasion, if a slave is exceptionally well-behaved, they may transfer from the former to the latter. `; + cages = `All new slaves are being re-educated in the specially-built slave school. Instructors kindly, yet firmly, instill in each slave Southern values of honesty, integrity, and unconditional love for their master.`; + commonArea = `The common area is stylized to look like a fine gentleman's club with a smokey atmosphere, dark wood, and red velvets.`; + barracks = `Soldiers sleep in clean, carefully constructed dormitories. The bunks inside are kept neat and uniform.`; + armoury = `The weapons and armor of your troops are stylized after the armies of the Confederacy, with each soldier gifted an ornate saber. It's common to see the soldiers here with reproduction or modernized Civil War-era firearms.`; + commandCenter = `The command center is extravagant. The atmosphere is smokey from your officers' cigar smoke. They toast crystal glass tumblers half-filled with amber-colored liquid around a huge paper map of the local region, studded with dozens of pins and a small model of the arcology at the center. `; + drugLab = `Meanwhile, the local pharmacy serves as a place of healing and enhancement, where miracles of cutting-edge modern medicine are delivered by men and women in old-fashioned clothing.`; + personalItems = `Antique military memorabilia, hand-carved tobacco pipes, silk smoking jackets, and other objects of finery have become popular accoutrements for your troops in between missions.`; + droneBay = `The nearby drone bay, known simply as 'the Battery', contains heavily-armored Ironclad-class drones, assembled right here in the arcology.`; + garage = `The garage is filled with the sparks and noise of mechanics performing routine maintenance, repairs, and upgrades to your fleet of vehicles. `; + vehicle = `Vehicles here are painted with the fluer-de-lis first, the old stars and bars, or some other form of southern regalia and then with the livery or seal of the commanding officer second. Most have been retrofitted with modern, high-strength sloped ceramic plating, painted a metallic grey, meant to evoke the stout shapes of ironclad battleships.`; + hangar = `The aircraft hanger is filled with the sparks and noise of mechanics performing routine maintenance, repairs, and upgrades to your fleet of vehicles.`; + aircraft = `The aircraft hulls are decorated with a variety of personalized pin-ups of stylized figures, most frequently barely-clothed or outright explicit images of women. As a joke, the pilots occasionally decorate guided missiles with inscriptions like "Catch!"`; + luxuries = `You also spot a wide variety of goods being sold here: from authentic bourbon and firearms to hand-sown and hand-tailored suits. Banners and flyers advertise classes in ballroom dancing, fencing, duelling, and even refined table manners.`; + perimeter = `Outside the Firebase gates, a imposing stone ediface stands between any would-be invader and the base. The walls are shaped like a star with five points and at each point is a bastion. All along the walls are emplaced precision-guidance artiliary pieces and firing positions for infantry and machine guns. The star-pointed design ensures the Firebase can fire upon invaders from any angle with overlapping fields of fire. With the collapse of most civilized fighting forces, the Firebase's fortifications present an imposing challenge to attackers.`; + roleplaying = `Your soldiers put in effort to carry themselves in a manner befitting of Southron gentlemen - that is, with dignity and pride. They identify first and foremost as cavalier soldiers of the South and are proud to have originated from a land of such chivalric and heroic tradition. In their personal dealings, they do their best to handle most affairs in English, but do not refrain from using dignified continental langauges such as French. They are true Southron men and women, and they strive to be distinquished for their warlike and fearless character as they are for their gallantry, honor, gentleness, and intellect. They proudly fight for the institution of slavery and feel that it is their god-given right to enslave lesser peoples.`; + colonel = `Antebellum Revivalism: Sometimes when The Colonel is relaxing or just making her rounds in the Firebase, you'll see her wearing her officer's uniform, long coat unbuttoned, revealing a loose, low-cut white blouse underneath tucked into her grey trousers. Her nipples poke through the sheer fabric. She keeps an entourage of slaves around her much of the time to relay orders or do chores for her; they make a fierce effort to not look down her shirt whenever she bends over. Significant effort has been made to adapt her battledress to the reality of modern warfare: her knee-length officer's coat and trousers are manufactured from a flexible, high-strength kevlar with additional inserts capable of stopping standard rifle cartridges.`; + break; case 'Multiculturalism': dec = `Multiculturalism: a commitment to allow your arcology's citizens cultural freedom.`; gift = `In anticipation of the impending global meltdown that doomsday preppers are currently preparing for all around the world, you've had a secret location installed in the arcology, created to match the essential specifications of a modern luxury 'doomsday' bunker. To guarantee The Colonel's survival and comfort in the event of an apocalyptic crisis, you've gone all out: You've carved out an underground formation far underneath the arcology's foundations to build her a private fallout shelter, complete with a secure communications center, her overseer bedroom and several private bedrooms & bathrooms, an artificial aquifer, an agricultural greenhouse, a gymnasium & swimming pool, a fireproof storeroom packed with years worth of dried rations & medical supplies, a stocked munitions room, and a sealed underground passageway leading back up to the surface. When she first entered the overseer bedroom, she found the various emergency survival tomes you've bought for her and her future fellow dwellers. She also saw the extraordinary modular HazMat suit you've had made to her exact measurements, for that special day when she will be ready to emerge from shelter and take on whatever is left of the world.`; diff --git a/src/arcologyBuilding/shops.js b/src/arcologyBuilding/shops.js index 952b0aad9ed65937d3db7ba8edce0ddd46b09555..52e4cb1731d8b06d2d985bb6cf520684ad5cb595 100644 --- a/src/arcologyBuilding/shops.js +++ b/src/arcologyBuilding/shops.js @@ -245,6 +245,13 @@ App.Arcology.Cell.Shop = class extends App.Arcology.Cell.BaseCell { : "and gives you a doubtful, questioning glance, politely asking whether you can join with credit to yourself, all without words. You nod and pick up the forms, having a basic familiarity with them. They're difficult, but you're able to get through the enjoyable exercise with credit." }`)); break; + case "Antebellum Revivalist": + fragment.append("dedicated to Antebellum Revivalism. Red brick and white staff buildings neatly line either side of the cobblestone boulevard here. Cupolas, painted in vivid colors, crown the occasional gable and brilliantly reflect natural light filtering through the arcology's walls. Printed on each shop's window are proud block letters that proclaim the highest quality of every imaginable type of goods, from home goods to the most perverted delights the Free Cities have to offer. The men, sporting canes or other sufficiently sophisticated attire, walk with dignity and convey a sense of mutual respect, if only for appearances. The scent of apple pie is wafting through the air from some unseen window.", + App.UI.DOM.linkReplace("Take a stroll", + "You take a stroll down the boulevard, absorbing the sights. As you pass, gentlemen tip their hats and give polite bows. The ladies, if not overcome by hysteria, cover their faces with their fans, or give low curtsies. Before long, you've been invited to a dozen balls and several galas, but must politely decline. You've got important business to attend to, or at least that's what you tell them, and move on."), + App.UI.DOM.linkReplace("Get a slice of pie", + "You follow that wonderful smell and, after a little ways, find a bakery tucked into a corner somewhere. Standing behind the counter is a beautiful older slave woman in a flour-stained apron. She politely greets you with a smile. An instant later, she recognizes who you are, and blushes a deep crimson. She nervously offers you to try anything in the store. She's already started to lift her apron when, having found the source of the smell, you help yourself to a slice of pie, flash a smile, and make your way out. This has got to be some of the best pie you've ever had.")); + break; case "Repopulationist": fragment.append(`dedicated to Repopulationism. The shops here offer a lovely mix of sex toys, fertility agents, maternity wear and furniture to fit even the biggest pregnancy. An attractive slave salesgirl with a huge belly is demonstrating the proper use of a swing designed to accommodate ${his} added heft to a female citizen just beginning to show and her curious husband. `, App.UI.DOM.linkReplace("Give the swing a try", diff --git a/src/cheats/cheatEditNeightbors.js b/src/cheats/cheatEditNeightbors.js index 0e8535a2deb410a3c3276dad3eb198b5a63aa5f8..74a96bd3809b59488312649252b018ffc43ae25a 100644 --- a/src/cheats/cheatEditNeightbors.js +++ b/src/cheats/cheatEditNeightbors.js @@ -23,7 +23,7 @@ App.UI.Cheat.neighbors = function() { ]; /** @type {FC.ArcologyState} */ const activeArcology = { - name: "Arcology X-", direction: compass.random(), government: govTypes.random(), honeymoon: 0, prosperity: 50, ownership: 50, minority: 20, PCminority: 0, demandFactor: 0, FSSupremacist: "unset", FSSupremacistRace: 0, FSSubjugationist: "unset", FSSubjugationistRace: 0, FSGenderRadicalist: "unset", FSGenderFundamentalist: "unset", FSPaternalist: "unset", FSDegradationist: "unset", FSIntellectualDependency: "unset", FSSlaveProfessionalism: "unset", FSBodyPurist: "unset", FSTransformationFetishist: "unset", FSYouthPreferentialist: "unset", FSMaturityPreferentialist: "unset", FSStatuesqueGlorification: "unset", FSPetiteAdmiration: "unset", FSSlimnessEnthusiast: "unset", FSAssetExpansionist: "unset", FSPastoralist: "unset", FSPhysicalIdealist: "unset", FSChattelReligionist: "unset", FSRomanRevivalist: "unset", FSAztecRevivalist: "unset", FSEgyptianRevivalist: "unset", FSEdoRevivalist: "unset", FSArabianRevivalist: "unset", FSChineseRevivalist: "unset", FSNull: "unset", FSRepopulationFocus: "unset", FSHedonisticDecadence: "unset", FSCummunism: "unset", FSIncestFetishist: "unset", FSRestart: "unset", embargo: 1, embargoTarget: -1, influenceTarget: -1, influenceBonus: 0, rival: 0 + name: "Arcology X-", direction: compass.random(), government: govTypes.random(), honeymoon: 0, prosperity: 50, ownership: 50, minority: 20, PCminority: 0, demandFactor: 0, FSSupremacist: "unset", FSSupremacistRace: 0, FSSubjugationist: "unset", FSSubjugationistRace: 0, FSGenderRadicalist: "unset", FSGenderFundamentalist: "unset", FSPaternalist: "unset", FSDegradationist: "unset", FSIntellectualDependency: "unset", FSSlaveProfessionalism: "unset", FSBodyPurist: "unset", FSTransformationFetishist: "unset", FSYouthPreferentialist: "unset", FSMaturityPreferentialist: "unset", FSStatuesqueGlorification: "unset", FSPetiteAdmiration: "unset", FSSlimnessEnthusiast: "unset", FSAssetExpansionist: "unset", FSPastoralist: "unset", FSPhysicalIdealist: "unset", FSChattelReligionist: "unset", FSRomanRevivalist: "unset", FSAztecRevivalist: "unset", FSEgyptianRevivalist: "unset", FSEdoRevivalist: "unset", FSArabianRevivalist: "unset", FSChineseRevivalist: "unset", FSAntebellumRevivalist: "unset", FSNull: "unset", FSRepopulationFocus: "unset", FSHedonisticDecadence: "unset", FSCummunism: "unset", FSIncestFetishist: "unset", FSRestart: "unset", embargo: 1, embargoTarget: -1, influenceTarget: -1, influenceBonus: 0, rival: 0 }; if (V.arcologies.length < 4) { diff --git a/src/data/backwardsCompatibility/backwardsCompatibility.js b/src/data/backwardsCompatibility/backwardsCompatibility.js index 033ec6041b41ae7f5d3da5637140dd411ab52abd..d13e4f1c23e937404d43a3ba573c1022da730504 100644 --- a/src/data/backwardsCompatibility/backwardsCompatibility.js +++ b/src/data/backwardsCompatibility/backwardsCompatibility.js @@ -561,6 +561,7 @@ App.Update.globalVariables = function(node) { FSEdoRevivalist: "unset", FSArabianRevivalist: "unset", FSChineseRevivalist: "unset", + FSAntebellumRevivalist: "unset", FSNull: "unset", FSRepopulationFocus: "unset", FSRestart: "unset", @@ -830,6 +831,18 @@ App.Update.globalVariables = function(node) { if ((typeof V.FSChineseRevivalistLaw !== "undefined") && V.FSChineseRevivalistLaw !== 0) { V.arcologies[0].FSChineseRevivalistLaw = V.FSChineseRevivalistLaw; } + if (typeof V.arcologies[0].FSAntebellumRevivalist === "undefined") { + V.arcologies[0].FSAntebellumRevivalist = "unset"; + } + if (typeof V.arcologies[0].FSAntebellumRevivalistSMR === "undefined") { + V.arcologies[0].FSAntebellumRevivalistSMR = 0; + } + if (typeof V.arcologies[0].FSAntebellumRevivalistLaw1 === "undefined") { + V.arcologies[0].FSAntebellumRevivalistLaw1 = 0; + } + if (typeof V.arcologies[0].FSAntebellumRevivalistLaw2 === "undefined") { + V.arcologies[0].FSAntebellumRevivalistLaw2 = 0; + } delete V.arcologies[0].FSNullLaw; if (V.arcologies[0].FSSubjugationist !== "unset" && !Number.isFinite(V.arcologies[0].FSSubjugationist)) { @@ -932,6 +945,10 @@ App.Update.globalVariables = function(node) { V.arcologies[0].FSAztecRevivalist = 10; App.UI.DOM.appendNewElement("div", node, `Fixed NaN FS value for FSAztecRevivalist`); } + if (V.arcologies[0].FSAntebellumRevivalist !== "unset" && !Number.isFinite(V.arcologies[0].FSAntebellumRevivalist)) { + V.arcologies[0].FSAntebellumRevivalist = 10; + App.UI.DOM.appendNewElement("div", node, `Fixed NaN FS value for FSAntebellumRevivalist`); + } if (V.arcologies[0].FSIntellectualDependency !== "unset" && !Number.isFinite(V.arcologies[0].FSIntellectualDependency)) { V.arcologies[0].FSIntellectualDependency = 10; App.UI.DOM.appendNewElement("div", node, `Fixed NaN FS value for FSIntellectualDependency`); diff --git a/src/descriptions/arcologyDescription.js b/src/descriptions/arcologyDescription.js index ae1fb8840058f67421a6b82af836d8ec0f08796e..210a76153e5adc438d74fd205cfa22cbaea101a5 100644 --- a/src/descriptions/arcologyDescription.js +++ b/src/descriptions/arcologyDescription.js @@ -137,8 +137,10 @@ App.Desc.playerArcology = function(lastElement) { buffer.push(`The entrances of the arcology are built of warm stone and crowded with the busy commerce of an Arabian revival.`); } else if (A.FSChineseRevivalistDecoration >= 100) { buffer.push(`The entrances of the arcology are guarded by bronze statues of traditional Chinese guardian spirits.`); + } else if (A.FSAntebellumRevivalistDecoration >= 100) { + buffer.push(`The entrances of the arcology are built of white stone, with hand-carved Corinthian columns, reminiscent of the grand plantations of old.`); } - + const {he: heP, his: hisP} = getPronouns(V.PC); let statue; if (V.PC.dick !== 0) { @@ -275,6 +277,9 @@ App.Desc.playerArcology = function(lastElement) { if (A.FSChineseRevivalistDecoration === 100) { buffer.push(`The central ${statue} figure is wearing the robes of an ancient Chinese ${V.PC.title === 1 ? "Emperor" : "Empress"}.`); } + if (A.FSAntebellumRevivalistDecoration === 100) { + buffer.push(`The central ${statue} figure rides a rearing horse, towering above bystanders. The figure is wearing an old-fashioned military uniform; ${heP} wields a saber in one hand, raised triumphantly towards the sky.`); + } return buffer.join(" "); } @@ -376,6 +381,8 @@ App.Desc.playerArcology = function(lastElement) { buffer.push(`Some are showing dramatic retellings of traditional Bedouin fables.`); } else if (A.FSChineseRevivalistDecoration >= 40) { buffer.push(`Some are showing ancient Chinese operas.`); + } else if (A.FSAntebellumRevivalistDecoration >= 40) { + buffer.push(`Some are showing films and media that demonstrate the inherent exceptionalism of America.`); } if (V.arcologyUpgrade.grid === 1) { buffer.push(`The programming is constantly updated to suit the individual viewer.`); @@ -675,6 +682,8 @@ App.Desc.playerArcology = function(lastElement) { buffer.push(`The central plaza is decorated to look like a thriving Arabian slave market.`); } else if (A.FSChineseRevivalistDecoration >= 60) { buffer.push(`The central plaza is constructed as a Chinese water market, with stalls set up to serve customers passing by on boats riding on shallow canals.`); + } else if (A.FSAntebellumRevivalistDecoration >= 60) { + buffer.push(`The central plaza is decorated to look like an enormous plantation garden, with elegant colonnades and hedgerows to direct foot traffic throughout the arcology. A paved square lies at the center with a platform for slave auctions.`); } return buffer.join(" "); } @@ -773,6 +782,8 @@ App.Desc.playerArcology = function(lastElement) { buffer.push(`Many are wearing beguiling harem girl outfits, and dance to set the little bells attached to the fabric jingling.`); } else if (A.FSChineseRevivalistDecoration >= 80) { buffer.push(`Many are wearing qipaos cut very short, and jostle and chatter in the throng that packs the plaza.`); + } else if (A.FSAntebellumRevivalistDecoration >= 80) { + buffer.push(`Many are wearing fine suits or lacy gowns, and carry themselves with an air of sophistication`); } if (A.FSGenderRadicalistDecoration >= 80) { if (A.FSGenderRadicalistResearch === 1) { @@ -904,6 +915,8 @@ App.Desc.playerArcology = function(lastElement) { buffer.push(`The throng packing the busy plaza must periodically give way before a new train of fresh slaves chained together at the neck, being led into the market by one of the arcology's many prosperous slavers.`); } else if (A.FSChineseRevivalistDecoration >= 80) { buffer.push(`The noise in the thriving open space is almost oppressive, with the sounds of drunken merriment, traditional music, and distant intercourse forming an omnipresent hum.`); + } else if (A.FSAntebellumRevivalistDecoration >= 80) { + buffer.push(`The sound of hushed gossip is just barely discernable over a waltz being played in some distant ballroom.`); } return buffer.join(" "); @@ -928,6 +941,12 @@ App.Desc.playerArcology = function(lastElement) { if (A.FSAztecRevivalistLaw === 1) { buffer.push(`Most citizens wear satin loincloths and cloaks, distinguished from those of slaves by the richness of their adornments.`); } + if (A.FSAntebellumRevivalistLaw1 === 1) { + buffer.push(`The law enshrining slave owners as the most vital members of your arcology has clearly gone to their heads; well-to-do citizens proudly walk by with a gaggle of slaves in tow. `); + } + if (A.FSAntebellumRevivalistLaw2 === 1) { + buffer.push(`On occasion, the subtle hint of a concealed holster can be seen on your citizenry.`); + } if (A.FSMaturityPreferentialistLaw === 1) { buffer.push(`Most citizens are at least middle-aged, and graying hair on a citizen is considered attractive here.`); } else if (A.FSYouthPreferentialistLaw === 1) { diff --git a/src/descriptions/officeDescription.js b/src/descriptions/officeDescription.js index 8e5555860bb5ada1a69fe814146bc5f4498272e3..867e5828a665201a0ff74c9df9315ffef04f3c42 100644 --- a/src/descriptions/officeDescription.js +++ b/src/descriptions/officeDescription.js @@ -321,6 +321,9 @@ App.Desc.officeDescription = function(lastElement) { case "chinese revivalist": r.push(`${heA}'s depicted wearing colorful silk robes; ${heA}'s pulled them open to flash ${hisA} lovely body.`); break; + case "antebellum revivalist": + r.push(`${heA}'s depicted in a low-cut lacy dress that draws attention to ${hisA} chest`); + break; case "supremacist": r.push(`${heA}'s depicted wearing the dress of an old world ${V.arcologies[0].FSSupremacistRace} noble ${womanA} and blowing a kiss in a sexy manner.`); break; diff --git a/src/endWeek/economics/arcmgmt.js b/src/endWeek/economics/arcmgmt.js index d5eeac94426dc7a92804c43d211acf9aed3b56ce..b91ad546909652c7bcdf4680ccc80876d5b2cea9 100644 --- a/src/endWeek/economics/arcmgmt.js +++ b/src/endWeek/economics/arcmgmt.js @@ -110,6 +110,12 @@ App.EndWeek.arcManagement = function() { if (V.arcologies[0].FSNeoImperialistLaw1 === 1) { r.push(`You can occasionally see an Imperial Knight in full, noble battle-dress coordinating groups of organized citizen's militias, dressed in uniform liveries. Your citizens take pride in their fighting abilities.`); } + if (V.arcologies[0].FSAntebellumRevivalistLaw1 === 1) { + r.push(`The law enshrining slave owners as vital members of your arcology has clearly gone to their heads; well-to-do citizens proudly strut by with a gaggle of slaves in tow. `); + } + if (V.arcologies[0].FSAntebellumRevivalistLaw2 === 1) { + r.push(`The citizenry organizes itself into numerous militias, each member proudly self-equipped and ready to defend their new home from any aggressor.`); + } if (V.arcologies[0].FSGenderRadicalistDecoration === 100) { r.push(`Every single one of the slaves is female by virtue of her fuckable asshole.`); } else if (V.arcologies[0].FSGenderFundamentalistSMR === 1) { @@ -968,6 +974,21 @@ App.EndWeek.arcManagement = function() { topClassP *= 1 + Math.trunc(Math.min(V.arcologies[0].FSNeoImperialist, 100) / 20) * 0.002; r.push(`Your new Imperium creates a staunchly hierarchical society, and while your elites and soldiers enjoy social prestige and luxury, the lower classes are often unhappy about being made to grovel.`); } + if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + FSScore += Math.min(V.arcologies[0].FSAntebellumRevivalist, 100); + slaveDemandU *= 1 + Math.trunc(Math.min(V.arcologies[0].FSAntebellumRevivalist, 100) / 20) * 0.075; + slaveDemandT *= 1 + Math.trunc(Math.min(V.arcologies[0].FSAntebellumRevivalist, 100) / 20) * 0.050; + welfareFS *= 1 + Math.trunc(Math.min(V.arcologies[0].FSAntebellumRevivalist, 100) / 20) * 0.05; + lowerClass += Math.trunc(Math.min(V.arcologies[0].FSAntebellumRevivalist, 100) / 20) * -15; + lowerClassP *= 1 + Math.trunc(Math.min(V.arcologies[0].FSAntebellumRevivalist, 100) / 20) * -0.004; + middleClass += Math.trunc(Math.min(V.arcologies[0].FSAntebellumRevivalist, 100) / 20) * 20; + middleClassP *= 1 + Math.trunc(Math.min(V.arcologies[0].FSAntebellumRevivalist, 100) / 20) * 0.005; + upperClass += Math.trunc(Math.min(V.arcologies[0].FSAntebellumRevivalist, 100) / 20) * 2.7; + upperClassP *= 1 + Math.trunc(Math.min(V.arcologies[0].FSAntebellumRevivalist, 100) / 20) * 0.001; + topClass += Math.trunc(Math.min(V.arcologies[0].FSAntebellumRevivalist, 100) / 20) * 0.025; + topClassP *= 1 + Math.trunc(Math.min(V.arcologies[0].FSAntebellumRevivalist, 100) / 20) * 0.001; + r.push(`Antebellum Revivalism prioritizes the wealthy while also encouraging a strong yeoman, or middle, class, but offers little assistance to the poor.`); + } if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { FSScore += Math.min(V.arcologies[0].FSEgyptianRevivalist, 100); slaveDemandU *= 1 + Math.trunc(Math.min(V.arcologies[0].FSEgyptianRevivalist, 100) / 20) * 0.02; @@ -1365,6 +1386,13 @@ App.EndWeek.arcManagement = function() { upperClass += -13.5; upperClassP *= 0.995; } + + if (V.arcologies[0].FSAntebellumRevivalistLaw1 === 1) { + middleClassP *= 1.50; + upperClassP *= 1.25; + topClassP *= 1.10; + } + if (r.length > 0) { App.UI.DOM.appendNewElement("h3", el, "Policies"); } diff --git a/src/endWeek/economics/fsDevelopments.js b/src/endWeek/economics/fsDevelopments.js index 8a9609099e1bb2a8e096f8772e20f43385434384..0f7bd6c401a2a765b41092e4c07ff3e58f328808 100644 --- a/src/endWeek/economics/fsDevelopments.js +++ b/src/endWeek/economics/fsDevelopments.js @@ -281,7 +281,7 @@ App.EndWeek.FSDevelopments = function() { arc.FSRepopulationFocusInterest--; } - if ([arc.FSSupremacistSMR, arc.FSSubjugationistSMR, arc.FSGenderFundamentalistSMR, arc.FSPaternalistSMR, arc.FSDegradationistSMR, arc.FSBodyPuristSMR, arc.FSTransformationFetishistSMR, arc.FSYouthPreferentialistSMR, arc.FSMaturityPreferentialistSMR, arc.FSSlimnessEnthusiastSMR, arc.FSAssetExpansionistSMR, arc.FSPastoralistSMR, arc.FSPhysicalIdealistSMR, arc.FSChattelReligionistSMR, arc.FSRomanRevivalistSMR, arc.FSAztecRevivalistSMR, arc.FSEgyptianRevivalistSMR, arc.FSEdoRevivalistSMR, arc.FSRepopulationFocusSMR, arc.FSRestartSMR, arc.FSHedonisticDecadenceSMR, arc.FSIntellectualDependencySMR, arc.FSSlaveProfessionalismSMR, arc.FSPetiteAdmirationSMR, arc.FSStatuesqueGlorificationSMR, arc.FSArabianRevivalistSMR, arc.FSChineseRevivalistSMR, arc.FSNeoImperialistSMR, arc.FSGenderRadicalistSMR].some((SMR) => SMR > 0)) { // RadicalistSMR was unused since vanilla, but maybe some day.... + if ([arc.FSSupremacistSMR, arc.FSSubjugationistSMR, arc.FSGenderFundamentalistSMR, arc.FSPaternalistSMR, arc.FSDegradationistSMR, arc.FSBodyPuristSMR, arc.FSTransformationFetishistSMR, arc.FSYouthPreferentialistSMR, arc.FSMaturityPreferentialistSMR, arc.FSSlimnessEnthusiastSMR, arc.FSAssetExpansionistSMR, arc.FSPastoralistSMR, arc.FSPhysicalIdealistSMR, arc.FSChattelReligionistSMR, arc.FSRomanRevivalistSMR, arc.FSAztecRevivalistSMR, arc.FSEgyptianRevivalistSMR, arc.FSEdoRevivalistSMR, arc.FSRepopulationFocusSMR, arc.FSRestartSMR, arc.FSHedonisticDecadenceSMR, arc.FSIntellectualDependencySMR, arc.FSSlaveProfessionalismSMR, arc.FSPetiteAdmirationSMR, arc.FSStatuesqueGlorificationSMR, arc.FSArabianRevivalistSMR, arc.FSChineseRevivalistSMR, arc.FSNeoImperialistSMR, arc.FSAntebellumRevivalistSMR, arc.FSGenderRadicalistSMR].some((SMR) => SMR > 0)) { // RadicalistSMR was unused since vanilla, but maybe some day.... r.push(`The slave market regulations help ensure the arcology's slaves fit within its society.`); } diff --git a/src/endWeek/economics/neighborsDevelopment.js b/src/endWeek/economics/neighborsDevelopment.js index 3e97621a7646f96a23bfe81c5ea222d098c84c15..56f7de056e53bb2f36c1348ce77ff69045c81ea8 100644 --- a/src/endWeek/economics/neighborsDevelopment.js +++ b/src/endWeek/economics/neighborsDevelopment.js @@ -1396,6 +1396,29 @@ App.EndWeek.neighborsDevelopment = function() { } } } + } else if (arc.FSAntebellumRevivalist !== "unset") { + r.push(passive.output("FSAntebellumRevivalist")); + if (arc.direction !== 0) { + if (arc.FSAntebellumRevivalist >= V.FSLockinLevel) { + if ((arc.name.indexOf("Arcology") !== -1) && (random(0, 2) === 0)) { + r.push(`Antebellum Revivalism has reached stability and acceptance there. The arcology has been renamed`); + arc.name = App.Neighbor.getUnusedName(App.Data.ArcologyNames.AntebellumRevivalist); + r.push(`<span class="bold">${arc.name}</span> to mark the occasion.`); + } + } else if (arc.FSAntebellumRevivalist < 0) { + r.push(`${arc.name} <span class="cyan">has given up</span> on Antebellum Revivalism.`); + arc.FSAntebellumRevivalist = "unset"; + } + } + if (arc.FSAntebellumRevivalist !== "unset") { + if (V.corp.Incorporated === 1) { + if (V.corp.SpecEducation > 0) { + r.push(`It's a <span class="lightgreen">good market</span> for your corporation's properly educated slaves.`); + arc.FSAntebellumRevivalist += 1; + App.Corporate.earnRevenue(corpBonus, 'foreign'); + } + } + } } FutureSocieties.overflowToInfluence(i); @@ -1769,6 +1792,10 @@ App.EndWeek.neighborsDevelopment = function() { r.push(`${desc} fascinated by classical Roman history, leading the arcology to <span class="yellow">adopt Roman Revivalism.</span>`); adoptRivalFS("FSRomanRevivalist"); return; + case "Antebellum Revivalism": + r.push(`${desc} fascinated by ancient Aztec history, leading the arcology to <span class="yellow">adopt Aztec Revivalism.</span>`); + adoptRivalFS("FSAztecRevivalist"); + return; default: delete V.rival.FS.adopted; } @@ -1920,7 +1947,7 @@ App.EndWeek.neighborsDevelopment = function() { return; } } - if (V.arcologies[0].FSRomanRevivalist > random(5, 60)) { + if (V.arcologies[0].FSRomanRevivalist > random(5, 60) || V.arcologies[0].FSAntebellumRevivalist > random(5, 60)) { if (validFSes.includes("FSAztecRevivalist")) { r.push(`${desc} fascinated by ancient Aztec history, leading the arcology to <span class="yellow">adopt Aztec Revivalism.</span>`); arc.FSAztecRevivalist = 5; @@ -2063,6 +2090,8 @@ App.EndWeek.neighborsDevelopment = function() { candidates.push({fs: "FSEdoRevivalist", msg: `since ${he}'s Japanese ${himself} and can claim high honor in such a society.`}); } else if (leader.nationality === "Mexican") { candidates.push({fs: "FSAztecRevivalist", msg: `since ${he}'s Mexican ${himself} and can claim high honor in such a society.`}); + } else if (leader.nationality === "American") { + candidates.push({fs: "FSAntebellumRevivalist", msg: `since ${he}'s American ${himself} and can claim high honor in such a society.`}); } else if (leader.nationality === "Egyptian") { candidates.push({fs: "FSEgyptianRevivalist", msg: `since ${he}'s Egyptian ${himself} and wants to relive the glory of the Pharaohs.`}); } else if (["German", "French", "Spanish", "English"].includes(leader.nationality)) { @@ -2101,7 +2130,11 @@ App.EndWeek.neighborsDevelopment = function() { { fs: "FSEgyptianRevivalist", msg: `The arcology's racial Subjugationist culture <span class="yellow">pushes it towards Egyptian Revivalism,</span> since the Ancient Egyptians are famous for keeping a race of slaves.` - } + }, + { + fs: "FSAntebellumRevivalist", + msg: `The arcology's racial Subjugationist culture <span class="yellow">pushes it towards Antebellum Revivalism,</span> since the Antebellum South was famous for keeping a race of slaves.` + }, ] ]], ["FSSupremacist", [ @@ -2119,7 +2152,12 @@ App.EndWeek.neighborsDevelopment = function() { fs: "FSChineseRevivalist", prereqs: () => arc.FSSupremacistRace === "asian", msg: `The arcology's racial Supremacist culture <span class="yellow">pushes it towards Chinese Revivalism,</span> since the wisdom of the Middle Kingdom is admired there.` - } + }, + { + fs: "FSAntebellumRevivalist", + prereqs: () => arc.FSSupremacistRace === "white", + msg: `The arcology's racial Supremacist culture <span class="yellow">pushes it towards Antebellum Revivalism,</span> since the genteel and chivalric ways of the Antebellum period are admired there.` + }, ] ]], ["FSRepopulationFocus", [ @@ -2478,6 +2516,16 @@ App.EndWeek.neighborsDevelopment = function() { msg: `The arcology's Chinese Revivalist culture <span class="yellow">pushes it towards Paternalism,</span> since traditional beliefs about duty and order have become accepted.` }, ]], + ["FSAntebellumRevivalist", [ + { + fs: "FSSlaveProfessionalism", + msg: `The arcology's Antebellum Revivalist culture <span class = "yellow">pushes it towards Slave Professionalism,</span> since educated, affable, and entertaining slaves are fashionable amongst the gentry there.` + }, + { + fs: "FSPaternalist", + msg: `The arcology's Antebellum Revivalist culture <span class = "yellow">pushes it towards Paternalism,</span> out of a belief that rebellious and hateful slaves reflect poorly on their master.` + }, + ]] ]); const validChoice = /** @param {crossFSDest} dest */ (dest) => validFSes.includes(dest.fs) && (!dest.prereqs || dest.prereqs()); const candidates = []; @@ -2751,6 +2799,10 @@ App.EndWeek.neighborsDevelopment = function() { r.push(`${desc} fascinated by the long rule of ancient European monarchs, leading the arcology to <span class="yellow">adopt Neo-Imperialism.</span>`); arc.FSNeoImperialist = 5; return; + case "FSAntebellumRevivalist": + r.push(`${desc} convinced of American exceptionalism and the romance of the Antebellum era, leading the arcology to <span class="yellow">adopt Antebellum Revivalism.</span>`); + arc.FSAntebellumRevivalist = 5; + return; } } diff --git a/src/endWeek/economics/persBusiness.js b/src/endWeek/economics/persBusiness.js index f7ec3e8407727ce3d5f7a50e15549a152a0ec83c..a1161fb2bb9265da3d4432f831c51cb2d80a8e6b 100644 --- a/src/endWeek/economics/persBusiness.js +++ b/src/endWeek/economics/persBusiness.js @@ -1689,6 +1689,10 @@ App.EndWeek.personalBusiness = function() { qualifiedFS.push("chinese law"); } else if (V.arcologies[0].FSChineseRevivalistDecoration >= 80) { qualifiedFS.push("chinese"); + } else if (V.arcologies[0].FSAntebellumRevivalistLaw1 === 1) { + qualifiedFS.push("southron law"); + } else if (V.arcologies[0].FSAntebellumRevivalistDecoration >= 80) { + qualifiedFS.push("southron"); } let caught = 0; if (V.rep >= 18000) { /* prestigious */ @@ -1863,6 +1867,14 @@ App.EndWeek.personalBusiness = function() { income += random(1500, 2500); r.push(`Being under what people call the Mandate of Heaven means you have a crucial importance in society, and some desperate people are willing to pay just for you to throw a word or small gesture in their direction, such as simply acknowledging a child or a slave, thinking that such things will make sure the Heavens smile upon them. For these services, you get <span class="yellowgreen">${cashFormat(income)}.</span>`); break; + case "southron law": + income += random(2000, 3000); + r.push(`Since enshrining the role of slaveowners in your arcology's society, the most prominent slaveowners in your arcology grew into important figures who command significant wealth and a modicum of power. In an act of respect, they give you a tribute of <span class="yellowgreen">${cashFormat(income)}</span> `); + break; + case "southron": + income += random(1500, 2500); + r.push(`The popularity of citizen-hosted formal events such as balls and galas have skyrocketed since embracing the Antebellum era. These events are used as opportunities to advance social standing through displays of obscene opulence, parading around well-trained slaves, and the attendance of prestigious guests. As owner of the arcology, you are the most prestigious guest of all and frequently receive 'gifts' encouraging your attendance. You received <span class="yellowgreen">${cashFormat(income)} this week.</span>`); + break; default: income += random(500, 2000); r.push(`You use former contacts to get you some opportunities in your arcology and deal with them. You make little money, only <span class="yellowgreen">${cashFormat(income)}.</span>`); diff --git a/src/endWeek/economics/reputation.js b/src/endWeek/economics/reputation.js index c0d5ab2cedab09ebb578f7f1d5de3e1911cda954..7840d27f4c0e66d7a99cd88efd84daeecb75d5d6 100644 --- a/src/endWeek/economics/reputation.js +++ b/src/endWeek/economics/reputation.js @@ -726,6 +726,79 @@ App.EndWeek.reputation = function() { r.push(`Continuing to use ${V.language} as the lingua franca of ${V.arcologies[0].name} rather than the Chinese of the Middle Kingdom <span class="red">disappoints</span> society and causes doubt about your revivalist project.`); FutureSocieties.Change("Chinese Revivalist", -2); } + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + if (App.Entity.facilities.servantsQuarters.totalEmployeesCount < Math.round(V.rep / 2000)) { + r.push(`Society <span class="red">disapproves</span> of your lack of maids and servants, ill-befitting of a supposed Southron aristocrat.`); + FutureSocieties.Change("Antebellum Revivalist", -2); + } else { + r.push(`Society <span class="green">approves</span> of the number of domestic workers you keep.`); + FutureSocieties.Change("Antebellum Revivalist", 2); + } + if (V.language !== "English") { + r.push(`Continuing to use ${V.language} as the lingua franca of ${V.arcologies[0].name} rather than pure American English <span class="red">disappoints</span> society and causes doubt about your revivalist project.`); + FutureSocieties.Change("Antebellum Revivalist", -2); + } + if (V.arcologies[0].FSSubjugationist !== "unset") { + r.push(`Society <span class="green">approves</span> of embracing both Antebellum Revivalism and Subjugationism.`); + FutureSocieties.Change("Antebellum Revivalist", 1); + FutureSocieties.Change("Subjugationist", 1); + } + if (V.arcologies[0].FSSupremacist !== "unset") { + r.push(`Society <span class="green">approves</span> of embracing both Antebellum Revivalism and Supremacism.`); + FutureSocieties.Change("Antebellum Revivalist", 1); + FutureSocieties.Change("Supremacist", 1); + } + + // 200 is probably a bit ridiculous side, but might as well give a fun little reward for it + if (V.slaves.length >= 200) { + r.push(`Society is in <span class="green">awe</span> with the sheer size of your stable of slaves.`); + FutureSocieties.Change("Antebellum Revivalist", 25); + } else if (V.slaves.length >= 100) { + r.push(`Society is <span class="green">impressed</span> with the number of slaves you own.`); + FutureSocieties.Change("Antebellum Revivalist", 10); + } else if (V.slaves.length >= 50) { + r.push(`Society holds <span class="green">great respect</span> for the number of slaves you own.`); + FutureSocieties.Change("Antebellum Revivalist", 5); + } else if (V.slaves.length >= 25) { + r.push(`Society <span class="green">approves</span> of the number of slaves you own.`); + FutureSocieties.Change("Antebellum Revivalist", 3); + } else if (V.slaves.length >= 10) { + r.push(`Society <span class="green">slightly approves</span> of the number of slaves you own.`); + FutureSocieties.Change("Antebellum Revivalist", 1); + } else if (V.slaves.length >= 5) { + r.push(`Society neither approves or disapproves of the size of your stable of slaves, but would respectively approve or disapprove if it grew or shrank.`); + } else { + r.push(`Society finds it <span class="green">strange</span> for someone of your stature to own so few slaves.`); + FutureSocieties.Change("Antebellum Revivalist", -1); + } + + if (V.PC.skill.slaving >= 100) { + r.push(`Society at large is <span class="green">envious</span> of your immense skill and talent at slaving.`); + FutureSocieties.Change("Antebellum Revivalist", 4); + } else if (V.PC.skill.slaving >= 80) { + r.push(`Society <span class="green">admires</span> expert slavers such as yourself.`); + FutureSocieties.Change("Antebellum Revivalist", 3); + } else if (V.PC.skill.slaving >= 60) { + r.push(`Society <span class="green">appreciates</span> skilled slavers such as yourself.`); + FutureSocieties.Change("Antebellum Revivalist", 2); + } else if (V.PC.skill.slaving >= 40) { + r.push(`Society <span class="green">respects</span> competent slavers such as yourself.`); + FutureSocieties.Change("Antebellum Revivalist", 1); + } else if (V.PC.skill.slaving >= 20) { + r.push(`Society would prefer you were a better slaver, but it isn't perceived as a great dishonor either.`); + } else if (V.PC.skill.slaving >= 0) { + r.push(`Society is <span class="red">disappointed</span> about your lack of knowledge on slaving.`); + FutureSocieties.Change("Antebellum Revivalist", -1); + } else if (V.PC.skill.slaving >= -40) { + r.push(`Society <span class="red">dislikes</span> your ignorance of slaving.`); + FutureSocieties.Change("Antebellum Revivalist", -2); + } else if (V.PC.skill.slaving >= -80) { + r.push(`Society experiences <span class="red">secondhand embarrassment</span> when it witnesses your talent as a slaver.`); + FutureSocieties.Change("Antebellum Revivalist", -3); + } else { + r.push(`Society is <span class="red">shocked and amused</span> that you are such a bungling slaver.`); + FutureSocieties.Change("Antebellum Revivalist", -4); + } } let noEugenics; diff --git a/src/endWeek/reports/clinicReport.js b/src/endWeek/reports/clinicReport.js index c8c53acf6c2866239846f5981f5dba82453ed83f..494deabe0199025f11cb7900970d6b334f048ef3 100644 --- a/src/endWeek/reports/clinicReport.js +++ b/src/endWeek/reports/clinicReport.js @@ -322,6 +322,7 @@ App.EndWeek.clinicReport = function() { case "Edo Revivalist": case "Egyptian Revivalist": case "Roman Revivalist": + case "Antebellum Revivalist": slave.rules.living = "normal"; break; default: diff --git a/src/endWeek/saChoosesOwnClothes.js b/src/endWeek/saChoosesOwnClothes.js index d82d70518886c64e8f0c7882e6b232cba504f74f..169954d1deb64cc6713f7cd8d660202718c1ecf1 100644 --- a/src/endWeek/saChoosesOwnClothes.js +++ b/src/endWeek/saChoosesOwnClothes.js @@ -128,6 +128,9 @@ App.SlaveAssignment.choosesOwnClothes = function saChoosesOwnClothes(slave) { case "FSChineseRevivalist": text = `${he} commonly sees others wearing qipaos and is drawn to doing so ${himself}.`; break; + case "FSAntebellumRevivalist": + text = `${he} commonly sees others wearing formal wear such as ball gowns or evening dresses and is drawn to doing so ${himself}.`; + break; case "FSGenderFundamentalist": text = `${he} commonly sees cheerleaders and bunnies around and instinctively follows along.`; break; @@ -264,6 +267,9 @@ App.SlaveAssignment.choosesOwnClothes = function saChoosesOwnClothes(slave) { if (isItemAccessible.entry("a mounty outfit") === true) { wardrobeAssignment.push({text: `and wears a mounty outfit to give ${him} that extra touch of authority.`, clothes: "a mounty outfit"}); } + if (isItemAccessible.entry("an evening dress") === true) { + wardrobeAssignment.push({text: `and wears an evening dress to give ${him} both a touch of feminine authority and sensuality.`, clothes: "an evening dress"}); + } if (isItemAccessible.entry("nice business attire") === true) { wardrobeAssignment.push({text: `and wears a handsome suit to give ${him} that extra touch of authority.`, clothes: "nice business attire"}); } @@ -306,6 +312,9 @@ App.SlaveAssignment.choosesOwnClothes = function saChoosesOwnClothes(slave) { if (isItemAccessible.entry("a red army uniform") === true) { wardrobeAssignment.push({text: `and wears a red army uniform to look even more brutal and authoritative.`, clothes: "a red army uniform"}); } + if (isItemAccessible.entry("a confederate army uniform") === true) { + wardrobeAssignment.push({text: `and wears a confederate army uniform to look even more brutal and authoritative.`, clothes: "a confederate army uniform"}); + } if (isItemAccessible.entry("stretch pants and a crop-top") === true) { wardrobeAssignment.push({text: `and decides to take it easy by slipping into some stretch pants. They come off just as quickly as they come on, just in case.`, clothes: "stretch pants and a crop-top"}); } @@ -369,6 +378,9 @@ App.SlaveAssignment.choosesOwnClothes = function saChoosesOwnClothes(slave) { if (isItemAccessible.entry("a red army uniform") === true) { wardrobeAssignment.push({text: `and wears a red army uniform to look the part of the honor guard.`, clothes: "a red army uniform"}); } + if (isItemAccessible.entry("a confederate army uniform") === true) { + wardrobeAssignment.push({text: `and wears a Confederate army uniform to look the part of the honor guard.`, clothes: "a confederate army uniform"}); + } if (isItemAccessible.entry("nice business attire") === true) { wardrobeAssignment.push({text: `and wears a nice suit to make it clear you mean business.`, clothes: "nice business attire"}); } @@ -393,6 +405,9 @@ App.SlaveAssignment.choosesOwnClothes = function saChoosesOwnClothes(slave) { if (isItemAccessible.entry("a ball gown") === true) { wardrobeAssignment.push({text: `and wears an opulent gown to showcase your wealth before those desperately seeking a better life.`, clothes: "a ball gown"}); } + if (isItemAccessible.entry("an evening dress") === true) { + wardrobeAssignment.push({text: `and wears a nice evening dress to appear more sophisticated and sexy before those desperately seeking a better life.`, clothes: "an evening dress"}); + } wardrobeAssignment.push({text: `and dresses as a succubus to attempt to lure any potential catches.`, clothes: "a succubus outfit"}); if (isItemAccessible.entry("harem gauze") === true) { wardrobeAssignment.push({text: `and dons ${his} finest silks to showcase the luxuries waiting would-be slaves.`, clothes: "harem gauze"}); @@ -516,6 +531,9 @@ App.SlaveAssignment.choosesOwnClothes = function saChoosesOwnClothes(slave) { wardrobeFS.push({text: `and wears a long qipao to show off and look Chinese at the same time.`, clothes: "a long qipao"}); } else if (V.arcologies[0].FSAztecRevivalist > 0) { wardrobeFS.push({text: `and drapes a huipil over ${himself} to fit in with your Aztec revivalism.`, clothes: "a huipil"}); + } else if (V.arcologies[0].FSAntebellumRevivalist > 0) { + wardrobeFS.push({text: `and wears a fine ball gown to take part in Antebellum revivalism.`, clothes: "a ball gown"}); + wardrobeFS.push({text: `and wears a classy evening dress to take part in Antebellum revivalism.`, clothes: "an evening dress"}); } if (V.arcologies[0].FSGenderFundamentalist > 0) { wardrobeFS.push({text: `and wears a schoolgirl outfit to look like a hot slut.`, clothes: "a schoolgirl outfit"}); @@ -578,6 +596,9 @@ App.SlaveAssignment.choosesOwnClothes = function saChoosesOwnClothes(slave) { wardrobeFS.push({text: `and wears a formal suit to look like the ideal older woman.`, clothes: "nice business attire"}); } wardrobeFS.push({text: `and wears a slutty suit to look like the ideal horny older woman.`, clothes: "slutty business attire"}); + if (isItemAccessible.entry("an evening dress") === true) { + wardrobeFS.push({text: `and wears a sensual yet mature evening dress to look like the ideal horny older woman.`, clothes: "an evening dress"}); + } wardrobeFS.push({text: `and wears only an apron to make ${himself} seem more matronly.`, clothes: "an apron"}); } else { if (isItemAccessible.entry("nice business attire") === true) { @@ -586,6 +607,9 @@ App.SlaveAssignment.choosesOwnClothes = function saChoosesOwnClothes(slave) { if (isItemAccessible.entry("a Santa dress") === true) { wardrobeFS.push({text: `and wears a dress referencing a figure of advanced age.`, clothes: "a Santa dress"}); } + if (isItemAccessible.entry("an evening dress") === true) { + wardrobeFS.push({text: `and wears a sensual yet mature evening dress in the hopes some of it rubs off on ${him}.`, clothes: "an evening dress"}); + } wardrobeFS.push({text: `and wears only an apron in an attempt to make ${himself} seem more matronly.`, clothes: "an apron"}); } } else if (V.arcologies[0].FSYouthPreferentialist > 0) { @@ -768,6 +792,9 @@ App.SlaveAssignment.choosesOwnClothes = function saChoosesOwnClothes(slave) { if (isItemAccessible.entry("a ball gown") === true) { wardrobeTastes.push({text: `and chooses a formal dress that makes ${him} feel like royalty.`, clothes: "a ball gown"}); } + if (isItemAccessible.entry("an evening dress") === true) { + wardrobeTastes.push({text: `and chooses a formal dress that makes ${him} feel like a celebrity.`, clothes: "an evening dress"}); + } } else if (slave.behavioralFlaw === "devout") { wardrobeTastes.push({text: `and wears something more appropriate for a monastery than a whorehouse.`, clothes: "a penitent nuns habit"}); if (isItemAccessible.entry("a burqa") === true) { @@ -801,6 +828,9 @@ App.SlaveAssignment.choosesOwnClothes = function saChoosesOwnClothes(slave) { if (isItemAccessible.entry("a halter top dress") === true) { wardrobeTastes.push({text: `and dresses up like ${he}'s about to go on a date.`, clothes: "a halter top dress"}); } + if (isItemAccessible.entry("an evening dress") === true) { + wardrobeTastes.push({text: `and dresses in a sexy thigh cut dress. `, clothes: "an evening dress"}); + } } else if (slave.sexualQuirk === "tease") { if (isItemAccessible.entry("kitty lingerie") === true) { wardrobeTastes.push({text: `and wears a set of provocatively designed lingerie.`, clothes: "kitty lingerie"}); diff --git a/src/endWeek/saRecruitGirls.js b/src/endWeek/saRecruitGirls.js index 998c8d2c6b269849ce0d8f7a3c4886866fb0a84a..6c35a797471133a689b4b3a734ef9f68c4c82ee0 100644 --- a/src/endWeek/saRecruitGirls.js +++ b/src/endWeek/saRecruitGirls.js @@ -695,6 +695,20 @@ App.SlaveAssignment.recruitGirls = function recruitGirls(slave) { } targetArcology.FSChineseRevivalist += influence; } + } else if (arcology.FSAntebellumRevivalist !== "unset") { + if (targetArcology.FSAntebellumRevivalist !== "unset") { + r.push(`${He} advances Antebellum Revivalism there by helping citizens make their slaves more convivial and entertaining,`); + if (slave.skill.entertainment > 95) { + r.push(`which ${he}'s perfect for, since ${he} is quite the entertainer ${himself}.`); + targetArcology.FSAntebellumRevivalist++; + } else if (slave.behavioralQuirk === "funny") { + r.push(`which ${he}'s perfect for, since ${he} has a good sense of humor.`); + targetArcology.FSAntebellumRevivalist++; + } else { + r.push(`but ${his} performance does leave something to be desired.`); + } + targetArcology.FSAntebellumRevivalist += influence; + } } } else { r.push(`assigned to be a sexual Ambassador to other arcologies, but you have not targeted a neighboring arcology for cultural influence, making the assignment pointless.`); @@ -1647,6 +1661,26 @@ App.SlaveAssignment.recruitGirls = function recruitGirls(slave) { } else { pushFS(`${His} poor attempts to espouse the benefits of true faith leave the crowd wondering if ${he} is next in line for sacrifice.`); } + } else if (arcology.FSAntebellumRevivalist !== "unset") { + if (slave.skill.entertainer > 95 && App.Entity.facilities.servantsQuarters.employeesIDs().size > 5 && (slave.behavioralQuirk === "funny" || totalInt > 50)) { + pushFS(`${He} puts together a charming little video touring your spotless estate, showing particular care to the well-staffed ${V.servantsQuartersName}.`); + if (V.servantsQuartersDecoration === "Arabian Revivalist") { + pushFS(`The decor really impresses the viewers.`); + seed += 1; + } + pushFS(`Altogether, it really sells the idea that you are an authentic, Southern aristocrat.`); + FSmatch++; + seed += 5; + arcology.FSAntebellumRevivalist += 0.02 * V.FSSingleSlaveRep; + } else if (V.slaves.length < 10) { + pushFS(`${He} wants to show-off your Penthouse to try and garner interest, but can't hide just how empty it is on camera.`); + } else if (V.servantsQuarters === 0) { + pushFS(`${He} doesn't feel right selling the idea of Southern hospitality without a stable of servants to cater to any would-be visitors.`); + } else if (App.Entity.facilities.servantsQuarters.employeesIDs().size <= 1) { + pushFS(`${He} worries she might embarrass you if ${he} inadvertently let slip how few servants you have.`); + } else { + pushFS(`${He} can't seem create anything entertaining enough that really sells the idea of your household.`) + } } const pMod = App.SlaveAssignment.PartTime.efficiencyModifier(slave); diff --git a/src/endWeek/saRules.js b/src/endWeek/saRules.js index 673579c6180cba2948ebb9705932c0d5fcccede4..f98145dffa352f86d42f5981ce9c6d5edcf3ca31 100644 --- a/src/endWeek/saRules.js +++ b/src/endWeek/saRules.js @@ -677,6 +677,10 @@ App.SlaveAssignment.rules = function(slave) { slave.trust += 2; slave.devotion += 1; break; + case "Antebellum Revivalist": + r.push(`The living conditions, despite their simple nature, are peaceful and quite ${him} <span class="mediumaquamarine">calming</span>.`) + slave.trust += 2; + break; case "Edo Revivalist": r.push(`The living conditions, despite their spartan nature, are <span class="mediumaquamarine">calming.</span> ${His} opinion of you <span class="hotpink">improves</span> with such a contrast to ${his} usual life.`); slave.trust += 1; @@ -725,6 +729,10 @@ App.SlaveAssignment.rules = function(slave) { r.push(`The living conditions, despite their spartan nature, are <span class="mediumaquamarine">calming.</span> ${He} enjoys ${his} stay at ${V.clinicName}.`); slave.trust += 1; break; + case "Antebellum Revivalist": + r.push(`All the fresh air is <span class="health inc">good for ${his} health.</span> ${He} appreciates ${his} stay at ${V.clinicName}.`); + slave.health.condition += 1; + break; case "standard": if (slave.trust > 40) { r.push(`The spare living conditions of ${V.clinicName} <span class="gold">remind ${him} not to get too comfortable</span> with ${his} life.`); @@ -950,6 +958,7 @@ App.SlaveAssignment.rules = function(slave) { r.push(App.EndWeek.Rules.speechRules(slave)); switch (V.cellblockDecoration) { + case "Antebellum Revivalist": case "Degradationist": r.push(`${He} expected spare living conditions. In reality, they are far worse. <span class="gold">Not one moment goes by that ${he} isn't filled with terror.</span>`); slave.trust -= 3; @@ -1103,6 +1112,10 @@ App.SlaveAssignment.rules = function(slave) { r.push(`The steam of the bathhouse lingers even in ${his} personal room and <span class="hotpink">dulls ${his} will.</span>`); slave.devotion += 1; break; + case "Antebellum Revivalist": + r.push(`The thick air of the greenhouse brings ${his} a deep, if temporary, class="mediumaquamarine">calm.</span>`); + slave.trust += 2; + break; case "Chattel Religionist": r.push(`${He} gets a space of ${his} own in the communal slave quarters, but the constant sexual presence of the other slaves <span class="hotpink">get ${him} used</span> to the routine of`); if (slave.trust > 20) { @@ -1143,6 +1156,10 @@ App.SlaveAssignment.rules = function(slave) { r.push(`The steam of the bathhouse lingers even in ${his} personal room and <span class="hotpink">renders ${him} even more submissive.</span>`); slave.devotion += 1; break; + case "Antebellum Revivalist": + r.push(`The thick air of the greenhouse brings ${his} a deeper, more serene, class="mediumaquamarine">calm.</span> now that ${his} mind is free from doubts about being your slave.`); + slave.trust += 4; + break; case "Chattel Religionist": r.push(`${He} likes ${his} personal space in ${V.spaName}, even if`); if (canSmell(slave)) { @@ -1673,6 +1690,7 @@ App.SlaveAssignment.rules = function(slave) { break; case "Subjugationist": case "Supremacist": + case "Antebellum Revivalist": r.push(`The spare living conditions <span class="hotpink">get ${him} used</span> to the routine of`); if (slave.trust > 20) { r.push(`slavery and <span class="gold">keep ${him} aware of ${his} lowly place.</span>`); @@ -1719,6 +1737,7 @@ App.SlaveAssignment.rules = function(slave) { break; case "Subjugationist": case "Supremacist": + case "Antebellum Revivalist": if (slave.trust > 40) { r.push(`The spare living conditions of ${V.servantsQuartersName} <span class="gold">remind ${him} not to get too comfortable</span> with ${his} life.`); slave.trust -= 2; @@ -1958,6 +1977,7 @@ App.SlaveAssignment.rules = function(slave) { case "Egyptian Revivalist": case "Roman Revivalist": case "Neo-Imperialist": + case "Antebellum Revivalist": r.push(`The spare living conditions and daily tasks <span class="hotpink">get ${him} used</span> to the routine of slavery.`); slave.devotion += 1; break; @@ -2040,6 +2060,10 @@ App.SlaveAssignment.rules = function(slave) { r.push(`The living conditions of ${V.dairyName} might be spare, but they are by no means meant to be uncomfortable.`); adequateConditions = 1; break; + case "Antebellum Revivalist": + r.push(`${He} likes ${his} personal space in ${V.dairyName}'s dormitory, even if it's like a barn stall.`); + adequateConditions = 1; + break; default: r.push(`${He} likes ${his} personal space in ${V.dairyName}'s dormitory, even if it's just a stall.`); } @@ -2246,6 +2270,7 @@ App.SlaveAssignment.rules = function(slave) { case "Edo Revivalist": case "Egyptian Revivalist": case "Neo-Imperialist": + case "Antebellum Revivalist": r.push(`The spare living conditions and daily tasks <span class="hotpink">get ${him} used</span> to the routine of slavery.`); slave.devotion += 1; break; @@ -2327,6 +2352,9 @@ App.SlaveAssignment.rules = function(slave) { slave.devotion += 2; slave.trust += 2; break; + case "Antebellum Revivalist": + r.push(`The living conditions of ${V.farmyardName}'s slave houses are undeniably spare, but they are not especially uncomfortable.`); + break; default: r.push(`${He} likes ${his} personal space in ${V.farmyardName}'s dormitory, even if it's just a small room.`); } diff --git a/src/endWeek/saSocialEffects.js b/src/endWeek/saSocialEffects.js index 9e8c8bad804d075498e6759d53b1f7f611284a91..5ff952257ef475f6e9ba96ac78013ea2036059e6 100644 --- a/src/endWeek/saSocialEffects.js +++ b/src/endWeek/saSocialEffects.js @@ -735,6 +735,23 @@ App.SlaveAssignment.saSocialEffects = function(slave) { } } + if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + if (slave.assignment == Job.QUARTER) { + if (V.arcologies[0].FSSubjugationist !== "unset" && slave.race === V.arcologies[0].FSSubjugationistRace) { + t.push(new SocialEffect("Antebellum Revivalist", 2, `Servants`, + `Society <span class="green">strongly approves</span> of ${slave.slaveName}, a slave of the inferior race, working as a servant.`)); + } else { + t.push(new SocialEffect("Antebellum Revivalist", 1, `Servants`, + `Society <span class="green">approves</span> of ${slave.slaveName} working as a servant.`)); + } + } + + if (slave.skill.entertainment > 60 && slave.devotion > 20) { + t.push(new SocialEffect("Antebellum Revivalist", 1, `Entertaining`, + `Society <span class="green">approves</span> of owning an obedient and affable slaves like ${slave.slaveName}.`)); + } + } + if (V.arcologies[0].FSSlimnessEnthusiast !== "unset") { if (isSlim(slave)) { t.push(new SocialEffect("Slimness Enthusiast", 1, `Slim`, diff --git a/src/events/PE/concubineInterview.js b/src/events/PE/concubineInterview.js index 7e74cf7380f8d2f16762666667f519c7b80336c7..a423a8bc3b4e394ffe62390624108dbc82f62f2f 100644 --- a/src/events/PE/concubineInterview.js +++ b/src/events/PE/concubineInterview.js @@ -269,23 +269,23 @@ App.Events.PEConcubineInterview = class PEConcubineInterview extends App.Events. case "a mini dress": case "a Santa dress": case "a biyelgee costume": + case "an evening dress": t.push(`dress.`); break; case "a latex catsuit": t.push(`latex catsuit.`); break; case "a military uniform": - t.push(`uniform.`); - break; case "a schutzstaffel uniform": + case "a red army uniform": + case "a mounty outfit": + case "a police uniform": + case "a confederate army uniform": t.push(`uniform.`); break; case "a slutty schutzstaffel uniform": t.push(`slutty uniform.`); break; - case "a red army uniform": - t.push(`uniform.`); - break; case "spats and a tank top": t.push(`spats.`); break; @@ -307,10 +307,6 @@ App.Events.PEConcubineInterview = class PEConcubineInterview extends App.Events. // case "skirt" //FIXME: skirts are not a thing apparently // t.push(`dress.`); // break; - case "a mounty outfit": - case "a police uniform": - t.push(`uniform.`); - break; case "lederhosen": t.push(`shorts.`); break; @@ -461,6 +457,8 @@ App.Events.PEConcubineInterview = class PEConcubineInterview extends App.Events. t.push(speak(`Blood empire reborn,`)); } else if (arcology.FSEgyptianRevivalist > 0) { t.push(speak(`the land of the Pharaohs reborn,`)); + } else if (arcology.FSAntebellumRevivalist > 0) { + t.push(speak(`a new Dixie reborn,`)); } if (arcology.FSGenderRadicalist > 0) { diff --git a/src/events/RE/reArcologyInspection.js b/src/events/RE/reArcologyInspection.js index 9439ab95fe34a2250d63f92b57b669a0d2fd732a..76115487cd00077d56bdb03c665ab84af2c8970d 100644 --- a/src/events/RE/reArcologyInspection.js +++ b/src/events/RE/reArcologyInspection.js @@ -154,6 +154,7 @@ App.Events.REArcologyInspection = class REArcologyInspection extends App.Events. ["FSEdoRevivalist", `attending a kabuki theater performance`], ["FSArabianRevivalist", `training citizens' harem slaves`], ["FSChineseRevivalist", `reviewing the administrative bureaucracy`], + ["FSAntebellumRevivalist", `attending some classic theater`], ["FSNull", `attending a multicultural festival`], ]); t.push(`You and ${agent ? agent.slaveName : "your trustee representative"} spend the rest of the day ${actionMap.get(fs)}, making sure that the news cameras are rolling.`); @@ -528,6 +529,7 @@ App.Events.REArcologyInspection = class REArcologyInspection extends App.Events. ["FSEdoRevivalist", `historical dramas set in Edo Japan`], ["FSArabianRevivalist", `dramatic retellings of traditional Bedouin fables`], ["FSChineseRevivalist", `ancient Chinese operas`], + ["FSAntebellumRevivalist", `period dramas glorifying the chivalrous South`], ["FSNull", `documentaries from cultures around the world`], // NPC FSes too ["FSIncestFetishist", `pornography featuring closely-related actors`], diff --git a/src/events/RE/reFSNonconformist.js b/src/events/RE/reFSNonconformist.js index 88c4c6b562eb9ab3e9eaddca265b39b0c341dd4d..fd1bbb7fc7fbf87794ba5a07f5f2a337f095d962 100644 --- a/src/events/RE/reFSNonconformist.js +++ b/src/events/RE/reFSNonconformist.js @@ -84,6 +84,8 @@ App.Events.REFSNonconformist = class REFSNonconformist extends App.Events.BaseEv r.push(`involved in your Revivalist vision. They're looking quite grim, an unusual mood for a group of oligarchs who do their best to project complete confidence that the arcology possesses the Mandate of Heaven,`); } else if (FSNonconformist === "Egyptian Revivalist") { r.push(`involved in your Revivalist vision. They're looking quite grim, an unusual mood for a group of oligarchs who partake of your serene confidence that your arcology is coming into a place as stable and long-lived as that of Ancient Egypt,`); + } else if (FSNonconformist === "Antebellum Revivalist") { + r.push(`involved in your Revivalist vision. They're looking quite grim, an unusual mood for a group of oligarchs who do their best embody the virtues of Southern gentry,`); } else { throw Error(`FS "${FSNonconformist}" not found `); } @@ -159,6 +161,8 @@ App.Events.REFSNonconformist = class REFSNonconformist extends App.Events.BaseEv r.push(`has been a longtime skeptic of historical revivalism, publicly deploring it as a childish game of dress-up. This never got much traction, since ancient China has become quite fashionable here. Frustrated, they're rumored to be planning a change of approach. Despairing of getting the population to give up the imperial project, they're going to set up a competing Mongol Revivalism. The quixotic effort is almost certainly doomed to fail, but the oligarchs fear it will be a distraction.`); } else if (FSNonconformist === "Egyptian Revivalist"){ r.push(`has been a longtime skeptic of historical revivalism, publicly deploring it as a childish game of dress-up. This never got much traction, since the land of the Pharaohs has become quite fashionable here. Frustrated, they're rumored to be planning a change of approach. Despairing of getting the population to give up the Egyptian project, they're going to set up a competing Ancient Greek Revivalism. The quixotic effort is almost certainly doomed to fail, but the oligarchs fear it will be a distraction.`); + } else if (FSNonconformist === "Antebellum Revivalist"){ + r.push(`has held a longtime grudge against the Antebellum era, publicly declaring it to be a caricature of the old South and, indeed, seems to loathe the Southron code of honor. Most citizens openly disagree, some going as far as demanding to duel for the honor of the arcology. Now, it's rumored that they're going to set up a competing Gilded Age Revivalism. The choice was is poignant one; the Gilded Age was birthed from the defeat of the South in the Civil War. While the North was flourishing, the South languished in post-war ruins.`); } else { throw Error(`FS "${FSNonconformist}" not found `); } @@ -282,6 +286,9 @@ App.Events.REFSNonconformist = class REFSNonconformist extends App.Events.BaseEv } else if (FSNonconformist === "Chinese Revivalist") { r.push(`offers their Mongol Revivalism alternative with great fanfare. It fizzles out within a week, mostly because its main backer is privately against all revivalism, but during that time it serves as a focal point for many citizens who are privately impatient with Chinese revivalism. This imbroglio <span class="red">sets back acceptance</span> of your revivalist project.`); V.arcologies[0].FSChineseRevivalist -= 10; + } else if (FSNonconformist === "Antebellum Revivalist") { + r.push(`offers their Gilded Age Revivalism alternative with great fanfare. It fizzles out within a week, mostly because its main backer is privately against all revivalism, but during that time it serves as a focal point for many citizens who are privately impatient with Antebellum revivalism. This imbroglio <span class="red">sets back acceptance</span> of your revivalist project.`); + V.arcologies[0].FSAntebellumRevivalist -= 10; } else { r.push(`offers their Ancient Greek Revivalism alternative with great fanfare. It fizzles out within a week, mostly because its main backer is privately against all revivalism, but during that time it serves as a focal point for many citizens who are privately impatient with Egyptian revivalism. This imbroglio <span class="red">sets back acceptance</span> of your revivalist project.`); V.arcologies[0].FSEgyptianRevivalist -= 10; @@ -381,6 +388,8 @@ App.Events.REFSNonconformist = class REFSNonconformist extends App.Events.BaseEv r.push(`offers their Byzantine Revivalism alternative with fanfare, but jihad may be waged with diplomacy as much as with the sword. The nasty little attempt founders on the growing conservatism of the arcology, whose citizens rally to you as their proper leader.`); } else if (FSNonconformist === "Chinese Revivalist") { r.push(`offers their Mongol Revivalism alternative with fanfare, but judicious strengthening of your imperial authority sees it off without trouble. The influence of Confucian ideas is spreading through your arcology, making it resistant to radical departures.`); + } else if (FSNonconformist === "Antebellum Revivalist") { + r.push(`offers their Gilded Age Revivalism alternative with fanfare, but fanfare rings empty compared to the rock-solid resolve of the Southron peoples. The nasty little attempt is shrugged off in a few days.`); } else { r.push(`offers their Ancient Greek Revivalism alternative with fanfare, but fanfare is something that the Egyptians could certainly manage. The nasty little attempt is barely noticed over the perfume and noise of a long and beautiful festival.`); } diff --git a/src/events/RE/reMaleCitizenHookup.js b/src/events/RE/reMaleCitizenHookup.js index 95328e7bfb4116a810796020b2a6384277731079..0b977873269d56b0a5ca878af7118385aba2d53f 100644 --- a/src/events/RE/reMaleCitizenHookup.js +++ b/src/events/RE/reMaleCitizenHookup.js @@ -110,6 +110,9 @@ App.Events.REMaleCitizenHookup = class REMaleCitizenHookup extends App.Events.Ba case "FSChineseRevivalist": r.push(`a handsome Chinese man`); break; + case "FSAntebellumRevivalist": + r.push(`a handsome Southron man`); + break; case "FSIntellectualDependency": r.push(`a cute party boy`); break; @@ -719,6 +722,9 @@ App.Events.REMaleCitizenHookup = class REMaleCitizenHookup extends App.Events.Ba break; case "FSArabianRevivalist": case "FSChineseRevivalist": + case "FSAntebellumRevivalist": + r.push(`exquisite mustache`); + break; case "FSEdoRevivalist": r.push(`graceful form`); break; diff --git a/src/events/RE/rePregInventorShowOff.js b/src/events/RE/rePregInventorShowOff.js index 30fa6ac21e85327c2196443fdd8fc355ee7728a2..7a5a1a37f0142c02c9b4cbb3b1e838331f56cea8 100644 --- a/src/events/RE/rePregInventorShowOff.js +++ b/src/events/RE/rePregInventorShowOff.js @@ -176,6 +176,8 @@ App.Events.rePregInventorShowOff = class rePregInventorShowOff extends App.Event r.push(`their sinful figures made modest by roomy abayas,`); } else if (V.arcologies[0].FSChineseRevivalist > 60) { r.push(`clad in traditional silk chang'ao and lotus shoes,`); + } else if (V.arcologies[0].FSAntebellumRevivalist > 60) { + r.push(`dressed in skimpy sheer white gowns,`); } else { r.push(`their clothing specifically chosen to supplement and flatter your hyperbroodmother's own outfit,`); } @@ -351,6 +353,8 @@ App.Events.rePregInventorShowOff = class rePregInventorShowOff extends App.Event r.push(`comfortable atmosphere of the facilities.`); } else if (V.spaDecoration === "Neo-Imperialist") { r.push(`sight of the verdant greenery, brilliant high-tech lighting, and steaming central bath.`); + } else if (V.spaDecoration === "Antebellum Revivalist") { + r.push(`intense humidity, like a sweet summer day in the South.`); } else { r.push(`sight of its spacious baths and pleasant atmosphere.`); } diff --git a/src/events/RESS/assFitting.js b/src/events/RESS/assFitting.js index b10249dabfa2b6d4162f028c3fd434c16882f58b..01ca098e3cc563cf50f6c646dfc97dd536b569f2 100644 --- a/src/events/RESS/assFitting.js +++ b/src/events/RESS/assFitting.js @@ -10,7 +10,7 @@ App.Events.RESSAssFitting = class RESSAssFitting extends App.Events.BaseEvent { s => s.assignment !== Job.QUARTER, s => s.devotion > 20, s => s.butt > 5, - s => ["a bimbo outfit", "a biyelgee costume", "a bunny outfit", "a burkini", "a cheerleader outfit", "a comfortable bodysuit", "a dirndl", "a fallen nuns habit", "a huipil", "a latex catsuit", "a leotard", "a long qipao", "a maternity dress", "a military uniform", "a monokini", "a mounty outfit", "a nice nurse outfit", "a red army uniform", "a scalemail bikini", "a schoolgirl outfit", "a schutzstaffel uniform", "a slutty nurse outfit", "a slutty outfit", "a slutty qipao", "a slutty schutzstaffel uniform", "a succubus outfit", "attractive lingerie for a pregnant woman", "attractive lingerie", "battlearmor", "chains", "clubslut netting", "conservative clothing", "cutoffs and a t-shirt", "kitty lingerie", "lederhosen", "nice business attire", "overalls", "restrictive latex", "striped panties", "slutty business attire", "slutty jewelry", "spats and a tank top", "stretch pants and a crop-top", "uncomfortable straps", "Western clothing", "Imperial Plate", "a tight Imperial bodysuit"].includes(s.clothes), + s => ["a bimbo outfit", "a biyelgee costume", "a bunny outfit", "a burkini", "a cheerleader outfit", "a comfortable bodysuit", "a dirndl", "a fallen nuns habit", "a huipil", "a latex catsuit", "a leotard", "a long qipao", "a maternity dress", "a military uniform", "a monokini", "a mounty outfit", "a nice nurse outfit", "a red army uniform", "a scalemail bikini", "a schoolgirl outfit", "a schutzstaffel uniform", "a slutty nurse outfit", "a slutty outfit", "a slutty qipao", "a slutty schutzstaffel uniform", "a succubus outfit", "attractive lingerie for a pregnant woman", "attractive lingerie", "battlearmor", "chains", "clubslut netting", "conservative clothing", "cutoffs and a t-shirt", "kitty lingerie", "lederhosen", "nice business attire", "overalls", "restrictive latex", "striped panties", "slutty business attire", "slutty jewelry", "spats and a tank top", "stretch pants and a crop-top", "uncomfortable straps", "Western clothing", "Imperial Plate", "a tight Imperial bodysuit", "a confederate army uniform", "a ball gown", "an evening dress"].includes(s.clothes), hasAnyArms, canStand, ] @@ -137,6 +137,7 @@ App.Events.RESSAssFitting = class RESSAssFitting extends App.Events.BaseEvent { case "a military uniform": t.push(`get ${his} perfectly pressed uniform skirt up over ${his} buttocks, not without risking the seams. ${He}'s got it`); break; + case "a confederate army uniform": case "a schutzstaffel uniform": t.push(`get ${his} perfectly pressed uniform trousers up over ${his} buttocks, not without risking the seams. ${He}'s got it`); break; @@ -207,7 +208,11 @@ App.Events.RESSAssFitting = class RESSAssFitting extends App.Events.BaseEvent { case "a bimbo outfit": t.push(`pull ${his} outfit's miniskirt up over ${his} buttocks, at least not while having to stop and dig ${his} thong out of ${his} crack after every try. ${He}'s got it`); break; - default: + case "a ball gown": + case "an evening dress": + t.push(`pull ${his} dress up over ${his} buttocks, not without ruining the garment. ${He}'s got them`); + break; + default: t.push(`get ${his} outfit pulled up over ${his} buttocks. ${He}'s got it`); break; } diff --git a/src/events/RESS/modestClothes.js b/src/events/RESS/modestClothes.js index 73504b5784ab6c345fde3e1edb4ea1f2110efb54..2d7b5b95acc7ebf644661a9e703e926c80f56291 100644 --- a/src/events/RESS/modestClothes.js +++ b/src/events/RESS/modestClothes.js @@ -142,6 +142,7 @@ App.Events.RESSModestClothes = class RESSModestClothes extends App.Events.BaseEv case "a halter top dress": case "a mini dress": case "a maternity dress": + case "an evening dress": clothesDesc = `dress`; break; case "a military uniform": @@ -149,6 +150,7 @@ App.Events.RESSModestClothes = class RESSModestClothes extends App.Events.BaseEv case "a red army uniform": case "a schutzstaffel uniform": case "a slutty schutzstaffel uniform": + case "a confederate army uniform": clothesDesc = `uniform`; break; case "spats and a tank top": diff --git a/src/events/RESS/review/aGift.js b/src/events/RESS/review/aGift.js index 6abddc6ef8a95f1136dcb0ccda3cb120459ae886..89c5acad633f7920a6489ce9bc0fcb10398cb1ce 100644 --- a/src/events/RESS/review/aGift.js +++ b/src/events/RESS/review/aGift.js @@ -94,6 +94,8 @@ App.Events.RESSAGift = class RESSAGift extends App.Events.BaseEvent { return "a complex minaret"; case "FSChineseRevivalist": return "an imperial pagoda"; + case "FSAntebellumRevivalist": + return "a fleur-de-lis"; default: return "a beautiful flower"; } diff --git a/src/events/assistant/assistantFS.js b/src/events/assistant/assistantFS.js index 66e26ceb7213d4804546035dce257cdc2868feaa..4176c30df40e5ef5b6c743e2368b145c42dfaf26 100644 --- a/src/events/assistant/assistantFS.js +++ b/src/events/assistant/assistantFS.js @@ -131,6 +131,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} appearance to resemble a djinn to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} appearance to resemble a demon to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} appearance to resemble a mishmash of creatures from American folklore to conform with your vision of building a new Antebellum South.`); } break; case "shemale": @@ -188,6 +190,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an oil millionaire to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} appearance to be tattooed with rude Chinese characters to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble old-fashioned, aristocratic garb to conform with your vision of building a new Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to look more ${V.arcologies[0].FSSupremacistRace} to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -253,6 +257,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an Arabian warrior to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a warrior monk to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble a Confederate soldier to confirm with your vision of building a new Antebellum South.`); } break; case "businesswoman": @@ -299,7 +305,7 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { } else if (V.arcologies[0].FSRomanRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a respectable Roman lady to conform with your vision of building a new Rome.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - r.push(`adjusts ${hisA} outfit to resemble a high-class old world businesswoman to conform with your vision of a new Imperial society.`); + r.push(`adjusts ${hisA} outfit to resemble a high-class old world business${womanA} to conform with your vision of a new Imperial society.`); } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble an Aztec priestess to conform with your vision of building a new Aztec Empire.`); } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { @@ -310,6 +316,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an Arabian oil heiress to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Chinese lady to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble a Southern lady to conform with your vision of building a new Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to look more ${V.arcologies[0].FSSupremacistRace} to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -358,7 +366,7 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { } else if (V.arcologies[0].FSRomanRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a respectable Roman ${girlA} to conform with your vision of building a new Rome.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - r.push(`adjusts ${hisA} outfit to resemble an innocent old-world girl to conform with your vision of a new Imperial society.`); + r.push(`adjusts ${hisA} outfit to resemble an innocent old-world ${girlA} to conform with your vision of a new Imperial society.`); } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble an Aztec ${womanA} to conform with your vision of building a new Aztec Empire.`); } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { @@ -369,6 +377,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an Arabian ${girlA} to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Chinese ${girlA} to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble a Southern ${girlA} to conform with your vision of building a new Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to look more ${V.arcologies[0].FSSupremacistRace} to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -419,7 +429,7 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { } else if (V.arcologies[0].FSRomanRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Roman ${girlA} to conform with your vision of building a new Rome.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - r.push(`adjusts ${hisA} outfit to resemble an old-world girl to conform with your vision of a new Imperial society.`); + r.push(`adjusts ${hisA} outfit to resemble an old-world ${girlA} to conform with your vision of a new Imperial society.`); } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble an Aztec ${womanA} to conform with your vision of building a new Aztec Empire.`); } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { @@ -430,6 +440,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an Arabian ${girlA} to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Chinese ${girlA} to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble a Southern ${girlA} to conform with your vision of building a new Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to look more ${V.arcologies[0].FSSupremacistRace} to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -480,7 +492,7 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { } else if (V.arcologies[0].FSRomanRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Roman lady to conform with your vision of building a new Rome.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - r.push(`adjusts ${hisA} outfit to resemble a high-tech woman bearing your crest to conform with your vision of a new Imperial society.`); + r.push(`adjusts ${hisA} outfit to resemble a high-tech ${womanA} bearing your crest to conform with your vision of a new Imperial society.`); } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble an Aztec ${womanA} to conform with your vision of building a new Aztec Empire.`); } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { @@ -491,6 +503,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an Arabian lady to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Chinese lady to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble Columbia, goddess of America, to conform with your vision of building a Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to look more ${V.arcologies[0].FSSupremacistRace} to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -541,7 +555,7 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { } else if (V.arcologies[0].FSRomanRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Roman lady to conform with your vision of building a new Rome.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - r.push(`adjusts ${hisA} outfit to resemble a high-tech woman bearing your crest to conform with your vision of a new Imperial society.`); + r.push(`adjusts ${hisA} outfit to resemble a high-tech ${womanA} bearing your crest to conform with your vision of a new Imperial society.`); } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble an Aztec ${womanA} to conform with your vision of building a new Aztec Empire.`); } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { @@ -552,6 +566,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an Arabian lady to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Chinese lady to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble Columbia, goddess of America, to conform with your vision of building a new Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to look more ${V.arcologies[0].FSSupremacistRace} to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -602,7 +618,7 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { } else if (V.arcologies[0].FSRomanRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a respectable Roman ${girlA} to conform with your vision of building a new Rome.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - r.push(`adjusts ${hisA} outfit to resemble an innocent old-world girl to conform with your vision of a new Imperial society.`); + r.push(`adjusts ${hisA} outfit to resemble an innocent old-world ${girlA} to conform with your vision of a new Imperial society.`); } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble an Aztec ${girlA} to conform with your vision of building a new Aztec Empire.`); } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { @@ -613,6 +629,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an Arabian ${girlA} to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Chinese ${girlA} to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble a Southern ${girlA} to conform with your vision of building a new Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to look more ${V.arcologies[0].FSSupremacistRace} to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -663,7 +681,7 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { } else if (V.arcologies[0].FSRomanRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Roman ${girlA} to conform with your vision of building a new Rome.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - r.push(`adjusts ${hisA} outfit to resemble an old-world girl to conform with your vision of a new Imperial society.`); + r.push(`adjusts ${hisA} outfit to resemble an old-world ${girlA} to conform with your vision of a new Imperial society.`); } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble an Aztec ${girlA} to conform with your vision of building a new Aztec Empire.`); } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { @@ -674,6 +692,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an Arabian ${girlA} to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Chinese ${girlA} to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble a Southern ${girlA} to confirm with your vision of building a new Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to look more ${V.arcologies[0].FSSupremacistRace} to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -724,7 +744,7 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { } else if (V.arcologies[0].FSRomanRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Roman ${womanA} to conform with your vision of building a new Rome.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - r.push(`adjusts ${hisA} outfit to resemble a high-tech woman bearing your crest to conform with your vision of a new Imperial society.`); + r.push(`adjusts ${hisA} outfit to resemble a high-tech ${womanA} bearing your crest to conform with your vision of a new Imperial society.`); } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble an Aztec priestess to conform with your vision of building a new Aztec Empire.`); } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { @@ -735,6 +755,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an Arabian ${womanA} to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Chinese ${womanA} to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble a Southern ${womanA} to confirm with your vision of building a new Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to look more ${V.arcologies[0].FSSupremacistRace} to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -785,7 +807,7 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { } else if (V.arcologies[0].FSRomanRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Roman ${womanA} to conform with your vision of building a new Rome.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - r.push(`adjusts ${hisA} outfit to resemble a high-tech woman bearing your crest to conform with your vision of a new Imperial society.`); + r.push(`adjusts ${hisA} outfit to resemble a high-tech ${womanA} bearing your crest to conform with your vision of a new Imperial society.`); } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble an Aztec priestess to conform with your vision of building a new Aztec Empire.`); } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { @@ -796,6 +818,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an Arabian ${womanA} to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Chinese ${womanA} to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble a Southern ${womanA} to confirm with your vision of building a new Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to look more ${V.arcologies[0].FSSupremacistRace} to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -846,7 +870,7 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { } else if (V.arcologies[0].FSRomanRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Roman ${womanA}, despite ${hisA} cock, to conform with your vision of building a new Rome.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - r.push(`adjusts ${hisA} outfit to resemble a high-tech old-world woman, despite ${hisA} cock, to conform with your vision of a new Imperial society.`); + r.push(`adjusts ${hisA} outfit to resemble a high-tech old-world ${womanA}, despite ${hisA} cock, to conform with your vision of a new Imperial society.`); } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble an Aztec ${womanA}, despite ${hisA} cock, to conform with your vision of building a new Aztec Empire.`); } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { @@ -857,6 +881,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an Arabian ${womanA}, despite ${hisA} cock, to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Chinese ${womanA}, despite ${hisA} cock, to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble a Southern ${womanA}, despite ${hisA} cock, to confirm with your vision of building a new Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to look more ${V.arcologies[0].FSSupremacistRace} to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -907,7 +933,7 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { } else if (V.arcologies[0].FSRomanRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a proper upper-class Roman lady to conform with your vision of building a new Rome.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - r.push(`adjusts ${hisA} outfit to resemble a high-class old-world woman bearing your crest to conform with your vision of a new Imperial society.`); + r.push(`adjusts ${hisA} outfit to resemble a high-class old-world ${womanA} bearing your crest to conform with your vision of a new Imperial society.`); } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble an Aztec ${womanA} to conform with your vision of building a new Aztec Empire.`); } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { @@ -918,6 +944,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an Arabian lady to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Chinese lady to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble a Southern lady to confirm with your vision of building a new Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to look more ${V.arcologies[0].FSSupremacistRace} to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -968,7 +996,7 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { } else if (V.arcologies[0].FSRomanRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Roman ${womanA} to conform with your vision of building a new Rome.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - r.push(`adjusts ${hisA} outfit to resemble a high-tech woman bearing your crest to conform with your vision of a new Imperial society.`); + r.push(`adjusts ${hisA} outfit to resemble a high-tech ${womanA} bearing your crest to conform with your vision of a new Imperial society.`); } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble an Aztec ${womanA} to conform with your vision of building a new Aztec Empire.`); } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { @@ -979,6 +1007,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an Arabian ${womanA} to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Chinese ${womanA} to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble a Southern ${womanA} to conform with your vision of building a new Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to look more ${V.arcologies[0].FSSupremacistRace} to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -1054,6 +1084,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`casts a spell to make ${himselfA} appear Arabic; ${heA} succeeds in making ${himselfA} look like a wannabe Arabian princess.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`casts a spell to make ${himselfA} appear Chinese; ${heA} succeeds in swapping the material of ${hisA} robes to a fine silk.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`casts a spell to make ${himselfA} appear Southern; ${heA} succeeds in becoming a caricature of the Antebellum aristocracy.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`casts a spell to look more ${V.arcologies[0].FSSupremacistRace}; ${heA} does too good of a job, ending up looking like an over-exaggerated ${V.arcologies[0].FSSupremacistRace} stereotype.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -1104,7 +1136,7 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { } else if (V.arcologies[0].FSRomanRevivalist !== "unset") { r.push(`adjusts ${hisA} form to a Roman ${womanA} to conform with your vision of building a new Rome.`); } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - r.push(`adjusts ${hisA} outfit to resemble a high-tech woman bearing your crest to conform with your vision of a new Imperial society.`); + r.push(`adjusts ${hisA} outfit to resemble a high-tech ${womanA} bearing your crest to conform with your vision of a new Imperial society.`); } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble an Aztec ${womanA} to conform with your vision of building a new Aztec Empire.`); } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { @@ -1115,6 +1147,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} form to an Arabian ${womanA} to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} form to a Chinese ${womanA} to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} form to a Southern ${womanA} to conform with your vision of building a new Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to look more ${V.arcologies[0].FSSupremacistRace} to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -1176,6 +1210,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { r.push(`adjusts ${hisA} outfit to resemble an Arab ${girlA} attending a Western school to conform with your vision of building a new Sultanate.`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`adjusts ${hisA} outfit to resemble a Chinese lady to conform with your vision of pursuing the Mandate of Heaven.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`adjusts ${hisA} outfit to resemble a Southern lady to conform with your vision of building a new Antebellum South.`); } else if (V.arcologies[0].FSSupremacist !== "unset") { r.push(`adjusts ${hisA} appearance to resemble a model ${V.arcologies[0].FSSupremacistRace} student to conform with your vision of glorifying the superior race.`); } else if (V.arcologies[0].FSSubjugationist !== "unset") { @@ -1250,6 +1286,8 @@ App.Events.assistantFS = class assistantFS extends App.Events.BaseEvent { V.assistant.fsAppearance = "arabian revivalist"; } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { V.assistant.fsAppearance = "chinese revivalist"; + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + V.assistant.fsAppearance = "antebellum revivalist"; } else if (V.arcologies[0].FSSupremacist !== "unset") { V.assistant.fsAppearance = "supremacist"; } else if (V.arcologies[0].FSSubjugationist !== "unset") { diff --git a/src/events/intro/acquisition.js b/src/events/intro/acquisition.js index f8718ee8367229eec565273633a4e38b2d5eddc4..a3a00a0561275f4d20bed3dfac568b5bae51985a 100644 --- a/src/events/intro/acquisition.js +++ b/src/events/intro/acquisition.js @@ -120,6 +120,9 @@ App.Intro.acquisition = function() { case "FSChineseRevivalist": r.push(`The only one of their slaves left is the Head Girl. ${He} should be willing to transfer ${his} loyalty to you, as ${his} proper superior.`); break; + case "FSAntebellumRevivalist": + r.push(`They kept a stable of servants, who the previous owner called 'house slaves'. They have hope that you'll be kinder to them, but do not trust you.`); + break; case "FSRestart": r.push(`The only one of their slaves left is an absolute beauty of a ${girl}. ${He} is too smart for ${his} own good and will likely not trust you.`); break; @@ -870,6 +873,39 @@ App.Intro.acquisition = function() { slave.assignment = "be your Head Girl"; V.HeadGirlID = slave.ID; break; + case "FSAntebellumRevivalist": + slave = GenerateNewSlave("XX", { + race: "black", nationality: "American", minAge: 18, maxAge: 24, ageOverridesPedoMode: 1, disableDisability: 1 + }); + slave.devotion = random(-20, 25); + slave.trust = random(-55, -20); + setHealth(slave, jsRandom(25, 45), 0, 0, 0, 0); + slave.accent = 1; + slave.face = random(10, 45); + slave.accent = 2; + slave.intelligence = jsRandom(-50, 25); + slave.skill.oral = jsRandom(20, 40); + slave.skill.anal = jsRandom(20, 40); + if (slave.vagina > -1) { + if (slave.vagina === 0) { + slave.vagina++; + } + slave.skill.vaginal = 15; + } + slave.skill.entertainment = 15; + slave.skill.whoring = 15; + SoftenBehavioralFlaw(slave); + SoftenSexualFlaw(slave); + slave.collar = "uncomfortable leather"; + slave.clothes = "a slutty maid outfit"; + slave.armAccessory = "elbow gloves"; + slave.legAccessory = "long stockings"; + slave.shoes = "heels"; + slave.assignment = "be a servant"; + slave.custom.desc = "$He speaks with the demeaning accent of slaves from the Old South."; + slave.slaveName = App.Data.misc.antebellumSlaveNames.random(); + slave.slaveSurname = App.Data.misc.antebellumSlaveSurnames.random(); + break; case "FSRestart": slave = GenerateNewSlave("XX", {disableDisability: 1}); slave.devotion = -100; diff --git a/src/events/intro/arcologySelection.js b/src/events/intro/arcologySelection.js index 429ea9817f5fc7570d3c764d7e57c2e3b7ef2f7e..1904567f95cca6ae03bcb20af5d4ffc4c42d55e8 100644 --- a/src/events/intro/arcologySelection.js +++ b/src/events/intro/arcologySelection.js @@ -146,6 +146,10 @@ App.Intro.generateEstablishedArcologies = function(inIntro = false) { innerDiv.append(App.UI.DOM.makeElement("span", `Chinese Revivalism,`, ["intro", "question"]), " which modernizes the assumed superiority of the Middle Kingdom."); innerDiv.append(App.UI.DOM.makeElement("div", "It has an established lingua franca: Chinese.")); break; + case "FSAntebellumRevivalist": + innerDiv.append(App.UI.DOM.makeElement("span", `Antebellum Revivalism,`, ["intro", "question"]), " which attempts to revive the romance and chivalry of the Antebellum South."); + innerDiv.append(App.UI.DOM.makeElement("div", "It has an established lingua franca: English.")); + break; case "FSRepopulationFocus": innerDiv.append(App.UI.DOM.makeElement("span", `Repopulationism,`, ["intro", "question"]), " the belief that the key to humanity's survival is a child in every fertile womb."); break; @@ -377,6 +381,8 @@ App.Intro.generateEstablishedArcologies = function(inIntro = false) { return App.Data.ArcologyNames.ArabianRevivalist.random(); case "FSChineseRevivalist": return App.Data.ArcologyNames.ChineseRevivalist.random(); + case "FSAntebellumRevivalist": + return App.Data.ArcologyNames.AntebellumRevivalist.random(); case "FSRepopulationFocus": return App.Data.ArcologyNames.Repopulationist.random(); case "FSRestart": diff --git a/src/events/intro/initNationalities.js b/src/events/intro/initNationalities.js index 3cde7bf881b3f4e0c32ab2cd6595bd21f80a1125..fd3e2473e69e9e5e423d6af8b02aeca104af4158 100644 --- a/src/events/intro/initNationalities.js +++ b/src/events/intro/initNationalities.js @@ -190,6 +190,7 @@ App.Intro.initNationalities = function() { FSNeoImperialist: "unset", FSArabianRevivalist: "unset", FSChineseRevivalist: "unset", + FSAntebellumRevivalist: "unset", FSNull: "unset", embargo: 1, embargoTarget: -1, @@ -253,6 +254,7 @@ App.Intro.initNationalities = function() { newArcology.FSChattelReligionistDecoration = 20; newArcology.FSRomanRevivalistDecoration = 20; newArcology.FSNeoImperialistDecoration = 20; + newArcology.FSAntebellumRevivalistDecoration = 20; newArcology.FSAztecRevivalistDecoration = 20; newArcology.FSEgyptianRevivalistDecoration = 20; newArcology.FSEdoRevivalistDecoration = 20; @@ -360,6 +362,9 @@ App.Intro.initNationalities = function() { V.arcologies[0].FSArabianRevivalistSMR = 0; V.arcologies[0].FSChineseRevivalistLaw = 0; V.arcologies[0].FSChineseRevivalistSMR = 0; + V.arcologies[0].FSAntebellumRevivalistSMR = 0; + V.arcologies[0].FSAntebellumRevivalistLaw1 = 0; + V.arcologies[0].FSAntebellumRevivalistLaw2 = 0; V.arcologies[0].FSRepopulationFocusLaw = 0; V.arcologies[0].FSRepopulationFocusSMR = 0; V.arcologies[0].FSRestartLaw = 0; diff --git a/src/events/nonRandom/daughters/pCoupAttempt.js b/src/events/nonRandom/daughters/pCoupAttempt.js index 15855266bfb10a241127be112617a83cee45a6f2..f1452866fd65c76a3e1428d51edce4e880b82942 100644 --- a/src/events/nonRandom/daughters/pCoupAttempt.js +++ b/src/events/nonRandom/daughters/pCoupAttempt.js @@ -47,6 +47,10 @@ App.Events.PCoupAttempt = class PCoupAttempt extends App.Events.BaseEvent { r.push(`${V.arcologies[0].name}, however, is guarded by your fanatically loyal and expertly-trained Imperial Knights, many of whom practically chomp at the bit in their heavy battle armor for just such an opportunity. Before you have even shouted your first command, you can hear the sound of ferocious battle. The Knights are not one to be surprised.`); } + if (V.arcologies[0].FSAntebellumRevivalistLaw2 === 1) { + r.push(`${V.arcologies[0].name}, however, is home to a society with more than one hundred firearms to each citizen, and more than enough of them have been itching for a time just like this. Before you have time to issue your first order, the citizens' militias have already mobilized and flooded the streets, eager for blood.`); + } + App.Events.addParagraph(node, r); r = []; @@ -82,7 +86,7 @@ App.Events.PCoupAttempt = class PCoupAttempt extends App.Events.BaseEvent { App.Events.addParagraph(node, r); r = []; - if (secExpUnits === 0 && V.mercenaries === 0 && V.arcologies[0].FSRomanRevivalistLaw === 0 && V.arcologies[0].FSNeoImperialistLaw1 === 0) { + if (secExpUnits === 0 && V.mercenaries === 0 && V.arcologies[0].FSRomanRevivalistLaw === 0 && V.arcologies[0].FSNeoImperialistLaw1 === 0 && V.arcologies[0].FSAntebellumRevivalistLaw2 === 0) { r.push(`You are alone in contributing to the defense of your home.`); } else if (V.mercenaries === 1) { r.push(`Your mercenaries desperately defend their barracks but manage little else.`); @@ -97,6 +101,9 @@ App.Events.PCoupAttempt = class PCoupAttempt extends App.Events.BaseEvent { if (V.arcologies[0].FSNeoImperialistLaw1 === 1) { r.push(`As the rebels reel back from the shockingly organized initial resistance of your always-ready Imperial Knights and their lightly-armed but fanatically determined guardsmen, it becomes increasingly clear just how well prepared your arcology was for this exact event. Even as fires rage through the streets of your home, Knights clamber forward through the rebel lines practically undisturbed by the fire that clatters off their enormously thick plate, laying down explosive volleys with enormous heavy guns and launching themselves into outright melee with their holographic weapons.`); } + if (V.arcologies[0].FSAntebellumRevivalistLaw2 === 1) { + r.push(`As the rebels are pushed back from the disturbingly eager mob of well-armed citizenry, it becomes obvious that many of the militia groups have been practicing for an attack of this nature for some time. They move as well-ordered squads through familiar corridors with an odd mishmash of practical and completely ornamental gear, each soldier or squadron uniquely dressed. They use their home advantage to ambush and catch the invaders out of position, terminating them with extreme prejudice. The taking of war trophies has already begun - stripped combatants trail after citizens on lengths of chain.`); + } if (secExpUnits >= 4) { r.push(`Your`); @@ -114,7 +121,7 @@ App.Events.PCoupAttempt = class PCoupAttempt extends App.Events.BaseEvent { r = []; const newSlaves = []; - if ((secExpUnits / 2) + V.arcologies[0].FSRomanRevivalistLaw + V.arcologies[0].FSNeoImperialistLaw1 + V.mercenaries + V.personalArms + V.hackerSupport + doubleAgent > 8) { + if ((secExpUnits / 2) + V.arcologies[0].FSRomanRevivalistLaw + V.arcologies[0].FSNeoImperialistLaw1 + V.arcologies[0].FSAntebellumRevivalistLaw2 + V.mercenaries + V.personalArms + V.hackerSupport + doubleAgent > 8) { r.push(`<span class="yellow">The Daughters of Liberty are utterly crushed.</span> ${V.arcologies[0].name} has been slightly damaged, but even as the last pockets of resistance are crushed, your citizens begin repairs themselves. The effect on your reputation is <span class="green">immensely positive,</span> since your victory was insultingly easy and barely set the arcology's prosperity back at all. You also took a truly impressive bag of prisoners.`); V.daughtersVictory = 3; cashX(-2000, "war"); @@ -141,7 +148,7 @@ App.Events.PCoupAttempt = class PCoupAttempt extends App.Events.BaseEvent { } addTrinket("a damaged plate carrier bearing Daughters of Liberty insignia"); r.push(IncreasePCSkills('warfare', 5)); - } else if (V.arcologies[0].FSRomanRevivalistLaw === 1 || V.arcologies[0].FSNeoImperialistLaw1 === 1) { + } else if (V.arcologies[0].FSRomanRevivalistLaw === 1 || V.arcologies[0].FSNeoImperialistLaw1 === 1 || V.arcologies[0].FSAntebellumRevivalistLaw2 === 1) { r.push(`<span class="yellow">The Daughters of Liberty are annihilated.</span> <span class="red">${V.arcologies[0].name} has been damaged,</span> and the repairs will be quite costly. However, the effect on your reputation is <span class="green">very positive,</span> since though your victory was hard-fought and set the arcology's prosperity back <span class="red">considerably,</span> you did better than other arcology owners have done when faced with similar well-armed unrest. You also took a truly impressive bag of prisoners.`); V.daughtersVictory = 3; cashX(-5000, "war"); diff --git a/src/events/nonRandom/mercs/pCitizensAndCivilians.js b/src/events/nonRandom/mercs/pCitizensAndCivilians.js index 7aa3cee0814beb2b02b0112531616e57ed7d3098..f6a760057b4c5341a1fb9cc70b892e433250f4fa 100644 --- a/src/events/nonRandom/mercs/pCitizensAndCivilians.js +++ b/src/events/nonRandom/mercs/pCitizensAndCivilians.js @@ -120,6 +120,9 @@ App.Events.PCitizensAndCivilians = class PCitizensAndCivilians extends App.Event if (V.arcologies[0].FSArabianRevivalist >= 10) { choices.push(new App.Events.Result(`They shall be my Janissaries`, FSArabianRevivalist, costDesc())); } + if (V.arcologies[0].FSAntebellumRevivalist >= 10) { + choices.push(new App.Events.Result(`They shall be my Knights of the White Camelia`, FSAntebellumRevivalist, costDesc())); + } if (V.arcologies[0].FSChattelReligionist >= 10) { choices.push(new App.Events.Result(`They shall be the Knights Templar`, FSChattelReligionist, costDesc())); } @@ -207,7 +210,6 @@ App.Events.PCitizensAndCivilians = class PCitizensAndCivilians extends App.Event setConsequences("Black Eagles"); return `You ask for a meeting with your mercenaries' captain and lay out a proposal for a new contract between you over ${V.PC.refreshment}. As he reviews the terms, he looks skeptical, then surprised, then interested, and finally, he breaks out into laughter. "${properTitle()}," he says, "you have no idea how fun this is going to be." He rises and gives you a short bow. "Black Marshal reporting for duty, ${properTitle()}." The mercenaries — no, the Black Eagles — are well looked after. They are each assigned a nice apartment, a freshly enslaved servant, and a suit of prototype armor equipped with the latest weapons and bearing a standard with your Imperial crest. Word of the innovation runs through the Free Cities <span class="green">like wildfire.</span>`; } - function FSAztecRevivalist() { setConsequences("Shorn Ones"); return `You ask for a meeting with your mercenaries' captain and lay out a proposal for a new contract between you over ${V.PC.refreshment}. As he reviews the terms, he looks skeptical, then surprised, then interested, and finally, he breaks out into laughter. "${properTitle()}," he says, "you have no idea how fun this is going to be." He rises and gives you a short bow. "Centurion reporting for duty, ${properTitle()}." The mercenaries — no, the Shorn Ones — are well looked after. They are each assigned a nice apartment, a freshly enslaved servant, and a suit of prototype armor equipped with the latest weapons and bearing an Aztec standard adorned on a spear. Word of the innovation runs through the Free Cities <span class="green">like wildfire.</span>`; @@ -228,6 +230,10 @@ App.Events.PCitizensAndCivilians = class PCitizensAndCivilians extends App.Event setConsequences("Janissaries"); return `You ask for a meeting with your mercenaries' captain and lay out a proposal for a new contract between you over ${V.PC.refreshment}. As he reviews the terms, he looks skeptical, then surprised, then interested, and finally, he breaks out into laughter. "${properTitle()}," he says, "you have no idea how fun this is going to be." He rises and gives you a short bow. "Corbaci reporting for duty, ${properTitle()}." The mercenaries — no, the Janissaries — are well looked after. They are each assigned a nice apartment, a freshly enslaved servant, and a suit of prototype armor equipped with the latest weapons and cloaked in an outer garment of fine oriental silks. Word of the innovation runs through the Free Cities <span class="green">like wildfire.</span>`; } + function FSAntebellumRevivalist() { + setConsequences("Knights of the White Camelia"); + return `You ask for a meeting with your mercenaries' captain and lay out a proposal for a new contract between you over ${V.PC.refreshment}. As he reviews the terms, he looks skeptical, then surprised, then interested, and finally, he breaks out into laughter. "${properTitle()}," he says, "you have no idea how fun this is going to be." He rises and gives you a short bow. "Knight-Commander reporting for duty, ${properTitle()}." The mercenaries — no, the Knights of the White Camelia — are well looked after. They are each assigned a nice apartment, and a suit of prototype armor equipped with the latest weapons, enamelled with white and gold, and emblazoned with a white-and-yellow camellia flower. Word of the innovation runs through the Free Cities <span class="green">like wildfire.</span>`; + } function FSChattelReligionist() { setConsequences("Knights Templar"); return `You ask for a meeting with your mercenaries' captain and lay out a proposal for a new contract between you over ${V.PC.refreshment}. As he reviews the terms, he looks skeptical, then surprised, then interested, and finally, he breaks out into laughter. "${properTitle()}," he says, "you have no idea how fun this is going to be." He rises and gives you a short bow. "Inquisitor-General reporting for duty, ${properTitle()}." The mercenaries — no, the Knights Templar — are well looked after. They are each assigned a nice apartment, a freshly enslaved servant, and a suit of prototype armor equipped with the latest weapons and bearing a cloak emblazoned with the symbol of God. Word of the innovation runs through the Free Cities <span class="green">like wildfire.</span>`; diff --git a/src/events/nonRandom/mercs/pMercsHelpCorp.js b/src/events/nonRandom/mercs/pMercsHelpCorp.js index 26d8b1a88b07e5b62dd3a4a2a92745433e149e76..442c26645c6fc35f44a78658e332edb097927fe3 100644 --- a/src/events/nonRandom/mercs/pMercsHelpCorp.js +++ b/src/events/nonRandom/mercs/pMercsHelpCorp.js @@ -22,6 +22,9 @@ App.Events.PMercsHelpCorp = class PMercsHelpCorp extends App.Events.BaseEvent { if (V.arcologies[0].FSNeoImperialistLaw1 > 0) { r.push(`your Knights vigilantly watching the streets for any possible threat,`); } + if (V.arcologies[0].FSAntebellumRevivalistLaw2 === 1) { + r.push(`your citizens' militias still scouring every corner of the arcology for stragglers,`); + } r.push(`and the ${V.mercenariesTitle} in excellent fighting condition, there just weren't enough concerns from either of your perspectives to fill the time. You sit across your desk from each other, discussing the global situation over ${V.PC.refreshment}.`); App.Events.addParagraph(node, r); diff --git a/src/events/randomEvent.js b/src/events/randomEvent.js index dc3fffff62c43ba80cca4211deed8b1115a7d328..1b405fd5ad5b268ac22a3c4beaecf69ce4e13974 100644 --- a/src/events/randomEvent.js +++ b/src/events/randomEvent.js @@ -347,6 +347,7 @@ App.Events.getNonindividualRecruitmentEvents = function() { new App.Events.REMalefactor(), // recFS + new App.Events.recFSAntebellumRevivalist(), new App.Events.recFSArabianRevivalist(), new App.Events.recFSAssetExpansionist(), new App.Events.recFSAssetExpansionistTwo(), diff --git a/src/events/recFS/recfsAntebellumRevivalist.js b/src/events/recFS/recfsAntebellumRevivalist.js new file mode 100644 index 0000000000000000000000000000000000000000..86d66b936bbd7947a545ff04eaec9e5e8c91ca96 --- /dev/null +++ b/src/events/recFS/recfsAntebellumRevivalist.js @@ -0,0 +1,84 @@ +App.Events.recFSAntebellumRevivalist = class recFSAntebellumRevivalist extends App.Events.BaseEvent { + eventPrerequisites() { + return [ + () => V.FSAnnounced === 1, + () => V.arcologies[0].FSAntebellumRevivalist > random(1, 100) || (V.debugMode > 0 && V.debugModeEventSelection > 0) + ]; + } + + execute(node) { + let r = []; + + let slaveRace = "" + if (V.arcologies[0].FSSubjugationistRace !== 0) { + slaveRace = V.arcologies[0].FSSubjugationistRace; + } else if (V.arcologies[0].FSSupremacist !== 0) { + slaveRace = App.Utils.getRaceArrayWithoutParamRace(V.arcologies[0].FSSupremacistRace).random(); + } else { + slaveRace = "black"; + } + + const slave = GenerateNewSlave("XX", { + minAge: 18, maxAge: 26, ageOverridesPedoMode: 1, mature: 0, nationality: 'American', race: slaveRace, disableDisability: 1 + }); + slave.origin = "$He offered $himself to you for enslavement as an outlet for $his raceplay fetish."; + slave.devotion = random(10, 25); + slave.trust = random(55, 65); + slave.career = "unemployed"; + setHealth(slave, jsRandom(10, 30), undefined, undefined, 0, 0); + slave.face = random(20, 100); + slave.skill.oral = random(5, 35); + slave.skill.anal = random(5, 35); + slave.skill.whoring = random(0, 10); + slave.skill.entertainment = random(35, 55); + slave.intelligence = random(-30, 10); + slave.teeth = "normal"; + slave.behavioralFlaw = "odd"; + slave.accent = 2; + slave.fetish = either("masochist", "submissive", "humiliation"); + slave.energy = 100; + + const { + He, + his, he, him, woman + } = getPronouns(slave); + const {HeA} = getPronouns(assistant.pronouns().main).appendSuffix("A"); + + const contractCost = 1000; + const cost = slaveCost(slave) - contractCost; + + r.push(`You receive so many messages, as a noted titan of the new Free Cities world, that ${V.assistant.name} has to be quite draconian in culling them. ${HeA} lets only the most important through to you. One category of message that always gets through regardless of content, though, is requests for voluntary enslavement. As the new world takes shape, they've become less rare than they once were.`); + App.Events.addParagraph(node, r); + + r = []; + r.push(`The call comes in directly from the petitioner's home in an impoverished urban area. The caller is a ${woman} who, after an initial episode of shyness, starts to excitedly ramble about your Antebellum revivalist project. It's clear ${he} doesn't know very much about it, but ${he} makes it obvious that ${he} strongly fetishizes racial sex play and thinks that's what your project is all about. It's not clear that ${he} even understands that ${he} is petitioning for ${his} own enslavement. ${He} is unemployed with few prospects, and it slowly becomes apparent that ${he} spends all of ${his} free time masturbating and writing pornographic historical fiction, which ${he} is strangely proud of. ${He} sends you a few choice videos and pieces with an awkward giggle, calling it ${his} application.`); + + App.Events.addParagraph(node, r); + node.append(App.Desc.longSlave(slave, {market: "generic"})); + + const choices = []; + + if (V.cash >= contractCost) { + choices.push(new App.Events.Result(`Enslave ${him}`, enslave, `This will cost ${cashFormat(contractCost)}`)); + choices.push(new App.Events.Result(`Sell ${him} immediately`, sell, `This will bring in ${cashFormat(cost)}`)); + } else { + choices.push(new App.Events.Result(null, null, `You lack the necessary funds to enslave ${him}.`)); + } + App.Events.addResponses(node, choices); + + function enslave() { + const frag = new DocumentFragment(); + r = []; + r.push(`${He} arrives and is amazed by the historical architecture, the kind but dignified demeanor of the people, and the luxuries your penthouse offers. However, ${he} quickly realizes they aren't meant for ${him}. ${He} is still quite compliant, and strips quickly once commanded. ${He} may not be very smart, but ${he} catches on quickly.`); + + r.push(App.UI.newSlaveIntro(slave)); + App.Events.addParagraph(frag, r); + return frag; + } + + function sell() { + cashX(cost, "slaveTransfer"); + return `${He} arrives is immediately pushed onto a stage before a small crowd of well-dressed citizens ready for a slave auction. These prospective owners flick their auction paddles up towards the stage, to which an auctioneer responds with vigor. After a few minutes, with the price rising expeditiously, a victor emerges and the auctioneer declares, "Sold!" Before the newly-made slave has a chance to react, ${he} is taken away by a satisfied looking gentleman.`; + } + } +}; diff --git a/src/events/scheduled/seFctvRemote.js b/src/events/scheduled/seFctvRemote.js index ee3cefdfbb201dab4448a28b959b333d669e8248..76f261e6e1244939406c3fd438422b30dcf4d513 100644 --- a/src/events/scheduled/seFctvRemote.js +++ b/src/events/scheduled/seFctvRemote.js @@ -408,6 +408,8 @@ App.Events.SEfctvRemote = class SEfctvRemote extends App.Events.BaseEvent { r.push(`the Caliphates,`); } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { r.push(`imperial China,`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + r.push(`the Antebellum days,`); } else { r.push(`ancient times,`); } diff --git a/src/events/scheduled/seIndependenceDay.js b/src/events/scheduled/seIndependenceDay.js index c00ed0355430ec195bd0d6d061ea7a528c646a68..d6d0188914c7120de473720ae1f802822fbc2f75 100644 --- a/src/events/scheduled/seIndependenceDay.js +++ b/src/events/scheduled/seIndependenceDay.js @@ -90,6 +90,14 @@ App.Events.SEIndependenceDay = class SEIndependenceDay extends App.Events.BaseEv r.push(`Empress`); } r.push(`and Holder of the Mandate of Heaven can command complete attention from ${hisP} arcology the moment ${heP} wishes.`); + } else if (arc.FSAntebellumRevivalist >= lockHigh) { + r.push(`the Reclaimer of the Cause and`); + if (V.PC.title === 1) { + r.push(`Lord of ${V.arcologies[0].name}`); + } else { + r.push(`Lady of ${V.arcologies[0].name}`); + } + r.push(`has the utmost respect from ${hisP} citizens and can command their complete attention the moment ${heP} wishes.`); } else if (arc.FSStatuesqueGlorification >= lockHigh) { r.push(`everyone must look up to ${HeP} Who Stands Above All.`); } else if (arc.FSSlaveProfessionalism >= lockHigh) { @@ -176,6 +184,14 @@ App.Events.SEIndependenceDay = class SEIndependenceDay extends App.Events.BaseEv r.push(`Empress,`); } r.push(`you command enough respect that your citizens will listen to you so long as you do not abuse the privilege.`); + } else if (arc.FSAntebellumRevivalist >= lockLow) { + r.push(`as the`); + if (V.PC.title === 1) { + r.push(`Lord`); + } else { + r.push(`Lady`); + } + r.push(`of the ${V.arcologies[0].name}, you command enough respect that your citizens will listen to you so long as you do not abuse the privilege.`); } else if (arc.FSSlaveProfessionalism >= lockLow) { r.push(`as a Genius, you command enough attention that your citizens will listen to you so long as you do not abuse the privilege.`); } else if (arc.FSSupremacist >= lockLow) { @@ -386,6 +402,12 @@ App.Events.SEIndependenceDay = class SEIndependenceDay extends App.Events.BaseEv } else if (arc.FSChineseRevivalist >= 40) { r.push(`You ask that your citizens will continue to support your pursuit of the Mandate of Heaven.`); } + } else if (arc.FSAntebellumRevivalist !== "unset") { + if (arc.FSAntebellumRevivalist >= 90) { + r.push(`You speak warmly of the state of the magnificent new Southron society that you have built together, and express a hope that it's strength will never again falter. `); + } else if (arc.FSAntebellumRevivalist >= 40) { + r.push(`You ask that your citizens will support the beauty of the American South and to uphold it's God-given principles.`); + } } if (arc.FSChattelReligionist !== "unset") { if (arc.FSChattelReligionist >= 90) { diff --git a/src/facilities/arcade/arcade.js b/src/facilities/arcade/arcade.js index 39ac9ba3a1afeab5888351f4de03b23f6abfbf5b..463bface44714ac3cd688eaa03f09c82f1e39a0d 100644 --- a/src/facilities/arcade/arcade.js +++ b/src/facilities/arcade/arcade.js @@ -51,6 +51,7 @@ App.Facilities.Arcade.arcade = class Arcade extends App.Facilities.Facility { "Edo Revivalist": `is built to look like an Edo onsen, with discreet partitions allowing citizens a modicum of privacy as they use the services here. There are baths available so they can wash themselves afterward.`, "Arabian Revivalist": `is built to look like a fantastical Arabian dungeon, with the inmates kept in iron cages that hold their holes in place for use.`, "Chinese Revivalist": `is set up to look like a rough bar in an ancient Chinese city, with the inmates immured in the bar itself. Rowdy citizens can drink and fuck the holes here while shouting and boasting over the slaves' heads.`, + "Antebellum Revivalist": `is built like a perverse saloon. Inmates are held in fine wood panelled walls, asses hanging out enough to be groped and abused, separated by small wooden dividers like those between urinals, so citizens can hold polite conversation while they're otherwise indisposed.`, "Chattel Religionist": `is well decorated with severe religious iconography, since this place is an acceptable if not respectable place for a citizen to find relief, so long as they keep the service of the slave they use here in mind.`, "Degradationist": `is nothing but a system of harnesses to hold slaves in the usual posture they would hold within a normal Free Cities sex arcade. This way, no iota of their degradation here is missed.`, "Asset Expansionist": `is constructed so that the slaves lie within the arcade facing up. The wall itself ends at waist height, so their breasts stick up to be groped while they are used from either end.`, diff --git a/src/facilities/barracks.js b/src/facilities/barracks.js index aa117a908485a1deeddae9aeed3b57d8c9efe728..1981265b414fa26c200809cba9d365fb263f73ab 100644 --- a/src/facilities/barracks.js +++ b/src/facilities/barracks.js @@ -49,6 +49,9 @@ App.UI.barracks = function() { case "Janissaries": r.push(`They consider themselves a caste apart, and keep to themselves, priding themselves on relentless training and perpetual readiness.`); break; + case "Knights of the White Camelia": + r.push(`In their gleaming armor, they, at times, resemble knights of Arthurian legend moreso than men of the 21st century.`); + break; case "Knights Templar": r.push(`All the armor includes a modernized version of a white surcoat emblazoned with the symbol of the new faith.`); break; @@ -245,6 +248,8 @@ App.UI.barracks = function() { // TODO: } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { // TODO: + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + // TODO: } } diff --git a/src/facilities/cellblock/cellblock.js b/src/facilities/cellblock/cellblock.js index 22728dba063c0c2a00f1c78a4856668676186ba2..869b69ebc05da3bdf02e9560e3538dff2a9eb22b 100644 --- a/src/facilities/cellblock/cellblock.js +++ b/src/facilities/cellblock/cellblock.js @@ -47,6 +47,7 @@ App.Facilities.Cellblock.cellblock = class Cellblock extends App.Facilities.Faci "Edo Revivalist": `is furnished in a severely medieval Japanese style. There is one refinement, but it's of exquisite cruelty. At the end of the hall, there's a fountain with a traditional bamboo boar scarer. As it fills with water, it tips against a stone with a thunk... thunk... thunk... thunk...`, "Arabian Revivalist": `is furnished as imagined Arabian slave pens, all set around a central pillar. This pillar is capped by shackles, so that slaves can be bound by their hands and whipped on the backs, buttocks, and thighs in clear view of all their fellow chattel.`, "Chinese Revivalist": `is furnished in a severely medieval Chinese style. There is one refinement, but it's of exquisite cruelty. Somewhere out of sight, water is dripping into an urn, drop by drop... drop... drop... drop...`, + "Antebellum Revivalist": `is dark, built of cold, cyclopean stones. A large, iron-reinforced hatch secures the entrance. The slaves are kept in iron shackles, confined in their tiny cells in the pitch blackness. Far below lies the oubliette, where the worst slaves are thrown and forgotten about - or, at least, that's what they're told.`, "Chattel Religionist": `is built of cold stone. Most of the cells are unfurnished little cubes inside which the only bed is the bare floor. A few are smaller still, so that the inmates can neither stand nor lie flat.`, "Degradationist": `is a nightmare. Everything is made of metal, and almost everything menaces with spikes of steel. Inmates must carefully avoid the walls of their own cells if they wish to avoid being stabbed.`, "Asset Expansionist": `is a straightforward prison, with one exception. Each cell features a screen displaying plans for its inmate's expansion. Day and night, inmates are confronted with the sight of themselves transformed.`, diff --git a/src/facilities/clinic/clinic.js b/src/facilities/clinic/clinic.js index 07fcd03b757dddee83b8bb400a7b756c6d373037..bb1e850b821e6574ab0e6201bca367b6bcd56586 100644 --- a/src/facilities/clinic/clinic.js +++ b/src/facilities/clinic/clinic.js @@ -52,6 +52,7 @@ App.Facilities.Clinic.clinic = class Clinic extends App.Facilities.Facility { "Edo Revivalist": `is clean and spartan to the point of featurelessness. Spotless tatami mats cover the floor, and partitions divide the space into cubicles.`, "Arabian Revivalist": `is open and airy; a thin trail of smoke wafts through the space on a gentle breeze, coming from a brazier burning incense.`, "Chinese Revivalist": `is open and airy; a thin trail of smoke wafts through the space on a gentle breeze, coming from a brazier burning medicinal herbs.`, + "Antebellum Revivalist": `is designed after a sanatorium; enormous windows here ensure there's a constant flow of air and bright sunshine, and the ceiling is particularly high here. Everything is simple and clean.`, "Chattel Religionist": `is open and airy; shaded beams of sunlight shine through skylights to bathe each bed in a pool of healing warmth.`, "Degradationist": `is clean and cold, all scrubbed tile and cool steel. The beds have prominent restraint attachment points to force patients into any position desired.`, "Repopulationist": `is warm and inviting, with wide corridors and ample seating for its pregnant clientèle. All the equipment is designed to accommodate heavily pregnant women.`, diff --git a/src/facilities/dairy/dairy.js b/src/facilities/dairy/dairy.js index b2589c70ec489519d36ad1b345679b934ddac566..fe3fea329d128532b2e0ec0e97fe7caab86099b6 100644 --- a/src/facilities/dairy/dairy.js +++ b/src/facilities/dairy/dairy.js @@ -131,6 +131,7 @@ App.Facilities.Dairy.dairy = class Dairy extends App.Facilities.Facility { "Edo Revivalist": `It looks out on a strangely contradictory sight: a beautiful and terrible combination of modern slavery and technology, placed amongst tatami mats and rice paper partitions.`, "Arabian Revivalist": `It looks out on a strangely contradictory sight: a beautiful and terrible combination of modern slavery and technology, placed inside brightly tiled walls.`, "Chinese Revivalist": `The milking machines are fascinating: they're encased in decorative carvings, making it look like the slaves are in the embrace of traditional Chinese depictions of lions, bears, and dragons.`, + "Antebellum Revivalist": `The gallery is richly decorated like an opera box, providing a comfortable spot to view the factory floor below. On one wall, long lines of chalk form a grid, with each row corresponding to one of the cattle. A little photograph, the cow's name, and various stats, such as asset volume and productivity, fill out the columns.`, "Chattel Religionist": `It presents the inmates as lessons, here to expiate their sins in a purgatory created by technology.`, "Degradationist": `The screens there feature, among a sea of facts and figures about each slave, their most recent brain scan.`, "Repopulationist": `The gallery is placed for a good view of each slave's swelling breasts and growing pregnancy. A screen is prominently displayed before each slave, detailing the number of babies she produced and the current number occupying their womb.`, @@ -164,6 +165,7 @@ App.Facilities.Dairy.dairy = class Dairy extends App.Facilities.Facility { "Edo Revivalist": `is clean and traditional. The stalls are constructed of bamboo and carefully shaped wood, and muscle power is used wherever possible. Cows exercise and help out by walking on a wooden wheel that raises fresh water to ${this.facility.name}.`, "Arabian Revivalist": `is clean and traditional. Its dusky stone walls keep it so warm that the cows go nude, basking in the hot sun between milkings.`, "Chinese Revivalist": `is clean and traditional. The stalls are constructed of bamboo and carefully shaped wood, and muscle power is used wherever possible. Cows exercise and help out by fetching and carrying as best they can.`, + "Antebellum Revivalist": `is like a barn, and isn't kept especially clean. Each cow has a stall fitted with a harness, not unlike a saddle, and the floor is covered with a healthy layer of straw.`, "Chattel Religionist": `is functional and clean. There are nice quotations from the holy book on the walls, and there is a little shrine designed to allow a cow who has difficulty standing to make their devotions comfortably.`, "Degradationist": `is harsh and utilitarian. There are stands to restrain cows who aren't being milked for dosing, punishment, or sexual use. There are cattle prods here and there to use on resistant cows, unproductive cows, or cows one wishes to hear scream.`, "Repopulationist": `is comfortable and well-kept. The milking machines are specially designed to maximize a pregnant cow's comfort. After a milking, cows have a wide selection of soft furniture to choose from, so comfortable that most fall fast asleep.`, diff --git a/src/facilities/farmyard/farmyardDecorations.js b/src/facilities/farmyard/farmyardDecorations.js index 0d01068c68dcb64b63a912c5126f7f4596087af9..717422507b56755bc9922e280706e96c2f18d851 100644 --- a/src/facilities/farmyard/farmyardDecorations.js +++ b/src/facilities/farmyard/farmyardDecorations.js @@ -11,6 +11,7 @@ App.Facilities.Farmyard.getDecoration = function() { "Edo Revivalist": `It does its best to mimic the rice patties and thatch roofed buildings of the Edo period despite the wide variety of crops tended by various slaves. Not every crop can thrive in flooded fields, but the ones that can take advantage of your attention to detail.`, "Arabian Revivalist": `Large plots of olive trees and date palms line the outer edges of the main crop area, while a combination of wheat, flax, and barley occupies the interior space. Irrigation canals snake through the area, ensuring every inch of cropland is well-watered.`, "Chinese Revivalist": `It does its best to capture the terraces that covered the ancient Chinese hills and mountains, turning every floor into ribbons of fields following a slight incline. Slaves wade through crops that can handle flooding and splash through the irrigation of the others when they aren't tending to${V.seeBestiality ? ` or breeding with` : ``} your animals.`, + "Antebellum Revivalist": `It looks like the spitting image of an old plantation, with a stately building adorned with doric columns serving as the central fixture. An immaculately maintained lawn and long, orderly rows of crops, dutifully attended by slaves, surround it. Overseers on horseback trot up and down the farm, diligently maintaining watch. A few patches of land are dedicated to the cultivation of historical cash crops, like cotton, coffee, tea, in a deliberate homage.`, "Chattel Religionist": `It runs like a well oiled machine, slaves bent in humble service as they tend crops grown on the Prophet's command, or see to the animals' needs. Their clothing is tucked up and out of the way as they see to their tasks, keeping them clean as they work ${V.seeBestiality ? `around animal-bloated bellies ` : ``}as divine will dictates.`, "Degradationist": `It is constructed less as a converted warehouse and more as something to visit, allowing guests to enjoy the spectacle of slaves ${V.seeBestiality ? `being pounded by eager animals` : `elbow deep in scrubbing animal waste`} to their satisfaction.`, "Repopulationist": `It teems with life, both in the belly of every animal and the belly of every slave, though the latter makes tending the fields difficult. They're ordered to take care, as they carry the future ${V.seeBestiality ? `of this farm` : `of the arcology`} in their bellies.`, @@ -47,6 +48,7 @@ App.Facilities.Farmyard.getDecoration = function() { "Edo Revivalist": `It does its best to mimic the rice patties and thatch roofed buildings of the Edo period despite the wide variety of crops tended by various slaves. Not every crop can thrive in flooded fields, but the ones that can take advantage of your attention to detail.`, "Arabian Revivalist": `Large plots of olive trees and date palms line the outer edges of the main crop area, while a combination of wheat, flax, and barley occupies the interior space. Irrigation canals snake through the area, ensuring every inch of cropland is well-watered.`, "Chinese Revivalist": `It does its best to capture the terraces that covered the ancient Chinese hills and mountains, turning every floor into ribbons of fields following a slight incline. Slaves wade through crops that can handle flooding and splash through the irrigation of the others when they aren't tending to${V.seeBestiality ? ` or breeding with` : ``} your animals.`, + "Antebellum Revivalist": `It looks like the spitting image of an old plantation, with a stately building adorned with doric columns serving as the central fixture. An immaculately maintained lawn and long, orderly rows of crops, dutifully attended by slaves, surround it. Overseers on horseback trot up and down the farm, diligently maintaining watch. A few patches of land are dedicated to the cultivation of historical cash crops, like cotton, coffee, tea, in a deliberate homage.`, "Chattel Religionist": `It runs like a well oiled machine, slaves bent in humble service as they tend crops grown on the Prophet's command, or see to the animals' needs. Their clothing is tucked up and out of the way as they see to their tasks, keeping them clean as they work ${V.seeBestiality ? `around animal-bloated bellies ` : ``}as divine will dictates.`, "Degradationist": `It is constructed less as a converted warehouse and more as something to visit, allowing guests to enjoy the spectacle of slaves ${V.seeBestiality ? `being pounded by eager animals` : `elbow deep in scrubbing animal waste`} to their satisfaction.`, "Repopulationist": `It teems with life, both in the belly of every animal and the belly of every slave, though the latter makes tending the fields difficult. They're ordered to take care, as they carry the future ${V.seeBestiality ? `of this farm` : `of the arcology`} in their bellies.`, @@ -82,6 +84,7 @@ App.Facilities.Farmyard.getDecoration = function() { "Edo Revivalist": `It does its best to mimic the rice patties and thatch roofed buildings of the Edo period despite the wide variety of crops tended by various slaves. Not every crop can thrive in flooded fields, but the ones that can take advantage of your attention to detail.`, "Arabian Revivalist": `Large plots of olive trees and date palms line the outer edges of the main crop area, while a combination of wheat, flax, and barley occupies the interior space. Irrigation canals snake through the area, ensuring every inch of cropland is well-watered.`, "Chinese Revivalist": `It does its best to capture the terraces that covered the ancient Chinese hills and mountains, turning every floor into ribbons of fields following a slight incline. Slaves wade through crops that can handle flooding and splash through the irrigation of the others when they aren't tending to${V.seeBestiality ? ` or breeding with` : ``} your animals.`, + "Antebellum Revivalist": `It looks like the spitting image of an old plantation, with a stately building adorned with doric columns serving as the central fixture. An immaculately maintained lawn and long, orderly rows of crops, dutifully attended by slaves, surround it. Overseers on horseback trot up and down the farm, diligently maintaining watch. A few patches of land are dedicated to the cultivation of historical cash crops, like cotton, coffee, tea, in a deliberate homage.`, "Chattel Religionist": `It runs like a well oiled machine, slaves bent in humble service as they tend crops grown on the Prophet's command, or see to the animals' needs. Their clothing is tucked up and out of the way as they see to their tasks, keeping them clean as they work ${V.seeBestiality ? `around animal-bloated bellies ` : ``}as divine will dictates.`, "Degradationist": `It is constructed less as a converted warehouse and more as something to visit, allowing guests to enjoy the spectacle of slaves ${V.seeBestiality ? `being pounded by eager animals` : `elbow deep in scrubbing animal waste`} to their satisfaction.`, "Repopulationist": `It teems with life, both in the belly of every animal and the belly of every slave, though the latter makes tending the fields difficult. They're ordered to take care, as they carry the future ${V.seeBestiality ? `of this farm` : `of the arcology`} in their bellies.`, diff --git a/src/facilities/masterSuite/masterSuite.js b/src/facilities/masterSuite/masterSuite.js index 9bd1ab46014bcdaecf737aa859b469b9fb2b1eae..4f7cb8ab0e5e7ccd6282dadeeac22ba5f666ef55 100644 --- a/src/facilities/masterSuite/masterSuite.js +++ b/src/facilities/masterSuite/masterSuite.js @@ -156,6 +156,7 @@ App.Facilities.MasterSuite.masterSuite = class MasterSuite extends App.Facilitie "Edo Revivalist": `in the spartan style of an Edo period castle's innermost rooms. Rice paper screens partition off many small cubicles around its large central space. There, around a low bed, there are many mats for servants to kneel around their ${properMaster()}.`, "Arabian Revivalist": `as a beguiling haze of Arabian decadence. There is a great gilded bed in the center of the space, piled with silk pillows for naked bodies to recline on. Gauzy curtains flutter in the warm, heady breeze.`, "Chinese Revivalist": `as though it were the innermost sanctum of the Forbidden City. A massive bed fills the central space. The walls are gorgeous gilded hand-carved screens, and heavy jade statues of favored gods crouch in the corners.`, + "Antebellum Revivalist": `is furnished with heavy, black oaken furniture intricately carved and inlaid with mother of pearl. A massive canopied bed draped in sheer chiffon curtains is the centerpiece. A cozy sitting area, prominently featuring a royal divan upholstered in a deep purple fabric, lies about a grand fireplace with marble façade. Large windows framed in exotic hardwood imported from North America give a wonderful, top-down view of the arcology below.`, "Chattel Religionist": `as a severe place of cold stone and hard wood. A single shaft of sunlight illuminates an enormous stone platform that serves as a bed where penitents give their bodies to their ${properMaster()}.`, "Degradationist": `with a gothic grandeur. Blood-red upholstery and hardwood menace crouch in the center of the space in the form of a massive poster bed with curtains of chain mail.`, "Repopulationist": `comfortably, with lots of cushions and seats for pregnant slaves to lounge on. Various specialized toys, as well as, lotions and creams are readily available. There's a huge, reinforced, low to the ground bed in the middle of the suite.`, @@ -189,6 +190,7 @@ App.Facilities.MasterSuite.masterSuite = class MasterSuite extends App.Facilitie "Edo Revivalist": `in the spartan style of an Edo period castle's innermost rooms. Rice paper screens partition off many small cubicles around its large central space.`, "Arabian Revivalist": `as a beguiling haze of Arabian decadence. Gauzy curtains flutter in the warm, heady breeze.`, "Chinese Revivalist": `as though it were the innermost sanctum of the Forbidden City. The walls are gorgeous gilded hand-carved screens, and heavy jade statues of favored gods crouch in the corners.`, + "Antebellum Revivalist": `is furnished with heavy, black oaken furniture intricately carved and inlaid with mother of pearl. A cozy sitting area, prominently featuring a royal divan upholstered in a deep purple fabric, lies about a grand fireplace with marble façade. Large windows framed in exotic hardwood imported from North America give a wonderful, top-down view of the arcology below.`, "Chattel Religionist": `as a severe place of cold stone and hard wood. A single shaft of sunlight illuminates the central space.`, "Degradationist": `with a gothic grandeur. Blood-red upholstery and hardwood menace decorate the walls.`, "Repopulationist": `comfortably, with lots of cushions and seats for a pregnant slaves to lounge on. There are various specialized toys, as well as, lotions and creams readily available.`, @@ -222,6 +224,7 @@ App.Facilities.MasterSuite.masterSuite = class MasterSuite extends App.Facilitie "Edo Revivalist": `in the spartan style of an Edo period mansion's innermost rooms. Rice paper screens divide it into subsections, each of which contains little more than a low bed.`, "Arabian Revivalist": `as a beguiling haze of Arabian decadence. Soft cushions are scattered across the floor and piled against the walls to provide something for dusky, naked bodies to recline on. Gauzy curtains partition the room into a number of cozy dens.`, "Chinese Revivalist": `like the mansion of a senior mandarin of ancient China. The walls are gorgeous hand-carved wooden screens, and heavy jade statues of favored gods crouch in the corners.`, + "Antebellum Revivalist": `after the master bedroom of a palatial plantation house. A cozy sitting area, prominently featuring a royal divan upholstered in a deep purple fabric, lies about a grand fireplace with marble façade. Large windows framed in exotic hardwood imported from North America give a wonderful, top-down view of the arcology below.`, "Chattel Religionist": `as a severe place of cold stone and hard wood. A single shaft of sunlight illuminates the bed where penitents give their bodies to their ${properTitle()}.`, "Repopulationist": `comfortably, with lots of cushions and seats for a pregnant slaves to lounge on. Various specialized toys, as well as, lotions and creams are readily available.`, "Eugenics": `comfortably, with lots of easy-to-clean leather and plentiful tools, toys, and lubricants to make fucking slave girls lots of fun. Condoms and spermicides are readily available throughout the suite.`, diff --git a/src/facilities/nursery/nursery.js b/src/facilities/nursery/nursery.js index d76f3c87d14c482e8d88ad757a9731e9ad0d93c7..3c82ccf309837fbaa4000812f93ae2e5f9484376 100644 --- a/src/facilities/nursery/nursery.js +++ b/src/facilities/nursery/nursery.js @@ -50,6 +50,7 @@ App.Facilities.Nursery.nursery = class Nursery extends App.Facilities.Facility { "Edo Revivalist": `is minimalist in nature, but the errant paintings of cherry blossoms and vibrant Japanese maples give a certain peaceful air as the caretakers do their duties.`, "Arabian Revivalist": `is decorated wall to wall with splendorous carvings and religious Hamsas meant to protect the fostering children.`, "Chinese Revivalist": `is ripe with Chinese spirit. Depictions of colorful dragons and oriental designs grace the halls, rooms, and cribs of the babies who reside inside.`, + "Antebellum Revivalist": `is warm and inviting. Carved wooden panels line the lower half of the walls while gentle pastel colored wall paper decorates the upper half; a soft pink for where the girls stay, and a baby blue for the boys. Big windows of frosted glass shine onto a rich walnut floor. Hand-crafted cribs line the walls.`, "Chattel Religionist": `is decorated with childish religious cartoons and artistic tapestries of slaves bowing in submission, their themes always subsiding varying degrees of sexual worship. The caretakers that wander the halls obediently wear their habits, and never waste a moment to tenderly lull the children to sleep with stories of their prophet.`, "Degradationist": `is bare and sullen. The cries of the neglected children destined for slavery trying to find comfort in their burlap coverings echo the halls, while those that await freedom are raised among luxury and are taught to look down on their less fortunate peers.`, "Repopulationist": `is designed to be very open and public; a showing testament to your arcology's repopulation efforts. For those old enough to support them, they are strapped with big, but body warming, empathy bellies as to remind them of their destiny.`, diff --git a/src/facilities/pit/pit.js b/src/facilities/pit/pit.js index 922dc56562a0a2cb6a26c718d2839c0e5cec7282..4b377f034145e3b5eb4e5029b2d91d2c384f21e1 100644 --- a/src/facilities/pit/pit.js +++ b/src/facilities/pit/pit.js @@ -142,6 +142,8 @@ App.Facilities.Pit.pit = function() { text.push(`Tian's gates, Jade Emperor's arcology, while on the wall of the fighting area, the disobedient one is tortured in Diyu by yaoguai-like raiders.`); } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { text.push(`Tonatiuhtlán's gates, TÅnatiuh's celestial arcology, to accompany the sun during the morning, while on the wall of the fighting area, the disobedient one is sent to MictlÄn to suffer through many challenges.`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + text.push(`Heaven's gates, God's celestial arcology, while on the wall of the fighting area, the disobedient one falls to Hell, where lakes of fire burn for eternity.`); } else { text.push(`Paradise's gates, Allslaver's celestial arcology, while on the wall of the fighting area, the disobedient one is sentenced to survive in the Wasteland of the Freedom Trickster.`); } @@ -157,6 +159,7 @@ App.Facilities.Pit.pit = function() { "Edo Revivalist": `is a lush Japanese garden surrounding a pond filled with large, colorful koi. A red wooden footbridge links the garden with the small island that lies in the middle of the pond, which is where the slaves fight.`, "Arabian Revivalist": `is a riad, a symmetrical indoor garden centered around the fighting area. Seating for guests are available under the shade of the flora and the surrounding balconies decorated with complex arabesque.`, "Chinese Revivalist": `is decorated like a traditional Chinese courtyard, with a large open area in the center surrounded by low buildings with brick walls and clay tile roofs. A couple of bronze-cast Chinese guardian lions protect the entrance of the structure.`, + "Antebellum Revivalist": `is a richly decorated theater. It is a large, cavernous space with a sandy pit in the center surrounded with tiered seating. An orchestra plays for particularly dramatic fights. The poorest sit near "the gods", the highest area of the theater, while wealthier citizens may have their own reserved boxes with private seating.`, "Chattel Religionist": chattelReligionist(), "Degradationist": `is a large, modern arena with huge screens mounted strategically to allow its guests the best possible view of the combatants' rape or dismemberment.`, "Repopulationist": `is a large, modern stadium with a large open area in the center for the fighters. The bleachers are connected with adjacent birthing areas furnished with wall screens allowing the mothers to enjoy the fight while increasing ${V.arcologies[0].name}'s population.`, @@ -173,7 +176,7 @@ App.Facilities.Pit.pit = function() { "Maturity Preferentialist": `is a large arena with the same architectural style as the arenas built in the first arcologies ever made.`, "Youth Preferentialist": `is a large, modern arena that is regularly decorated by the most trending arcologies' fashion designers.`, "Body Purist": `is a large arena made entirely out of local wood and stone and constructed with little to no fasteners, bindings or adhesives.`, - "Slimness Enthusiast": `is a large, modern arena made of graphene and other lightweight materials, allowing natural light to illuminate every corner of the structure.`, + "Slimness Enthusiast": `is a large, modern arena made of graphene and other lightweight materials, allowing natural light to illuminate every corner of the structure.`, "Hedonistic": `is both a large, modern arena and a congregation of restaurants. Its many chefs compete as fiercely as the fighters to offer vast quantities of caloric nourishment for the audience.`, "Intellectual Dependency": `is a large, modern arena decorated with simple and cartoonish representation of gladiatorial fights. Phallus-shaped foam bats are given to the easily-bored bimbo slaves while their masters watch the fights in peace.`, "Slave Professionalism": `is a large, modern arena decorated with displays of armed and unarmed fighting stances to incite slave owners to train their favorite slaves with combat skills.`, diff --git a/src/facilities/schoolroom/schoolroom.js b/src/facilities/schoolroom/schoolroom.js index 52a1464dfd39f2baac1037c2fd4711069e34d01d..78e5816be6ac38e10665ab9718077665cd62f1c0 100644 --- a/src/facilities/schoolroom/schoolroom.js +++ b/src/facilities/schoolroom/schoolroom.js @@ -50,6 +50,7 @@ App.Facilities.Schoolroom.schoolroom = class Schoolroom extends App.Facilities.F "Edo Revivalist": `showing an interpretation of Japanese cultural history that emphasizes a serf's duty to her social superiors.`, "Arabian Revivalist": `showing an interpretation of Arabian cultural history that focuses on thriving slave markets and vibrant harems.`, "Chinese Revivalist": `showing an interpretation of Chinese cultural history that focuses on concubinage, palace etiquette, and social order.`, + "Antebellum Revivalist": `showing a film which demonstrates just how good the slaves at your arcology have it and how, on other plantations, slave owners horribly mistreat their property.`, "Chattel Religionist": `displaying a passage from the holy book that supports slavery.`, "Degradationist": `displaying a rote recitation of a slave's proper acceptance of her subhuman status.`, "Repopulationist": `reviewing a number of sexual positions to accommodate a heavily pregnant girl.`, diff --git a/src/facilities/servantsQuarters/servantsQuarters.js b/src/facilities/servantsQuarters/servantsQuarters.js index 781446d93855c8758b8ae676b77d80b4fa4e0368..67fd950b60d2a0e128a05011e73dee26a1eb26ce 100644 --- a/src/facilities/servantsQuarters/servantsQuarters.js +++ b/src/facilities/servantsQuarters/servantsQuarters.js @@ -47,6 +47,7 @@ App.Facilities.ServantsQuarters.servantsQuarters = class ServantsQuarters extend "Edo Revivalist": `are spartan and functional. Fresh mats are laid across the floor every day, and the simple beds of blankets and wooden blocks are neatly stowed against the walls before sunrise.`, "Arabian Revivalist": `are utilitarian, yet warm and well-kept. They are floored with beautifully patterned tile; there are channels for clean running water that make it easy to keep clean and fresh, so long as one is willing to bathe in the open.`, "Chinese Revivalist": `are spartan, yet functional. At one end of the long dormitory there is an alcove with a shrine hosting a bronze statue of a watchful dragon.`, + "Antebellum Revivalist": `are spartan, yet functional. There is an unyielding, hostile quality to the environment. The design deliberately gives the impression that the ${this.facility.nameCaps} is separate from the rest of the penthouse.`, "Chattel Religionist": `are spartan, yet functional. Servants here are expected to be clean and hardworking, and there is a penitents cell ready for them if they are not.`, "Degradationist": `are severe and utilitarian. Servants sleep uncomfortably here, knowing that even on their meager bedrolls, they are fair game for abuse.`, "Repopulationist": `are comfortable and well-kept. Though there is little privacy here, the servants are provided for. There's even a small rest area for them to rest their pregnant bodies between shifts. A closet contains specialized cleaning tools to accommodate their distended bodies.`, diff --git a/src/facilities/spa/spa.js b/src/facilities/spa/spa.js index 4aa53f535c1357ba8d388d68269e61b845c50942..ef89cdb964fb0765230d5fb6122c00685b6b6adb 100644 --- a/src/facilities/spa/spa.js +++ b/src/facilities/spa/spa.js @@ -53,6 +53,7 @@ App.Facilities.Spa.spa = class Spa extends App.Facilities.Facility { "Edo Revivalist": `is decorated like a traditional onsen. The stone-lined pools are surrounded by meticulously kept gardens, and there are proper provisions for bathing in the old Japanese style.`, "Arabian Revivalist": `looks like a dream of an Arabian palace garden. Every surface is richly tiled in vibrant colors, and the beguiling scents of perfumes from the Levant hang in the air.`, "Chinese Revivalist": `is gloomy and hot, filled with an oppressive steam that immediately dulls the senses. Though relaxation is possible and indeed easy here, it is a stultifying relaxation whose humid warmth seems to suppress independence.`, + "Antebellum Revivalist": `is humid and dim, like the jungle floor. From suspended pots, exotic flowers dangle beautiful blooms over a steaming pool tiled in beautiful mosaic. The green glass panes which make up the ceiling and walls are lined with glistening scrollwork and opaque with steam.`, "Chattel Religionist": `is dedicated to the purification of the body and the spirit. The pools are arranged for the completion of self-purification procedures which include ritual masturbation.`, "Degradationist": `is utilitarian. There are waterproof cameras positioned throughout the spa so that anyone who wants to can watch the nude slaves. One wall has a screen showing the current viewer count to keep the slaves aware of this.`, "Asset Expansionist": `is utilitarian. It is equipped with all sorts of devices to help slaves care for huge assets, including lifts to help them in and out of the water, and all around showers to help clean and moisturize difficult to reach spots.`, diff --git a/src/facilities/wardrobe/wardrobeShoppingData.js b/src/facilities/wardrobe/wardrobeShoppingData.js index c57af76fc4fde4b77db038a3f630dcde8eec8d1c..5de7828c6c6121cb64c88d3259d8b758682645c0 100644 --- a/src/facilities/wardrobe/wardrobeShoppingData.js +++ b/src/facilities/wardrobe/wardrobeShoppingData.js @@ -133,6 +133,12 @@ App.Data.WardrobeShopping.Clothing = { contains: ["a tight Imperial bodysuit"], owned: "You are well stocked with tight-fitting cybernetic bodysuits clearly bearing your family crest.", }, + "antebellum": { + title: "a shipment of dresses in the Antebellum fashion", + cost: 7500, + contains: ["a confederate army uniform", "an evening dress"], + owned: "You are well stocked with extravagant Antebellum dresses." + } }, other: { "military": { diff --git a/src/futureSocieties/fsPassage.js b/src/futureSocieties/fsPassage.js index e0e9be9cb304dcd115d2aa1cf79792b36810c76b..99771ff7badddfa9e05a4f4dc88cb5fc22e0343d 100644 --- a/src/futureSocieties/fsPassage.js +++ b/src/futureSocieties/fsPassage.js @@ -276,6 +276,19 @@ App.UI.fsPassage = function() { } ) ); + } else if (arc.FSAntebellumRevivalist !== "unset") { + linkArray.push( + App.UI.DOM.link( + "Rename all your slaves according to old Southern custom", + () => { + for (const slave of V.slaves) { + slave.slaveName = App.Data.misc.antebellumSlaveNames.random(); + slave.slaveSurname = App.Data.misc.antebellumSlaveSurnames.random(); + } + refresh(); + } + ) + ); } if (arc.FSDegradationist !== "unset") { linkArray.push( @@ -1201,7 +1214,7 @@ App.UI.fsPassage = function() { /* Revival section */ p = document.createElement("p"); r = []; - if ((arc.FSAztecRevivalist === "unset") && (arc.FSEgyptianRevivalist === "unset") && (arc.FSEdoRevivalist === "unset") && (arc.FSArabianRevivalist === "unset") && (arc.FSChineseRevivalist === "unset") && (arc.FSNeoImperialist === "unset")) { + if ((arc.FSAztecRevivalist === "unset") && (arc.FSEgyptianRevivalist === "unset") && (arc.FSEdoRevivalist === "unset") && (arc.FSArabianRevivalist === "unset") && (arc.FSChineseRevivalist === "unset") && (arc.FSNeoImperialist === "unset") && (arc.FSAntebellumRevivalist === "unset")) { if (arc.FSRomanRevivalist !== "unset") { r.push(pursuit()); r.push(`a vision of a new Rome.`); @@ -1226,7 +1239,7 @@ App.UI.fsPassage = function() { } App.Events.addNode(p, r, "div"); r = []; - if ((arc.FSAztecRevivalist === "unset") && (arc.FSEgyptianRevivalist === "unset") && (arc.FSEdoRevivalist === "unset") && (arc.FSArabianRevivalist === "unset") && (arc.FSChineseRevivalist === "unset") && (arc.FSRomanRevivalist === "unset")) { + if ((arc.FSAztecRevivalist === "unset") && (arc.FSEgyptianRevivalist === "unset") && (arc.FSEdoRevivalist === "unset") && (arc.FSArabianRevivalist === "unset") && (arc.FSChineseRevivalist === "unset") && (arc.FSRomanRevivalist === "unset") && (arc.FSAntebellumRevivalist === "unset")) { if (arc.FSNeoImperialist !== "unset") { r.push(pursuit()); r.push(`a vision of a new Imperial Society.`); @@ -1251,7 +1264,7 @@ App.UI.fsPassage = function() { } App.Events.addNode(p, r, "div"); r = []; - if ((arc.FSRomanRevivalist === "unset") && (arc.FSEgyptianRevivalist === "unset") && (arc.FSEdoRevivalist === "unset") && (arc.FSArabianRevivalist === "unset") && (arc.FSChineseRevivalist === "unset") && (arc.FSNeoImperialist === "unset")) { + if ((arc.FSRomanRevivalist === "unset") && (arc.FSEgyptianRevivalist === "unset") && (arc.FSEdoRevivalist === "unset") && (arc.FSArabianRevivalist === "unset") && (arc.FSChineseRevivalist === "unset") && (arc.FSNeoImperialist === "unset") && (arc.FSAntebellumRevivalist === "unset")) { if (arc.FSAztecRevivalist !== "unset") { r.push(pursuit()); r.push(`a vision of a new Aztec Empire.`); @@ -1276,7 +1289,7 @@ App.UI.fsPassage = function() { } App.Events.addNode(p, r, "div"); r = []; - if ((arc.FSRomanRevivalist === "unset") && (arc.FSAztecRevivalist === "unset") && (arc.FSEdoRevivalist === "unset") && (arc.FSArabianRevivalist === "unset") && (arc.FSChineseRevivalist === "unset") && (arc.FSNeoImperialist === "unset")) { + if ((arc.FSRomanRevivalist === "unset") && (arc.FSAztecRevivalist === "unset") && (arc.FSEdoRevivalist === "unset") && (arc.FSArabianRevivalist === "unset") && (arc.FSChineseRevivalist === "unset") && (arc.FSNeoImperialist === "unset") && (arc.FSAntebellumRevivalist === "unset")) { if (arc.FSEgyptianRevivalist !== "unset") { r.push(pursuit()); r.push(`a vision of Pharaoh's Egypt.`); @@ -1302,7 +1315,7 @@ App.UI.fsPassage = function() { } App.Events.addNode(p, r, "div"); r = []; - if ((arc.FSRomanRevivalist === "unset") && (arc.FSAztecRevivalist === "unset") && (arc.FSEgyptianRevivalist === "unset") && (arc.FSArabianRevivalist === "unset") && (arc.FSChineseRevivalist === "unset") && (arc.FSNeoImperialist === "unset")) { + if ((arc.FSRomanRevivalist === "unset") && (arc.FSAztecRevivalist === "unset") && (arc.FSEgyptianRevivalist === "unset") && (arc.FSArabianRevivalist === "unset") && (arc.FSChineseRevivalist === "unset") && (arc.FSNeoImperialist === "unset") && (arc.FSAntebellumRevivalist === "unset")) { if (arc.FSEdoRevivalist !== "unset") { r.push(pursuit()); r.push(`a vision of Edo Japan.`); @@ -1327,7 +1340,7 @@ App.UI.fsPassage = function() { } App.Events.addNode(p, r, "div"); r = []; - if ((arc.FSRomanRevivalist === "unset") && (arc.FSAztecRevivalist === "unset") && (arc.FSEgyptianRevivalist === "unset") && (arc.FSEdoRevivalist === "unset") && (arc.FSChineseRevivalist === "unset") && (arc.FSNeoImperialist === "unset")) { + if ((arc.FSRomanRevivalist === "unset") && (arc.FSAztecRevivalist === "unset") && (arc.FSEgyptianRevivalist === "unset") && (arc.FSEdoRevivalist === "unset") && (arc.FSChineseRevivalist === "unset") && (arc.FSNeoImperialist === "unset") && (arc.FSAntebellumRevivalist === "unset")) { if (arc.FSArabianRevivalist !== "unset") { r.push(pursuit()); r.push(`a vision of the Sultanate of old.`); @@ -1352,7 +1365,7 @@ App.UI.fsPassage = function() { } App.Events.addNode(p, r, "div"); r = []; - if ((arc.FSRomanRevivalist === "unset") && (arc.FSAztecRevivalist === "unset") && (arc.FSEgyptianRevivalist === "unset") && (arc.FSEdoRevivalist === "unset") && (arc.FSArabianRevivalist === "unset") && (arc.FSNeoImperialist === "unset")) { + if ((arc.FSRomanRevivalist === "unset") && (arc.FSAztecRevivalist === "unset") && (arc.FSEgyptianRevivalist === "unset") && (arc.FSEdoRevivalist === "unset") && (arc.FSArabianRevivalist === "unset") && (arc.FSNeoImperialist === "unset") && (arc.FSAntebellumRevivalist === "unset")) { if (arc.FSChineseRevivalist !== "unset") { r.push(pursuit()); r.push(`a vision of ancient China.`); @@ -1376,6 +1389,31 @@ App.UI.fsPassage = function() { } } App.Events.addNode(p, r, "div"); + r = []; + if ((arc.FSRomanRevivalist === "unset") && (arc.FSAztecRevivalist === "unset") && (arc.FSEgyptianRevivalist === "unset") && (arc.FSEdoRevivalist === "unset") && (arc.FSArabianRevivalist === "unset") && (arc.FSArabianRevivalist === "unset") && (arc.FSNeoImperialist === "unset")) { + if (arc.FSAntebellumRevivalist !== "unset") { + r.push(pursuit()); + r.push(`a vision of the Antebellum South.`); + r.push(activeFS("FSAntebellumRevivalist", ["boughtItem.clothing.antebellum"])); + } else { + if (FSCredits > 0) { + r.push( + App.UI.DOM.link( + "Antebellum Revivalism", + () => { + arc.FSAntebellumRevivalist = 4; + App.UI.reload(); + } + ) + ); + r.push(`is a vision of the Antebellum South.`); + r.push(evaluation("FSAntebellumRevivalist")); + } else { + /* <span class="note"><span style="font-weight:Bold">Antebellum South:</span> a vision of the Antebellum South.</span>*/ + } + } + } + App.Events.addNode(p, r, "div"); el.append(p); return el; diff --git a/src/futureSocieties/futureSociety.js b/src/futureSocieties/futureSociety.js index e9f299f9ac5afcda44ba2e1fb856cdcc1b2e7132..d8f650f7797fc5d25d4306898c1b5a4e93532b5d 100644 --- a/src/futureSocieties/futureSociety.js +++ b/src/futureSocieties/futureSociety.js @@ -369,6 +369,11 @@ globalThis.FutureSocieties = (function() { arcology.FSNeoImperialistLaw2 = 0; arcology.FSNeoImperialistSMR = 0; break; + case "FSAntebellumRevivalist": + arcology.FSAntebellumRevivalistLaw1 = 0; + arcology.FSAntebellumRevivalistLaw2 = 0; + arcology.FSAntebellumRevivalistSMR = 0; + break; case "FSNull": break; default: // all others have one law and one SMR @@ -749,6 +754,15 @@ globalThis.FutureSocieties = (function() { `${arc.name} is unconvinced of the wisdom of your project to build a new Imperial Society.` ] ], + [ + "FSAntebellumRevivalist", + [ + `${arc.name} believes implicitly that your arcology is truly a new Antebellum South.`, + `${arc.name} agrees strongly with your project to build a new Antebellum South.`, + `${arc.name} is sympathetic to your project to build a new Antebellum South.`, + `${arc.name} is unconvinced of the wisdom of your project to build a new Antebellum South.` + ] + ], [ "FSAztecRevivalist", [ diff --git a/src/gui/Encyclopedia/encyclopediaFutureSocities.js b/src/gui/Encyclopedia/encyclopediaFutureSocities.js index f2beeb7c1a9bccd90b2a498d062c3b2424625883..89403a02407c93e16f1333240146af2b49f90451 100644 --- a/src/gui/Encyclopedia/encyclopediaFutureSocities.js +++ b/src/gui/Encyclopedia/encyclopediaFutureSocities.js @@ -499,6 +499,20 @@ App.Encyclopedia.addArticle("Neo-Imperialism", function() { return t; }, "FutureSocities"); +App.Encyclopedia.addArticle("Antebellum Revivalism", function() { + const t = new DocumentFragment(); + const r = new SpacedTextAccumulator(t); + r.push(App.UI.DOM.makeElement("span", "Antebellum Revivalism", ["bold"]), "is a future society model which approves of"); + r.push("maintaining honor and integrity, keeping a large number of slaves and servants, and having skill at breaking slaves."); + r.toNode("div"); + App.Events.addNode(t, ["Increases prosperity for the upper echelons of society."], "div", ["indent"]); + App.Events.addNode(t, ["Slows increases in the ratio of slaves to citizens."], "div", ["indent"]); + App.Events.addNode(t, ["Can be developed to improve the Arcology's defensive capabilities."], "div", ["indent"]); + App.Events.addNode(t, ["Provides demand for entertaining slaves from", App.UI.DOM.combineNodes(App.Encyclopedia.link("The Corporation"), ".")]); + App.Events.addNode(t, ["Mutually exclusive with all Revivalist models."], "div", ["indent"]); + return t; +}, "FutureSocities"); + App.Encyclopedia.addArticle("Gender Radicalism Research", function() { const t = new DocumentFragment(); App.Events.addNode(t, ["Advanced Gender Radicalist societies can fund research to produce modified uteri and ovaries designed to be implanted into male slaves to grant them the ability to become pregnant, thus leaving no gender specific traits remaining."], "div"); @@ -592,6 +606,7 @@ App.Encyclopedia.addCategory("FutureSocities", function() { modded.push(App.Encyclopedia.link("Hedonistic Decadence")); modded.push(App.Encyclopedia.link("Aztec Revivalism")); modded.push(App.Encyclopedia.link("Neo-Imperialism")); + modded.push(App.Encyclopedia.link("Antebellum Revivalism")); research.push(App.Encyclopedia.link("Gender Radicalism Research")); research.push(App.Encyclopedia.link("Slave Professionalism Research")); diff --git a/src/interaction/main/toychest.js b/src/interaction/main/toychest.js index 31aafcf5bde6f577f3840223805cfec511a99596..ea9815d1b4fc881e5a59d356e4abbd7839faca8c 100644 --- a/src/interaction/main/toychest.js +++ b/src/interaction/main/toychest.js @@ -76,15 +76,10 @@ App.Interact.ToyChest = function(slave) { r += `${His} complete suit of latex makes ${him} a nice, artistic display, a plastic work of art in the shape of a female form.`; break; case "a military uniform": - r += `${His} uniformed presence lends your office the air of a military command center.`; - break; case "a schutzstaffel uniform": - r += `${His} uniformed presence lends your office the air of a military command center.`; - break; case "a slutty schutzstaffel uniform": - r += `${His} uniformed presence lends your office the air of a military command center.`; - break; case "a red army uniform": + case "a confederate army uniform": r += `${His} uniformed presence lends your office the air of a military command center.`; break; case "a long qipao": @@ -224,6 +219,9 @@ App.Interact.ToyChest = function(slave) { case "a ball gown": r += `The fabulous silken ball gown ${he}'s wearing lifts the entire atmosphere.`; break; + case "an evening dress": + r += `The sensual evening dress ${he}'s wearing lends your office a refined, yet sexual air.` + break; case "a slave gown": r += `The gorgeous gown ${he}'s wearing lends an air of class to the office.`; break; diff --git a/src/interaction/main/useGuard.js b/src/interaction/main/useGuard.js index 057c5c88154d20c03d0d301a83144614f8d6e8a7..8dd163b3457f62e069e20f27e213fddb52bcca29 100644 --- a/src/interaction/main/useGuard.js +++ b/src/interaction/main/useGuard.js @@ -31,17 +31,14 @@ App.Interact.guardPose = function(slave) { r += `${His} practical nurse's outfit make ${his} weapons look like surgical instruments of death.`; break; case "a military uniform": - r += `${His} military uniform is most befitting of an honor guard.`; - break; case "a schutzstaffel uniform": + case "a red army uniform": + case "a confederate army uniform": r += `${His} military uniform is most befitting of an honor guard.`; break; case "a slutty schutzstaffel uniform": r += `${His} military uniform is most befitting of an honor guard and your personal whore.`; break; - case "a red army uniform": - r += `${His} military uniform is most befitting of an honor guard.`; - break; case "a long qipao": r += `${His} elegant qipao makes ${him} seem less deadly than ${he} actually is.`; break; @@ -132,6 +129,9 @@ App.Interact.guardPose = function(slave) { case "a ball gown": r += `${His} fabulous silken ball gown and elegant weapons make ${him} look refined, yet deadly.`; break; + case "an evening dress": + r += `${His} sensual evening dress and elegant weapons make ${him} look refined, yet deadly.`; + break; case "a nice maid outfit": r += `${His} pretty maid outfit and weapons make ${him} look like a character from an animated movie.`; break; diff --git a/src/interaction/main/walkPast.js b/src/interaction/main/walkPast.js index ec64bf325cb5e8b117a91ab34948e80d6621100a..3c711aa4398f1cedc5e6170c6184aadd287543f1 100644 --- a/src/interaction/main/walkPast.js +++ b/src/interaction/main/walkPast.js @@ -2236,6 +2236,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} beautiful halter top dress almost seems to be sculpted around ${his} body.`; break; + case "an evening dress": + t += `${His} sensual evening dress is tailored to accentuate the shape of ${his} ${breasts}.`; + break; case "a ball gown": t += `${His} fabulous silken ball gown is tailored to accentuate the shape of ${his} ${breasts}.`; break; @@ -2317,6 +2320,9 @@ globalThis.walkPast = (function() { case "a red army uniform": t += `${His} uniform tunic and shirt are formal, but they could be removed easily enough.`; break; + case "a confederate army uniform": + t += `${His} uniform is formal, but they could be removed easily enough.`; + break; case "battlearmor": t += `${His} battlearmor will take some considerable effort to get out of.`; break; @@ -2636,6 +2642,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} beautiful halter top dress seems to be sculpted around ${his} bottom.`; break; + case "an evening dress": + t += `${His} sensual evening dress is tailored to fit ${him} and accentuates the shape of ${his} butt.`; + break; case "a ball gown": t += `${His} fabulous silken ball gown is tailored to fit ${him} and accentuates the shape of ${his} butt.`; break; @@ -2759,6 +2768,7 @@ globalThis.walkPast = (function() { case "a red army uniform": t += `${His} uniform skirt is nevertheless tight enough to show off ${his} derrière.`; break; + case "a confederate army uniform": case "a schutzstaffel uniform": t += `${His} uniform trousers are nevertheless tight enough to show off ${his} derrière.`; break; @@ -3021,6 +3031,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} giant belly fills ${his} halter top dress, which struggles to contain it.`; break; + case "an evening dress": + t += `${His} giant belly fills ${his} evening dress, which struggles to contain it.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} giant pregnant belly by ${his} struggling fabulous silken ball gown.`; break; @@ -3255,6 +3268,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} strained halter top dress shows every jiggle in ${his} massive gut as ${he} moves. Every little motion threatens to burst ${his} seams and free the soft mass to the world.`; break; + case "an evening dress": + t += `${His} strained evening dress shows every jiggle in ${his} massive gut as ${he} moves. Every little motion threatens to burst ${his} seams and free the soft mass to the world.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} massive gut by ${his} fabulous silken ball gown. Every little motion has a chance for it to pop out and jiggle free for all to see clearly.`; break; @@ -3303,15 +3319,6 @@ globalThis.walkPast = (function() { case "restrictive latex": t += `${His} huge belly looks like a large beach ball under ${his} tight latex; ${his} popped navel breaks the smoothness.`; break; - case "a military uniform": - t += `${His} huge belly threatens to pop the buttons off ${his} tunic.`; - break; - case "a schutzstaffel uniform": - t += `${His} huge belly threatens to pop the buttons off ${his} tunic.`; - break; - case "a slutty schutzstaffel uniform": - t += `${His} huge belly threatens to pop the buttons off ${his} tunic.`; - break; case "a long qipao": t += `${His} huge belly threatens to tear ${his} dress.`; break; @@ -3321,9 +3328,6 @@ globalThis.walkPast = (function() { case "Imperial Plate": t += `Even through ${his} massive Imperial armor, ${his} huge belly is obvious.`; break; - case "a mounty outfit": - t += `${His} huge belly threatens to pop the buttons off ${his} tunic.`; - break; case "a dirndl": t += `${His} huge belly threatens to pop the laces off ${his} dress.`; break; @@ -3333,9 +3337,16 @@ globalThis.walkPast = (function() { case "a biyelgee costume": t += `${His} huge belly threatens to tear ${his} dress.`; break; + case "a military uniform": + case "a schutzstaffel uniform": + case "a slutty schutzstaffel uniform": case "a red army uniform": + case "a mounty outfit": t += `${His} huge belly threatens to pop the buttons off ${his} tunic.`; break; + case "a confederate army uniform": + t += `${His} huge belly threatens to pop the buttons off ${his} military jacket.`; + break; case "a nice nurse outfit": t += `${His} huge belly strains against ${his} scrub top, making ${him} resemble more a maternity ward patient than a nurse.`; break; @@ -3360,6 +3371,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} huge belly fills out ${his} halter top dress, the seams straining to contain it.`; break; + case "an evening dress": + t += `${His} huge belly fills out ${his} evening dress, the seams straining to contain it.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} huge pregnant belly by ${his} fabulous silken ball gown.`; break; @@ -3505,16 +3519,11 @@ globalThis.walkPast = (function() { t += `${His} giant gut resembles a beachball under ${his} tight latex.`; break; case "a military uniform": - t += `The buttons on ${his} staining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; - break; case "a schutzstaffel uniform": - t += `The buttons on ${his} staining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; - break; case "a slutty schutzstaffel uniform": - t += `The buttons on ${his} staining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; - break; case "a red army uniform": - t += `The buttons on ${his} staining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; + case "a confederate army uniform": + t += `The buttons on ${his} straining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; break; case "a long qipao": t += `${His} giant jiggling gut threatens to tear ${his} dress.`; @@ -3648,6 +3657,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} stretched halter top dress shows every jiggle in ${his} giant gut as ${he} moves.`; break; + case "an evening dress": + t += `${His} stretched evening dress shows every jiggle in ${his} giant gut as ${he} moves.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} giant gut by ${his} fabulous silken ball gown.`; break; @@ -3707,16 +3719,12 @@ globalThis.walkPast = (function() { t += `${His} big gut has no room to move under ${his} tight latex.`; break; case "a military uniform": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} big jiggling gut.`; - break; case "a schutzstaffel uniform": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} big jiggling gut.`; - break; case "a slutty schutzstaffel uniform": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} big jiggling gut.`; - break; case "a red army uniform": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} big jiggling gut.`; + case "a mounty outfit": + case "a confederate army uniform": + t += `The buttons on ${his} straining jacket struggle to hold back ${his} big jiggling gut.`; break; case "a long qipao": t += `${His} stretched qipao shows every jiggle in ${his} big gut as ${he} moves.`; @@ -3727,9 +3735,6 @@ globalThis.walkPast = (function() { case "Imperial Plate": t += `${His} fat gut makes ${his} ultra-heavy armor wobble slightly with motion.`; break; - case "a mounty outfit": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} big jiggling gut.`; - break; case "a dirndl": t += `${His} dress jiggles along with ${his} big gut as ${he} moves.`; break; @@ -3853,6 +3858,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} stretched halter top dress shows every jiggle in ${his} big gut as ${he} moves.`; break; + case "an evening dress": + t += `${His} stretched evening dress shows every jiggle in ${his} big gut as ${he} moves.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} big gut by ${his} fabulous silken ball gown.`; break; @@ -3912,15 +3920,11 @@ globalThis.walkPast = (function() { t += `${His} big belly looks like a beach ball under ${his} tight latex; ${his} popped navel breaks the smoothness.`; break; case "a military uniform": - t += `${His} big belly strains the buttons on ${his} jacket.`; - break; case "a schutzstaffel uniform": - t += `${His} big belly strains the buttons on ${his} jacket.`; - break; case "a slutty schutzstaffel uniform": - t += `${His} big belly strains the buttons on ${his} jacket.`; - break; case "a red army uniform": + case "a mounty outfit": + case "a confederate army uniform": t += `${His} big belly strains the buttons on ${his} jacket.`; break; case "a long qipao": @@ -3932,9 +3936,6 @@ globalThis.walkPast = (function() { case "Imperial Plate": t += `${His} fat gut makes ${his} ultra-heavy armor wobble slightly with motion.`; break; - case "a mounty outfit": - t += `${His} big belly strains the buttons on ${his} jacket.`; - break; case "a dirndl": t += `${His} dress jiggles along with ${his} big belly as ${he} moves.`; break; @@ -3968,6 +3969,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} big belly fills out ${his} halter top dress.`; break; + case "an evening dress": + t += `${His} big belly fills out ${his} evening dress.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} big pregnant belly by ${his} fabulous silken ball gown.`; break; @@ -4119,16 +4123,12 @@ globalThis.walkPast = (function() { t += `${His} fat gut barely has any room to move under ${his} tight latex.`; break; case "a military uniform": - t += `The buttons on ${his} staining jacket can barely hold back ${his} fat, jiggling gut.`; - break; case "a schutzstaffel uniform": - t += `The buttons on ${his} staining jacket can barely hold back ${his} fat, jiggling gut.`; - break; case "a slutty schutzstaffel uniform": - t += `The buttons on ${his} staining jacket can barely hold back ${his} fat, jiggling gut.`; - break; case "a red army uniform": - t += `The buttons on ${his} staining jacket can barely hold back ${his} fat, jiggling gut.`; + case "a mounty outfit": + case "a confederate army uniform": + t += `The buttons on ${his} straining jacket can barely hold back ${his} fat, jiggling gut.`; break; case "a long qipao": t += `${His} dress barely contains ${his} fat, jiggling gut.`; @@ -4139,9 +4139,6 @@ globalThis.walkPast = (function() { case "Imperial Plate": t += `${His} fat gut makes ${his} ultra-heavy armor wobble slightly with motion.`; break; - case "a mounty outfit": - t += `The buttons on ${his} staining jacket can barely hold back ${his} fat, jiggling gut.`; - break; case "a dirndl": t += `${His} dress barely contains ${his} fat, jiggling gut.`; break; @@ -4175,6 +4172,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} stretched halter top dress shows every jiggle in ${his} fat gut as ${he} moves.`; break; + case "an evening dress": + t += `${His} stretched evening dress shows every jiggle in ${his} fat gut as ${he} moves.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} fat gut by ${his} fabulous silken ball gown.`; break; @@ -4317,15 +4317,11 @@ globalThis.walkPast = (function() { t += `${His} growing belly bulges beneath ${his} tight latex.`; break; case "a military uniform": - t += `${His} growing belly bulges ${his} uniform tunic.`; - break; case "a schutzstaffel uniform": - t += `${His} growing belly bulges ${his} uniform tunic.`; - break; case "a slutty schutzstaffel uniform": - t += `${His} growing belly bulges ${his} uniform tunic.`; - break; case "a red army uniform": + case "a mounty outfit": + case "a confederate army uniform": t += `${His} growing belly bulges ${his} uniform tunic.`; break; case "a long qipao": @@ -4337,9 +4333,6 @@ globalThis.walkPast = (function() { case "Imperial Plate": t += `You can see a hint of ${his} growing belly swelling underneath ${his} ultra-heavy armor.`; break; - case "a mounty outfit": - t += `${His} growing belly bulges ${his} uniform tunic.`; - break; case "a dirndl": t += `${His} growing belly bulges ${his} dress.`; break; @@ -4379,6 +4372,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} growing belly bulges ${his} halter top dress.`; break; + case "an evening dress": + t += `${His} growing belly bulges ${his} evening dress.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} growing pregnant belly by ${his} fabulous silken ball gown.`; break; @@ -4683,6 +4679,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} giant belly fills ${his} halter top dress, which struggles to contain it.`; break; + case "an evening dress": + t += `${His} giant belly fills ${his} evening dress, which struggles to contain it.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} giant belly by ${his} struggling fabulous silken ball gown.`; break; @@ -4949,6 +4948,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} strained halter top dress shows every jiggle in ${his} massive gut as ${he} moves. Every little motion threatens to burst ${his} seams and free the soft mass to the world.`; break; + case "an evening dress": + t += `${His} strained evening dress shows every jiggle in ${his} massive gut as ${he} moves. Every little motion threatens to burst ${his} seams and free the soft mass to the world.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} massive gut by ${his} fabulous silken ball gown. Every little motion has a chance for it to pop out and jiggle free for all to see clearly.`; break; @@ -4998,17 +5000,14 @@ globalThis.walkPast = (function() { t += `${His} huge belly looks like a large beach ball under ${his} tight latex; ${his} popped navel breaks the smoothness.`; break; case "a military uniform": - t += `${His} huge belly threatens to pop the buttons off ${his} tunic.`; - break; case "a schutzstaffel uniform": - t += `${His} huge belly threatens to pop the buttons off ${his} tunic.`; - break; case "a slutty schutzstaffel uniform": - t += `${His} huge belly threatens to pop the buttons off ${his} tunic.`; - break; case "a red army uniform": t += `${His} huge belly threatens to pop the buttons off ${his} tunic.`; break; + case "a confederate army uniform": + t += `${His} huge belly threatens to pop the buttons off ${his} military jacket.`; + break; case "a long qipao": t += `The front of ${his} qipao rests atop ${his} huge belly.`; break; @@ -5054,6 +5053,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} huge belly fills out ${his} halter top dress, the seams straining to contain it.`; break; + case "an evening dress": + t += `${His} huge belly fills out ${his} evening dress, the seams straining to contain it.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} huge belly by ${his} fabulous silken ball gown.`; break; @@ -5233,16 +5235,11 @@ globalThis.walkPast = (function() { t += `${His} giant gut resembles a beachball under ${his} tight latex.`; break; case "a military uniform": - t += `The buttons on ${his} staining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; - break; case "a schutzstaffel uniform": - t += `The buttons on ${his} staining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; - break; case "a slutty schutzstaffel uniform": - t += `The buttons on ${his} staining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; - break; case "a red army uniform": - t += `The buttons on ${his} staining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; + case "a confederate army uniform": + t += `The buttons on ${his} straining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; break; case "a nice nurse outfit": t += `${His} scrub top jiggles along with ${his} giant gut as ${he} moves.`; @@ -5374,6 +5371,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} stretched halter top dress shows every jiggle in ${his} giant gut as ${he} moves.`; break; + case "an evening dress": + t += `${His} stretched evening dress shows every jiggle in ${his} giant gut as ${he} moves.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} giant gut by ${his} fabulous silken ball gown.`; break; @@ -5426,16 +5426,11 @@ globalThis.walkPast = (function() { t += `${His} big gut has no room to move under ${his} tight latex.`; break; case "a military uniform": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} big jiggling gut.`; - break; case "a schutzstaffel uniform": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} big jiggling gut.`; - break; case "a slutty schutzstaffel uniform": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} big jiggling gut.`; - break; case "a red army uniform": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} big jiggling gut.`; + case "a confederate army uniform": + t += `The buttons on ${his} straining jacket struggle to hold back ${his} big jiggling gut.`; break; case "a long qipao": t += `${His} stretched qipao shows every jiggle in ${his} big gut as ${he} moves.`; @@ -5447,7 +5442,7 @@ globalThis.walkPast = (function() { t += `${His} ultra-heavy armor isn't quite massive enough to hide the jiggle of ${his} big gut.`; break; case "a mounty outfit": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} big jiggling gut.`; + t += `The buttons on ${his} straining jacket struggle to hold back ${his} big jiggling gut.`; break; case "a dirndl": t += `${His} stretched dirndl shows every jiggle in ${his} big gut as ${he} moves.`; @@ -5591,6 +5586,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} stretched halter top dress shows every jiggle in ${his} big gut as ${he} moves.`; break; + case "an evening dress": + t += `${His} stretched evening dress shows every jiggle in ${his} big gut as ${he} moves.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} big gut by ${his} fabulous silken ball gown.`; break; @@ -5634,15 +5632,10 @@ globalThis.walkPast = (function() { t += `${His} big belly looks like a beach ball under ${his} tight latex; ${his} popped navel breaks the smoothness.`; break; case "a military uniform": - t += `${His} big belly strains the buttons on ${his} jacket.`; - break; case "a schutzstaffel uniform": - t += `${His} big belly strains the buttons on ${his} jacket.`; - break; case "a slutty schutzstaffel uniform": - t += `${His} big belly strains the buttons on ${his} jacket.`; - break; case "a red army uniform": + case "a confederate army uniform": t += `${His} big belly strains the buttons on ${his} jacket.`; break; case "a long qipao": @@ -5709,6 +5702,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} big belly fills out ${his} halter top dress.`; break; + case "an evening dress": + t += `${His} big belly fills out ${his} evening dress.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} big belly by ${his} fabulous silken ball gown.`; break; @@ -5848,16 +5844,12 @@ globalThis.walkPast = (function() { t += `${His} fat gut barely has any room to move under ${his} tight latex.`; break; case "a military uniform": - t += `The buttons on ${his} staining jacket can barely hold back ${his} fat, jiggling gut.`; - break; case "a schutzstaffel uniform": - t += `The buttons on ${his} staining jacket can barely hold back ${his} fat, jiggling gut.`; - break; case "a slutty schutzstaffel uniform": - t += `The buttons on ${his} staining jacket can barely hold back ${his} fat, jiggling gut.`; - break; case "a red army uniform": - t += `The buttons on ${his} staining jacket can barely hold back ${his} fat, jiggling gut.`; + case "a mounty outfit": + case "a confederate army uniform": + t += `The buttons on ${his} straining jacket can barely hold back ${his} fat, jiggling gut.`; break; case "a long qipao": t += `${His} stretched qipao shows every jiggle in ${his} fat, jiggling gut as ${he} moves.`; @@ -5868,9 +5860,6 @@ globalThis.walkPast = (function() { case "Imperial Plate": t += `${His} ultra-heavy armor isn't quite massive enough to hide the jiggle of ${his} big gut.`; break; - case "a mounty outfit": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} fat, jiggling gut.`; - break; case "a dirndl": t += `${His} stretched dirndl shows every jiggle in ${his} fat, jiggling gut as ${he} moves.`; break; @@ -5923,6 +5912,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} stretched halter top dress shows every jiggle in ${his} fat gut as ${he} moves.`; break; + case "an evening dress": + t += `${His} stretched evening dress shows every jiggle in ${his} fat gut as ${he} moves.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} fat gut by ${his} fabulous silken ball gown.`; break; @@ -6083,17 +6075,14 @@ globalThis.walkPast = (function() { t += `${His} distended belly bulges beneath ${his} tight latex.`; break; case "a military uniform": - t += `${His} distended belly bulges ${his} uniform tunic.`; - break; case "a schutzstaffel uniform": - t += `${His} distended belly bulges ${his} uniform tunic.`; - break; case "a slutty schutzstaffel uniform": - t += `${His} distended belly bulges ${his} uniform tunic.`; - break; case "a red army uniform": t += `${His} distended belly bulges ${his} uniform tunic.`; break; + case "a confederate army uniform": + t += `${His} distended belly bulges ${his} military jacket.`; + break; case "a nice nurse outfit": t += `${His} distended belly is clearly visible through ${his} scrub top.`; break; @@ -6143,6 +6132,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} distended belly bulges ${his} halter top dress.`; break; + case "an evening dress": + t += `${His} distended belly bulges ${his} evening dress.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} distended belly by ${his} fabulous silken ball gown.`; break; @@ -6411,6 +6403,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} strained halter top dress shows every jiggle in ${his} massive gut as ${he} moves. Every little motion threatens to burst ${his} seams and free the soft mass to the world.`; break; + case "an evening dress": + t += `Your gaze is drawn to ${his} massive gut by ${his} sensual evening dress. Every little motion has a chance for it to pop out and jiggle free for all to see clearly.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} massive gut by ${his} fabulous silken ball gown. Every little motion has a chance for it to pop out and jiggle free for all to see clearly.`; break; @@ -6463,17 +6458,15 @@ globalThis.walkPast = (function() { t += `${His} taut, sloshing belly looks like a large beach ball under ${his} tight latex; ${his} popped navel breaks the smoothness.`; break; case "a military uniform": - t += `${His} taut, sloshing belly threatens to pop the buttons off ${his} tunic. ${His} belly bulges out between them.`; - break; case "a schutzstaffel uniform": - t += `${His} taut, sloshing belly threatens to pop the buttons off ${his} tunic. ${His} belly bulges out between them.`; - break; case "a slutty schutzstaffel uniform": - t += `${His} taut, sloshing belly threatens to pop the buttons off ${his} tunic. ${His} belly bulges out between them.`; - break; case "a red army uniform": + case "a mounty outfit": t += `${His} taut, sloshing belly threatens to pop the buttons off ${his} tunic. ${His} belly bulges out between them.`; break; + case "a confederate army uniform": + t += `${His} taut, sloshing belly threatens to pop the buttons off ${his} jacket. ${His} belly bulges out between them.`; + break; case "a long qipao": t += `${His} dress is completely filled by ${his} taut, sloshing belly.`; break; @@ -6483,9 +6476,6 @@ globalThis.walkPast = (function() { case "Imperial Plate": t += `${His} ultra-heavy armor is slightly swollen by ${his} taut, sloshing belly.`; break; - case "a mounty outfit": - t += `${His} taut, sloshing belly threatens to pop the buttons off ${his} tunic. ${His} belly bulges out between them.`; - break; case "a dirndl": t += `${His} loose dress is completely filled by ${his} taut, sloshing belly.`; break; @@ -6519,6 +6509,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} taut, sloshing belly fills out ${his} halter top dress, the seams straining to contain it. ${His} belly bulges between the gaps.`; break; + case "an evening dress": + t += `Your gaze is drawn to ${his} taut, sloshing belly by ${his} sensual evening dress.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} taut, sloshing belly by ${his} fabulous silken ball gown.`; break; @@ -6677,16 +6670,11 @@ globalThis.walkPast = (function() { t += `${His} giant gut resembles a beachball under ${his} tight latex.`; break; case "a military uniform": - t += `The buttons on ${his} staining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; - break; case "a schutzstaffel uniform": - t += `The buttons on ${his} staining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; - break; case "a slutty schutzstaffel uniform": - t += `The buttons on ${his} staining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; - break; case "a red army uniform": - t += `The buttons on ${his} staining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; + case "a confederate army uniform": + t += `The buttons on ${his} straining jacket threaten to pop off with every motion of ${his} giant jiggling gut.`; break; case "a long qipao": t += `${His} dress is completely filled by ${his} giant jiggling gut.`; @@ -6839,6 +6827,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} stretched halter top dress shows every jiggle in ${his} giant gut as ${he} moves.`; break; + case "an evening dress": + t += `Your gaze is drawn to ${his} giant gut by ${his} sensual evening dress.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} giant gut by ${his} fabulous silken ball gown.`; break; @@ -6891,13 +6882,11 @@ globalThis.walkPast = (function() { t += `${His} big gut has no room to move under ${his} tight latex.`; break; case "a military uniform": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} big jiggling gut.`; - break; case "a schutzstaffel uniform": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} big jiggling gut.`; - break; case "a red army uniform": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} big jiggling gut.`; + case "a mounty outfit": + case "a confederate army uniform": + t += `The buttons on ${his} straining jacket struggle to hold back ${his} big jiggling gut.`; break; case "a long qipao": t += `The front of ${his} qipao rests atop ${his} big gut.`; @@ -6908,9 +6897,6 @@ globalThis.walkPast = (function() { case "Imperial Plate": t += `${His} big gut pushes out the front of ${his} ultra-heavy armor.`; break; - case "a mounty outfit": - t += `The buttons on ${his} staining jacket struggle to hold back ${his} big jiggling gut.`; - break; case "a dirndl": t += `The front of ${his} dirndl rests atop ${his} big gut.`; break; @@ -7046,6 +7032,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} stretched halter top dress shows every jiggle in ${his} big gut as ${he} moves.`; break; + case "a ball gown": + t += `Your gaze is drawn to ${his} big gut by ${his} sensual evening dress.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} big gut by ${his} fabulous silken ball gown.`; break; @@ -7105,15 +7094,11 @@ globalThis.walkPast = (function() { t += `${His} rounded, sloshing belly looks like a beach ball under ${his} tight latex; ${his} popped navel breaks the smoothness.`; break; case "a military uniform": - t += `${His} rounded, sloshing belly strains the buttons on ${his} jacket. It bulges slightly between them.`; - break; case "a schutzstaffel uniform": - t += `${His} rounded, sloshing belly strains the buttons on ${his} jacket. It bulges slightly between them.`; - break; case "a slutty schutzstaffel uniform": - t += `${His} rounded, sloshing belly strains the buttons on ${his} jacket. It bulges slightly between them.`; - break; case "a red army uniform": + case "a mounty outfit": + case "a confederate army uniform": t += `${His} rounded, sloshing belly strains the buttons on ${his} jacket. It bulges slightly between them.`; break; case "a long qipao": @@ -7125,9 +7110,6 @@ globalThis.walkPast = (function() { case "Imperial Plate": t += `${His} ultra-heavy armor is slightly swollen by ${his} rounded, sloshing belly.`; break; - case "a mounty outfit": - t += `${His} rounded, sloshing belly strains the buttons on ${his} jacket. It bulges slightly between them.`; - break; case "a dirndl": t += `The front of ${his} dirndl rests atop ${his} rounded, sloshing belly.`; break; @@ -7161,6 +7143,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} rounded, sloshing belly fills out ${his} halter top dress.`; break; + case "an evening dress": + t += `${His} rounded, sloshing belly fills out ${his} evening dress.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} rounded, sloshing belly by ${his} fabulous silken ball gown.`; break; @@ -7316,16 +7301,12 @@ globalThis.walkPast = (function() { t += `${His} fat gut barely has any room to move under ${his} tight latex.`; break; case "a military uniform": - t += `The buttons on ${his} staining jacket can barely hold back ${his} fat, jiggling gut.`; - break; case "a schutzstaffel uniform": - t += `The buttons on ${his} staining jacket can barely hold back ${his} fat, jiggling gut.`; - break; case "a slutty schutzstaffel uniform": - t += `The buttons on ${his} staining jacket can barely hold back ${his} fat, jiggling gut.`; - break; case "a red army uniform": - t += `The buttons on ${his} staining jacket can barely hold back ${his} fat, jiggling gut.`; + case "a mounty outfit": + case "a confederate army uniform": + t += `The buttons on ${his} straining jacket can barely hold back ${his} fat, jiggling gut.`; break; case "a long qipao": t += `The front of ${his} qipao rests atop, and jiggles with, ${his} fat gut as ${he} moves.`; @@ -7336,9 +7317,6 @@ globalThis.walkPast = (function() { case "Imperial Plate": t += `Even ${his} ultra-heavy armor struggles to constrain the obvious swell of ${his} fat, jiggling gut.`; break; - case "a mounty outfit": - t += `The buttons on ${his} staining jacket can barely hold back ${his} fat, jiggling gut.`; - break; case "a dirndl": t += `The front of ${his} dirndl rests atop, and jiggles with, ${his} fat gut as ${he} moves.`; break; @@ -7391,6 +7369,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} stretched halter top dress shows every jiggle in ${his} fat gut as ${he} moves.`; break; + case "an evening dress": + t += `${His} stretched evening dress shows every jiggle in ${his} fat gut as ${he} moves.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} fat gut by ${his} fabulous silken ball gown.`; break; @@ -7530,17 +7511,15 @@ globalThis.walkPast = (function() { t += `${His} distended belly bulges beneath ${his} tight latex.`; break; case "a military uniform": - t += `${His} distended belly bulges ${his} uniform tunic.`; - break; case "a schutzstaffel uniform": - t += `${His} distended belly bulges ${his} uniform tunic.`; - break; case "a slutty schutzstaffel uniform": - t += `${His} distended belly bulges ${his} uniform tunic.`; - break; case "a red army uniform": + case "a mounty outfit": t += `${His} distended belly bulges ${his} uniform tunic.`; break; + case "a confederate army uniform": + t += `${His} distended belly bulges ${his} uniform.`; + break; case "a long qipao": t += `The front of ${his} qipao rests atop ${his} distended belly.`; break; @@ -7550,9 +7529,6 @@ globalThis.walkPast = (function() { case "Imperial Plate": t += `${His} ultra-heavy armor is slightly swollen by ${his} distended belly.`; break; - case "a mounty outfit": - t += `${His} distended belly bulges ${his} uniform tunic.`; - break; case "a dirndl": t += `The front of ${his} dirndl rests atop ${his} distended belly.`; break; @@ -7592,6 +7568,9 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} distended belly bulges ${his} halter top dress.`; break; + case "an evening dress": + t += `${His} distended belly bulges ${his} evening dress.`; + break; case "a ball gown": t += `Your gaze is drawn to ${his} distended belly by ${his} fabulous silken ball gown.`; break; @@ -8095,6 +8074,17 @@ globalThis.walkPast = (function() { t += `${His} beautiful halter top dress is almost sculpted around ${him}.`; } break; + case "an evening dress": + if (isAmputee(slave) && (slave.vagina !== -1)) { + t += `${He}'s wearing a 'sensual evening dress' designed specifically for an amputee.`; + } else if ((slave.dick !== 0) && (slave.vagina !== -1)) { + t += `${His} sensual evening dress is almost sculpted around ${him}, but ${his} cock tents the fabric as ${he} moves.`; + } else if (slave.dick !== 0) { + t += `${His} sensual evening dress is almost sculpted around ${him}; but ${his} cock tents the fabric as ${he} moves.`; + } else { + t += `${His} sensual evening dress is almost sculpted around ${him}.`; + } + break; case "a ball gown": if (isAmputee(slave) && (slave.vagina !== -1)) { t += `${He}'s wearing a 'fabulous silken ball gown' designed specifically for an amputee.`; @@ -8685,6 +8675,17 @@ globalThis.walkPast = (function() { t += `${His} beautiful halter top dress is almost sculpted around ${him}.`; } break; + case "an evening dress": + if (isAmputee(slave) && (slave.vagina !== -1)) { + t += `${He}'s wearing a 'sensual evening dress' designed specifically for an amputee.`; + } else if ((slave.dick !== 0) && (slave.vagina !== -1)) { + t += `${His} sensual evening dress is almost sculpted around ${him}, but ${his} cock tents the fabric as ${he} moves.`; + } else if (slave.dick !== 0) { + t += `${His} sensual evening dress is almost sculpted around ${him}; but ${his} cock tents the fabric as ${he} moves.`; + } else { + t += `${His} sensual evening dress is almost sculpted around ${him}.`; + } + break; case "a ball gown": if (isAmputee(slave) && (slave.vagina !== -1)) { t += `${He}'s wearing a 'fabulous silken ball gown' designed specifically for an amputee.`; @@ -9137,8 +9138,11 @@ globalThis.walkPast = (function() { case "a halter top dress": t += `${His} dress should slide up over ${his} butt to reveal ${his} backdoor.`; break; + case "an evening dress": + t += `${His} dress should slide up over ${his} butt to reveal ${his} backdoor.`; + break; case "a ball gown": - t += `${His} ballgown and its petticoats could easily be flipped up to bare ${his} butt.`; + t += `${His} ball gown and its petticoats could easily be flipped up to bare ${his} butt.`; break; case "slutty business attire": t += `${His} short skirt will easily slide up to bare ${his} asshole.`; @@ -9155,6 +9159,7 @@ globalThis.walkPast = (function() { case "a military uniform": t += `${His} uniform skirt can be slid up over ${his} hips to bare ${his} butthole.`; break; + case "a confederate army uniform": case "a schutzstaffel uniform": t += `${His} uniform's trousers can be easily slid down to expose ${his} butthole.`; break; diff --git a/src/interaction/sellSlave.js b/src/interaction/sellSlave.js index 246da5e1f5731fdd089250d4e48ac2318429455e..2bd1dda74674d23c0b6d7f63e9126c866453e32c 100644 --- a/src/interaction/sellSlave.js +++ b/src/interaction/sellSlave.js @@ -82,6 +82,8 @@ App.Interact.sellSlave = function(slave) { reviewers.push("arabian"); } else if (V.arcologies[0].FSChineseRevivalist > 20) { reviewers.push("chinese"); + } else if (V.arcologies[0].FSAntebellumRevivalist > 20) { + reviewers.push("southron"); } if (V.arcologies[0].FSChattelReligionist > 20) { reviewers.push("priestess"); diff --git a/src/interaction/siCustom.js b/src/interaction/siCustom.js index 1afa30bea50fd602432d1e18c9abcf301a67edab..793b3720a035bde6689ad854f767d44b7f04a0ea 100644 --- a/src/interaction/siCustom.js +++ b/src/interaction/siCustom.js @@ -420,6 +420,17 @@ App.UI.SlaveInteract.custom = function(slave, refresh) { } ) ); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + linkArray.push( + App.UI.DOM.link( + `Give ${him} a random full old Southern name`, + () => { + slave.slaveName = App.Data.misc.antebellumSlaveNames.random(); + slave.slaveSurname = App.Data.misc.antebellumSlaveSurnames.random(); + updateName(slave, {oldName: oldName, oldSurname: oldSurname}); + } + ) + ); } if (V.arcologies[0].FSDegradationist > -1) { linkArray.push( diff --git a/src/js/SlaveState.js b/src/js/SlaveState.js index 65f660557e4a406a180bdd7bf0147d16c040667c..26b176d0ffd0914d71cabee59546dadb49d7a31b 100644 --- a/src/js/SlaveState.js +++ b/src/js/SlaveState.js @@ -1944,9 +1944,11 @@ App.Entity.SlaveState = class SlaveState { * * "a toga" * * "a tube top" * * "a tube top and thong" + * * "a confederate army uniform" * * "an apron" * * "an oversized t-shirt" * * "an oversized t-shirt and boyshorts" + * * "an evening dress" * * "attractive lingerie" * * "attractive lingerie for a pregnant woman" * * "battlearmor" diff --git a/src/js/assignJS.js b/src/js/assignJS.js index 12d17a3cfb0bfdbd589c26488492e803dcf4b243..823c3192a4eae32a433dc8087829fb6edcfa66e2 100644 --- a/src/js/assignJS.js +++ b/src/js/assignJS.js @@ -137,6 +137,7 @@ globalThis.assignJob = function(slave, job) { case "Egyptian Revivalist": case "Arabian Revivalist": case "Chinese Revivalist": + case "Antebellum Revivalist": case "Chattel Religionist": case "Edo Revivalist": slave.rules.living = LivingRule.NORMAL; @@ -188,6 +189,7 @@ globalThis.assignJob = function(slave, job) { case "Edo Revivalist": case "Arabian Revivalist": case "Egyptian Revivalist": + case "Antebellum Revivalist": case "Supremacist": case "Subjugationist": case "Degradationist": @@ -242,6 +244,7 @@ globalThis.assignJob = function(slave, job) { case "Degradationist": case "Arabian Revivalist": case "Egyptian Revivalist": + case "Antebellum Revivalist": slave.rules.living = LivingRule.SPARE; break; case "Slave Professionalism": diff --git a/src/js/birth/birth.js b/src/js/birth/birth.js index cada04583ae40a4437328aba74e97d8a771b850c..d6260c2d87a3d6902a192920714a929a08462f3a 100644 --- a/src/js/birth/birth.js +++ b/src/js/birth/birth.js @@ -7129,6 +7129,7 @@ globalThis.birth = function(slave, {birthStorm = false, cSection = false, artRen case "harem gauze": case "lederhosen": case "a hijab and blouse": + case "an evening dress": // dresses and etc if (clothesSeed < 60) { undressed = 1; @@ -7156,6 +7157,7 @@ globalThis.birth = function(slave, {birthStorm = false, cSection = false, artRen case "a red army uniform": case "a schutzstaffel uniform": case "a slutty schutzstaffel uniform": + case "a confederate army uniform": case "overalls": case "slutty business attire": case "slutty jewelry": @@ -7736,6 +7738,7 @@ globalThis.birth = function(slave, {birthStorm = false, cSection = false, artRen case "a military uniform": case "a red army uniform": + case "a confederate army uniform": case "a hijab and blouse": case "a slutty schutzstaffel uniform": case "a dirndl": @@ -8128,6 +8131,7 @@ globalThis.birth = function(slave, {birthStorm = false, cSection = false, artRen } break; + case "an evening dress": case "a ball gown": if (slave.fetish === Fetish.MINDBROKEN) { r.push(`${babies}, indifferent to the obvious wetness forming`); @@ -8653,6 +8657,9 @@ globalThis.birth = function(slave, {birthStorm = false, cSection = false, artRen case "a red army uniform": r.push(`red army uniform`); break; + case "a confederate army uniform": + r.push(`confederate army uniform`) + break; case "a long qipao": r.push(`long qipao`); break; @@ -8699,6 +8706,9 @@ globalThis.birth = function(slave, {birthStorm = false, cSection = false, artRen case "a ball gown": r.push(`ball gown`); break; + case "an evening dress": + r.push(`evening dress`); + break; case "a maternity dress": r.push(`maternity dress`); break; @@ -8936,6 +8946,9 @@ globalThis.birth = function(slave, {birthStorm = false, cSection = false, artRen case "a red army uniform": r.push(`red army uniform`); break; + case "a confederate army uniform": + r.push(`confederate army uniform`) + break; case "a long qipao": r.push(`long qipao`); break; @@ -8982,6 +8995,9 @@ globalThis.birth = function(slave, {birthStorm = false, cSection = false, artRen case "a ball gown": r.push(`ball gown`); break; + case "an evening dress": + r.push(`evening dress`); + break; case "a maternity dress": r.push(`maternity dress`); break; diff --git a/src/js/rulesAssistantOptions.js b/src/js/rulesAssistantOptions.js index c2819680f42843e8dc91cbe97d127320fbc0863c..28c15b756b0fcdec07a9176e9311e55ffa4f8474 100644 --- a/src/js/rulesAssistantOptions.js +++ b/src/js/rulesAssistantOptions.js @@ -3535,7 +3535,11 @@ App.RA.options = (function() { if (V.arcologies[0].FSChineseRevivalist !== "unset") { items.push(["(FS) Imperial Seal", "a small image of your Imperial Seal"]); } - + + if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + items.push(["(FS) Fleur-de-lis", "a small, intricate symbol representing a lily"]); + } + super("Your brand design is", items, true, true); this.setValue(current_rule.set.brandDesign); this.onchange = (value) => current_rule.set.brandDesign = value; diff --git a/src/js/slaveCostJS.js b/src/js/slaveCostJS.js index 2fc3469270011df54bc763ac57b63834491f70b6..31657cdb1678002e5aa6416573ea82887db9d9e2 100644 --- a/src/js/slaveCostJS.js +++ b/src/js/slaveCostJS.js @@ -63,7 +63,7 @@ globalThis.minimumSlaveCost = function(includeLaws = false) { 'FSYouthPreferentialistSMR', 'FSMaturityPreferentialistSMR', 'FSSlimnessEnthusiastSMR', 'FSAssetExpansionistSMR', 'FSPastoralistSMR', 'FSPhysicalIdealistSMR', 'FSHedonisticDecadenceSMR', 'FSEgyptianRevivalistSMR', 'FSEdoRevivalistSMR', - 'FSArabianRevivalistSMR', 'FSChineseRevivalistSMR', 'FSNeoImperialistSMR' + 'FSArabianRevivalistSMR', 'FSChineseRevivalistSMR', 'FSNeoImperialistSMR', `FSAntebellumRevivalistSMR` ]; for (const key of FS) { if (V.arcologies[0][key]) { diff --git a/src/js/utilsPC.js b/src/js/utilsPC.js index abde58fc22dd39c962009274eb064924f1162061..2f18d167e8f575601f86a6a4cdf02d46be985be4 100644 --- a/src/js/utilsPC.js +++ b/src/js/utilsPC.js @@ -467,6 +467,14 @@ globalThis.PCTitle = function() { } } + if (V.arcologies[0].FSAntebellumRevivalist >= V.FSLockinLevel * 0.9) { + titles.push(`Reclaimer of the Cause and ${V.PC.title === 1 ? 'Lord' : 'Lady'} of ${V.arcologies[0].name}`); + } else if (V.arcologies[0].FSAntebellumRevivalist >= V.FSLockinLevel * 0.6) { + titles.push(`${V.PC.title === 1 ? 'Lord' : 'Lady'} of ${V.arcologies[0].name}`); + } else if (V.arcologies[0].FSAntebellumRevivalist >= V.FSLockinLevel * 0.3) { + titles.push(`${V.PC.title === 1 ? 'Son' : 'Daughter'} of the South`); + } + const facilities = App.Entity.facilities; if (facilities.brothel.employeesIDs().size >= 15) { if (V.PC.title === 1) { diff --git a/src/js/vignettes.js b/src/js/vignettes.js index 55d59ede62ee00cc6377d41c0bb3505ed731121b..4473316eef6c29735b05a224811b95388b39b54f 100644 --- a/src/js/vignettes.js +++ b/src/js/vignettes.js @@ -1837,6 +1837,13 @@ globalThis.GetVignette = function(slave) { effect: 1, }); } + if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + vignettes.push({ + text: `a street preacher arguing that your new religion is the natural theological evolution of Protestant Christianity attracted a large crowd near ${him},`, + type: "cash", + effect: 1, + }); + } if (V.arcologies[0].FSSupremacist !== "unset") { if (V.arcologies[0].FSSupremacistRace === "asian") { vignettes.push({ @@ -1948,6 +1955,15 @@ globalThis.GetVignette = function(slave) { effect: 1, }); } + if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + if (slave.devotion > 75 && slave.sexualQuirk === "romantic") { + vignettes.push({ + text: `${he} received a generous tip from a gentleman infatuated with ${him},`, + type: "cash", + effect: 1, + }); + } + } if (V.seeAge !== 0) { if (slave.birthWeek >= 51) { if (V.arcologies[0].FSDegradationist !== "unset") { @@ -3841,6 +3857,13 @@ globalThis.GetVignette = function(slave) { effect: 1, }); } + if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + vignettes.push({ + text: `a street preacher arguing that your new religion is the natural theological evolution of Protestant Christianity attracted a large crowd near ${him},`, + type: "rep", + effect: 1, + }); + } if (V.arcologies[0].FSSupremacist !== "unset") { if (V.arcologies[0].FSSupremacistRace === "asian") { vignettes.push({ @@ -3952,6 +3975,15 @@ globalThis.GetVignette = function(slave) { effect: 1, }); } + if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + if (slave.devotion > 75 && slave.sexualQuirk === "romantic") { + vignettes.push({ + text: `${he} received a letter from a gentleman infatuated with ${him},`, + type: "rep", + effect: 1, + }); + } + } if (V.seeAge !== 0) { if (slave.birthWeek >= 51) { if (V.arcologies[0].FSDegradationist !== "unset") { diff --git a/src/neighbor/neighborDescription.js b/src/neighbor/neighborDescription.js index cc97a4a1c3f75d0e8c82056f108261766ca6545a..05db793a7ecf8b7822a3613a1d5441c1e46c583b 100644 --- a/src/neighbor/neighborDescription.js +++ b/src/neighbor/neighborDescription.js @@ -216,6 +216,11 @@ App.UI.neighborDescription = function(i) { 40: `often aggressive about its status as the middle kingdom to the point that it betrays uncertainty`, 0: `moving towards a stage of refinement that will allow it to present itself properly`, }, + FSAntebellumRevivalist : { + 95: `famed for it's Greek-revival style architecture, well-mannered citizenry, and chivalrous aristocrats.`, + 40: `a superficial and sappy reflection of the old American South, too busy indulging in the extravagant architecture of Antebellum plantation houses`, + 0: `struggling to center its society around slave-owning aristocrats and facing resistance from certain ethnic groups who fear they may become a class of chattel slaves.` + }, }; for (const fs of App.Data.FutureSociety.fsNames) { diff --git a/src/npc/bodyguard/bgDescription.js b/src/npc/bodyguard/bgDescription.js index 3e1d6270abe4c5a87683337d28950eeec56195b8..0c74ac9329a7f1b7b9efa103782c4dd541f4f19c 100644 --- a/src/npc/bodyguard/bgDescription.js +++ b/src/npc/bodyguard/bgDescription.js @@ -37,23 +37,25 @@ App.Desc.bodyguard = function(slave) { const w = []; if ((slave.muscles + slave.height - 100) / 25 > 5) { w.push(`${He} has a long ceramic`); - if (V.arcologies[0].FSRomanRevivalist !== "unset") { - w.push('spatha'); - } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - w.push(`claymore`); - } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { - w.push(`shotel`); - } else if (V.arcologies[0].FSEdoRevivalist !== "unset") { - w.push(`odachi`); - } else if (V.arcologies[0].FSArabianRevivalist !== "unset") { - w.push(`kilij`); - } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { - w.push(`changdao`); - } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { - w.push(`macuahuitl`); - } else { - w.push(``); - } + if (V.arcologies[0].FSRomanRevivalist !== "unset") { + w.push('spatha'); + } else if (V.arcologies[0].FSNeoImperialist !== "unset") { + w.push(`claymore`); + } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { + w.push(`shotel`); + } else if (V.arcologies[0].FSEdoRevivalist !== "unset") { + w.push(`odachi`); + } else if (V.arcologies[0].FSArabianRevivalist !== "unset") { + w.push(`kilij`); + } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { + w.push(`changdao`); + } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { + w.push(`macuahuitl`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + w.push(`saber`); + } else { + w.push(``); + } w.push(`sword strapped to ${his} back,`); switch (slave.nationality) { case "American": @@ -167,23 +169,25 @@ App.Desc.bodyguard = function(slave) { w.push(`slung crosswise on ${his} chest.`); } else if ((slave.muscles + slave.height - 100) / 25 > 4) { w.push(`${He} has a ceramic`); - if (V.arcologies[0].FSRomanRevivalist !== "unset") { - w.push('gladius'); - } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - w.push(`kightly`); - } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { - w.push(`khopesh`); - } else if (V.arcologies[0].FSEdoRevivalist !== "unset") { - w.push(`katana`); - } else if (V.arcologies[0].FSArabianRevivalist !== "unset") { - w.push(`shamshir`); - } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { - w.push(`jian`); - } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { - w.push(`macuahuitl`); - } else { - w.push(``); - } + if (V.arcologies[0].FSRomanRevivalist !== "unset") { + w.push('gladius'); + } else if (V.arcologies[0].FSNeoImperialist !== "unset") { + w.push(`kightly`); + } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { + w.push(`khopesh`); + } else if (V.arcologies[0].FSEdoRevivalist !== "unset") { + w.push(`katana`); + } else if (V.arcologies[0].FSArabianRevivalist !== "unset") { + w.push(`shamshir`); + } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { + w.push(`jian`); + } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { + w.push(`macuahuitl`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + w.push(`saber`); + } else { + w.push(``); + } w.push(`sword strapped to ${his} back`); switch (slave.nationality) { case "American": @@ -327,23 +331,25 @@ App.Desc.bodyguard = function(slave) { w.push(`slung across ${his} chest.`); } else if ((slave.muscles + slave.height - 100) / 25 > 3) { w.push(`${He} has a`); - if (V.arcologies[0].FSRomanRevivalist !== "unset") { - w.push('curved ceramic falcata'); - } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - w.push(`straight ceramic estoc`); - } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { - w.push(`sickle-shaped`); - } else if (V.arcologies[0].FSEdoRevivalist !== "unset") { - w.push(`curved ceramic wakizashi`); - } else if (V.arcologies[0].FSArabianRevivalist !== "unset") { - w.push(`curved ceramic yatagan`); - } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { - w.push(`curved ceramic dao`); - } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { - w.push(`straight ceramic macuahuitl`); - } else { - w.push(`straight ceramic`); - } + if (V.arcologies[0].FSRomanRevivalist !== "unset") { + w.push('curved ceramic falcata'); + } else if (V.arcologies[0].FSNeoImperialist !== "unset") { + w.push(`straight ceramic estoc`); + } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { + w.push(`sickle-shaped`); + } else if (V.arcologies[0].FSEdoRevivalist !== "unset") { + w.push(`curved ceramic wakizashi`); + } else if (V.arcologies[0].FSArabianRevivalist !== "unset") { + w.push(`curved ceramic yatagan`); + } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { + w.push(`curved ceramic dao`); + } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { + w.push(`straight ceramic macuahuitl`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + w.push(`curved ceramic saber`); + } else { + w.push(`straight ceramic`); + } w.push(`sword strapped to ${his} back`); switch (slave.nationality) { case "American": @@ -453,23 +459,25 @@ App.Desc.bodyguard = function(slave) { w.push(`slung across ${his} chest.`); } else { w.push(`${He} has a short ceramic`); - if (V.arcologies[0].FSRomanRevivalist !== "unset") { - w.push('pugio'); - } else if (V.arcologies[0].FSNeoImperialist !== "unset") { - w.push(`baselard`); - } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { - w.push(`acinaces`); - } else if (V.arcologies[0].FSEdoRevivalist !== "unset") { - w.push(`tanto`); - } else if (V.arcologies[0].FSArabianRevivalist !== "unset") { - w.push(`jambiya`); - } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { - w.push(`nandao`); - } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { - w.push(`macuahuitl`); - } else { - w.push(``); - } + if (V.arcologies[0].FSRomanRevivalist !== "unset") { + w.push('pugio'); + } else if (V.arcologies[0].FSNeoImperialist !== "unset") { + w.push(`baselard`); + } else if (V.arcologies[0].FSEgyptianRevivalist !== "unset") { + w.push(`acinaces`); + } else if (V.arcologies[0].FSEdoRevivalist !== "unset") { + w.push(`tanto`); + } else if (V.arcologies[0].FSArabianRevivalist !== "unset") { + w.push(`jambiya`); + } else if (V.arcologies[0].FSChineseRevivalist !== "unset") { + w.push(`nandao`); + } else if (V.arcologies[0].FSAztecRevivalist !== "unset") { + w.push(`macuahuitl`); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + w.push(`Bowie knife`); + } else { + w.push(``); + } w.push(`sword strapped to ${his} back`); switch (slave.nationality) { case "American": diff --git a/src/npc/descriptions/belly/belly.js b/src/npc/descriptions/belly/belly.js index d9a47a56fa02aebf45e629ca14e174c12aa35f0a..0e0f8b7a71f59fc4da6ef63ffa6f021caf69de4d 100644 --- a/src/npc/descriptions/belly/belly.js +++ b/src/npc/descriptions/belly/belly.js @@ -5262,6 +5262,7 @@ App.Desc.belly = function(slave, descType = DescType.NORMAL) { case "a military uniform": case "a red army uniform": case "a mounty outfit": + case "a confederate army uniform": if (slave.belly >= 1000000) { // WIP// } else if (slave.belly >= 750000) { @@ -11341,6 +11342,113 @@ App.Desc.belly = function(slave, descType = DescType.NORMAL) { r.push(`${slave.slaveName}'s beautiful halter top dress hugs ${his} ripped abs, clearly displaying the six pack beneath.`); } break; + case "an evening dress": + if (slave.belly >= 1000000) { + // WIP// + } else if (slave.belly >= 750000) { + if (isBellyFluidLargest) { + // TODO: write me + } else if (slave.bellyImplant > 0) { + r.push(`${slave.slaveName}'s sensual evening dress is specially designed to flatter the massively gravid, even if they are just pretending. Its material tightly clings to ${his} monolithic implant-filled belly while offering a diamond window to display ${his} popped navel and a massive expanse of skin around it.`); + } else { + r.push(`${slave.slaveName}'s sensual evening dress is specially designed to flatter the hugely gravid. Its material tightly clings to the bulges of life within ${his} monolithic pregnant belly while offering a diamond window to display ${his} popped navel and the expanse of skin around it, which is now held in place by several of ${his} brood also stuck protruding through the gap.`); + } + } else if (slave.bellyPreg >= 600000) { + if (isBellyFluidLargest) { + // TODO: write me + } else if (slave.bellyImplant > 0) { + r.push(`${slave.slaveName}'s sensual evening dress is specially designed to flatter the massively gravid, even if they are just pretending. Its material tightly clings to ${his} titanic implant-filled belly while offering a diamond window to display ${his} popped navel and an expanse of skin around it.`); + } else { + r.push(`${slave.slaveName}'s sensual evening dress is specially designed to flatter the hugely gravid. Its material tightly clings to the bulges of life within ${his} titanic pregnant belly while offering a diamond window to display ${his} popped navel and the expanse of skin around it, which, given how overfilled ${he} is, is constantly drifting off-center thanks to ${his} rowdy brood.`); + } + } else if (slave.belly >= 450000) { + if (isBellyFluidLargest) { + // TODO: write me + } else if (slave.bellyImplant > 0) { + r.push(`${slave.slaveName}'s sensual evening dress is specially designed to flatter the massively gravid, even if they are just pretending. Its material tightly clings to ${his} gigantic implant-filled belly while offering a diamond window to display ${his} popped navel and an expanse of skin around it.`); + } else { + r.push(`${slave.slaveName}'s sensual evening dress is specially designed to flatter the hugely gravid. Its material tightly clings to ${his} gigantic pregnant belly while offering a diamond window to display ${his} popped navel and an expanse of skin around it, which tends to drift with the movements of ${his} brood.`); + } + } else if (slave.belly >= 300000) { + if (isBellyFluidLargest) { + // TODO: write me + } else if (slave.bellyImplant > 0) { + r.push(`${slave.slaveName}'s sensual evening dress is specially designed to flatter the hugely gravid, even if they are just pretending. Its material tightly clings to ${his} massive implant-filled belly while offering a diamond window to display ${his} popped navel and an expanse of skin around it.`); + } else { + r.push(`${slave.slaveName}'s sensual evening dress is specially designed to flatter the hugely gravid. Its material tightly clings to ${his} massive pregnant belly while offering a diamond window to display ${his} popped navel and an expanse of skin around it.`); + } + } else if (slave.belly >= 120000) { + if (isBellyFluidLargest) { + // TODO: write me + } else if (slave.bellyImplant > 0) { + r.push(`${slave.slaveName}'s sensual evening dress is specially designed to flatter the hugely gravid, even if they are just pretending. Its material tightly hugs ${his} giant implant-filled belly while offering a diamond window to display ${his} popped navel and surrounding skin.`); + } else { + r.push(`${slave.slaveName}'s sensual evening dress is specially designed to flatter the hugely gravid. Its material tightly hugs ${his} giant pregnant belly while offering a diamond window to display ${his} popped navel and surrounding skin.`); + } + } else if (slave.belly >= 30000) { + if (isBellyFluidLargest) { + // TODO: write me + } else if (slave.bellyImplant > 0) { + r.push(`${slave.slaveName}'s sensual evening dress is specially designed to flatter the hugely gravid, even if they are just pretending. Its material tightly hugs ${his} huge implant-filled belly while offering a diamond window to display ${his} popped navel.`); + } else { + r.push(`${slave.slaveName}'s sensual evening dress is specially designed to flatter the hugely gravid. Its material tightly hugs ${his} huge pregnant belly while offering a diamond window to display ${his} popped navel.`); + } + } else if (slave.weight > 190) { + r.push(`${slave.slaveName}'s sensual evening dress is strained by ${his} massively fat belly. Every crease, fold, roll and motion is clearly visible within it. Its seams strain to hold back the tide of flesh pushing against them.`); + } else if (slave.belly >= 15000 || slave.bellyAccessory === "a huge empathy belly") { + if (slave.bellyAccessory === "a huge empathy belly") { + r.push(`${slave.slaveName}'s sensual evening dress is strained by ${his} huge pregnant belly. ${His} popped navel prominently pokes through its front.`); + } else if (isBellyFluidLargest) { + // TODO: write me + } else if (slave.bellyImplant > 0) { + r.push(`${slave.slaveName}'s sensual evening dress is strained by ${his} huge implant-filled belly. ${His} popped navel prominently pokes through its front.`); + } else { + r.push(`${slave.slaveName}'s sensual evening dress is strained by ${his} huge pregnant belly. ${His} popped navel prominently pokes through its front.`); + } + } else if (slave.belly >= 10000 || slave.bellyAccessory === "a large empathy belly") { + if (slave.bellyAccessory === "a large empathy belly") { + r.push(`${slave.slaveName}'s sensual evening dress is filled by ${his} big pregnant belly. ${His} popped navel prominently pokes through its front.`); + } else if (isBellyFluidLargest) { + r.push(`${slave.slaveName}'s sensual evening dress bulges obscenely with ${his} hugely swollen belly.`); + } else if (slave.bellyImplant > 0) { + r.push(`${slave.slaveName}'s sensual evening dress is filled by ${his} big implant-filled belly. ${His} popped navel prominently pokes through its front.`); + } else { + r.push(`${slave.slaveName}'s sensual evening dress is filled by ${his} big pregnant belly. ${His} popped navel prominently pokes through its front.`); + } + } else if (slave.weight > 160) { + r.push(`${slave.slaveName}'s sensual evening dress is filled by ${his} hugely fat belly. Every crease, fold, roll and motion is clearly visible within it.`); + } else if (slave.weight > 130) { + r.push(`${slave.slaveName}'s sensual evening dress is filled by ${his} big fat belly. Every crease, fold and roll is clearly visible within it.`); + } else if (slave.belly >= 5000 || slave.bellyAccessory === "a medium empathy belly") { + if (slave.bellyAccessory === "a medium empathy belly") { + r.push(`${slave.slaveName}'s sensual evening dress is filled by ${his} pregnant belly. ${His} popped navel prominently pokes through the front of ${his} dress.`); + } else if (isBellyFluidLargest) { + r.push(`${slave.slaveName}'s sensual evening dress bulges with ${his} jiggling ${slave.inflationType}-filled belly.`); + } else if (slave.bellyImplant > 0) { + r.push(`${slave.slaveName}'s sensual evening dress is filled by ${his} implant-filled belly. ${His} popped navel prominently pokes through the front of ${his} dress.`); + } else { + r.push(`${slave.slaveName}'s sensual evening dress is filled by ${his} pregnant belly. ${His} popped navel prominently pokes through the front of ${his} dress.`); + } + } else if (slave.weight > 95) { + r.push(`${slave.slaveName}'s sensual evening dress is filled by ${his} fat belly. Every crease, fold and roll is clearly visible within it.`); + } else if (slave.belly >= 1500 || slave.bellyAccessory === "a small empathy belly") { + if (slave.bellyAccessory === "a small empathy belly") { + r.push(`${slave.slaveName}'s sensual evening dress is filled out by ${his} small pregnant belly.`); + } else if (isBellyFluidLargest) { + r.push(`${slave.slaveName}'s sensual evening dress bulges with ${his} ${slave.inflationType}-swollen belly.`); + } else if (slave.bellyImplant > 0) { + r.push(`${slave.slaveName}'s sensual evening dress is filled out by ${his} implant-rounded belly.`); + } else { + r.push(`${slave.slaveName}'s sensual evening dress is filled out by ${his} growing belly.`); + } + } else if (slave.weight > 30) { + r.push(`${slave.slaveName}'s sensual evening dress is filled by ${his} chubby belly. Every crease, fold and roll is clearly visible within it.`); + } else if (slave.bellyPreg >= 100 || slave.bellyImplant >= 100) { + r.push(`${slave.slaveName}'s sensual evening dress bulges slightly with the swell of ${his} lower belly.`); + } else if (slave.muscles > 30) { + r.push(`${slave.slaveName}'s sensual evening dress hugs ${his} ripped abs, clearly displaying the six pack beneath.`); + } + break; case "a ball gown": if (slave.belly >= 1000000) { // WIP// diff --git a/src/npc/descriptions/boobs/boobs.js b/src/npc/descriptions/boobs/boobs.js index 2490c7498ff93c27966cbb239092af4678810732..281544be4c86b1893ef3d8aba97563cc057d5b40 100644 --- a/src/npc/descriptions/boobs/boobs.js +++ b/src/npc/descriptions/boobs/boobs.js @@ -608,6 +608,21 @@ App.Desc.boobs = function() { r += `${slave.slaveName} is wearing a beautiful silky halter top dress, almost as if it was sculpted to match ${his} frame.`; } break; + case "an evening dress": + if (slave.boobs > 12000) { + r += `${slave.slaveName}'s ${adjNoun} could never fit inside ${his} dress; instead it has been redesigned to allow them to hang freely.`; + } else if (slave.boobs > 4000) { + r += `${slave.slaveName}'s ${adjNoun} are spilling out of ${his} sensual evening dress, threatening to burst free out with every ${hasBothLegs(slave) ? `step` : `movement`}.`; + } else if (slave.boobs > 2000) { + r += `${slave.slaveName}'s ${adjNoun} are pushed up and bulging out of ${his} sensual evening dress, giving ${him} a jaw-dropping amount of cleavage.`; + } else if (slave.boobs > 800) { + r += `${slave.slaveName}'s ${adjNoun} are separated by a plunging neckline, displaying an ample amount of side boob for ${his} size.`; + } else if (slave.boobs < 300) { + r += `${slave.slaveName} sensual evening dress tastefully frames ${his} flat chest.`; + } else { + r += `${slave.slaveName} sensual evening dress tastefully frames ${his} chest.`; + } + break; case "a ball gown": if (slave.boobs > 12000) { r += `${slave.slaveName} fabulous silken ball gown is designed to allow ${his} oversized breasts to hang free.`; @@ -684,6 +699,19 @@ App.Desc.boobs = function() { r += `${slave.slaveName} cuts a dashing figure in ${his} tunic. ${slave.boobs < 300 ? `${His} ${App.Desc.boobBits.adjective(slave.boobs)} breasts are barely there.` : ''}`; } break; + case "a confederate army uniform": + if (slave.boobs > 12000) { + r += `${slave.slaveName}'s tits are so immense that ${his} shirt and jacket cannot be buttoned.`; + } else if (slave.boobs > 4000) { + r += `${slave.slaveName}'s tits are so huge that ${his} military jacket threatens to burst at the seams.`; + } else if (slave.boobs > 2000) { + r += `${slave.slaveName}'s tits make a distracting bulge in ${his} military jacket, straining the top buttons.`; + } else if (slave.boobs > 800) { + r += `${slave.slaveName}'s ${adjNoun} lend a feminine curve to ${his} military jacket.`; + } else { + r += `${slave.slaveName} cuts a dashing figure in ${his} military jacket. ${slave.boobs < 300 ? `${His} ${App.Desc.boobBits.adjective(slave.boobs)} breasts are hardly visible.` : ''}`; + } + break; case "a long qipao": if (slave.boobs > 12000) { r += `${slave.slaveName}'s tits are so immense that ${his} dress is on the verge of bursting open.`; diff --git a/src/npc/descriptions/butt/butt.js b/src/npc/descriptions/butt/butt.js index c635c0fca480c8fa919175691ceaf577619a34a7..814f20c7254989326d1ac86d4f5454f2caf3ad60 100644 --- a/src/npc/descriptions/butt/butt.js +++ b/src/npc/descriptions/butt/butt.js @@ -486,6 +486,19 @@ App.Desc.butt = function(slave, descType = DescType.NORMAL) { } r.push(`buttocks.`); break; + case "an evening dress": + r.push(`${His} sensual evening dress is`); + if (slave.butt > 10) { + r.push(`tailored, and can only barely contain ${his} inhuman`); + } else if (slave.butt > 6) { + r.push(`tailored as much as possible for ${his} massive butt, but nevertheless causes the thigh cut rides up ${his} leg, unintentionally exposing more of ${him}.`); + } else if (slave.butt > 3) { + r.push(`tailored and accentuates ${his} big`); + } else { + r.push(`clings to ${his} butt.`); + } + r.push(`butt.`); + break; case "a dirndl": r.push(`${His} beautiful dirndl is`); if (slave.butt > 10) { @@ -593,6 +606,7 @@ App.Desc.butt = function(slave, descType = DescType.NORMAL) { } break; case "a schutzstaffel uniform": + case "a confederate army uniform": r.push(`${His} uniform trousers`); if (slave.butt > 10) { r.push(`are tailored as tastefully as possible to restrain ${his} enormous buttocks, though its massive size strains the seams.`); diff --git a/src/npc/descriptions/butt/buttplug.js b/src/npc/descriptions/butt/buttplug.js index b2736db64e53771820118bbb1cf5188e8417960d..b11aaa8696242846f9994f9330efcd21c6f00c2e 100644 --- a/src/npc/descriptions/butt/buttplug.js +++ b/src/npc/descriptions/butt/buttplug.js @@ -361,6 +361,13 @@ App.Desc.buttplug = function(slave, descType = DescType.NORMAL) { r.push(`Though ${his} silken ball gown is fabulous, ${his} asshole is bare beneath it.`); } break; + case "an evening dress": + if (slave.chastityAnus) { + r.push(`${His} dress hides ${his} anal chastity accessory underneath, but leaves a faintly visible impression on the fabric.`); + } else { + r.push(`${His} sensual evening dress completely hides her bare asshole.`); + } + break; case "a comfortable bodysuit": r.push(`${His} bodysuit is so form-fitting that the shape of ${his}`); if (slave.chastityAnus) { @@ -545,6 +552,7 @@ App.Desc.buttplug = function(slave, descType = DescType.NORMAL) { case "a schutzstaffel uniform": case "a slutty schutzstaffel uniform": case "a red army uniform": + case "a confederate army uniform": case "a button-up shirt and panties": case "a gothic lolita dress": case "a hanbok": diff --git a/src/npc/descriptions/crotch/crotch.js b/src/npc/descriptions/crotch/crotch.js index 12b99298486f8777afb445e62ba6eb8d460ea249..3943071899c461d3a90e402c9c82878927ebe39d 100644 --- a/src/npc/descriptions/crotch/crotch.js +++ b/src/npc/descriptions/crotch/crotch.js @@ -663,6 +663,22 @@ App.Desc.crotch = function(slave, descType = DescType.NORMAL) { r.push(`pussy is concealed by ${his} fabulous silken ball gown.`); } break; + case "an evening dress": + r.push(`${slave.slaveName}'s`); + if (slave.dick > 4) { + r.push(`cock is so large it's visible through the thigh slit of ${his} sensual evening dress.`); + } else if (slave.dick > 3) { + r.push(`cock tents the front of ${his} sensual evening dress, hiking the thigh slit almost up to ${his} crotch at the right angle.`); + } else if ((slave.dick > 0) && (slave.vagina > -1)) { + r.push(`hermaphroditic genitalia are hidden by ${his} sensual evening dress.`); + } else if (slave.dick > 0) { + r.push(`cock is hidden by ${his} sensual evening dress.`); + } else if (slave.vagina === -1) { + r.push(`featureless groin is concealed by ${his} sensual evening dress.`); + } else { + r.push(`pussy is concealed by ${his} sensual evening dress.`); + } + break; case "slutty business attire": r.push(`${slave.slaveName}'s`); if (slave.dick > 3) { @@ -717,6 +733,7 @@ App.Desc.crotch = function(slave, descType = DescType.NORMAL) { r.push(`${slave.slaveName}'s uniform skirt gives no hint of the cock behind it.`); } break; + case "a confederate army uniform": case "a schutzstaffel uniform": if (slave.dick > 3) { r.push(`${slave.slaveName}'s uniform trousers bulges forward in front.`); diff --git a/src/npc/descriptions/describePiercings.js b/src/npc/descriptions/describePiercings.js index 2ad1e1d8b1e38e6f09afe5e0d83e072ffb0d469a..df122da9df061cbf8f776420309af4eb2da22603 100644 --- a/src/npc/descriptions/describePiercings.js +++ b/src/npc/descriptions/describePiercings.js @@ -147,6 +147,7 @@ App.Desc.piercing = function(slave, surface) { case "a halter top dress": case "a ball gown": case "a maternity dress": + case "an evening dress": r.push(`${He}'s wearing lovely diamond earrings; the stones are cut in an alluring, feminine style.`); break; case "slutty business attire": @@ -183,6 +184,8 @@ App.Desc.piercing = function(slave, surface) { case "a courtesan dress": r.push(`${He}'s wearing hanging earrings that accentuate each movement of ${his} head.`); break; + case "a confederate army uniform": + r.push(`${He}'s wearing a little, unobtrusive stud earring in the shape of a Fleur-de-lis.`); case "slutty jewelry": r.push(`${He}'s wearing gold earrings in the shape of a pair of`); if (slave.dick > 0 && slave.balls === 0) { @@ -575,15 +578,12 @@ App.Desc.piercing = function(slave, surface) { } break; case "a military uniform": - r.push(`${his} tunic hides them completely, but they're laced tightly, so ${he}'s aware they're there.`); - break; case "a schutzstaffel uniform": - r.push(`${his} tunic hides them completely, but they're laced tightly, so ${he}'s aware they're there.`); - break; case "a slutty schutzstaffel uniform": - r.push(`${his} tunic hides them completely, but they're laced tightly, so ${he}'s aware they're there.`); - break; + case "lederhosen": case "a red army uniform": + case "a mounty outfit": + case "a confederate army uniform": r.push(`${his} tunic hides them completely, but they're laced tightly, so ${he}'s aware they're there.`); break; case "battlearmor": @@ -595,12 +595,6 @@ App.Desc.piercing = function(slave, surface) { case "a dirndl": r.push(`${his} dress hides them completely, but they're laced tightly, so ${he}'s aware they're there.`); break; - case "lederhosen": - r.push(`${his} tunic hides them completely, but they're laced tightly, so ${he}'s aware they're there.`); - break; - case "a mounty outfit": - r.push(`${his} tunic hides them completely, but they're laced tightly, so ${he}'s aware they're there.`); - break; case "a biyelgee costume": r.push(`${his} dress hides them completely, but they're laced tightly, so ${he}'s aware they're there.`); break; @@ -676,6 +670,7 @@ App.Desc.piercing = function(slave, surface) { case "a tube top": case "a tube top and thong": case "leather pants and a tube top": + case "an evening dress": r.push(`the piercings are only partly visible on ${his} back.`); break; case "a button-up shirt": diff --git a/src/npc/descriptions/style/clothing.js b/src/npc/descriptions/style/clothing.js index 2955b378133624c3aebf3da7e393b6742fe5e30d..49870b1c29b7600224fe248f7319ffb1c8bcd21f 100644 --- a/src/npc/descriptions/style/clothing.js +++ b/src/npc/descriptions/style/clothing.js @@ -394,6 +394,21 @@ App.Desc.clothing = function(slave) { r.push(`back.`); } break; + case "an evening dress": + r.push(`a fashionable, floor-length garment showing off ${his}`); + if (slave.muscles > 30) { + r.push('muscular') + } else if (slave.muscles > 6) { + r.push('toned') + } else { + r.push('bare') + } + r.push(`back and shoulders.`); + if (hasAnyLegs(slave)) { + r.push(`A long slit creeps up the length the dress exposing ${his} upper thigh. Peeking out from beneath the hem is`); + r.push(App.Desc.footwear(slave)); + } + break; case "a mini dress": r.push(`a body hugging strapless number that shows as much skin as it`); if (hasAnyLegs(slave)) { @@ -871,6 +886,34 @@ App.Desc.clothing = function(slave) { } r.push(`along with various ribbons denoting sexual aptitude and prized traits.`); break; + case "a confederate army uniform": + r.push(`consisting of a shirt, single breasted military shell jacket, frock coat, `); + if (hasAnyLegs(slave)) { + r.push(`matching trousers all in a blue-gray tone, and`); + r.push(App.Desc.footwear(slave)); + } else { + r.push(`and matching trousers all in a blue-gray tone.`); + } + r.push(`The collar of ${his} jacket is`) + if ((slave.ID === V.BodyguardID) || (slave.ID === V.HeadGirlID) || (slave.ID === V.RecruiterID) || (slave.ID === V.ConcubineID)) { + r.push(`pinned with a golden wreath partially encompassing a golden whip and manacles, the insignia of a senior slave officer.`); + } else if ((slave.ID === V.MadamID) || (slave.ID === V.NurseID) || (slave.ID === V.AttendantID) || (slave.ID === V.MatronID) || (slave.ID === V.djID) || (slave.ID === V.MilkmaidID) || (slave.ID === V.FarmerID) || (slave.ID === V.StewardessID) || (slave.ID === V.SchoolteacherID) || (slave.ID === V.WardenessID)) { + r.push(`pinned with golden whip and manacles, the insignia of a slave officer.`); + } else if (slave.trust > 50 || slave.devotion > 50) { + r.push(`pinned with golden manacles, the insignia of a junior slave officer.`); + } else { + r.push(`unadorned, indicating a slave's lack of experience or trustworthiness.`); + } + r.push(`${His} jacket sleeve is`); + if ((slave.skill.combat > 60) && getLimbCount(slave, 105) > 0) { + r.push(`pinned with two black chevrons, the insignia of an augmented slave soldier as well as`); + } else if ((slave.skill.combat > 60) && !isAmputee(slave)) { + r.push(`pinned with a single black chevron, the insignia of a slave soldier as well as`); + } else { + r.push(`undecorated, aside from`); + } + r.push(`various ribbons denoting sexual aptitude and prized traits.`); + break; case "battledress": r.push(`including comfortable fatigue`); if (hasAnyLegs(slave)) { diff --git a/src/npc/descriptions/style/clothingCorset.js b/src/npc/descriptions/style/clothingCorset.js index 9d7d202c2a5f35683274d5fb05db81a067afb1a7..d9620067f955214e589a9ffe96c82ee0579ed05e 100644 --- a/src/npc/descriptions/style/clothingCorset.js +++ b/src/npc/descriptions/style/clothingCorset.js @@ -260,6 +260,7 @@ App.Desc.clothingCorset = function(slave) { } break; case "a halter top dress": + case "an evening dress": if (slave.bellyAccessory === "a corset") { r.push(`The dress has an elegant integral corset.`); } else if (slave.bellyAccessory === "an extreme corset") { @@ -450,6 +451,7 @@ App.Desc.clothingCorset = function(slave) { case "a schutzstaffel uniform": case "a slutty schutzstaffel uniform": case "a police uniform": + case "a confederate army uniform": if (slave.bellyAccessory === "a corset") { r.push(`${His} tunic conceals ${his} corset.`); } else if (slave.bellyAccessory === "an extreme corset") { diff --git a/src/npc/descriptions/style/footwear.js b/src/npc/descriptions/style/footwear.js index fb0a856acbe727d350db3c5703df1e59bed4bfa5..199ceacfb34c6a2b57a467f0e504cbbc1d4c176e 100644 --- a/src/npc/descriptions/style/footwear.js +++ b/src/npc/descriptions/style/footwear.js @@ -2187,6 +2187,69 @@ App.Desc.footwear = function(slave) { r.push(`with ${his} ridiculously bare ${feet} in tights.`); } break; + case "an evening dress": + switch (slave.shoes) { + case "flats": + if (bothFeet) { + r.push(`a pair of simple, yet elegant, embroidered flats.`); + } else { + r.push(`a flat shoe with simple, yet elegant, embroidered design.`); + } + break; + case "boots": + if (bothFeet) { + r.push(`a fashionable pair of crushed velvet thigh-high boots.`); + } else { + r.push(`a fashionable crushed velvet thigh-high boot.`); + } + break; + case "heels": + if (bothFeet) { + r.push(`a flirty pair of strappy heels.`); + } else { + r.push(`a flirty strappy heel.`); + } + break; + case "pumps": + if (bothFeet) { + r.push(`an elegant pair of stiletto pumps.`); + } else { + r.push(`an elegant stiletto pump.`); + } + break; + case "extreme heels": + if (bothFeet) { + r.push(`tights and a pair of stiletto heels so extreme ${he} has to concentrate just to stand.`); + } else { + r.push(`tights and a stiletto heel so extreme ${he} can't even stand.`); + } + break; + case "platform shoes": + if (bothFeet) { + r.push(`a pair of platform shoes with decorative bows.`); + } else { + r.push(`a platform shoe with a decorative bow.`); + } + break; + case "platform heels": + if (bothFeet) { + r.push(`an elegant pair of platform heels`); + } else { + r.push(`an elegant platform heel`); + } + r.push(`complete with stiletto.`); + break; + case "extreme platform heels": + if (bothFeet) { + r.push(`a narrow pair of platform heels so extreme ${he} has to concentrate just to stand.`); + } else { + r.push(`a narrow platform heel so extreme ${he} can't even stand.`); + } + break; + default: + r.push(`${his} ridiculously bare ${feet}.`); + } + break; case "a mini dress": switch (slave.shoes) { case "flats": @@ -3592,6 +3655,7 @@ App.Desc.footwear = function(slave) { case "a slutty schutzstaffel uniform": case "a red army uniform": case "a mounty outfit": + case "a confederate army uniform": switch (slave.shoes) { case "flats": if (bothFeet) { diff --git a/src/npc/descriptions/style/hairClothing.js b/src/npc/descriptions/style/hairClothing.js index 1e49e206b15c4780ab2eef6446c2cd2977c45438..fee2f4de72aa2f24291ecee223271c1b8773d29e 100644 --- a/src/npc/descriptions/style/hairClothing.js +++ b/src/npc/descriptions/style/hairClothing.js @@ -37,6 +37,7 @@ App.Desc.hairClothing = function(slave) { break; case "a halter top dress": case "a ball gown": + case "an evening dress": r.push(`cascades gorgeously down ${his} bare back.`); break; case "a courtesan dress": @@ -139,6 +140,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`is kept out of ${his} face by a couple of sturdy hairpins.`); break; case "Imperial Plate": @@ -195,6 +197,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`flows fashionably down ${his} bare back.`); break; case "a courtesan dress": @@ -297,6 +300,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`is kept out of ${his} face by a couple of sturdy hairpins.`); break; case "Imperial Plate": @@ -354,6 +358,7 @@ App.Desc.hairClothing = function(slave) { break; case "a halter top dress": case "a ball gown": + case "an evening dress": r.push(`follows the latest fashion.`); break; case "a courtesan dress": @@ -456,6 +461,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`is kept out of ${his} face by a sturdy hairpin.`); break; case "Imperial Plate": @@ -505,9 +511,8 @@ App.Desc.hairClothing = function(slave) { r.push(`is covered by a flimsy hairnet.`); break; case "a halter top dress": - r.push(`is gelled into a fashionable wave.`); - break; case "a ball gown": + case "an evening dress": r.push(`is gelled into a fashionable wave.`); break; case "a courtesan dress": @@ -602,6 +607,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`is in a utilitarian cut.`); break; case "Imperial Plate": @@ -672,6 +678,7 @@ App.Desc.hairClothing = function(slave) { break; case "a halter top dress": case "a ball gown": + case "an evening dress": r.push(`is piled up on ${his} head in a perfect 60's beehive.`); break; case "a burkini": @@ -764,6 +771,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`is pulled hard back into a big bun held in place with paracord.`); break; case "Imperial Plate": @@ -820,6 +828,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is piled up on ${his} head in a perfect 60's beehive.`); break; case "a courtesan dress": @@ -918,6 +927,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`is pulled hard back into a bun held in place with paracord.`); break; case "Imperial Plate": @@ -974,6 +984,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is piled up on ${his} head in a perfect 60's 'do.`); break; case "a courtesan dress": @@ -1072,6 +1083,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`is pulled hard back into a bun held in place with paracord.`); break; case "Imperial Plate": @@ -1267,6 +1279,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is combed into beautiful long tails, one of which comes around to run down ${his} chest.`); break; case "slutty business attire": @@ -1428,6 +1441,7 @@ App.Desc.hairClothing = function(slave) { break; case "a halter top dress": case "a ball gown": + case "an evening dress": r.push(`is combed into beautiful tails, one of which comes around to fall between ${his} breasts.`); break; case "slutty business attire": @@ -1589,6 +1603,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is combed into short tails set low at the nape of ${his} neck.`); break; case "slutty business attire": @@ -1837,6 +1852,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is braided into a gorgeous, lengthy dutch braid that comes around to run down ${his} chest.`); break; case "slutty business attire": @@ -1998,6 +2014,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is braided into a elegant dutch braid that comes around to run down ${his} chest.`); break; case "slutty business attire": @@ -2159,6 +2176,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is braided into a charming dutch braid that comes around to run down ${his} chest.`); break; case "slutty business attire": @@ -2407,6 +2425,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is braided into two gorgeous, lengthy dutch braids that come around to run down ${his} chest.`); break; case "slutty business attire": @@ -2568,6 +2587,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is braided into two elegant dutch braids that come around to run down ${his} chest.`); break; case "slutty business attire": @@ -2729,6 +2749,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is braided into two charming dutch braids that come around to run down ${his} chest.`); break; case "slutty business attire": @@ -2928,6 +2949,7 @@ App.Desc.hairClothing = function(slave) { break; case "a halter top dress": case "a ball gown": + case "an evening dress": r.push(`is partly braided into a grand-looking crown braid that circles ${his} head, while the rest of it cascades gorgeously down ${his} bare back.`); break; case "a courtesan dress": @@ -3026,6 +3048,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`is partly braided into a grand-looking crown braid that circles ${his} head, while the rest of it is decorated with a couple of sturdy hairpins.`); break; case "Imperial Plate": @@ -3082,6 +3105,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is partly braided into a elegant-looking crown braid that circles ${his} head, while the rest of it flows fashionably down ${his} bare back.`); break; case "a courtesan dress": @@ -3184,6 +3208,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`is partly braided into a elegant-looking crown braid that circles ${his} head, while the rest of it is decorated with a couple of sturdy hairpins.`); break; case "Imperial Plate": @@ -3241,6 +3266,7 @@ App.Desc.hairClothing = function(slave) { break; case "a halter top dress": case "a ball gown": + case "an evening dress": r.push(`is braided into a charming crown braid that only just circles ${his} head, and is topped with a dainty little tiara.`); break; case "a courtesan dress": @@ -3343,6 +3369,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`is braided into a charming crown braid that only just circles ${his} head, and is decorated with sturdy hairpins.`); break; case "Imperial Plate": @@ -3392,9 +3419,8 @@ App.Desc.hairClothing = function(slave) { r.push(`is covered by a flimsy hairnet.`); break; case "a halter top dress": - r.push(`is gelled into a fashionable wave.`); - break; case "a ball gown": + case "an evening dress": r.push(`is gelled into a fashionable wave.`); break; case "a courtesan dress": @@ -3489,6 +3515,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`is in a utilitarian cut.`); break; case "Imperial Plate": @@ -3608,6 +3635,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is combed into a beautiful long ponytail, which swooshes as ${he} moves.`); break; case "slutty business attire": @@ -3769,6 +3797,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is combed into a beautiful ponytail, which swooshes as ${he} moves.`); break; case "slutty business attire": @@ -3930,6 +3959,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is combed into a short ponytail set low at the nape of ${his} neck.`); break; case "slutty business attire": @@ -4111,6 +4141,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is combed into beautiful long braids, one of which comes around to run down ${his} chest.`); break; case "slutty business attire": @@ -4266,6 +4297,7 @@ App.Desc.hairClothing = function(slave) { break; case "a halter top dress": case "a ball gown": + case "an evening dress": r.push(`is in beautiful braids, one of which comes around to fall between ${his} breasts.`); break; case "slutty business attire": @@ -4420,6 +4452,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is combed into short braids set low at the nape of ${his} neck.`); break; case "slutty business attire": @@ -4601,6 +4634,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is in dreadlocks, spreading out in many directions and almost reaching the ground.`); break; case "slutty business attire": @@ -4755,9 +4789,8 @@ App.Desc.hairClothing = function(slave) { r.push(`is in dreadlocks, but they're hidden by ${his} surplice.`); break; case "a halter top dress": - r.push(`is in dreadlocks, spreading out in many directions.`); - break; case "a ball gown": + case "an evening dress": r.push(`is in dreadlocks, spreading out in many directions.`); break; case "slutty business attire": @@ -4913,6 +4946,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is in short dreadlocks, spreading around ${his} head.`); break; case "slutty business attire": @@ -5094,6 +5128,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is curled into long flowing locks, almost reaching the ground.`); break; case "slutty business attire": @@ -5249,6 +5284,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is curled into long locks, reaching past ${his} shoulders.`); break; case "slutty business attire": @@ -5404,6 +5440,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is curled into short locks.`); break; case "slutty business attire": @@ -5585,6 +5622,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is permed into long flowing curls, almost reaching the ground.`); break; case "slutty business attire": @@ -5740,6 +5778,7 @@ App.Desc.hairClothing = function(slave) { break; case "a halter top dress": case "a ball gown": + case "an evening dress": r.push(`is permed, reaching past ${his} shoulders.`); break; case "slutty business attire": @@ -5895,6 +5934,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is permed into short waves.`); break; case "slutty business attire": @@ -6031,6 +6071,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is in luxurious layered locks flowing gorgeously down ${his} bare back.`); break; case "a kimono": @@ -6133,6 +6174,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`is in luxurious layered locks kept out of ${his} face by a couple of sturdy hairpins.`); break; case "Imperial Plate": @@ -6187,6 +6229,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is in luxurious layered locks flowing gorgeously down ${his} bare back.`); break; case "a kimono": @@ -6289,6 +6332,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`is in luxurious layered locks kept out of ${his} face by a couple of sturdy hairpins.`); break; case "Imperial Plate": @@ -6343,6 +6387,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is in luxuriously styled short locks.`); break; case "a kimono": @@ -6445,6 +6490,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "a mounty outfit": case "battlearmor": + case "a confederate army uniform": r.push(`is in luxuriously styled short locks kept out of ${his} face by a sturdy hairpin.`); break; case "Imperial Plate": @@ -6489,6 +6535,7 @@ App.Desc.hairClothing = function(slave) { case "a military uniform": case "a halter top dress": case "a ball gown": + case "an evening dress": case "conservative clothing": case "nice business attire": case "slutty business attire": @@ -6503,6 +6550,7 @@ App.Desc.hairClothing = function(slave) { case "a slutty schutzstaffel uniform": case "a red army uniform": case "a courtesan dress": + case "a confederate army uniform": r.push(`is in luxuriously styled short locks.`); break; case "Imperial Plate": @@ -6776,6 +6824,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "a mounty outfit": case "battlearmor": + case "a confederate army uniform": r.push(`is shaved into a long braided strip.`); break; case "Imperial Plate": @@ -6914,6 +6963,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "a mounty outfit": case "battlearmor": + case "a confederate army uniform": r.push(`is shaved into a strip down the middle of ${his} head.`); break; case "Imperial Plate": @@ -7193,6 +7243,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "a mounty outfit": case "battlearmor": + case "a confederate army uniform": r.push(`is shaved into a long, flowing undercut.`); break; case "Imperial Plate": @@ -7326,6 +7377,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "a mounty outfit": case "battlearmor": + case "a confederate army uniform": r.push(`is shaved to one side in an undercut that bristles against ${his} armor.`); break; case "Imperial Plate": @@ -7647,6 +7699,7 @@ App.Desc.hairClothing = function(slave) { break; case "a halter top dress": case "a ball gown": + case "an evening dress": r.push(`cascades down ${his} bare back in a hime cut with shoulder-length side-locks.`); break; case "a courtesan dress": @@ -7749,6 +7802,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`cascades down ${his} back in a hime cut with shoulder-length side-locks and is kept out of ${his} face by a couple of sturdy hairpins.`); break; case "Imperial Plate": @@ -7800,6 +7854,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`flows down ${his} bare back in a hime cut with cheek-length side-locks.`); break; case "a courtesan dress": @@ -7902,6 +7957,7 @@ App.Desc.hairClothing = function(slave) { case "a red army uniform": case "battlearmor": case "a mounty outfit": + case "a confederate army uniform": r.push(`flows down ${his} back in a hime cut with cheek-length side-locks and is kept out of ${his} face by a couple of sturdy hairpins.`); break; case "Imperial Plate": @@ -8127,6 +8183,7 @@ App.Desc.hairClothing = function(slave) { break; case "a ball gown": case "a halter top dress": + case "an evening dress": r.push(`is wound into enormous, exquisite coils that come to rest across ${his} chest.`); break; case "slutty business attire": @@ -8285,6 +8342,7 @@ App.Desc.hairClothing = function(slave) { break; case "a halter top dress": case "a ball gown": + case "an evening dress": r.push(`is wound into large coils which rest atop ${his} breasts.`); break; case "slutty business attire": diff --git a/src/npc/generate/generateMarketSlave.js b/src/npc/generate/generateMarketSlave.js index 84f4c115e5ea52c54588a46a8cd3f53bef0abc5f..c9e58b45201bb493d9d518c050286da582b051d6 100644 --- a/src/npc/generate/generateMarketSlave.js +++ b/src/npc/generate/generateMarketSlave.js @@ -1088,6 +1088,11 @@ globalThis.generateMarketSlave = function(market = "kidnappers", numArcology = 1 slave.intelligence += jsRandom(0, 20); } } + } else if (neighbor.FSAntebellumRevivalist > 20) { + r += `They've been immersed in a romantic culture of aristocratic gentlemen and chivalrous, Southron knights, and it may have rubbed off on them.`; + if (jsRandom(0, 1) === 0) { + slave.sexualQuirk = "romantic"; + } } if (neighbor.FSIncestFetishist > 20) { r += `Incest is acceptable, if not preferable to them. `; diff --git a/src/npc/generate/lawCompliance.js b/src/npc/generate/lawCompliance.js index 050138c0eab13b9324cbafdd6e0d582f3bc4272a..4cdf13f6feb2763012bb0748babc6d9cfd2a0191 100644 --- a/src/npc/generate/lawCompliance.js +++ b/src/npc/generate/lawCompliance.js @@ -92,6 +92,9 @@ App.Desc.lawCompliance = function(slave, market = 0) { if (V.arcologies[0].FSChineseRevivalistSMR === 1) { r.push(FSChineseRevivalistSMR()); } + if (V.arcologies[0].FSAntebellumRevivalistSMR === 1) { + r.push(FSAntebellumRevivalistSMR()); + } if (V.policies.SMR.basicSMR === 0) { r.push(basicSMR()); @@ -497,6 +500,11 @@ App.Desc.lawCompliance = function(slave, market = 0) { return `As ${he} passed though the slave markets, ${he} saw countless marvels of technological advancement, and the absolute obedience of tightly-disciplined slaves to their noble masters. The almost utter subservience of other slaves is deeply <span class="gold">concerning</span> to ${him}.`; } + function FSAntebellumRevivalistSMR() { + slave.trust -= 5; + return `As ${he} passed though the slave markets, ${he} saw the dehumanizing horror of chattel slavery. The lack of sympathy from slave owners <span class="gold">scares</span> ${him}.`; + } + function FSAztecRevivalistSMR() { const r = []; r.push(`As ${he} passed though the golden city, ${he} saw a less valuable`); diff --git a/src/npc/generate/newChildIntro.js b/src/npc/generate/newChildIntro.js index 9535ded5dcd16f9a25a1763b7e9f57f08e624412..3af74e4f817ad38f3cf75aa4cdb8f8e80d8cf9e3 100644 --- a/src/npc/generate/newChildIntro.js +++ b/src/npc/generate/newChildIntro.js @@ -370,6 +370,20 @@ App.UI.newChildIntro = function(slave) { } ) ); + } else if (V.arcologies[0].FSAntebellumRevivalist !== "unset") { + App.UI.DOM.appendNewElement( + "div", + surnaming, + App.UI.DOM.link( + `Give ${him} a random old Southern-style surname`, + () => { + slave.slaveSurname = App.Data.misc.antebellumRevivalistSlaveSurnames.random(); + slave.birthSurname = slave.slaveSurname; + jQuery(surnaming).empty().append(`${V.assistant.name} registers the new ${girl}'s surname as "${slave.slaveSurname}" in your registry.`); + jQuery(newName).empty().append(SlaveFullName(slave)); + } + ) + ); } el.append(surnaming); diff --git a/src/npc/generate/newSlaveIntro.js b/src/npc/generate/newSlaveIntro.js index 4fc0e3a6244f15616f40ddaf56ef8b8b00b6dc3c..a08c7e4705dec110762e15f04de4c21903bc9eb0 100644 --- a/src/npc/generate/newSlaveIntro.js +++ b/src/npc/generate/newSlaveIntro.js @@ -802,6 +802,11 @@ App.UI.newSlaveIntro = function(slave, slave2, {tankBorn = false, momInterest = r.push(`Though ${he} knows it's not a truly authentic ancient Chinese restoration, ${his} educated mind grasps the potential benefits of ancient Confucian philosophy for slaves, and ${he} <span class="mediumaquamarine">hopes</span> your arcology at least maintains some pretense of order and conservatism.`); slave.trust += 2; } + } else if (V.arcologies[0].FSAntebellumRevivalist >= 50) { + if (slave.intelligenceImplant >= 15) { + r.push(`Though ${he} knows it's not a truly authentic restoration of the Antebellum South, ${his} educated mind grasps the potential benefits of Southern mores for slaves, and ${he} <span class="mediumaquamarine">hopes</span> your arcology will put ${him} in a treasured position.`); + slave.trust += 2; + } } if (V.arcologies[0].FSPaternalistLaw === 1) { diff --git a/src/npc/interaction/fAbuse.js b/src/npc/interaction/fAbuse.js index 3812a95d08e1d9ed845e8a04c2094a10d40afdd9..cd7fdbee231e6e36d089121b04c5d084abff828d 100644 --- a/src/npc/interaction/fAbuse.js +++ b/src/npc/interaction/fAbuse.js @@ -130,16 +130,15 @@ App.Interact.fAbuse = function(slave) { case "restrictive latex": r.push(`In ${his} haste to get out of ${his} clinging latex ${he} trips and falls flat in a tangle of latex and trembling flesh.`); break; - case "a military uniform": - r.push(`${He}'s desperately torn between hurry to avoid punishment and fear ${he}'ll damage ${his} shirt.`); - break; case "a schutzstaffel uniform": r.push(`${He}'s desperately torn between hurry to avoid punishment and fear ${he}'ll damage ${his} trousers.`); break; case "a slutty schutzstaffel uniform": r.push(`${He}'s desperately torn between hurry to avoid punishment and fear ${he}'ll tear ${his} miniskirt.`); break; + case "a military uniform": case "a red army uniform": + case "a confederate army uniform": r.push(`${He}'s desperately torn between hurry to avoid punishment and fear ${he}'ll damage ${his} shirt.`); break; case "a mounty outfit": @@ -386,6 +385,7 @@ App.Interact.fAbuse = function(slave) { r.push(`${He}'s desperately torn between hurry to avoid punishment and fear ${he}'ll rip ${his} delicate gown.`); break; case "a halter top dress": + case "an evening dress": r.push(`${He}'s desperately torn between hurry to avoid punishment and fear ${he}'ll rip ${his} delicate dress.`); break; case "a ball gown": diff --git a/src/npc/interaction/fFeelings.js b/src/npc/interaction/fFeelings.js index b8a2590c988ad9f2466b06fd1fb2dd7ba1e9513c..1afb09926d52486ce823fc5508ecbfe6d817ede1 100644 --- a/src/npc/interaction/fFeelings.js +++ b/src/npc/interaction/fFeelings.js @@ -2031,6 +2031,15 @@ App.Interact.fFeelings = function(slave) { text.push(`${Spoken(slave, `Being a slave in this new Egypt is a little reassuring. Some of the other slaves say they used to use slaves for great things, anyway.`)}`); } } + if (V.arcologies[0].FSAntebellumRevivalist >= 10) { + if (slave.intelligence+slave.intelligenceImplant > 50) { + text.push(`${Spoken(slave, `The South was a strange place, but fascinating place, ${Master}. Were slave owners like you really the most important people in society back then?`)}`); + } else if (slave.devotion > 20) { + text.push(`${Spoken(slave, `I am proud to serve Dixie, ${Master}.`)}`); + } else { + text.push(`${Spoken(slave, `I don't know much about the old South, ${Master}, but didn't they treat ladies with respect?`)}`); + } + } if (V.arcologies[0].FSChattelReligionist >= 10) { if (slave.intelligence+slave.intelligenceImplant > 50) { text.push(`${Spoken(slave, `It's interesting, seeing how fast a new faith can take hold.`)}`); diff --git a/src/npc/interaction/killSlave.js b/src/npc/interaction/killSlave.js index d703c7a983b19b1948d2589721c7c59dbf771f87..63d85c72287569ee3597f699c832ee9dda8d62e1 100644 --- a/src/npc/interaction/killSlave.js +++ b/src/npc/interaction/killSlave.js @@ -11,6 +11,7 @@ App.UI.SlaveInteract.killSlave = function(slave) { FSEdoRevivalist: "katana", FSArabianRevivalist: "scimitar", FSChineseRevivalist: "jian", + FSAntebellumRevivalist: "saber" }; const oneWeek = V.threatened[1]; diff --git a/src/personalAssistant/assistantAppearance.js b/src/personalAssistant/assistantAppearance.js index 7f22ab0a6ac239b4b149ecc5d46511cf7f9ba87b..34337f8676defadf1e26c14aad2fad276c64d922 100644 --- a/src/personalAssistant/assistantAppearance.js +++ b/src/personalAssistant/assistantAppearance.js @@ -703,6 +703,7 @@ globalThis.PersonalAssistantAppearance = function() { case "arabian revivalist": r.push(`${HeA} has ${hisA} pants pulled off and is absentmindedly using them to jerk off. When ${heA} notices you watching, ${heA} waves ${hisA} throbbing erection at you, imploring you to finish ${himA} off.`); break; + case "antebellum revivalist": case "chattel religionist": r.push(`${HeA} is gingerly massaging ${hisA} swollen balls. When ${heA} notices you watching, ${heA} struggles to sit up and implores you to pull out the stopper and bathe in ${hisA} blessing.`); break; @@ -909,7 +910,7 @@ globalThis.PersonalAssistantAppearance = function() { } return r.join(" "); - + // TODO: write all of the descriptions for assistant appearance function FSfunc() { /** @type {appearance} */ const fsAppearance = { @@ -926,6 +927,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": ``, "arabian revivalist": ``, "chinese revivalist": ``, + "antebellum revivalist": ``, "chattel religionist": ``, "repopulation focus": ``, "eugenics": ``, @@ -958,6 +960,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `${HeA}'s given ${hisA} appearance a Japanese style, making ${himA} look like a demon.`, "arabian revivalist": `${HeA}'s given ${hisA} appearance a mystical Arabian style, making ${himA} look like a djinn.`, "chinese revivalist": `${HeA}'s given ${hisA} appearance a Chinese style, making ${himA} look like a demon.`, + "antebellum revivalist": `${HeA} head has been replaced with the skull of a deer adorned with heavy antlers. An eerie red glow emits from the shadowed eye sockets. Underneath the patchwork of scarred skin and black, bristly fur, the unmistakable curve of large, teardrop-shaped breasts and wide hips is discernable.`, "chattel religionist": `${HeA}'s wearing the garb of a priestess of the new faith, which clashes amusingly with ${hisA} demonic appearance.`, "repopulation focus": `${HeA}'s very pregnant; ${hisA} belly is covered in large bulges revealing the eggs growing within ${himA}.`, eugenics: `${HeA}'s wearing a complex chastity device, keeping ${hisA} dicks and cunt unusable.`, @@ -990,6 +993,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `${HeA}'s wearing a brief Japanese bathhouse robe.`, "arabian revivalist": `${HeA}'s dressed ${himselfA} like an oil millionaire, with aviator sunglasses and a headscarf.`, "chinese revivalist": `${HeA}'s added various tattoos of rude Chinese characters to ${hisA} body recently.`, + "antebellum revivalist": `${HeA}'s wearing fine Antebellum aristocratic clothing.`, "chattel religionist": `${HeA}'s wearing the garb of a priestess of the new faith, which frames ${hisA} cock prominently.`, "repopulation focus": `${HeA} is incredibly pregnant, ${hisA} belly preventing ${himA} from playing with ${himselfA} effectively.`, eugenics: `${HisA} sizable dick is restrained in a complicated chastity device.`, @@ -1022,6 +1026,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `wearing a Japanese warrior's robe with a pair of swords tucked into its sash.`, "arabian revivalist": `with a bare chest, loose pantaloons, and a broad silk sash wound around ${hisA} waist with a scimitar thrust into it.`, "chinese revivalist": `wearing loose silk robes belted with rope and carrying a simple warrior monk's staff.`, + "antebellum revivalist": `wearing an unbuttoned Confederate army coat, exposing a loose, low-cut blouse. ${HeA} has an old-fashioned revolver holstered on one hip and a calvary saber sheathed on the other. ${HeA} confidently pushes out ${hisA} chest, giving you a nice view down ${hisA} shirt.`, "chattel religionist": V.arcologies[0].FSChattelReligionistLaw2 === 1 ? `with your religion's holy symbol painted on ${hisA} nude body. ${HisA} long blonde hair cascades down ${hisA} back in golden glory.` : `wearing a crusader's mail. ${HisA} long blonde hair cascades down the back of ${hisA} surcoat in golden glory.`, "repopulation focus": `with an enormous belly. Its oversized occupant kicks and squirms ferociously, eager to be born.`, eugenics: `with a complex bone chastity belt blocking ${hisA} vagina.`, @@ -1054,6 +1059,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `wearing a fine kimono, getae, tabi, and an expression of perfect serenity.`, "arabian revivalist": `wearing a tailored suit, a silk headscarf, and aviator sunglasses, making ${himA} look like a little oil heiress.`, "chinese revivalist": `wearing a conservative silk qipao. ${HisA} hair is pulled back into a bun and secured by a couple of chopsticks.`, + "antebellum revivalist": `wearing a frock coat and vest with a handsome top hat.`, "chattel religionist": `wearing a tailored suit. ${HeA} has a prominent religious symbol on a necklace that rests over ${hisA} generous bosom.`, "physical idealist": `wearing a tailored suit. ${HeA}'s proportioned to make it very obvious that ${heA} works out.`, "hedonistic decadence": `wearing a tailored suit. ${HeA}'s proportioned to make it very obvious that ${heA} enjoys a good drink after the day is done.`, @@ -1085,7 +1091,8 @@ globalThis.PersonalAssistantAppearance = function() { "egyptian revivalist": `wielding an ankh-headed staff. ${HeA}'s wearing a gilded headdress and linen skirt, but leaves ${hisA} breasts and pregnant stomach bare to gleam like bronze.`, "edo revivalist": `${hisA} swollen hips and pregnant belly loosely wrapped in a red tomesode. ${HisA} waterfall of black hair is held by a comb shaped like big pointed fox ears.`, "arabian revivalist": `with swollen hips and breasts and a big pregnant belly. ${HeA}'s wrapped ${himselfA} in white silks, but only the veil around ${hisA} face is opaque.`, - "chinese revivalist": `${hisA} swollen hips and pregnant belly barely concealed under colorful silk robes, covered in flowers and embroidery.`, + "chinese revivalist": `${HisA} swollen hips and pregnant belly barely concealed under colorful silk robes, covered in flowers and embroidery.`, + "antebellum revivalist": `with swollen hips and breasts and a big pregnant belly. ${HeA} wears a Phrygian cap and a gown fashioned from the flag of the Confederacy. A single, heavy breast is deliberately left exposed. ${HeA} is Columbia, goddess of America`, "chattel religionist": `with swollen breasts and a big pregnant belly. ${HeA}'s surrounded by a nimbus of light and flowing platinum hair, like an angel carrying a few new cherubim.`, "physical idealist": `trim and athletic despite ${hisA} pregnant belly. ${HeA}'s nude aside from a crown of flowers, ${hisA} modesty protected only by ${hisA} flowing hair.`, "hedonistic decadence": `with soft, plush features. ${HisA} belly is so fat it is difficult to tell ${heA} is pregnant at first. ${HeA}'s nude aside from a crown of flowers, ${hisA} modesty protected only by ${hisA} flowing hair.`, @@ -1120,6 +1127,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `${HeA}'s wearing a brief Japanese bathhouse robe. Occasionally a stream of liquid pours from ${hisA} crotch along with a healthy baby.`, "arabian revivalist": `${HeA}'s dressed ${himselfA} like an oil millionaire's broodmother, with silken linens. Occasionally a stream of liquid pours from ${hisA} crotch along with a healthy baby.`, "chinese revivalist": `${HeA}'s added various tattoos of rude Chinese characters to ${hisA} body recently. Occasionally a stream of liquid pours from ${hisA} crotch along with a healthy baby.`, + "antebellum revivalist": `${HeA}'s dressed in a gown fashioned from the flag of the Confederacy, distended by ${hisA} belly. Occasionally a stream of liquid pours from ${hisA} crotch along with a healthy baby.`, "chattel religionist": `${HeA}'s wearing the garb of a priestess of the new faith, which frames ${hisA} belly prominently. Occasionally a stream of liquid pours from ${hisA} crotch along with a healthy baby.`, "physical idealist": `${HeA}'s extremely muscular: ${HeA} hefts ${hisA} massive belly easily off the floor.`, "hedonistic decadence": `${HeA}'s extremely fat, though it does nothing to hide ${hisA} immense dome of a belly. ${HeA} is constantly eating something fatty or sucking down ${hisA} own milk; the only thing hungrier than ${himA} is ${hisA} brood. Occasionally a stream of liquid pours from ${hisA} crotch along with a plump, healthy baby.`, @@ -1160,6 +1168,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `wearing a simple robe appropriate for a proper, traditional Japanese lady.`, "arabian revivalist": `wearing a long plaid skirt, a clean white shirt, and a headscarf, making ${himA} look like an Arab ${girlA} attending a Western school.`, "chinese revivalist": `wearing a plaid skirt and a white shirt. ${HisA} hair is pulled back into a bun and secured by a couple of chopsticks.`, + "antebellum revivalist": `wearing remarkably conservative clothing. ${HeA} wears a white long-sleeved shirt tucked into an ankle-length skirt. A colorful, lacy bow is fixed to ${hisA} collar.`, "chattel religionist": `wearing a plaid skirt and a white shirt. ${HeA} has a prominent religious symbol on a necklace that rests at the level of ${hisA} perky tits.`, "physical idealist": `wearing a plaid skirt, a white shirt, and athletic shoes. ${HeA} usually renders ${himselfA} flushed with exercise, as though ${heA} just came from gym class.`, "hedonistic decadence": `wearing a plaid skirt and a white shirt. The buttons of ${hisA} shirt struggle against ${hisA} plush body, and ${hisA} skirt rides up ${hisA} plump butt to expose ${hisA} panties.`, @@ -1191,6 +1200,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `${girlA} wearing a kimono far too large for ${himselfA}.`, "arabian revivalist": `${girlA} wearing a simple linen dress and a headscarf.`, "chinese revivalist": `${girlA} wearing a cute silk qipao.`, + "antebellum revivalist": `${girlA} wearing a cute, lacy gown.`, "chattel religionist": `${girlA} wearing the garb of a priestess of the new faith.`, "repopulation focus": `${girlA} wearing a loose dress; its middle bulges considerably from ${hisA} pregnancy.`, "eugenics": `slave ${girlA} wearing nothing but an overly complex chastity belt and trying ${hisA} best to do master proud.`, @@ -1216,14 +1226,15 @@ globalThis.PersonalAssistantAppearance = function() { "paternalist": `belly, wearing a cute pink dress. The middle is stretched tight by ${hisA} growing belly.`, "supremacist": `belly, wearing a cute yellow dress. ${HeA} cradles ${hisA} swollen belly protectively, glowing with pride at carrying ${V.arcologies[0].FSSupremacistRace !== 0 ? addA(V.arcologies[0].FSSupremacistRace) : ""} child.`, "subjugationist": `belly, wearing nothing but a pregnancy biometrics collar. The collar's display reads 'Carrying 2 more ${V.arcologies[0].FSSubjugationistRace} subhumans!', something the ${girlA} occasionally reads aloud to ${himselfA}.`, - "roman revivalist": `belly, wearing a ${girlA}'s stola.`, - "neoimperialist": `belly, wearing a tiny elementary schooler's uniform, complete with miniature plaid skirt. ${HisA} belly swells underneath the cotton shirt.`, - "aztec revivalist": `belly, wearing only an overshirt which struggles to cover ${hisA} rounded middle; ${hisA} cute little legs are complimented by ${hisA} twin tails.`, - "egyptian revivalist": `belly, wearing a bulging white linen dress, kohl eyeshadow and sandals.`, - "edo revivalist": `belly, wearing a kimono far too large for ${himselfA} but does nothing to distract from ${hisA} swollen midriff.`, - "arabian revivalist": `belly, wearing a bulging linen dress and a headscarf.`, - "chinese revivalist": `belly, wearing a tight silk qipao.`, - "chattel religionist": `belly, wearing the garb of a priestess of the new faith.`, + "roman revivalist": `belly wearing a ${girlA}'s stola.`, + "neoimperialist": `belly wearing a tiny elementary schooler's uniform, complete with miniature plaid skirt. ${HisA} belly swells underneath the cotton shirt.`, + "aztec revivalist": `belly wearing only an overshirt which struggles to cover ${hisA} rounded middle; ${hisA} cute little legs are complimented by ${hisA} twin tails.`, + "egyptian revivalist": `belly wearing a bulging white linen dress, kohl eye shadow and sandals.`, + "edo revivalist": `belly wearing a kimono far too large for ${himselfA} but does nothing to distract from ${hisA} swollen midriff.`, + "arabian revivalist": `belly wearing a bulging linen dress and a headscarf.`, + "chinese revivalist": `belly wearing a tight silk qipao.`, + "antebellum revivalist": `belly wearing a bulging, lacy gown.`, + "chattel religionist": `belly wearing the garb of a priestess of the new faith.`, "repopulation focus": `belly. ${HeA} recently adjusted ${hisA} pregnancy size to make it even larger. ${HisA} swelling ass and tits spill out from ${hisA} shorts and tube-top and the occasional kick can be seen from ${hisA} octuplets.`, "eugenics": `belly, or rather, ${heA} was. ${HisA} chastity belt has been torn open and ${hisA} belly is grotesquely swollen with subhuman spawn. Occasionally a malformed, impish child claws its way out of ${hisA} violated pussy.`, "degradationist": `belly, wearing an open vest and a thong. It shows off ${hisA} pierced milky B-cup tits and swollen pregnant belly. A large bar is driven through ${hisA} popped navel.`, @@ -1257,6 +1268,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `fairy wearing a fine kimono and holding a little fan. ${HeA} looks like a little Hina doll.`, "arabian revivalist": `fairy wearing a strip of silk as a dress.`, "chinese revivalist": `fairy wearing a silk cheongsam with a little green cap on ${hisA} head. ${HisA} hair is braided on the sides. ${HeA} looks like a figurine from some kind of game.`, + "antebellum revivalist": `fairy wearing a sheer lacy garment that leaves little to the imagination.`, "chattel religionist": `fairy wearing a little gold-white habit.`, "physical idealist": `fairy wearing a training bra and spats. ${HeA} has abs poorly drawn on ${hisA} belly with a marker.`, "hedonistic decadence": `fairy, naked and sitting in a cup of pudding, happily digging into its contents.`, @@ -1289,6 +1301,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `wearing a fine kimono and holding a little fan. ${HeA} looks like a little Hina doll.`, "arabian revivalist": `wearing a strip of silk as a dress.`, "chinese revivalist": `wearing a silk cheongsam with a little green cap on ${hisA} head. ${HisA} hair is braided on the sides. ${HeA} looks like a figurine from some kind of game.`, + "antebellum revivalist": `fairy wearing a sheer lacy garment, which shows off ${hisA} swollen belly.`, "chattel religionist": `wearing a little gold-white habit and glowing with purity.`, "physical idealist": `wearing a training bra and spats. ${HisA} large belly sticks out even more.`, "hedonistic decadence": `totally nude and sitting upon a large pastry, covered in cream. ${HeA} occasionally pulls off a piece to nibble on.`, @@ -1318,8 +1331,9 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `slime, with a silken kimono floating inside ${himA}.`, "arabian revivalist": `slime, with a headscarf and a pair of sunglasses floating inside ${himA}.`, "aztec revivalist": `slime.`, // TODO: missing in SC, expand someday. - "chinese revivalist": `slime, with a silk qipao floating inside ${himA}.`, - "chattel religionist": `slime, with several symbols of the new faith floating inside ${himA}.`, + "chinese revivalist": `slime with a silk qipao floating inside ${himA}.`, + "antebellum revivalist": `slime, with a colorful broad-brimmed hat adorned with a giant, fake flower floating side ${himA}.`, + "chattel religionist": `slime with several symbols of the new faith floating inside ${himA}.`, "repopulation focus": `slime. ${HisA} amorphous body has noticeable hip, butt, and breast curves as well as several more cores gathered in ${hisA} rounded stomach.`, "eugenics": `slime, with a chastity belt floating inside ${himA}.`, "degradationist": `slime, with a number of piercings sinking into ${hisA} body.`, @@ -1352,8 +1366,9 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `${HeA} is wearing a fine kimono with slits for ${hisA} wings, getae, tabi, and an expression of perfect serenity.`, "arabian revivalist": `${HeA} is wearing a tailored suit, a silk headscarf, and aviator sunglasses, making ${himA} look ridiculous.`, "chinese revivalist": `${HeA} is wearing a conservative silk qipao with special slits for ${hisA} wings. ${HisA} hair is pulled back into a bun and secured by a couple of chopsticks.`, - "chattel religionist": `${HeA} has adjusted ${hisA} outfit to consist of nothing but the symbol of your new religion, carefully tailored to cover ${hisA} nipples and crotch. ${HeA} wears another around ${hisA} neck and a blush on ${hisA} cheeks.`, - "physical idealist": `${HeA} has swapped out ${hisA} usual linen dress for one that shows off ${hisA} toned arms, legs, and abs.`, + "antebellum revivalist": `${HeA} is wearing a wearing a almost transparent white gown. Large, downy wings, protrude from ${hisA} back and a golden halo hovers perfectly in place above ${hisA} head.`, + "chattel religionist": `${HeA} has adjusted ${hisA} outfit to consist of nothing but the symbol of your new religion carefully tailored to cover ${hisA} nipples and crotch. ${HeA} wears another around ${hisA} neck and a blush on ${hisA} cheeks.`, + "physical idealist": `${HeA} has swapped out ${hisA} usual linen dress for one that shows off ${hisA} toned arms, legs and abs.`, "hedonistic decadence": `${HeA} has swapped out ${hisA} usual linen dress for one that covers ${hisA} plush curves. ${HeA} finds walking easier than trying to fly with ${hisA} weighty body.`, "repopulation focus": `${HisA} simple white linen dress is parted by ${hisA} full term pregnancy; likely a lost soul being given a new chance.`, "eugenics": `${HeA} has swapped out ${hisA} usual linen dress for a fabulous one to match ${hisA} perfect appearance. ${HeA} proudly wears the symbol of high society on ${hisA} arm and, judging by the slight curve to ${hisA} middle, is growing a child just as beautiful as ${himA}.`, @@ -1392,7 +1407,8 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `${HeA} is wearing a cute little kimono with slits for ${hisA} wings. Occasionally you get a glance up it; a lovely pair of panties say hello.`, "arabian revivalist": `${HeA} wears a fine dress, a silk headscarf, aviator sunglasses, and an overly conservative posture. No seeing up ${hisA} dress for you!`, "chinese revivalist": `${HeA} is wearing a conservative silk qipao with special slits for ${hisA} wings. ${HisA} hair is pulled back into a bun and secured by a couple of chopsticks. It you try really hard, you can get a peek of ${hisA} panties as ${heA} flutters by.`, - "chattel religionist": `${HeA} has adjusted ${hisA} outfit to consist of nothing but the symbol of your new religion, carefully tailored to cover ${hisA} nipples and crotch. Another dangles from ${hisA} neck. ${HisA} attire leaves little to the imagination.`, + "antebellum revivalist": `${HeA} is wearing a cute little white gown with cutouts for ${hisA} wings. It's practically transparent. A tiny, white thong barely obscures her little pussy.`, + "chattel religionist": `${HeA} has adjusted ${hisA} outfit to consist of nothing but the symbol of your new religion carefully tailored to cover ${hisA} nipples and crotch. Another dangles from ${hisA} neck. ${HisA} attire leaves little to the imagination.`, "physical idealist": `${HeA} has chosen to ditch ${hisA} usual linen dress for nothing but ${hisA} undies in order to show off ${hisA} muscles.`, "hedonistic decadence": `${HeA} has become so plump lately that no amount of tugging will get ${hisA} linen dress to cover ${hisA} exposed panties. ${HeA} struggles to stay aloft with such a plush body.`, "repopulation focus": `${HeA} has chosen to ditch ${hisA} usual linen dress for just ${hisA} panties. ${HeA} struggles to fly with ${hisA} heavy pregnancy and milk-laden breasts.`, @@ -1433,6 +1449,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `${HeA} has tightly bound ${himselfA} in shibari ropes, although they don't achieve much given ${heA} can still fly freely.`, "arabian revivalist": `${HeA} has donned the skimpiest, sluttiest outfit ${heA} could think of. ${HeA}'s just begging to get stoned.`, "chinese revivalist": `${HeA} has added a number of piercings to ${hisA} body to allow ${himA} to be suspended by hooks rather than flying.`, + "antebellum revivalist": `${HeA} has chosen a lean and muscular form inspired by satanic Christian imagery: dark red skin and large, curling horns like a bull.`, "chattel religionist": `${HeA} has chosen to go fully naked, exposing the symbols of your religion pierced through ${hisA} nipples and clit.`, "physical idealist": `${HeA} has adjusted ${hisA} appearance to be rather muscular. Not only can ${heA} crack a whip harder than ever, but when ${heA} flexes, ${heA} nearly pops the belt around ${hisA} chest.`, "hedonistic decadence": `${HeA} has become rather chubby lately. ${HeA} may want to change up ${hisA} routine of tormenting the hungry by devouring food before them.`, @@ -1474,6 +1491,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `${HeA}'s managed to correct the spell, somewhat, though ${heA} now resembles something that belongs in a hentai.`, "arabian revivalist": `${HeA}'s managed to correct the spell, and even succeed at it. ${HeA} has altered ${hisA} appearance to resemble a gorgeous djinn. ${HeA} is seductively performing a belly dance for you.`, "chinese revivalist": `${HeA} has chosen to embrace the outcome of ${hisA} spell, even pushing ${hisA} luck a little more, leaving ${himA} wearing a long and very fashionable qipao.`, + "antebellum revivalist": `${HeA}'s managed to refine the spell and appears now as a gorgeous Southern belle, yet ${heA} exudes an unnatural aura. ${HeA} gives you a mischievous smile and lifts up ${hisA} skirt, exposing both ${hisA} pussy and occult markings covering ${hisA} skin.`, "chattel religionist": `${HeA} has chosen to embrace the outcome of ${hisA} spell, proudly displaying the various holy symbols hanging from around ${hisA} neck and dangling from ${hisA} nipples, navel and clit.`, "physical idealist": `${HeA} managed to regain freedom of movement, but has chosen to leave ${hisA} torn robes unfixed to further highlight ${hisA} ridiculous muscles.`, "hedonistic decadence": `${HeA} has managed to lighten ${hisA} body enough to regain mobility, but no amount of ${hisA} magic can summon a robe big enough to cover ${hisA} enormously fat body without looking ridiculous.`, @@ -1524,6 +1542,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `wearing a loose kimono. ${HeA} looks vaguely Japanese, but wrong. You swear you see movement under ${hisA} skin.`, "arabian revivalist": `wearing various silks. ${HeA} looks vaguely Arabic, but wrong. You swear you see movement under ${hisA} skin.`, "chinese revivalist": `wearing an ill fitting qipao. ${HeA} looks vaguely Chinese, but wrong. You swear you see movement under ${hisA} clothing and even skin.`, + "antebellum revivalist": `wearing a poorly fitted ball gown. ${HeA} looks vaguely Southern, but wrong. You wear you see movement under ${hisA} skin.`, "chattel religionist": `wearing nothing at all. A pulsing symbol of your religion sprouts from ${hisA} chest, runs between ${hisA} breasts and down to ${hisA} crotch, where it penetrates ${hisA} pussy. If the symbol weren't off-putting enough, you also swear you see movement under ${hisA} skin.`, "physical idealist": `wearing nothing at all. ${HeA} is covered in what appear to be muscles, though they bulge and squirm uncomfortably.`, "hedonistic decadence": `wearing nothing at all. ${HeA} is covered in what appears to be a dense layer of fat, though occasionally you swear you see something peering out from between ${hisA} folds.`, @@ -1576,6 +1595,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `${HeA} is an ideal Japanese man, complete with something big and heavy between ${hisA} legs.`, "arabian revivalist": `${HeA} is an ideal Arabian man, complete with something big and heavy filling out ${hisA} silken pants.`, "chinese revivalist": `${HeA} is an ideal Chinese man, complete with something big and heavy between ${hisA} legs.`, + "antebellum revivalist": `${HeA} is an ideal Southern man, complete with something big and heavy between ${hisA} legs.`, "chattel religionist": `${HeA} is wearing nothing but an immense erection. ${HisA} balls visibly pulse, begging for release, but ${hisA} load is blocked by a large plug capped with the symbol of your new religion. One pull is all it would take to bathe in ${hisA} blessing.`, "physical idealist": `${HeA} is wearing nothing but an immense erection and is coated in the perfect amount of muscle.`, "hedonistic decadence": `${HeA} is wearing nothing but an immense erection and is coated in the perfect amount of fat.`, @@ -1648,6 +1668,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": `In fact, ${heA} is the most gorgeous Japanese ${womanA} you've ever seen.`, "arabian revivalist": `In fact, ${heA} is the most gorgeous Arabic ${womanA} you've ever seen.`, "chinese revivalist": `In fact, ${heA} is the most gorgeous Chinese ${womanA} you've ever seen.`, + "antebellum revivalist": `In fact, ${heA} is the most gorgeous Southern ${womanA} you've ever seen.`, "chattel religionist": `${HeA} is wearing a tight dress modeled after the symbol of your new religion; it leaves ${hisA} nipples and crotch fully exposed.`, get "physical idealist"() { if (V.arcologies[0].FSPhysicalIdealistStrongFat === 1) { @@ -1761,6 +1782,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": ``, "arabian revivalist": ``, "chinese revivalist": ``, + "antebellum revivalist": ``, "chattel religionist": ``, "repopulation focus": ``, "eugenics": ``, @@ -1793,6 +1815,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": ``, "arabian revivalist": ``, "chinese revivalist": ``, + "antebellum revivalist": ``, "chattel religionist": ``, "repopulation focus": ``, "eugenics": ``, @@ -1825,6 +1848,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": ``, "arabian revivalist": ``, "chinese revivalist": ``, + "antebellum revivalist": ``, "chattel religionist": ``, "repopulation focus": ``, "eugenics": ``, @@ -1857,6 +1881,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": ``, "arabian revivalist": ``, "chinese revivalist": ``, + "antebellum revivalist": ``, "chattel religionist": ``, "repopulation focus": ``, "eugenics": ``, @@ -1889,6 +1914,7 @@ globalThis.PersonalAssistantAppearance = function() { "edo revivalist": ``, "arabian revivalist": ``, "chinese revivalist": ``, + "antebellum revivalist": ``, "chattel religionist": ``, "repopulation focus": ``, "eugenics": ``, diff --git a/src/personalAssistant/assistantOptions.js b/src/personalAssistant/assistantOptions.js index e4ba712a4b67ec78f408a7bb4bcbbe1e691d03bb..ff5467ce440c8858f09114a141b3ee00a0f7b794 100644 --- a/src/personalAssistant/assistantOptions.js +++ b/src/personalAssistant/assistantOptions.js @@ -264,6 +264,7 @@ App.UI.personalAssistantOptions = function() { ["edo revivalist", "FSEdoRevivalistDecoration"], ["arabian revivalist", "FSArabianRevivalistDecoration"], ["chinese revivalist", "FSChineseRevivalistDecoration"], + ["antebellum revivalist", "FSAntebellumRevivalistDecoration"], ]); makeFSlink("default");