{"version":3,"file":"money_controller-4o7zHgTQ.js","sources":["../../../app/javascript/controllers/artifact/entity/money_controller.js"],"sourcesContent":["import PropertyController from './property_controller'\n\nimport { useNumberHelpers } from '@/controllers/mixins/useNumberHelpers'\n\nexport default class extends PropertyController {\n static targets = [\n 'currencyPopover',\n 'currencyPopoverTrigger',\n 'currencyItem',\n 'currencyInput',\n ]\n\n static values = {\n currency: String,\n }\n\n initialize() {\n this.newCurrency = this.currencyValue\n this.valueValue = this.inputTarget.value\n\n super.initialize()\n }\n\n connect() {\n useNumberHelpers(this)\n super.connect()\n }\n\n save() {\n if(!this.inputTarget.value) {\n return this.restore()\n }\n\n this.currencyValue = this.newCurrency\n this.valueValue = this.inputTarget.value\n\n this.hide(this.inputSectionTarget)\n this.show(this.placeholderButtonTarget)\n\n this.placeholderButtonTarget.textContent = [\n this.numberWithDelimiter(this.valueValue),\n this.currencyValue\n ].join(' ')\n\n if(this.currencyValue && this.valueValue) {\n this.addClass(this.placeholderButtonTarget, 'font-medium')\n this.removeClass(this.placeholderButtonTarget, 'text-night-60')\n }\n }\n\n restore() {\n super.restore()\n this.newCurrency = this.currencyValue\n this.updateCurrencyLabel()\n }\n\n updateCurrency({ currentTarget }) {\n this.newCurrency = currentTarget.dataset.currency\n this.focus(this.inputTarget, { moveCursorToEnd: true })\n\n this.updateCurrencyLabel(this.newCurrency)\n }\n\n currencyValueChanged() {\n this.updateCurrencyLabel()\n this.currencyInputTarget.value = this.currencyValue\n }\n\n updateCurrencyLabel(currency = this.currencyValue) {\n this.currencyPopoverTriggerTarget.textContent = currency\n\n this.currencyItemTargets.forEach(item => {\n if(item.dataset.currency === currency) {\n item.classList.add('bg-lavender-light')\n } else {\n item.classList.remove('bg-lavender-light')\n }\n })\n }\n\n setAmountFromProduct({ detail: amount }) {\n if(this.valueValue) return\n\n this.inputTarget.value = amount.amount\n this.newCurrency = amount.currency\n\n this.save()\n }\n\n get valid() {\n console.log(this.valueValue)\n return this.currencyValue && this.valueValue\n }\n}\n"],"names":["money_controller","PropertyController","useNumberHelpers","currentTarget","currency","item","amount","__publicField"],"mappings":"6QAIe,MAAKA,UAASC,CAAmB,CAY9C,YAAa,CACX,KAAK,YAAc,KAAK,cACxB,KAAK,WAAa,KAAK,YAAY,MAEnC,MAAM,WAAU,CACpB,CAEE,SAAU,CACRC,EAAiB,IAAI,EACrB,MAAM,QAAO,CACjB,CAEE,MAAO,CACL,GAAG,CAAC,KAAK,YAAY,MACnB,OAAO,KAAK,QAAO,EAGrB,KAAK,cAAgB,KAAK,YAC1B,KAAK,WAAa,KAAK,YAAY,MAEnC,KAAK,KAAK,KAAK,kBAAkB,EACjC,KAAK,KAAK,KAAK,uBAAuB,EAEtC,KAAK,wBAAwB,YAAc,CACzC,KAAK,oBAAoB,KAAK,UAAU,EACxC,KAAK,aACN,EAAC,KAAK,GAAG,EAEP,KAAK,eAAiB,KAAK,aAC5B,KAAK,SAAS,KAAK,wBAAyB,aAAa,EACzD,KAAK,YAAY,KAAK,wBAAyB,eAAe,EAEpE,CAEE,SAAU,CACR,MAAM,QAAO,EACb,KAAK,YAAc,KAAK,cACxB,KAAK,oBAAmB,CAC5B,CAEE,eAAe,CAAE,cAAAC,GAAiB,CAChC,KAAK,YAAcA,EAAc,QAAQ,SACzC,KAAK,MAAM,KAAK,YAAa,CAAE,gBAAiB,EAAM,CAAA,EAEtD,KAAK,oBAAoB,KAAK,WAAW,CAC7C,CAEE,sBAAuB,CACrB,KAAK,oBAAmB,EACxB,KAAK,oBAAoB,MAAQ,KAAK,aAC1C,CAEE,oBAAoBC,EAAW,KAAK,cAAe,CACjD,KAAK,6BAA6B,YAAcA,EAEhD,KAAK,oBAAoB,QAAQC,GAAQ,CACpCA,EAAK,QAAQ,WAAaD,EAC3BC,EAAK,UAAU,IAAI,mBAAmB,EAEtCA,EAAK,UAAU,OAAO,mBAAmB,CAE5C,CAAA,CACL,CAEE,qBAAqB,CAAE,OAAQC,GAAU,CACpC,KAAK,aAER,KAAK,YAAY,MAAQA,EAAO,OAChC,KAAK,YAAcA,EAAO,SAE1B,KAAK,KAAI,EACb,CAEE,IAAI,OAAQ,CACV,eAAQ,IAAI,KAAK,UAAU,EACpB,KAAK,eAAiB,KAAK,UACtC,CACA,CAxFEC,EADkBP,EACX,UAAU,CACf,kBACA,yBACA,eACA,eACJ,GAEEO,EARkBP,EAQX,SAAS,CACd,SAAU,MACd"}