mirror of
				https://github.com/BookStackApp/BookStack.git
				synced 2025-10-25 06:37:36 +03:00 
			
		
		
		
	Updated another set of components
This commit is contained in:
		| @@ -1,9 +1,10 @@ | ||||
| /** | ||||
|  * A simple component to render a code editor within the textarea | ||||
|  * this exists upon. | ||||
|  * @extends {Component} | ||||
|  */ | ||||
| class CodeTextarea { | ||||
| import {Component} from "./component"; | ||||
|  | ||||
| export class CodeTextarea extends Component { | ||||
|  | ||||
|     async setup() { | ||||
|         const mode = this.$opts.mode; | ||||
|   | ||||
| @@ -1,18 +1,19 @@ | ||||
| import {Component} from "./component"; | ||||
|  | ||||
| class CustomCheckbox { | ||||
| export class CustomCheckbox extends Component { | ||||
|  | ||||
|     constructor(elem) { | ||||
|         this.elem = elem; | ||||
|         this.checkbox = elem.querySelector('input[type=checkbox]'); | ||||
|         this.display = elem.querySelector('[role="checkbox"]'); | ||||
|     setup() { | ||||
|         this.container = this.$el; | ||||
|         this.checkbox = this.container.querySelector('input[type=checkbox]'); | ||||
|         this.display = this.container.querySelector('[role="checkbox"]'); | ||||
|  | ||||
|         this.checkbox.addEventListener('change', this.stateChange.bind(this)); | ||||
|         this.elem.addEventListener('keydown', this.onKeyDown.bind(this)); | ||||
|         this.container.addEventListener('keydown', this.onKeyDown.bind(this)); | ||||
|     } | ||||
|  | ||||
|     onKeyDown(event) { | ||||
|         const isEnterOrPress = event.keyCode === 32 || event.keyCode === 13; | ||||
|         if (isEnterOrPress) { | ||||
|         const isEnterOrSpace = event.key === ' ' || event.key === 'Enter'; | ||||
|         if (isEnterOrSpace) { | ||||
|             event.preventDefault(); | ||||
|             this.toggle(); | ||||
|         } | ||||
| @@ -29,6 +30,4 @@ class CustomCheckbox { | ||||
|         this.display.setAttribute('aria-checked', checked); | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
| export default CustomCheckbox; | ||||
| } | ||||
| @@ -1,9 +1,7 @@ | ||||
| /** | ||||
|  * @extends {Component} | ||||
|  */ | ||||
| import {htmlToDom} from "../services/dom"; | ||||
| import {Component} from "./component"; | ||||
|  | ||||
| class EntityPermissions { | ||||
| export class EntityPermissions extends Component { | ||||
|  | ||||
|     setup() { | ||||
|         this.container = this.$el; | ||||
| @@ -74,6 +72,4 @@ class EntityPermissions { | ||||
|         row.remove(); | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
| export default EntityPermissions; | ||||
| } | ||||
| @@ -1,14 +1,10 @@ | ||||
| /** | ||||
|  * Entity Selector Popup | ||||
|  * @extends {Component} | ||||
|  */ | ||||
| class EntitySelectorPopup { | ||||
| import {Component} from "./component"; | ||||
|  | ||||
| export class EntitySelectorPopup extends Component { | ||||
|  | ||||
|     setup() { | ||||
|         this.elem = this.$el; | ||||
|         this.container = this.$el; | ||||
|         this.selectButton = this.$refs.select; | ||||
|  | ||||
|         window.EntitySelectorPopup = this; | ||||
|         this.selectorEl = this.$refs.selector; | ||||
|  | ||||
|         this.callback = null; | ||||
| @@ -21,12 +17,12 @@ class EntitySelectorPopup { | ||||
|  | ||||
|     show(callback) { | ||||
|         this.callback = callback; | ||||
|         this.elem.components.popup.show(); | ||||
|         this.container.components.popup.show(); | ||||
|         this.getSelector().focusSearch(); | ||||
|     } | ||||
|  | ||||
|     hide() { | ||||
|         this.elem.components.popup.hide(); | ||||
|         this.container.components.popup.hide(); | ||||
|     } | ||||
|  | ||||
|     getSelector() { | ||||
| @@ -51,6 +47,4 @@ class EntitySelectorPopup { | ||||
|         this.getSelector().reset(); | ||||
|         if (this.callback && entity) this.callback(entity); | ||||
|     } | ||||
| } | ||||
|  | ||||
| export default EntitySelectorPopup; | ||||
| } | ||||
| @@ -10,23 +10,22 @@ export {BookSort} from "./book-sort.js" | ||||
| export {ChapterContents} from "./chapter-contents.js" | ||||
| // export {CodeEditor} from "./code-editor.js" | ||||
| export {CodeHighlighter} from "./code-highlighter.js" | ||||
| // export {CodeTextarea} from "./code-textarea.js" | ||||
| export {CodeTextarea} from "./code-textarea.js" | ||||
| // export {Collapsible} from "./collapsible.js" | ||||
| // export {ConfirmDialog} from "./confirm-dialog" | ||||
| // export {CustomCheckbox} from "./custom-checkbox.js" | ||||
| export {CustomCheckbox} from "./custom-checkbox.js" | ||||
| export {DetailsHighlighter} from "./details-highlighter.js" | ||||
| export {Dropdown} from "./dropdown.js" | ||||
| // export {DropdownSearch} from "./dropdown-search.js" | ||||
| // export {Dropzone} from "./dropzone.js" | ||||
| // export {EditorToolbox} from "./editor-toolbox.js" | ||||
| // export {EntityPermissions} from "./entity-permissions" | ||||
| export {EntityPermissions} from "./entity-permissions" | ||||
| // export {EntitySearch} from "./entity-search.js" | ||||
| export {EntitySelector} from "./entity-selector.js" | ||||
| // export {EntitySelectorPopup} from "./entity-selector-popup.js" | ||||
| export {EntitySelectorPopup} from "./entity-selector-popup.js" | ||||
| // export {EventEmitSelect} from "./event-emit-select.js" | ||||
| // export {ExpandToggle} from "./expand-toggle.js" | ||||
| // export {HeaderMobileToggle} from "./header-mobile-toggle.js" | ||||
| // export {HomepageControl} from "./homepage-control.js" | ||||
| // export {ImageManager} from "./image-manager.js" | ||||
| // export {ImagePicker} from "./image-picker.js" | ||||
| // export {ListSortControl} from "./list-sort-control.js" | ||||
| @@ -37,12 +36,13 @@ export {Notification} from "./notification.js" | ||||
| export {PageComments} from "./page-comments.js" | ||||
| // export {PageDisplay} from "./page-display.js" | ||||
| // export {PageEditor} from "./page-editor.js" | ||||
| // export {PagePicker} from "./page-picker.js" | ||||
| // export {PermissionsTable} from "./permissions-table.js" | ||||
| export {PagePicker} from "./page-picker.js" | ||||
| export {PermissionsTable} from "./permissions-table.js" | ||||
| export {Pointer} from "./pointer.js"; | ||||
| // export {Popup} from "./popup.js" | ||||
| // export {SettingAppColorPicker} from "./setting-app-color-picker.js" | ||||
| // export {SettingColorPicker} from "./setting-color-picker.js" | ||||
| export {Popup} from "./popup.js" | ||||
| export {SettingAppColorPicker} from "./setting-app-color-picker.js" | ||||
| export {SettingColorPicker} from "./setting-color-picker.js" | ||||
| export {SettingHomepageControl} from "./setting-homepage-control.js" | ||||
| // export {ShelfSort} from "./shelf-sort.js" | ||||
| export {Shortcuts} from "./shortcuts" | ||||
| export {ShortcutInput} from "./shortcut-input" | ||||
| @@ -52,7 +52,7 @@ export {ShortcutInput} from "./shortcut-input" | ||||
| // export {Tabs} from "./tabs.js" | ||||
| // export {TagManager} from "./tag-manager.js" | ||||
| // export {TemplateManager} from "./template-manager.js" | ||||
| // export {ToggleSwitch} from "./toggle-switch.js" | ||||
| export {ToggleSwitch} from "./toggle-switch.js" | ||||
| // export {TriLayout} from "./tri-layout.js" | ||||
| // export {UserSelect} from "./user-select.js" | ||||
| // export {WebhookEvents} from "./webhook-events"; | ||||
|   | ||||
| @@ -1,14 +1,14 @@ | ||||
| import {Component} from "./component"; | ||||
|  | ||||
| class PagePicker { | ||||
| export class PagePicker extends Component { | ||||
|  | ||||
|     constructor(elem) { | ||||
|         this.elem = elem; | ||||
|         this.input = elem.querySelector('input'); | ||||
|         this.resetButton = elem.querySelector('[page-picker-reset]'); | ||||
|         this.selectButton = elem.querySelector('[page-picker-select]'); | ||||
|         this.display = elem.querySelector('[page-picker-display]'); | ||||
|         this.defaultDisplay = elem.querySelector('[page-picker-default]'); | ||||
|         this.buttonSep = elem.querySelector('span.sep'); | ||||
|     setup() { | ||||
|         this.input = this.$refs.input; | ||||
|         this.resetButton = this.$refs.resetButton; | ||||
|         this.selectButton = this.$refs.selectButton; | ||||
|         this.display = this.$refs.display; | ||||
|         this.defaultDisplay = this.$refs.defaultDisplay; | ||||
|         this.buttonSep = this.$refs.buttonSeperator; | ||||
|  | ||||
|         this.value = this.input.value; | ||||
|         this.setupListeners(); | ||||
| @@ -24,7 +24,9 @@ class PagePicker { | ||||
|     } | ||||
|  | ||||
|     showPopup() { | ||||
|         window.EntitySelectorPopup.show(entity => { | ||||
|         /** @type {EntitySelectorPopup} **/ | ||||
|         const selectorPopup = window.$components.first('entity-selector-popup'); | ||||
|         selectorPopup.show(entity => { | ||||
|             this.setValue(entity.id, entity.name); | ||||
|         }); | ||||
|     } | ||||
| @@ -36,7 +38,7 @@ class PagePicker { | ||||
|     } | ||||
|  | ||||
|     controlView(name) { | ||||
|         let hasValue = this.value && this.value !== 0; | ||||
|         const hasValue = this.value && this.value !== 0; | ||||
|         toggleElem(this.resetButton, hasValue); | ||||
|         toggleElem(this.buttonSep, hasValue); | ||||
|         toggleElem(this.defaultDisplay, !hasValue); | ||||
| @@ -55,8 +57,5 @@ class PagePicker { | ||||
| } | ||||
|  | ||||
| function toggleElem(elem, show) { | ||||
|     let display = (elem.tagName === 'BUTTON' || elem.tagName === 'SPAN') ? 'inline-block' : 'block'; | ||||
|     elem.style.display = show ? display : 'none'; | ||||
| } | ||||
|  | ||||
| export default PagePicker; | ||||
|     elem.style.display = show ? null : 'none'; | ||||
| } | ||||
| @@ -1,5 +1,6 @@ | ||||
| import {Component} from "./component"; | ||||
|  | ||||
| class PermissionsTable { | ||||
| export class PermissionsTable extends Component { | ||||
|  | ||||
|     setup() { | ||||
|         this.container = this.$el; | ||||
| @@ -62,6 +63,4 @@ class PermissionsTable { | ||||
|         } | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
| export default PermissionsTable; | ||||
| } | ||||
| @@ -1,13 +1,13 @@ | ||||
| import {fadeIn, fadeOut} from "../services/animations"; | ||||
| import {onSelect} from "../services/dom"; | ||||
| import {Component} from "./component"; | ||||
|  | ||||
| /** | ||||
|  * Popup window that will contain other content. | ||||
|  * This component provides the show/hide functionality | ||||
|  * with the ability for popup@hide child references to close this. | ||||
|  * @extends {Component} | ||||
|  */ | ||||
| class Popup { | ||||
| export class Popup extends Component { | ||||
|  | ||||
|     setup() { | ||||
|         this.container = this.$el; | ||||
| @@ -56,6 +56,4 @@ class Popup { | ||||
|         this.onHide = onHide; | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
| export default Popup; | ||||
| } | ||||
| @@ -1,23 +1,13 @@ | ||||
| import {Component} from "./component"; | ||||
|  | ||||
| class SettingAppColorPicker { | ||||
| export class SettingAppColorPicker extends Component { | ||||
|  | ||||
|     constructor(elem) { | ||||
|         this.elem = elem; | ||||
|         this.colorInput = elem.querySelector('input[type=color]'); | ||||
|         this.lightColorInput = elem.querySelector('input[name="setting-app-color-light"]'); | ||||
|         this.resetButton = elem.querySelector('[setting-app-color-picker-reset]'); | ||||
|         this.defaultButton = elem.querySelector('[setting-app-color-picker-default]'); | ||||
|     setup() { | ||||
|         this.colorInput = this.$refs.input; | ||||
|         this.lightColorInput = this.$refs.lightInput; | ||||
|  | ||||
|         this.colorInput.addEventListener('change', this.updateColor.bind(this)); | ||||
|         this.colorInput.addEventListener('input', this.updateColor.bind(this)); | ||||
|         this.resetButton.addEventListener('click', event => { | ||||
|             this.colorInput.value = this.colorInput.dataset.current; | ||||
|             this.updateColor(); | ||||
|         }); | ||||
|         this.defaultButton.addEventListener('click', event => { | ||||
|             this.colorInput.value = this.colorInput.dataset.default; | ||||
|             this.updateColor(); | ||||
|         }); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -44,8 +34,8 @@ class SettingAppColorPicker { | ||||
|     /** | ||||
|      * Covert a hex color code to rgb components. | ||||
|      * @attribution https://stackoverflow.com/a/5624139 | ||||
|      * @param hex | ||||
|      * @returns {*} | ||||
|      * @param {String} hex | ||||
|      * @returns {{r: Number, g: Number, b: Number}} | ||||
|      */ | ||||
|     hexToRgb(hex) { | ||||
|         const result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex); | ||||
| @@ -57,5 +47,3 @@ class SettingAppColorPicker { | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
| export default SettingAppColorPicker; | ||||
|   | ||||
| @@ -1,18 +1,20 @@ | ||||
| import {Component} from "./component"; | ||||
|  | ||||
| class SettingColorPicker { | ||||
| export class SettingColorPicker extends Component { | ||||
|  | ||||
|     constructor(elem) { | ||||
|         this.elem = elem; | ||||
|         this.colorInput = elem.querySelector('input[type=color]'); | ||||
|         this.resetButton = elem.querySelector('[setting-color-picker-reset]'); | ||||
|         this.defaultButton = elem.querySelector('[setting-color-picker-default]'); | ||||
|         this.resetButton.addEventListener('click', event => { | ||||
|             this.colorInput.value = this.colorInput.dataset.current; | ||||
|         }); | ||||
|         this.defaultButton.addEventListener('click', event => { | ||||
|           this.colorInput.value = this.colorInput.dataset.default; | ||||
|         }); | ||||
|     setup() { | ||||
|         this.colorInput = this.$refs.input; | ||||
|         this.resetButton = this.$refs.resetButton; | ||||
|         this.defaultButton = this.$refs.defaultButton; | ||||
|         this.currentColor = this.$opts.current; | ||||
|         this.defaultColor = this.$opts.default; | ||||
|  | ||||
|         this.resetButton.addEventListener('click', () => this.setValue(this.currentColor)); | ||||
|         this.defaultButton.addEventListener('click', () => this.setValue(this.defaultColor)); | ||||
|     } | ||||
| } | ||||
|  | ||||
| export default SettingColorPicker; | ||||
|     setValue(value) { | ||||
|         this.colorInput.value = value; | ||||
|         this.colorInput.dispatchEvent(new Event('change')); | ||||
|     } | ||||
| } | ||||
| @@ -1,10 +1,10 @@ | ||||
| import {Component} from "./component"; | ||||
| 
 | ||||
| class HomepageControl { | ||||
| export class SettingHomepageControl extends Component { | ||||
| 
 | ||||
|     constructor(elem) { | ||||
|         this.elem = elem; | ||||
|         this.typeControl = elem.querySelector('[name="setting-app-homepage-type"]'); | ||||
|         this.pagePickerContainer = elem.querySelector('[page-picker-container]'); | ||||
|     setup() { | ||||
|         this.typeControl = this.$refs.typeControl; | ||||
|         this.pagePickerContainer = this.$refs.pagePickerContainer; | ||||
| 
 | ||||
|         this.typeControl.addEventListener('change', this.controlPagePickerVisibility.bind(this)); | ||||
|         this.controlPagePickerVisibility(); | ||||
| @@ -14,9 +14,4 @@ class HomepageControl { | ||||
|         const showPagePicker = this.typeControl.value === 'page'; | ||||
|         this.pagePickerContainer.style.display = (showPagePicker ? 'block' : 'none'); | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| export default HomepageControl; | ||||
| } | ||||
| @@ -1,10 +1,10 @@ | ||||
| import {Component} from "./component"; | ||||
|  | ||||
| class ToggleSwitch { | ||||
| export class ToggleSwitch extends Component { | ||||
|  | ||||
|     constructor(elem) { | ||||
|         this.elem = elem; | ||||
|         this.input = elem.querySelector('input[type=hidden]'); | ||||
|         this.checkbox = elem.querySelector('input[type=checkbox]'); | ||||
|     setup() { | ||||
|         this.input = this.$el.querySelector('input[type=hidden]'); | ||||
|         this.checkbox = this.$el.querySelector('input[type=checkbox]'); | ||||
|  | ||||
|         this.checkbox.addEventListener('change', this.stateChange.bind(this)); | ||||
|     } | ||||
| @@ -18,6 +18,4 @@ class ToggleSwitch { | ||||
|         this.input.dispatchEvent(changeEvent); | ||||
|     } | ||||
|  | ||||
| } | ||||
|  | ||||
| export default ToggleSwitch; | ||||
| } | ||||
| @@ -4,7 +4,7 @@ $value | ||||
| $checked | ||||
| $label | ||||
| --}} | ||||
| <label custom-checkbox class="toggle-switch @if($errors->has($name)) text-neg @endif"> | ||||
| <label component="custom-checkbox" class="toggle-switch @if($errors->has($name)) text-neg @endif"> | ||||
|     <input type="checkbox" name="{{$name}}" value="{{ $value }}" @if($checked) checked="checked" @endif @if($disabled ?? false) disabled="disabled" @endif> | ||||
|     <span tabindex="0" role="checkbox" | ||||
|           aria-checked="{{ $checked ? 'true' : 'false' }}" | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| <label toggle-switch="{{$name}}" custom-checkbox class="toggle-switch"> | ||||
| <label components="custom-checkbox toggle-switch" class="toggle-switch"> | ||||
|     <input type="hidden" name="{{$name}}" value="{{$value?'true':'false'}}"/> | ||||
|     <input type="checkbox" @if($value) checked="checked" @endif> | ||||
|     <span tabindex="0" role="checkbox" | ||||
|   | ||||
| @@ -59,13 +59,16 @@ | ||||
|                     <label class="setting-list-label">{{ trans('settings.app_primary_color') }}</label> | ||||
|                     <p class="small">{!! trans('settings.app_primary_color_desc') !!}</p> | ||||
|                 </div> | ||||
|                 <div setting-app-color-picker class="text-m-right pt-xs"> | ||||
|                     <input type="color" data-default="#206ea7" data-current="{{ setting('app-color') }}" value="{{ setting('app-color') }}" name="setting-app-color" id="setting-app-color" placeholder="#206ea7"> | ||||
|                     <input type="hidden" value="{{ setting('app-color-light') }}" name="setting-app-color-light" id="setting-app-color-light"> | ||||
|                 <div component="setting-app-color-picker setting-color-picker" | ||||
|                      option:setting-color-picker:default="#206ea7" | ||||
|                      option:setting-color-picker:current="{{ setting('app-color') }}" | ||||
|                      class="text-m-right pt-xs"> | ||||
|                     <input refs="setting-color-picker@input setting-app-color-picker@input" type="color" value="{{ setting('app-color') }}" name="setting-app-color" id="setting-app-color" placeholder="#206ea7"> | ||||
|                     <input refs="setting-app-color-picker@light-input" type="hidden" value="{{ setting('app-color-light') }}" name="setting-app-color-light" id="setting-app-color-light"> | ||||
|                     <div class="pr-s"> | ||||
|                         <button type="button" class="text-button text-muted mt-s" setting-app-color-picker-default>{{ trans('common.default') }}</button> | ||||
|                         <button refs="setting-color-picker@default-button" type="button" class="text-button text-muted mt-s">{{ trans('common.default') }}</button> | ||||
|                         <span class="sep">|</span> | ||||
|                         <button type="button" class="text-button text-muted mt-s" setting-app-color-picker-reset>{{ trans('common.reset') }}</button> | ||||
|                         <button refs="setting-color-picker@reset-button" type="button" class="text-button text-muted mt-s">{{ trans('common.reset') }}</button> | ||||
|                     </div> | ||||
|  | ||||
|                 </div> | ||||
| @@ -90,20 +93,22 @@ | ||||
|                 </div> | ||||
|             </div> | ||||
|  | ||||
|             <div homepage-control id="homepage-control" class="grid half gap-xl items-center"> | ||||
|             <div component="setting-homepage-control" id="homepage-control" class="grid half gap-xl items-center"> | ||||
|                 <div> | ||||
|                     <label for="setting-app-homepage-type" class="setting-list-label">{{ trans('settings.app_homepage') }}</label> | ||||
|                     <p class="small">{{ trans('settings.app_homepage_desc') }}</p> | ||||
|                 </div> | ||||
|                 <div> | ||||
|                     <select name="setting-app-homepage-type" id="setting-app-homepage-type"> | ||||
|                     <select refs="setting-homepage-control@type-control" | ||||
|                             name="setting-app-homepage-type" | ||||
|                             id="setting-app-homepage-type"> | ||||
|                         <option @if(setting('app-homepage-type') === 'default') selected @endif value="default">{{ trans('common.default') }}</option> | ||||
|                         <option @if(setting('app-homepage-type') === 'books') selected @endif value="books">{{ trans('entities.books') }}</option> | ||||
|                         <option @if(setting('app-homepage-type') === 'bookshelves') selected @endif value="bookshelves">{{ trans('entities.shelves') }}</option> | ||||
|                         <option @if(setting('app-homepage-type') === 'page') selected @endif value="page">{{ trans('entities.pages_specific') }}</option> | ||||
|                     </select> | ||||
|  | ||||
|                     <div page-picker-container style="display: none;" class="mt-m"> | ||||
|                     <div refs="setting-homepage-control@page-picker-container" style="display: none;" class="mt-m"> | ||||
|                         @include('settings.parts.page-picker', ['name' => 'setting-app-homepage', 'placeholder' => trans('settings.app_homepage_select'), 'value' => setting('app-homepage')]) | ||||
|                     </div> | ||||
|                 </div> | ||||
|   | ||||
| @@ -1,13 +1,13 @@ | ||||
|  | ||||
| {{--Depends on entity selector popup--}} | ||||
| <div page-picker> | ||||
| <div component="page-picker"> | ||||
|     <div class="input-base"> | ||||
|         <span @if($value) style="display: none" @endif page-picker-default class="text-muted italic">{{ $placeholder }}</span> | ||||
|         <a @if(!$value) style="display: none" @endif href="{{ url('/link/' . $value) }}" target="_blank" rel="noopener" class="text-page" page-picker-display>#{{$value}}, {{$value ? \BookStack\Entities\Models\Page::find($value)->name : '' }}</a> | ||||
|         <span @if($value) style="display: none" @endif refs="page-picker@default-display" class="text-muted italic">{{ $placeholder }}</span> | ||||
|         <a @if(!$value) style="display: none" @endif href="{{ url('/link/' . $value) }}" target="_blank" rel="noopener" class="text-page" refs="page-picker@display">#{{$value}}, {{$value ? \BookStack\Entities\Models\Page::find($value)->name : '' }}</a> | ||||
|     </div> | ||||
|     <br> | ||||
|     <input type="hidden" value="{{$value}}" name="{{$name}}" id="{{$name}}"> | ||||
|     <button @if(!$value) style="display: none" @endif type="button" page-picker-reset class="text-button">{{ trans('common.reset') }}</button> | ||||
|     <span @if(!$value) style="display: none" @endif class="sep">|</span> | ||||
|     <button type="button" page-picker-select class="text-button">{{ trans('common.select') }}</button> | ||||
|     <input refs="page-picker@input" type="hidden" value="{{$value}}" name="{{$name}}" id="{{$name}}"> | ||||
|     <button @if(!$value) style="display: none" @endif type="button" refs="page-picker@reset-button" class="text-button">{{ trans('common.reset') }}</button> | ||||
|     <span refs="page-picker@button-seperator" @if(!$value) style="display: none" @endif class="sep">|</span> | ||||
|     <button type="button" refs="page-picker@select-button" class="text-button">{{ trans('common.select') }}</button> | ||||
| </div> | ||||
| @@ -1,17 +1,19 @@ | ||||
| {{-- | ||||
|     @type - Name of entity type | ||||
| --}} | ||||
| <div setting-color-picker class="grid no-break half mb-l"> | ||||
| <div component="setting-color-picker" | ||||
|      option:setting-color-picker:default="{{ config('setting-defaults.'. $type .'-color') }}" | ||||
|      option:setting-color-picker:current="{{ setting($type .'-color') }}" | ||||
|      class="grid no-break half mb-l"> | ||||
|     <div> | ||||
|         <label for="setting-{{ $type }}-color" class="text-dark">{{ trans('settings.'. str_replace('-', '_', $type) .'_color') }}</label> | ||||
|         <button type="button" class="text-button text-muted" setting-color-picker-default>{{ trans('common.default') }}</button> | ||||
|         <button refs="setting-color-picker@default-button" type="button" class="text-button text-muted">{{ trans('common.default') }}</button> | ||||
|         <span class="sep">|</span> | ||||
|         <button type="button" class="text-button text-muted" setting-color-picker-reset>{{ trans('common.reset') }}</button> | ||||
|         <button refs="setting-color-picker@reset-button" type="button" class="text-button text-muted">{{ trans('common.reset') }}</button> | ||||
|     </div> | ||||
|     <div> | ||||
|         <input type="color" | ||||
|                data-default="{{ config('setting-defaults.'. $type .'-color') }}" | ||||
|                data-current="{{ setting($type .'-color') }}" | ||||
|                refs="setting-color-picker@input" | ||||
|                value="{{ setting($type .'-color') }}" | ||||
|                name="setting-{{ $type }}-color" | ||||
|                id="setting-{{ $type }}-color" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user