unordered list. \",\"created\":1630086528,\"installed\":false,\"namespace\":\"ProcessWire\\\\\",\"core\":true},\"TextformatterNewlineBR\":{\"name\":\"TextformatterNewlineBR\",\"title\":\"Newlines to XHTML Line Breaks\",\"version\":100,\"versionStr\":\"1.0.0\",\"summary\":\"Converts newlines to XHTML line break tags. \",\"created\":1630086528,\"installed\":false,\"namespace\":\"ProcessWire\\\\\",\"core\":true},\"TextformatterStripTags\":{\"name\":\"TextformatterStripTags\",\"title\":\"Strip Markup Tags\",\"version\":100,\"versionStr\":\"1.0.0\",\"summary\":\"Strips HTML\\/XHTML Markup Tags\",\"created\":1630086528,\"installed\":false,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"core\":true},\"TextformatterPstripper\":{\"name\":\"TextformatterPstripper\",\"title\":\"Paragraph Stripper\",\"version\":100,\"versionStr\":\"1.0.0\",\"summary\":\"Strips paragraph tags that may have been applied by other text formatters before it. \",\"created\":1630086528,\"installed\":false,\"namespace\":\"ProcessWire\\\\\",\"core\":true},\"FieldtypeNotifications\":{\"name\":\"FieldtypeNotifications\",\"title\":\"Notifications\",\"version\":4,\"versionStr\":\"0.0.4\",\"summary\":\"Field that stores user notifications.\",\"requiresVersions\":{\"SystemNotifications\":[\">=\",0]},\"created\":1630086528,\"installed\":false,\"namespace\":\"ProcessWire\\\\\",\"core\":true},\"SystemNotifications\":{\"name\":\"SystemNotifications\",\"title\":\"System Notifications\",\"version\":12,\"versionStr\":\"0.1.2\",\"summary\":\"Adds support for notifications in ProcessWire (currently in development)\",\"icon\":\"bell\",\"installs\":[\"FieldtypeNotifications\"],\"autoload\":true,\"created\":1630086528,\"installed\":false,\"configurable\":\"SystemNotificationsConfig.php\",\"namespace\":\"ProcessWire\\\\\",\"core\":true},\"MarkupCache\":{\"name\":\"MarkupCache\",\"title\":\"Markup Cache\",\"version\":101,\"versionStr\":\"1.0.1\",\"summary\":\"A simple way to cache segments of markup in your templates. \",\"href\":\"https:\\/\\/processwire.com\\/api\\/modules\\/markupcache\\/\",\"autoload\":true,\"singular\":true,\"created\":1630086528,\"installed\":false,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"core\":true},\"MarkupPageFields\":{\"name\":\"MarkupPageFields\",\"title\":\"Markup Page Fields\",\"version\":100,\"versionStr\":\"1.0.0\",\"summary\":\"Adds $page->renderFields() and $page->images->render() methods that return basic markup for output during development and debugging.\",\"autoload\":true,\"singular\":true,\"created\":1630086528,\"installed\":false,\"namespace\":\"ProcessWire\\\\\",\"core\":true,\"permanent\":true},\"MarkupRSS\":{\"name\":\"MarkupRSS\",\"title\":\"Markup RSS Feed\",\"version\":104,\"versionStr\":\"1.0.4\",\"summary\":\"Renders an RSS feed. Given a PageArray, renders an RSS feed of them.\",\"icon\":\"rss-square\",\"created\":1630086528,\"installed\":false,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"core\":true}}', '2010-04-08 03:10:01');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__1613c1ac701df9dd5eafbdfab24487f2', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/layout\\/main.php\",\"hash\":\"1ca6a2ea8525a64768730885183514fe\",\"size\":713,\"time\":1676721609,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/layout\\/main.php\",\"hash\":\"1ca6a2ea8525a64768730885183514fe\",\"size\":713,\"time\":1676721609}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__a6edbd8ce26a0c1bccf8929bb1594b30', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/ready.php\",\"hash\":\"d656410a9c3bf6f1b87a1830102ca9ab\",\"size\":887,\"time\":1666870641,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/ready.php\",\"hash\":\"d656410a9c3bf6f1b87a1830102ca9ab\",\"size\":887,\"time\":1666870641}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('Modules.site/modules/', 'ProcessDatabaseBackups/ProcessDatabaseBackups.module\nFileValidatorSvgSanitizer-master/FileValidatorSvgSanitizer.module.php\nColorPicker/FieldtypeColorPicker.module\nColorPicker/InputfieldColorPicker.module\nProcessWireUpgrade/ProcessWireUpgrade.module\nProcessWireUpgrade/ProcessWireUpgradeCheck.module\nFieldtypeMapMarker/FieldtypeMapMarker.module\nFieldtypeMapMarker/InputfieldMapMarker.module\nFieldtypeMapMarker/MarkupGoogleMap.module\nFieldtypeTextUnique/FieldtypeTextUnique.module', '2010-04-08 03:10:01');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('ModulesVerbose.info', '{\"125\":{\"summary\":\"Throttles login attempts to help prevent dictionary attacks.\",\"core\":true,\"versionStr\":\"1.0.3\"},\"192\":{\"summary\":\"Enables front-end editing of page fields.\",\"author\":\"Ryan Cramer\",\"core\":true,\"versionStr\":\"0.0.3\",\"permissions\":{\"page-edit-front\":\"Use the front-end page editor\"}},\"115\":{\"summary\":\"Adds a render method to Page and caches page output.\",\"core\":true,\"versionStr\":\"1.0.5\"},\"3\":{\"summary\":\"Field that stores a single line of text\",\"core\":true,\"versionStr\":\"1.0.2\"},\"106\":{\"summary\":\"Close a fieldset opened by FieldsetOpen. \",\"core\":true,\"versionStr\":\"1.0.0\"},\"105\":{\"summary\":\"Open a fieldset to group fields. Should be followed by a Fieldset (Close) after one or more fields.\",\"core\":true,\"versionStr\":\"1.0.1\"},\"133\":{\"summary\":\"Field that stores a hashed and salted password\",\"core\":true,\"versionStr\":\"1.0.1\"},\"89\":{\"summary\":\"Field that stores a floating point number\",\"core\":true,\"versionStr\":\"1.0.7\"},\"97\":{\"summary\":\"This Fieldtype stores an ON\\/OFF toggle via a single checkbox. The ON value is 1 and OFF value is 0.\",\"core\":true,\"versionStr\":\"1.0.1\"},\"6\":{\"summary\":\"Field that stores one or more files\",\"core\":true,\"versionStr\":\"1.0.7\"},\"174\":{\"summary\":\"Repeats fields from another template. Provides the input for FieldtypeRepeater.\",\"core\":true,\"versionStr\":\"1.1.1\"},\"173\":{\"summary\":\"Maintains a collection of fields that are repeated for any number of times.\",\"core\":true,\"versionStr\":\"1.1.2\"},\"135\":{\"summary\":\"Field that stores a URL\",\"core\":true,\"versionStr\":\"1.0.1\"},\"189\":{\"summary\":\"Field that stores user posted comments for a single Page\",\"core\":true,\"versionStr\":\"1.0.9\"},\"191\":{\"summary\":\"Uses the Akismet service to identify comment spam. Module plugin for the Comments Fieldtype.\",\"core\":true,\"versionStr\":\"2.0.0\"},\"190\":{\"summary\":\"Provides an administrative interface for working with comments\",\"core\":true,\"versionStr\":\"1.0.4\"},\"84\":{\"summary\":\"Field that stores an integer\",\"core\":true,\"versionStr\":\"1.0.2\"},\"57\":{\"summary\":\"Field that stores one or more GIF, JPG, or PNG images\",\"core\":true,\"versionStr\":\"1.0.2\"},\"172\":{\"summary\":\"Field that stores single and multi select options.\",\"core\":true,\"versionStr\":\"0.0.2\"},\"4\":{\"summary\":\"Field that stores one or more references to ProcessWire pages\",\"core\":true,\"versionStr\":\"1.0.6\"},\"107\":{\"summary\":\"Open a fieldset to group fields. Same as Fieldset (Open) except that it displays in a tab instead.\",\"core\":true,\"versionStr\":\"1.0.0\"},\"27\":{\"summary\":\"Field that stores a reference to another module\",\"core\":true,\"versionStr\":\"1.0.2\"},\"111\":{\"summary\":\"Field that stores a page title\",\"core\":true,\"versionStr\":\"1.0.0\"},\"29\":{\"summary\":\"Field that stores an e-mail address\",\"core\":true,\"versionStr\":\"1.0.1\"},\"1\":{\"summary\":\"Field that stores multiple lines of text\",\"core\":true,\"versionStr\":\"1.0.7\"},\"28\":{\"summary\":\"Field that stores a date and optionally time\",\"core\":true,\"versionStr\":\"1.0.5\"},\"165\":{\"summary\":\"Provides language translation capabilities for ProcessWire core and modules.\",\"author\":\"Ryan Cramer\",\"core\":true,\"versionStr\":\"1.0.2\"},\"170\":{\"summary\":\"Field that stores a multiple lines of text in multiple languages\",\"core\":true,\"versionStr\":\"1.0.0\"},\"163\":{\"summary\":\"ProcessWire multi-language support.\",\"author\":\"Ryan Cramer\",\"core\":true,\"versionStr\":\"1.0.3\"},\"167\":{\"summary\":\"Required to use multi-language fields.\",\"author\":\"Ryan Cramer\",\"core\":true,\"versionStr\":\"1.0.1\"},\"166\":{\"summary\":\"Organizes multi-language fields into tabs for a cleaner easier to use interface.\",\"author\":\"adamspruijt, ryan\",\"core\":true,\"versionStr\":\"1.1.5\"},\"169\":{\"summary\":\"Field that stores a page title in multiple languages. Use this only if you want title inputs created for ALL languages on ALL pages. Otherwise create separate languaged-named title fields, i.e. title_fr, title_es, title_fi, etc. \",\"author\":\"Ryan Cramer\",\"core\":true,\"versionStr\":\"1.0.0\"},\"164\":{\"summary\":\"Manage system languages\",\"author\":\"Ryan Cramer\",\"core\":true,\"versionStr\":\"1.0.3\",\"permissions\":{\"lang-edit\":\"Administer languages and static translation files\"}},\"171\":{\"summary\":\"Required to use multi-language page names.\",\"author\":\"Ryan Cramer\",\"core\":true,\"versionStr\":\"0.1.3\"},\"168\":{\"summary\":\"Field that stores a single line of text in multiple languages\",\"core\":true,\"versionStr\":\"1.0.0\"},\"55\":{\"summary\":\"One or more file uploads (sortable)\",\"core\":true,\"versionStr\":\"1.2.6\"},\"86\":{\"summary\":\"Text input validated as a ProcessWire Page name field\",\"core\":true,\"versionStr\":\"1.0.6\"},\"79\":{\"summary\":\"Contains any other markup and optionally child Inputfields\",\"core\":true,\"versionStr\":\"1.0.2\"},\"39\":{\"summary\":\"Radio buttons for selection of a single item\",\"core\":true,\"versionStr\":\"1.0.6\"},\"155\":{\"summary\":\"CKEditor textarea rich text editor.\",\"core\":true,\"versionStr\":\"1.7.0\"},\"40\":{\"summary\":\"Hidden value in a form\",\"core\":true,\"versionStr\":\"1.0.1\"},\"30\":{\"summary\":\"Contains one or more fields in a form\",\"core\":true,\"versionStr\":\"1.0.7\"},\"15\":{\"summary\":\"Selection of a single page from a ProcessWire page tree list\",\"core\":true,\"versionStr\":\"1.0.1\"},\"137\":{\"summary\":\"Selection of multiple pages from a ProcessWire page tree list\",\"core\":true,\"versionStr\":\"1.0.3\"},\"80\":{\"summary\":\"E-Mail address in valid format\",\"core\":true,\"versionStr\":\"1.0.1\"},\"108\":{\"summary\":\"URL in valid format\",\"core\":true,\"versionStr\":\"1.0.3\"},\"35\":{\"summary\":\"Multiple lines of text\",\"core\":true,\"versionStr\":\"1.0.3\"},\"36\":{\"summary\":\"Selection of a single value from a select pulldown\",\"core\":true,\"versionStr\":\"1.0.2\"},\"60\":{\"summary\":\"Select one or more pages\",\"core\":true,\"versionStr\":\"1.0.8\"},\"175\":{\"summary\":\"Enables input of user entered tags or selection of predefined tags.\",\"core\":true,\"versionStr\":\"0.0.5\"},\"162\":{\"summary\":\"Select an icon\",\"core\":true,\"versionStr\":\"0.0.3\"},\"41\":{\"summary\":\"Text input validated as a ProcessWire name field\",\"core\":true,\"versionStr\":\"1.0.0\"},\"187\":{\"summary\":\"Multiple Page selection using auto completion and sorting capability. Intended for use as an input field for Page reference fields.\",\"core\":true,\"versionStr\":\"1.1.2\"},\"25\":{\"summary\":\"Multiple selection, progressive enhancement to select multiple\",\"core\":true,\"versionStr\":\"2.0.3\"},\"78\":{\"summary\":\"Groups one or more fields together in a container\",\"core\":true,\"versionStr\":\"1.0.1\"},\"112\":{\"summary\":\"Handles input of Page Title and auto-generation of Page Name (when name is blank)\",\"core\":true,\"versionStr\":\"1.0.2\"},\"43\":{\"summary\":\"Select multiple items from a list\",\"core\":true,\"versionStr\":\"1.0.1\"},\"149\":{\"summary\":\"Build a page finding selector visually.\",\"author\":\"Avoine + ProcessWire\",\"core\":true,\"versionStr\":\"0.2.8\"},\"131\":{\"summary\":\"Form button element that you can optionally pass an href attribute to.\",\"core\":true,\"versionStr\":\"1.0.0\"},\"176\":{\"summary\":\"A toggle providing similar input capability to a checkbox but much more configurable.\",\"core\":true,\"versionStr\":\"0.0.1\"},\"56\":{\"summary\":\"One or more image uploads (sortable)\",\"core\":true,\"versionStr\":\"1.2.4\"},\"37\":{\"summary\":\"Single checkbox toggle\",\"core\":true,\"versionStr\":\"1.0.6\"},\"34\":{\"summary\":\"Single line of text\",\"core\":true,\"versionStr\":\"1.0.6\"},\"94\":{\"summary\":\"Inputfield that accepts date and optionally time\",\"core\":true,\"versionStr\":\"1.0.7\"},\"38\":{\"summary\":\"Multiple checkbox toggles\",\"core\":true,\"versionStr\":\"1.0.8\"},\"85\":{\"summary\":\"Integer (positive or negative)\",\"core\":true,\"versionStr\":\"1.0.5\"},\"122\":{\"summary\":\"Password input with confirmation field that doesn't ever echo the input back.\",\"core\":true,\"versionStr\":\"1.0.2\"},\"32\":{\"summary\":\"Form submit button\",\"core\":true,\"versionStr\":\"1.0.3\"},\"90\":{\"summary\":\"Floating point number with precision\",\"core\":true,\"versionStr\":\"1.0.5\"},\"114\":{\"summary\":\"Adds various permission methods to Page objects that are used by Process modules.\",\"core\":true,\"versionStr\":\"1.0.5\"},\"76\":{\"summary\":\"Lists the Process assigned to each child page of the current\",\"core\":true,\"versionStr\":\"1.0.1\"},\"12\":{\"summary\":\"List pages in a hierarchical tree structure\",\"core\":true,\"versionStr\":\"1.2.4\"},\"161\":{\"summary\":\"View and manage system logs.\",\"author\":\"Ryan Cramer\",\"core\":true,\"versionStr\":\"0.0.2\",\"permissions\":{\"logs-view\":\"Can view system logs\",\"logs-edit\":\"Can manage system logs\"},\"page\":{\"name\":\"logs\",\"parent\":\"setup\",\"title\":\"Logs\"}},\"150\":{\"summary\":\"Admin tool for finding and listing pages by any property.\",\"author\":\"Ryan Cramer\",\"core\":true,\"versionStr\":\"0.2.6\",\"permissions\":{\"page-lister\":\"Use Page Lister\"}},\"109\":{\"summary\":\"Handles emptying of Page trash\",\"core\":true,\"versionStr\":\"1.0.3\"},\"129\":{\"summary\":\"Provides image manipulation functions for image fields and rich text editors.\",\"core\":true,\"versionStr\":\"1.2.0\"},\"50\":{\"summary\":\"List, edit or install\\/uninstall modules\",\"core\":true,\"versionStr\":\"1.2.0\"},\"83\":{\"summary\":\"All page views are routed through this Process\",\"core\":true,\"versionStr\":\"1.0.6\"},\"10\":{\"summary\":\"Login to ProcessWire\",\"core\":true,\"versionStr\":\"1.0.8\"},\"7\":{\"summary\":\"Edit a Page\",\"core\":true,\"versionStr\":\"1.1.1\"},\"104\":{\"summary\":\"Provides a page search engine for admin use.\",\"core\":true,\"versionStr\":\"1.0.7\"},\"159\":{\"summary\":\"Shows a list of recently edited pages in your admin.\",\"author\":\"Ryan Cramer\",\"href\":\"http:\\/\\/modules.processwire.com\\/\",\"core\":true,\"versionStr\":\"0.0.2\",\"permissions\":{\"page-edit-recent\":\"Can see recently edited pages\"},\"page\":{\"name\":\"recent-pages\",\"parent\":\"page\",\"title\":\"Recent\"}},\"17\":{\"summary\":\"Add a new page\",\"core\":true,\"versionStr\":\"1.0.9\"},\"121\":{\"summary\":\"Provides a link capability as used by some Fieldtype modules (like rich text editors).\",\"core\":true,\"versionStr\":\"1.0.9\"},\"138\":{\"summary\":\"Enables user to change their password, email address and other settings that you define.\",\"core\":true,\"versionStr\":\"1.0.5\"},\"66\":{\"summary\":\"Manage system users\",\"core\":true,\"versionStr\":\"1.0.7\",\"searchable\":\"users\"},\"48\":{\"summary\":\"Edit individual fields that hold page data\",\"core\":true,\"versionStr\":\"1.1.3\",\"searchable\":\"fields\"},\"47\":{\"summary\":\"List and edit the templates that control page output\",\"core\":true,\"versionStr\":\"1.1.4\",\"searchable\":\"templates\"},\"134\":{\"summary\":\"List, Edit and Add pages of a specific type\",\"core\":true,\"versionStr\":\"1.0.1\"},\"136\":{\"summary\":\"Manage system permissions\",\"core\":true,\"versionStr\":\"1.0.1\"},\"68\":{\"summary\":\"Manage user roles and what permissions are attached\",\"core\":true,\"versionStr\":\"1.0.4\"},\"87\":{\"summary\":\"Acts as a placeholder Process for the admin root. Ensures proper flow control after login.\",\"core\":true,\"versionStr\":\"1.0.1\"},\"14\":{\"summary\":\"Handles page sorting and moving for PageList\",\"core\":true,\"versionStr\":\"1.0.0\"},\"160\":{\"summary\":\"Uikit v3 admin theme\",\"core\":true,\"versionStr\":\"0.3.3\"},\"148\":{\"summary\":\"Minimal admin theme that supports all ProcessWire features.\",\"core\":true,\"versionStr\":\"0.1.4\"},\"61\":{\"summary\":\"Entity encode ampersands, quotes (single and double) and greater-than\\/less-than signs using htmlspecialchars(str, ENT_QUOTES). It is recommended that you use this on all text\\/textarea fields except those using a rich text editor or a markup language like Markdown.\",\"core\":true,\"versionStr\":\"1.0.0\"},\"139\":{\"summary\":\"Manages system versions and upgrades.\",\"core\":true,\"versionStr\":\"0.2.0\"},\"113\":{\"summary\":\"Adds renderPager() method to all PaginatedArray types, for easy pagination output. Plus a render() method to PageArray instances.\",\"core\":true,\"versionStr\":\"1.0.0\"},\"156\":{\"summary\":\"Front-end to the HTML Purifier library.\",\"core\":true,\"versionStr\":\"4.9.6\"},\"98\":{\"summary\":\"Generates markup for pagination navigation\",\"core\":true,\"versionStr\":\"1.0.5\"},\"67\":{\"summary\":\"Generates markup for data tables used by ProcessWire admin\",\"core\":true,\"versionStr\":\"1.0.7\"},\"103\":{\"summary\":\"Provides a jQuery plugin for sorting tables.\",\"href\":\"http:\\/\\/mottie.github.io\\/tablesorter\\/\",\"core\":true,\"versionStr\":\"2.2.1\"},\"116\":{\"summary\":\"jQuery Core as required by ProcessWire Admin and plugins\",\"href\":\"http:\\/\\/jquery.com\",\"core\":true,\"versionStr\":\"1.8.3\"},\"45\":{\"summary\":\"Provides a jQuery plugin for generating tabs in ProcessWire.\",\"core\":true,\"versionStr\":\"1.1.0\"},\"117\":{\"summary\":\"jQuery UI as required by ProcessWire and plugins\",\"href\":\"http:\\/\\/ui.jquery.com\",\"core\":true,\"versionStr\":\"1.9.6\"},\"151\":{\"summary\":\"Provides lightbox capability for image galleries. Replacement for FancyBox. Uses Magnific Popup by @dimsemenov.\",\"href\":\"http:\\/\\/dimsemenov.com\\/plugins\\/magnific-popup\\/\",\"core\":true,\"versionStr\":\"0.0.1\"},\"181\":{\"summary\":\"Create and\\/or restore database backups from ProcessWire admin.\",\"author\":\"Ryan Cramer\",\"versionStr\":\"0.0.6\",\"permissions\":{\"db-backup\":\"Manage database backups (recommended for superuser only)\"},\"page\":{\"name\":\"db-backups\",\"parent\":\"setup\",\"title\":\"DB Backups\"}},\"184\":{\"summary\":\"Validates and\\/or sanitizes uploaded SVG files.\",\"author\":\"Adrian and Ryan\",\"versionStr\":\"0.0.5\"},\"185\":{\"summary\":\"Fieldtype that stores a HEX color or the value transp. Color can be picked using a jQuery ColorPicker Plugin by http:\\/\\/www.eyecon.ro\\/colorpicker\\/ or from a configurable color swatch.\",\"href\":\"http:\\/\\/processwire.com\\/talk\\/topic\\/865-module-colorpicker\\/page__gopid__7340#entry7340\",\"versionStr\":\"2.0.3\"},\"186\":{\"summary\":\"Choose your colors the easy way.\",\"href\":\"http:\\/\\/processwire.com\\/talk\\/topic\\/865-module-colorpicker\\/page__gopid__7340#entry7340\",\"versionStr\":\"2.0.3\"},\"182\":{\"summary\":\"Tool that helps you identify and install core and module upgrades.\",\"author\":\"Ryan Cramer\",\"versionStr\":\"0.1.1\"},\"183\":{\"summary\":\"Automatically checks for core and installed module upgrades at routine intervals.\",\"author\":\"Ryan Cramer\",\"versionStr\":\"0.0.9\"},\"177\":{\"summary\":\"Field that stores an address with latitude and longitude coordinates and has built-in geocoding capability with Google Maps API.\",\"versionStr\":\"2.0.9\"},\"178\":{\"summary\":\"Provides input for the MapMarker Fieldtype\",\"versionStr\":\"2.0.9\"},\"180\":{\"summary\":\"Renders Google Maps for the MapMarker Fieldtype\",\"versionStr\":\"1.0.1\"},\"179\":{\"summary\":\"Same as the Text fieldtype, but enforces that values stored are unique, site-wide.\",\"href\":\"https:\\/\\/github.com\\/ryancramerdesign\\/FieldtypeTextUnique\",\"versionStr\":\"3.0.1\"}}', '2010-04-08 03:10:01');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__38fbce971a6759f735c72eaf82cf3fe0', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/modules\\/FieldtypeMapMarker\\/FieldtypeMapMarker.module\",\"hash\":\"c7bbf8b170a6522aceb828af8f9aa765\",\"size\":7833,\"time\":1474919790,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/FieldtypeMapMarker\\/FieldtypeMapMarker.module\",\"hash\":\"43b43c720b322303a15b4a981fd76d55\",\"size\":8333,\"time\":1474919790}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__5e9fc415fceca2c46895c776898ccdc3', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/modules\\/FieldtypeMapMarker\\/InputfieldMapMarker.module\",\"hash\":\"7baee363a016fa292a480b4be47ad9a3\",\"size\":10470,\"time\":1474919790,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/FieldtypeMapMarker\\/InputfieldMapMarker.module\",\"hash\":\"c3d11ba227a8b1ff482f0202d94053ca\",\"size\":10776,\"time\":1474919790}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__0ca3f1e18b19f721f85b9bb93d6f83e1', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/templates\\/admin.php\",\"hash\":\"1e0b59ea7b71052027a7c9dd37c55e85\",\"size\":479,\"time\":1630086528,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/admin.php\",\"hash\":\"1e0b59ea7b71052027a7c9dd37c55e85\",\"size\":479,\"time\":1630086528}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__b52e7dd9e6b934121fd036c07cc30c07', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/modules\\/FieldtypeMapMarker\\/MarkupGoogleMap.module\",\"hash\":\"241030f3dc29515e601755ec3655e30f\",\"size\":8140,\"time\":1474919790,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/FieldtypeMapMarker\\/MarkupGoogleMap.module\",\"hash\":\"d5652d21155c430780b365f93c859bf3\",\"size\":8428,\"time\":1474919790}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__f6391b06cfe1804dfa258daf87415015', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/modules\\/FieldtypeMapMarker\\/MapMarker.php\",\"hash\":\"69086227b4fffbe1f047199d9c174127\",\"size\":3324,\"time\":1474919790,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/FieldtypeMapMarker\\/MapMarker.php\",\"hash\":\"0b492fa8d2a75dda461ac619ab34b302\",\"size\":3363,\"time\":1474919790}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__509072507382cca0c9ba5c9266666da0', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/templates\\/home.php\",\"hash\":\"6c82b007e29d3932a88941da7ba2fbd7\",\"size\":294,\"time\":1646778337,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/home.php\",\"hash\":\"6c82b007e29d3932a88941da7ba2fbd7\",\"size\":294,\"time\":1646778337}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__cc69bdb79f54e7d14c0f9a1d78d821d6', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/templates\\/basic-page.php\",\"hash\":\"db5828c7dd5a5123c7963c0fb016f7a7\",\"size\":419,\"time\":1630086528,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/basic-page.php\",\"hash\":\"db5828c7dd5a5123c7963c0fb016f7a7\",\"size\":419,\"time\":1630086528}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__dd349205e266422635e6abf7317652d1', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/templates\\/_init.php\",\"hash\":\"6e08251a5aa91e6cd431c8dec8eea0f8\",\"size\":187,\"time\":1646844039,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/_init.php\",\"hash\":\"6e08251a5aa91e6cd431c8dec8eea0f8\",\"size\":187,\"time\":1646844039}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__01b21d28576b9461e3a43cf1e6fb0e86', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/templates\\/_main.php\",\"hash\":\"850fc77ba95c925e06efe8865d7f267d\",\"size\":161,\"time\":1649323796,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/_main.php\",\"hash\":\"850fc77ba95c925e06efe8865d7f267d\",\"size\":161,\"time\":1649323796}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__8d56a6688d3f912ccc25eb68f5167dc0', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/templates\\/portada.php\",\"hash\":\"bab89f91387f957a98cadf5ec0a0397f\",\"size\":799,\"time\":1649405929,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/portada.php\",\"hash\":\"bab89f91387f957a98cadf5ec0a0397f\",\"size\":799,\"time\":1649405929}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__11677518f995d293ffa5e61a25ba396b', '{\"source\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/templates\\/admin.php\",\"hash\":\"1e0b59ea7b71052027a7c9dd37c55e85\",\"size\":479,\"time\":1630086528,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/admin.php\",\"hash\":\"1e0b59ea7b71052027a7c9dd37c55e85\",\"size\":479,\"time\":1630086528}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__f18169fdb4d841d1ac22749a1bc8468a', '{\"source\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/templates\\/_init.php\",\"hash\":\"6e08251a5aa91e6cd431c8dec8eea0f8\",\"size\":187,\"time\":1646844039,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/_init.php\",\"hash\":\"6e08251a5aa91e6cd431c8dec8eea0f8\",\"size\":187,\"time\":1646844039}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__ba1d039d660d27880189f16b951a3577', '{\"source\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/templates\\/_main.php\",\"hash\":\"ae45e31494da3644650726f6cf2147a8\",\"size\":452,\"time\":1646862374,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/_main.php\",\"hash\":\"ae45e31494da3644650726f6cf2147a8\",\"size\":452,\"time\":1646862374}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__9ab725762947eb79163507a131886f8a', '{\"source\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/templates\\/portada.php\",\"hash\":\"06fe938f0c465999ce1673e6ddd6d609\",\"size\":412,\"time\":1646861914,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/portada.php\",\"hash\":\"06fe938f0c465999ce1673e6ddd6d609\",\"size\":412,\"time\":1646861914}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__a83047b501c77208bb8c71364880012b', '{\"source\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/templates\\/basic-page.php\",\"hash\":\"db5828c7dd5a5123c7963c0fb016f7a7\",\"size\":419,\"time\":1630086528,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/basic-page.php\",\"hash\":\"db5828c7dd5a5123c7963c0fb016f7a7\",\"size\":419,\"time\":1630086528}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__b27fe00c652cc80946675ffb6f28b651', '{\"source\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/modules\\/FieldtypeMapMarker\\/FieldtypeMapMarker.module\",\"hash\":\"c7bbf8b170a6522aceb828af8f9aa765\",\"size\":7833,\"time\":1474919790,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/FieldtypeMapMarker\\/FieldtypeMapMarker.module\",\"hash\":\"43b43c720b322303a15b4a981fd76d55\",\"size\":8333,\"time\":1474919790}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__e5abc812dac65fa7c39cb8aaa758c0e1', '{\"source\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/modules\\/FieldtypeMapMarker\\/MapMarker.php\",\"hash\":\"69086227b4fffbe1f047199d9c174127\",\"size\":3324,\"time\":1474919790,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/FieldtypeMapMarker\\/MapMarker.php\",\"hash\":\"0b492fa8d2a75dda461ac619ab34b302\",\"size\":3363,\"time\":1474919790}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__82428355061bed6c604421423acf8da4', '{\"source\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/modules\\/FieldtypeMapMarker\\/InputfieldMapMarker.module\",\"hash\":\"7baee363a016fa292a480b4be47ad9a3\",\"size\":10470,\"time\":1474919790,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/FieldtypeMapMarker\\/InputfieldMapMarker.module\",\"hash\":\"c3d11ba227a8b1ff482f0202d94053ca\",\"size\":10776,\"time\":1474919790}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__b16fecc6db9e97d4763c10af5f291771', '{\"source\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/modules\\/FieldtypeMapMarker\\/MarkupGoogleMap.module\",\"hash\":\"241030f3dc29515e601755ec3655e30f\",\"size\":8140,\"time\":1474919790,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/FieldtypeMapMarker\\/MarkupGoogleMap.module\",\"hash\":\"d5652d21155c430780b365f93c859bf3\",\"size\":8428,\"time\":1474919790}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__80b09c3832bd7176c3470fff4a6f3462', '{\"source\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/templates\\/pagina.php\",\"hash\":\"7cb0178a23531c7c0125043885d3c7f6\",\"size\":262,\"time\":1647250440,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/pagina.php\",\"hash\":\"7cb0178a23531c7c0125043885d3c7f6\",\"size\":262,\"time\":1647250440}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__558cda2f5b1928f1707b0f24dabf8aa1', '{\"source\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/templates\\/blog.php\",\"hash\":\"3fa9c6d6b1d3bc42bed7c01cabc1d9e4\",\"size\":252,\"time\":1647251514,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/blog.php\",\"hash\":\"3fa9c6d6b1d3bc42bed7c01cabc1d9e4\",\"size\":252,\"time\":1647251514}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__9448c470f7a821b399acc95b54f7d2d2', '{\"source\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/templates\\/contacto.php\",\"hash\":\"d71cebf5b0324f0acad1a563521101d0\",\"size\":669,\"time\":1647252162,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/home\\/aldara\\/www\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/contacto.php\",\"hash\":\"d71cebf5b0324f0acad1a563521101d0\",\"size\":669,\"time\":1647252162}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__aac8b37ac61318bf5778b2fb3073de30', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/templates\\/blog.php\",\"hash\":\"3fa9c6d6b1d3bc42bed7c01cabc1d9e4\",\"size\":252,\"time\":1647251514,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/blog.php\",\"hash\":\"3fa9c6d6b1d3bc42bed7c01cabc1d9e4\",\"size\":252,\"time\":1647251514}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__8bc846c585f0a304fd42fd16f7fd718e', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/templates\\/contacto.php\",\"hash\":\"d71cebf5b0324f0acad1a563521101d0\",\"size\":669,\"time\":1647252162,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/contacto.php\",\"hash\":\"d71cebf5b0324f0acad1a563521101d0\",\"size\":669,\"time\":1647252162}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__38b71a8b84c12b52cc51bcfa61debbe3', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/modules\\/ColorPicker\\/FieldtypeColorPicker.module\",\"hash\":\"a5662dad93c52208b2bb67ee927704a9\",\"size\":4310,\"time\":1535639495,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/ColorPicker\\/FieldtypeColorPicker.module\",\"hash\":\"075fa213e401de3a823507bd005ec87f\",\"size\":4479,\"time\":1535639495}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__877b2a23fdb4c05d7a2f8a9ebcee9c83', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/modules\\/ColorPicker\\/InputfieldColorPicker.module\",\"hash\":\"61be546def986999e0fdff5833779d84\",\"size\":3009,\"time\":1535639495,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/ColorPicker\\/InputfieldColorPicker.module\",\"hash\":\"e164f2881909deb7457cf4eef67a4701\",\"size\":3022,\"time\":1535639495}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__636d0b2ee6748aaf54ee480d3398c6a9', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/templates\\/pagina.php\",\"hash\":\"8546088aebad358a5190861901cde9f4\",\"size\":991,\"time\":1651496402,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/pagina.php\",\"hash\":\"8546088aebad358a5190861901cde9f4\",\"size\":991,\"time\":1651496402}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__4bf0848de9ce93203793b796e796816f', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/modules\\/FieldtypeMapMarker\\/MarkupGoogleMap.module\",\"hash\":\"241030f3dc29515e601755ec3655e30f\",\"size\":8140,\"time\":1474919790,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/FieldtypeMapMarker\\/MarkupGoogleMap.module\",\"hash\":\"d5652d21155c430780b365f93c859bf3\",\"size\":8428,\"time\":1474919790}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__147d4beb662b3cf37b7909cce6eef7bc', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/templates\\/habitacones.php\",\"hash\":\"8546088aebad358a5190861901cde9f4\",\"size\":991,\"time\":1651496402,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/habitacones.php\",\"hash\":\"8546088aebad358a5190861901cde9f4\",\"size\":991,\"time\":1651496402}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__bbcfb7cbe934543965f895f0d919ae83', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/templates\\/habitaciones.php\",\"hash\":\"b80c45ccc5f28265dee27f19cfb9cd06\",\"size\":1344,\"time\":1651505759,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/habitaciones.php\",\"hash\":\"b80c45ccc5f28265dee27f19cfb9cd06\",\"size\":1344,\"time\":1651505759}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__7704be919e5cc969093d55f8a6c91446', '{\"source\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/templates\\/habitacion.php\",\"hash\":\"8546088aebad358a5190861901cde9f4\",\"size\":991,\"time\":1651496402,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/php.artabro\\/praiadeseselle\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/habitacion.php\",\"hash\":\"8546088aebad358a5190861901cde9f4\",\"size\":991,\"time\":1651496402}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__f91cbc5029a9f5205c746a200325b567', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/modules\\/ColorPicker\\/FieldtypeColorPicker.module\",\"hash\":\"a5662dad93c52208b2bb67ee927704a9\",\"size\":4310,\"time\":1535639495,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/ColorPicker\\/FieldtypeColorPicker.module\",\"hash\":\"075fa213e401de3a823507bd005ec87f\",\"size\":4479,\"time\":1535639495}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__cf7f9da8f28b00881f76a3f8910e8110', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/modules\\/FieldtypeMapMarker\\/FieldtypeMapMarker.module\",\"hash\":\"c7bbf8b170a6522aceb828af8f9aa765\",\"size\":7833,\"time\":1474919790,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/FieldtypeMapMarker\\/FieldtypeMapMarker.module\",\"hash\":\"43b43c720b322303a15b4a981fd76d55\",\"size\":8333,\"time\":1474919790}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__491b2b8b87411234219f3d961bd83ba6', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/modules\\/FieldtypeMapMarker\\/MapMarker.php\",\"hash\":\"69086227b4fffbe1f047199d9c174127\",\"size\":3324,\"time\":1474919790,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/FieldtypeMapMarker\\/MapMarker.php\",\"hash\":\"0b492fa8d2a75dda461ac619ab34b302\",\"size\":3363,\"time\":1474919790}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__1f3b1961041b8cdbe348f1ca485bd32b', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/_init.php\",\"hash\":\"b4d2e98bddb16547e9c9e70ff0e7437a\",\"size\":219,\"time\":1669029782,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/_init.php\",\"hash\":\"b4d2e98bddb16547e9c9e70ff0e7437a\",\"size\":219,\"time\":1669029782}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__c73270b0c558bd8ba3cbb4b4fb8873a1', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/_main.php\",\"hash\":\"850fc77ba95c925e06efe8865d7f267d\",\"size\":161,\"time\":1665047406,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/_main.php\",\"hash\":\"850fc77ba95c925e06efe8865d7f267d\",\"size\":161,\"time\":1665047406}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__8b6c3104a9d3e8563d0ac551b8881d08', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/portada.php\",\"hash\":\"f4c7c0bc3dafbc1a1e22921af46383a2\",\"size\":670,\"time\":1665053249,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/portada.php\",\"hash\":\"f4c7c0bc3dafbc1a1e22921af46383a2\",\"size\":670,\"time\":1665053249}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__608c7a0b6aa7c25d9d5b60f43d8c93b1', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/admin.php\",\"hash\":\"1e0b59ea7b71052027a7c9dd37c55e85\",\"size\":479,\"time\":1630086528,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/admin.php\",\"hash\":\"1e0b59ea7b71052027a7c9dd37c55e85\",\"size\":479,\"time\":1630086528}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__1f94f666c920d3a41fa27472f0b9fee1', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/modules\\/ColorPicker\\/InputfieldColorPicker.module\",\"hash\":\"61be546def986999e0fdff5833779d84\",\"size\":3009,\"time\":1535639495,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/ColorPicker\\/InputfieldColorPicker.module\",\"hash\":\"e164f2881909deb7457cf4eef67a4701\",\"size\":3022,\"time\":1535639495}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__ded8f599a190d760bb08ae7be8cff298', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/habitacions.php\",\"hash\":\"d48ca3ff38dd77b0c7be349ce8e5c866\",\"size\":978,\"time\":1676733294,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/habitacions.php\",\"hash\":\"d48ca3ff38dd77b0c7be349ce8e5c866\",\"size\":978,\"time\":1676733294}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__cbacf185d9c8d6349987991bdac7a798', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/contacto.php\",\"hash\":\"ba9d92c3ea25abec5bd27f30897bcab0\",\"size\":964,\"time\":1666869456,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/contacto.php\",\"hash\":\"ba9d92c3ea25abec5bd27f30897bcab0\",\"size\":964,\"time\":1666869456}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__4132ba091036ad770967784e60b50b66', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/paxina.php\",\"hash\":\"c1eaa633680e3a1384fdb0118eb21516\",\"size\":676,\"time\":1676708744,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/paxina.php\",\"hash\":\"c1eaa633680e3a1384fdb0118eb21516\",\"size\":676,\"time\":1676708744}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__c411e904f2b404cfb8cd245c70bff1aa', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/blogue.php\",\"hash\":\"cf6c711aa840d03f37dd264c0c9c81bd\",\"size\":1367,\"time\":1676708744,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/blogue.php\",\"hash\":\"cf6c711aa840d03f37dd264c0c9c81bd\",\"size\":1367,\"time\":1676708744}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__6aabed82c0e18bb090833295c4a2076f', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/modules\\/FieldtypeMapMarker\\/InputfieldMapMarker.module\",\"hash\":\"7baee363a016fa292a480b4be47ad9a3\",\"size\":10470,\"time\":1474919790,\"ns\":\"\\\\\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/modules\\/FieldtypeMapMarker\\/InputfieldMapMarker.module\",\"hash\":\"c3d11ba227a8b1ff482f0202d94053ca\",\"size\":10776,\"time\":1474919790}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__e1f56f6f2ffd5e319520a6d46de724a7', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/_xes-main.php\",\"hash\":\"3fe40dbe444914507320062e0c8097ff\",\"size\":150,\"time\":1665052760,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/_xes-main.php\",\"hash\":\"3fe40dbe444914507320062e0c8097ff\",\"size\":150,\"time\":1665052760}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__851711b4eee93a6a0fe40ecc7dd125c5', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/xestion.php\",\"hash\":\"3df97be5919fa0e7b14c74c3e22073e4\",\"size\":304,\"time\":1665052280,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/xestion.php\",\"hash\":\"3df97be5919fa0e7b14c74c3e22073e4\",\"size\":304,\"time\":1665052280}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__6f9d2b3a4dd0ef7814ac4ae16cb34ee5', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/xes-acceder.php\",\"hash\":\"7e2e4c404f98368c95b14b3709bb53b8\",\"size\":5382,\"time\":1666556712,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/xes-acceder.php\",\"hash\":\"7e2e4c404f98368c95b14b3709bb53b8\",\"size\":5382,\"time\":1666556712}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('Modules.info', '{\"125\":{\"name\":\"SessionLoginThrottle\",\"title\":\"Session Login Throttle\",\"version\":103,\"autoload\":\"function\",\"singular\":true,\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\"},\"192\":{\"name\":\"PageFrontEdit\",\"title\":\"Front-End Page Editor\",\"version\":3,\"icon\":\"cube\",\"autoload\":true,\"created\":1669033360,\"configurable\":\"PageFrontEditConfig.php\",\"namespace\":\"ProcessWire\\\\\",\"license\":\"MPL 2.0\"},\"115\":{\"name\":\"PageRender\",\"title\":\"Page Render\",\"version\":105,\"autoload\":true,\"singular\":true,\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"3\":{\"name\":\"FieldtypeText\",\"title\":\"Text\",\"version\":102,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"106\":{\"name\":\"FieldtypeFieldsetClose\",\"title\":\"Fieldset (Close)\",\"version\":100,\"singular\":true,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"105\":{\"name\":\"FieldtypeFieldsetOpen\",\"title\":\"Fieldset (Open)\",\"version\":101,\"singular\":true,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"133\":{\"name\":\"FieldtypePassword\",\"title\":\"Password\",\"version\":101,\"singular\":true,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"89\":{\"name\":\"FieldtypeFloat\",\"title\":\"Float\",\"version\":107,\"singular\":true,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"97\":{\"name\":\"FieldtypeCheckbox\",\"title\":\"Checkbox\",\"version\":101,\"singular\":true,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"6\":{\"name\":\"FieldtypeFile\",\"title\":\"Files\",\"version\":107,\"created\":1646741672,\"configurable\":4,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"174\":{\"name\":\"InputfieldRepeater\",\"title\":\"Repeater\",\"version\":111,\"requiresVersions\":{\"FieldtypeRepeater\":[\">=\",0]},\"created\":1646743304,\"namespace\":\"ProcessWire\\\\\"},\"173\":{\"name\":\"FieldtypeRepeater\",\"title\":\"Repeater\",\"version\":112,\"installs\":[\"InputfieldRepeater\"],\"autoload\":true,\"singular\":true,\"created\":1646743304,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\"},\"135\":{\"name\":\"FieldtypeURL\",\"title\":\"URL\",\"version\":101,\"singular\":true,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"189\":{\"name\":\"FieldtypeComments\",\"title\":\"Comments\",\"version\":109,\"installs\":[\"InputfieldCommentsAdmin\"],\"singular\":true,\"created\":1666692895,\"namespace\":\"ProcessWire\\\\\"},\"191\":{\"name\":\"CommentFilterAkismet\",\"title\":\"Comment Filter: Akismet\",\"version\":200,\"requiresVersions\":{\"FieldtypeComments\":[\">=\",0]},\"created\":1666692906,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\"},\"190\":{\"name\":\"InputfieldCommentsAdmin\",\"title\":\"Comments Admin\",\"version\":104,\"requiresVersions\":{\"FieldtypeComments\":[\">=\",0]},\"created\":1666692895,\"namespace\":\"ProcessWire\\\\\"},\"84\":{\"name\":\"FieldtypeInteger\",\"title\":\"Integer\",\"version\":102,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"57\":{\"name\":\"FieldtypeImage\",\"title\":\"Images\",\"version\":102,\"created\":1646741672,\"configurable\":4,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"172\":{\"name\":\"FieldtypeOptions\",\"title\":\"Select Options\",\"version\":2,\"singular\":true,\"created\":1646743276,\"namespace\":\"ProcessWire\\\\\"},\"4\":{\"name\":\"FieldtypePage\",\"title\":\"Page Reference\",\"version\":106,\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"107\":{\"name\":\"FieldtypeFieldsetTabOpen\",\"title\":\"Fieldset in Tab (Open)\",\"version\":100,\"singular\":true,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"27\":{\"name\":\"FieldtypeModule\",\"title\":\"Module Reference\",\"version\":102,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"111\":{\"name\":\"FieldtypePageTitle\",\"title\":\"Page Title\",\"version\":100,\"singular\":true,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"29\":{\"name\":\"FieldtypeEmail\",\"title\":\"E-Mail\",\"version\":101,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\"},\"1\":{\"name\":\"FieldtypeTextarea\",\"title\":\"Textarea\",\"version\":107,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"28\":{\"name\":\"FieldtypeDatetime\",\"title\":\"Datetime\",\"version\":105,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\"},\"165\":{\"name\":\"ProcessLanguageTranslator\",\"title\":\"Language Translator\",\"version\":102,\"requiresVersions\":{\"LanguageSupport\":[\">=\",0]},\"permission\":\"lang-edit\",\"singular\":1,\"created\":1646742978,\"namespace\":\"ProcessWire\\\\\"},\"170\":{\"name\":\"FieldtypeTextareaLanguage\",\"title\":\"Textarea (Multi-language)\",\"version\":100,\"requiresVersions\":{\"LanguageSupportFields\":[\">=\",0]},\"singular\":true,\"created\":1646743011,\"namespace\":\"ProcessWire\\\\\"},\"163\":{\"name\":\"LanguageSupport\",\"title\":\"Languages Support\",\"version\":103,\"installs\":[\"ProcessLanguage\",\"ProcessLanguageTranslator\"],\"autoload\":true,\"singular\":true,\"created\":1646742977,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"addFlag\":32},\"167\":{\"name\":\"LanguageSupportFields\",\"title\":\"Languages Support - Fields\",\"version\":101,\"requiresVersions\":{\"LanguageSupport\":[\">=\",0]},\"installs\":[\"FieldtypePageTitleLanguage\",\"FieldtypeTextareaLanguage\",\"FieldtypeTextLanguage\"],\"autoload\":true,\"singular\":true,\"created\":1646743011,\"namespace\":\"ProcessWire\\\\\"},\"166\":{\"name\":\"LanguageTabs\",\"title\":\"Languages Support - Tabs\",\"version\":115,\"requiresVersions\":{\"LanguageSupport\":[\">=\",0]},\"autoload\":\"template=admin\",\"singular\":true,\"created\":1646743008,\"configurable\":4,\"namespace\":\"ProcessWire\\\\\"},\"169\":{\"name\":\"FieldtypePageTitleLanguage\",\"title\":\"Page Title (Multi-Language)\",\"version\":100,\"requiresVersions\":{\"LanguageSupportFields\":[\">=\",0],\"FieldtypeTextLanguage\":[\">=\",0]},\"singular\":true,\"created\":1646743011,\"namespace\":\"ProcessWire\\\\\"},\"164\":{\"name\":\"ProcessLanguage\",\"title\":\"Languages\",\"version\":103,\"icon\":\"language\",\"requiresVersions\":{\"LanguageSupport\":[\">=\",0]},\"permission\":\"lang-edit\",\"singular\":1,\"created\":1646742977,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"useNavJSON\":true},\"171\":{\"name\":\"LanguageSupportPageNames\",\"title\":\"Languages Support - Page Names\",\"version\":13,\"requiresVersions\":{\"LanguageSupport\":[\">=\",0],\"LanguageSupportFields\":[\">=\",0]},\"autoload\":true,\"singular\":true,\"created\":1646743022,\"configurable\":4,\"namespace\":\"ProcessWire\\\\\"},\"168\":{\"name\":\"FieldtypeTextLanguage\",\"title\":\"Text (Multi-language)\",\"version\":100,\"requiresVersions\":{\"LanguageSupportFields\":[\">=\",0]},\"singular\":true,\"created\":1646743011,\"namespace\":\"ProcessWire\\\\\"},\"55\":{\"name\":\"InputfieldFile\",\"title\":\"Files\",\"version\":126,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"86\":{\"name\":\"InputfieldPageName\",\"title\":\"Page Name\",\"version\":106,\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"79\":{\"name\":\"InputfieldMarkup\",\"title\":\"Markup\",\"version\":102,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"39\":{\"name\":\"InputfieldRadios\",\"title\":\"Radio Buttons\",\"version\":106,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"155\":{\"name\":\"InputfieldCKEditor\",\"title\":\"CKEditor\",\"version\":170,\"installs\":[\"MarkupHTMLPurifier\"],\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\"},\"40\":{\"name\":\"InputfieldHidden\",\"title\":\"Hidden\",\"version\":101,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"30\":{\"name\":\"InputfieldForm\",\"title\":\"Form\",\"version\":107,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"15\":{\"name\":\"InputfieldPageListSelect\",\"title\":\"Page List Select\",\"version\":101,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"137\":{\"name\":\"InputfieldPageListSelectMultiple\",\"title\":\"Page List Select Multiple\",\"version\":103,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"80\":{\"name\":\"InputfieldEmail\",\"title\":\"Email\",\"version\":101,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\"},\"108\":{\"name\":\"InputfieldURL\",\"title\":\"URL\",\"version\":103,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\"},\"35\":{\"name\":\"InputfieldTextarea\",\"title\":\"Textarea\",\"version\":103,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"36\":{\"name\":\"InputfieldSelect\",\"title\":\"Select\",\"version\":102,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"60\":{\"name\":\"InputfieldPage\",\"title\":\"Page\",\"version\":108,\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"175\":{\"name\":\"InputfieldTextTags\",\"title\":\"Text Tags\",\"version\":5,\"icon\":\"tags\",\"created\":1646743465,\"namespace\":\"ProcessWire\\\\\"},\"162\":{\"name\":\"InputfieldIcon\",\"title\":\"Icon\",\"version\":3,\"created\":1646741753,\"namespace\":\"ProcessWire\\\\\"},\"41\":{\"name\":\"InputfieldName\",\"title\":\"Name\",\"version\":100,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"187\":{\"name\":\"InputfieldPageAutocomplete\",\"title\":\"Page Auto Complete\",\"version\":112,\"created\":1651499990,\"namespace\":\"ProcessWire\\\\\"},\"25\":{\"name\":\"InputfieldAsmSelect\",\"title\":\"asmSelect\",\"version\":203,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"78\":{\"name\":\"InputfieldFieldset\",\"title\":\"Fieldset\",\"version\":101,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"112\":{\"name\":\"InputfieldPageTitle\",\"title\":\"Page Title\",\"version\":102,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"43\":{\"name\":\"InputfieldSelectMultiple\",\"title\":\"Select Multiple\",\"version\":101,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"149\":{\"name\":\"InputfieldSelector\",\"title\":\"Selector\",\"version\":28,\"autoload\":\"template=admin\",\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"addFlag\":32},\"131\":{\"name\":\"InputfieldButton\",\"title\":\"Button\",\"version\":100,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"176\":{\"name\":\"InputfieldToggle\",\"title\":\"Toggle\",\"version\":1,\"created\":1646743484,\"namespace\":\"ProcessWire\\\\\"},\"56\":{\"name\":\"InputfieldImage\",\"title\":\"Images\",\"version\":124,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"37\":{\"name\":\"InputfieldCheckbox\",\"title\":\"Checkbox\",\"version\":106,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"34\":{\"name\":\"InputfieldText\",\"title\":\"Text\",\"version\":106,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"94\":{\"name\":\"InputfieldDatetime\",\"title\":\"Datetime\",\"version\":107,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"38\":{\"name\":\"InputfieldCheckboxes\",\"title\":\"Checkboxes\",\"version\":108,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"85\":{\"name\":\"InputfieldInteger\",\"title\":\"Integer\",\"version\":105,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"122\":{\"name\":\"InputfieldPassword\",\"title\":\"Password\",\"version\":102,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"32\":{\"name\":\"InputfieldSubmit\",\"title\":\"Submit\",\"version\":103,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"90\":{\"name\":\"InputfieldFloat\",\"title\":\"Float\",\"version\":105,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"114\":{\"name\":\"PagePermissions\",\"title\":\"Page Permissions\",\"version\":105,\"autoload\":true,\"singular\":true,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"76\":{\"name\":\"ProcessList\",\"title\":\"List\",\"version\":101,\"permission\":\"page-view\",\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"12\":{\"name\":\"ProcessPageList\",\"title\":\"Page List\",\"version\":124,\"icon\":\"sitemap\",\"permission\":\"page-edit\",\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true,\"useNavJSON\":true},\"161\":{\"name\":\"ProcessLogger\",\"title\":\"Logs\",\"version\":2,\"icon\":\"tree\",\"permission\":\"logs-view\",\"singular\":1,\"created\":1646741753,\"namespace\":\"ProcessWire\\\\\",\"useNavJSON\":true},\"150\":{\"name\":\"ProcessPageLister\",\"title\":\"Lister\",\"version\":26,\"icon\":\"search\",\"permission\":\"page-lister\",\"created\":1646741672,\"configurable\":true,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true,\"useNavJSON\":true,\"addFlag\":32},\"109\":{\"name\":\"ProcessPageTrash\",\"title\":\"Page Trash\",\"version\":103,\"singular\":1,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"129\":{\"name\":\"ProcessPageEditImageSelect\",\"title\":\"Page Edit Image\",\"version\":120,\"permission\":\"page-edit\",\"singular\":1,\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"50\":{\"name\":\"ProcessModule\",\"title\":\"Modules\",\"version\":120,\"permission\":\"module-admin\",\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true,\"useNavJSON\":true,\"nav\":[{\"url\":\"?site#tab_site_modules\",\"label\":\"Site\",\"icon\":\"plug\",\"navJSON\":\"navJSON\\/?site=1\"},{\"url\":\"?core#tab_core_modules\",\"label\":\"Core\",\"icon\":\"plug\",\"navJSON\":\"navJSON\\/?core=1\"},{\"url\":\"?configurable#tab_configurable_modules\",\"label\":\"Configure\",\"icon\":\"gear\",\"navJSON\":\"navJSON\\/?configurable=1\"},{\"url\":\"?install#tab_install_modules\",\"label\":\"Install\",\"icon\":\"sign-in\",\"navJSON\":\"navJSON\\/?install=1\"},{\"url\":\"?new#tab_new_modules\",\"label\":\"New\",\"icon\":\"plus\"},{\"url\":\"?reset=1\",\"label\":\"Refresh\",\"icon\":\"refresh\"}]},\"83\":{\"name\":\"ProcessPageView\",\"title\":\"Page View\",\"version\":106,\"permission\":\"page-view\",\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"10\":{\"name\":\"ProcessLogin\",\"title\":\"Login\",\"version\":108,\"permission\":\"page-view\",\"created\":1646741672,\"configurable\":4,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"7\":{\"name\":\"ProcessPageEdit\",\"title\":\"Page Edit\",\"version\":111,\"icon\":\"edit\",\"permission\":\"page-edit\",\"singular\":1,\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true,\"useNavJSON\":true},\"104\":{\"name\":\"ProcessPageSearch\",\"title\":\"Page Search\",\"version\":107,\"permission\":\"page-edit\",\"singular\":1,\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"159\":{\"name\":\"ProcessRecentPages\",\"title\":\"Recent Pages\",\"version\":2,\"icon\":\"clock-o\",\"permission\":\"page-edit-recent\",\"singular\":1,\"created\":1646741720,\"namespace\":\"ProcessWire\\\\\",\"useNavJSON\":true,\"nav\":[{\"url\":\"?edited=1\",\"label\":\"Edited\",\"icon\":\"users\",\"navJSON\":\"navJSON\\/?edited=1\"},{\"url\":\"?added=1\",\"label\":\"Created\",\"icon\":\"users\",\"navJSON\":\"navJSON\\/?added=1\"},{\"url\":\"?edited=1&me=1\",\"label\":\"Edited by me\",\"icon\":\"user\",\"navJSON\":\"navJSON\\/?edited=1&me=1\"},{\"url\":\"?added=1&me=1\",\"label\":\"Created by me\",\"icon\":\"user\",\"navJSON\":\"navJSON\\/?added=1&me=1\"},{\"url\":\"another\\/\",\"label\":\"Add another\",\"icon\":\"plus-circle\",\"navJSON\":\"anotherNavJSON\\/\"}]},\"17\":{\"name\":\"ProcessPageAdd\",\"title\":\"Page Add\",\"version\":109,\"icon\":\"plus-circle\",\"permission\":\"page-edit\",\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true,\"useNavJSON\":true},\"121\":{\"name\":\"ProcessPageEditLink\",\"title\":\"Page Edit Link\",\"version\":109,\"icon\":\"link\",\"permission\":\"page-edit\",\"singular\":1,\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"138\":{\"name\":\"ProcessProfile\",\"title\":\"User Profile\",\"version\":105,\"permission\":\"profile-edit\",\"singular\":1,\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"66\":{\"name\":\"ProcessUser\",\"title\":\"Users\",\"version\":107,\"icon\":\"group\",\"permission\":\"user-admin\",\"created\":1646741672,\"configurable\":\"ProcessUserConfig.php\",\"namespace\":\"ProcessWire\\\\\",\"permanent\":true,\"useNavJSON\":true},\"48\":{\"name\":\"ProcessField\",\"title\":\"Fields\",\"version\":113,\"icon\":\"cube\",\"permission\":\"field-admin\",\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true,\"useNavJSON\":true,\"addFlag\":32},\"47\":{\"name\":\"ProcessTemplate\",\"title\":\"Templates\",\"version\":114,\"icon\":\"cubes\",\"permission\":\"template-admin\",\"created\":1646741672,\"configurable\":4,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true,\"useNavJSON\":true},\"134\":{\"name\":\"ProcessPageType\",\"title\":\"Page Type\",\"version\":101,\"singular\":1,\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true,\"useNavJSON\":true,\"addFlag\":32},\"136\":{\"name\":\"ProcessPermission\",\"title\":\"Permissions\",\"version\":101,\"icon\":\"gear\",\"permission\":\"permission-admin\",\"singular\":1,\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true,\"useNavJSON\":true},\"68\":{\"name\":\"ProcessRole\",\"title\":\"Roles\",\"version\":104,\"icon\":\"gears\",\"permission\":\"role-admin\",\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true,\"useNavJSON\":true},\"87\":{\"name\":\"ProcessHome\",\"title\":\"Admin Home\",\"version\":101,\"permission\":\"page-view\",\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"14\":{\"name\":\"ProcessPageSort\",\"title\":\"Page Sort and Move\",\"version\":100,\"permission\":\"page-edit\",\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"160\":{\"name\":\"AdminThemeUikit\",\"title\":\"Uikit\",\"version\":33,\"autoload\":\"template=admin\",\"created\":1646741720,\"configurable\":4,\"namespace\":\"ProcessWire\\\\\"},\"148\":{\"name\":\"AdminThemeDefault\",\"title\":\"Default\",\"version\":14,\"autoload\":\"template=admin\",\"created\":1646741672,\"configurable\":19,\"namespace\":\"ProcessWire\\\\\"},\"61\":{\"name\":\"TextformatterEntities\",\"title\":\"HTML Entity Encoder (htmlspecialchars)\",\"version\":100,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\"},\"139\":{\"name\":\"SystemUpdater\",\"title\":\"System Updater\",\"version\":20,\"singular\":true,\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"113\":{\"name\":\"MarkupPageArray\",\"title\":\"PageArray Markup\",\"version\":100,\"autoload\":true,\"singular\":true,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\"},\"156\":{\"name\":\"MarkupHTMLPurifier\",\"title\":\"HTML Purifier\",\"version\":496,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\"},\"98\":{\"name\":\"MarkupPagerNav\",\"title\":\"Pager (Pagination) Navigation\",\"version\":105,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\"},\"67\":{\"name\":\"MarkupAdminDataTable\",\"title\":\"Admin Data Table\",\"version\":107,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"103\":{\"name\":\"JqueryTableSorter\",\"title\":\"jQuery Table Sorter Plugin\",\"version\":221,\"singular\":1,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\"},\"116\":{\"name\":\"JqueryCore\",\"title\":\"jQuery Core\",\"version\":183,\"singular\":true,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"45\":{\"name\":\"JqueryWireTabs\",\"title\":\"jQuery Wire Tabs Plugin\",\"version\":110,\"created\":1646741672,\"configurable\":3,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"117\":{\"name\":\"JqueryUI\",\"title\":\"jQuery UI\",\"version\":196,\"singular\":true,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\",\"permanent\":true},\"151\":{\"name\":\"JqueryMagnific\",\"title\":\"jQuery Magnific Popup\",\"version\":1,\"singular\":1,\"created\":1646741672,\"namespace\":\"ProcessWire\\\\\"},\"181\":{\"name\":\"ProcessDatabaseBackups\",\"title\":\"Database Backups\",\"version\":6,\"icon\":\"database\",\"requiresVersions\":{\"ProcessWire\":[\">=\",\"3.0.62\"]},\"permission\":\"db-backup\",\"singular\":1,\"created\":1646743936,\"nav\":[{\"url\":\".\\/\",\"label\":\"View\",\"icon\":\"list\"},{\"url\":\"backup\\/\",\"label\":\"Backup\",\"icon\":\"plus-circle\"},{\"url\":\"upload\\/\",\"label\":\"Upload\",\"icon\":\"cloud-upload\"}]},\"184\":{\"name\":\"FileValidatorSvgSanitizer\",\"title\":\"SVG File Sanitizer\\/Validator\",\"version\":5,\"requiresVersions\":{\"ProcessWire\":[\">=\",\"3.0.148\"]},\"created\":1649149616,\"configurable\":\"FileValidatorSvgSanitizer.config.php\",\"validates\":[\"svg\"]},\"185\":{\"name\":\"FieldtypeColorPicker\",\"title\":\"ColorPicker\",\"version\":203,\"installs\":[\"InputfieldColorPicker\"],\"singular\":true,\"created\":1651490354,\"namespace\":\"\\\\\"},\"186\":{\"name\":\"InputfieldColorPicker\",\"title\":\"ColorPicker\",\"version\":203,\"requiresVersions\":{\"FieldtypeColorPicker\":[\">=\",0]},\"created\":1651490354,\"namespace\":\"\\\\\"},\"182\":{\"name\":\"ProcessWireUpgrade\",\"title\":\"Upgrades\",\"version\":11,\"icon\":\"coffee\",\"requiresVersions\":{\"ProcessWire\":[\">=\",\"3.0.0\"]},\"installs\":[\"ProcessWireUpgradeCheck\"],\"singular\":1,\"created\":1646743940},\"183\":{\"name\":\"ProcessWireUpgradeCheck\",\"title\":\"Upgrades Checker\",\"version\":9,\"icon\":\"coffee\",\"requiresVersions\":{\"ProcessWireUpgrade\":[\">=\",0]},\"autoload\":\"template=admin\",\"singular\":true,\"created\":1646743940,\"configurable\":\"ProcessWireUpgradeCheck.config.php\"},\"177\":{\"name\":\"FieldtypeMapMarker\",\"title\":\"Map Marker\",\"version\":209,\"icon\":\"map-marker\",\"installs\":[\"InputfieldMapMarker\"],\"singular\":true,\"created\":1646743894,\"configurable\":true,\"namespace\":\"\\\\\"},\"178\":{\"name\":\"InputfieldMapMarker\",\"title\":\"Map Marker\",\"version\":209,\"icon\":\"map-marker\",\"requiresVersions\":{\"FieldtypeMapMarker\":[\">=\",0]},\"created\":1646743894,\"namespace\":\"\\\\\"},\"180\":{\"name\":\"MarkupGoogleMap\",\"title\":\"Map Markup (Google Maps)\",\"version\":101,\"requiresVersions\":{\"FieldtypeMapMarker\":[\">=\",0]},\"created\":1646743929,\"namespace\":\"\\\\\"},\"179\":{\"name\":\"FieldtypeTextUnique\",\"title\":\"Text Unique\",\"version\":301,\"requiresVersions\":{\"ProcessWire\":[\">=\",\"3.0.150\"]},\"singular\":true,\"created\":1646743909}}', '2010-04-08 03:10:01');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__0b187ee19201c3e2f6d4a02803c758cc', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/habitacion.php\",\"hash\":\"2d5ed65f22db663997261abc46d1ff35\",\"size\":567,\"time\":1676734043,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/habitacion.php\",\"hash\":\"2d5ed65f22db663997261abc46d1ff35\",\"size\":567,\"time\":1676734043}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('Permissions.names', '{\"db-backup\":1021,\"lang-edit\":1015,\"logs-edit\":1014,\"logs-view\":1013,\"page-delete\":34,\"page-edit\":32,\"page-edit-front\":1139,\"page-edit-recent\":1011,\"page-lister\":1006,\"page-lock\":54,\"page-move\":35,\"page-sort\":50,\"page-template\":51,\"page-view\":36,\"profile-edit\":53,\"user-admin\":52}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__337c322df3302a5702dd833ea9e4d991', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/publicacion.php\",\"hash\":\"3f6827367f809c5089bf58310e619f90\",\"size\":446,\"time\":1666869931,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/publicacion.php\",\"hash\":\"3f6827367f809c5089bf58310e619f90\",\"size\":446,\"time\":1666869931}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__58ae8395d12f4ee0b0ae44d0db51be6f', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/categoria.php\",\"hash\":\"ca043c3d36ca655ff54e42d23ed5baba\",\"size\":1059,\"time\":1666864825,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/categoria.php\",\"hash\":\"ca043c3d36ca655ff54e42d23ed5baba\",\"size\":1059,\"time\":1666864825}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__2e2889d5da4d34bb152870942d979193', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/contedor.php\",\"hash\":\"aff7fbe76b0f4ff11701759b8eeef789\",\"size\":85,\"time\":1666776127,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/contedor.php\",\"hash\":\"aff7fbe76b0f4ff11701759b8eeef789\",\"size\":85,\"time\":1666776127}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__bfbc44b964564f826218c4670294577b', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/etiqueta.php\",\"hash\":\"df5175cf180da246540995fd04ec7e6a\",\"size\":1054,\"time\":1666864845,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/etiqueta.php\",\"hash\":\"df5175cf180da246540995fd04ec7e6a\",\"size\":1054,\"time\":1666864845}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('ModulesVersions.info', '{\"165\":101,\"108\":102,\"104\":106}', '2010-04-08 03:10:01');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__35a4df95cd090859925b1128e3cf66d0', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/inicio.php\",\"hash\":\"d34343b431476ee4c11e714aa742f6c1\",\"size\":716,\"time\":1676722623,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/inicio.php\",\"hash\":\"d34343b431476ee4c11e714aa742f6c1\",\"size\":716,\"time\":1676722623}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__f35570cbd774f725b7ca8ad54decc5d5', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/layout\\/xes.php\",\"hash\":\"36dabd4bd58860c99db9bb6a84e3ea86\",\"size\":246,\"time\":1669372278,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/layout\\/xes.php\",\"hash\":\"36dabd4bd58860c99db9bb6a84e3ea86\",\"size\":246,\"time\":1669372278}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__10c6d001ffd9e83915f35d8a3e156708', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/layout\\/init.php\",\"hash\":\"a07b45b7246b4e18bb47b4898a878e56\",\"size\":620,\"time\":1676709958,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/layout\\/init.php\",\"hash\":\"a07b45b7246b4e18bb47b4898a878e56\",\"size\":620,\"time\":1676709958}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__2347999f8a54eb18c1f6bc9404f94d05', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/bootstrap-portada.php\",\"hash\":\"28958c7e537bb9a4cf9487d1d6b34aaa\",\"size\":553,\"time\":1669018758,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/bootstrap-portada.php\",\"hash\":\"28958c7e537bb9a4cf9487d1d6b34aaa\",\"size\":553,\"time\":1669018758}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__3698fe2238c458417807ef41e2ecf8d0', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/xes-inicio.php\",\"hash\":\"3df97be5919fa0e7b14c74c3e22073e4\",\"size\":304,\"time\":1669032959,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/xes-inicio.php\",\"hash\":\"3df97be5919fa0e7b14c74c3e22073e4\",\"size\":304,\"time\":1669032959}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__1e271072c1326985cfdffd6397bda4d9', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/xes-panel.php\",\"hash\":\"8d36fdb982eb2a9f6b1966ebe1ca4b7b\",\"size\":208,\"time\":1669374461,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/xes-panel.php\",\"hash\":\"8d36fdb982eb2a9f6b1966ebe1ca4b7b\",\"size\":208,\"time\":1669374461}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__19cde1791553d8c5b778a9b24f93d2fd', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/bs-inicio.php\",\"hash\":\"d3a5f31862ef47d8400767c3fa0fcce9\",\"size\":700,\"time\":1670794404,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/bs-inicio.php\",\"hash\":\"d3a5f31862ef47d8400767c3fa0fcce9\",\"size\":700,\"time\":1670794404}}', '2010-04-08 03:10:10');
+INSERT INTO `caches` (`name`, `data`, `expires`) VALUES('FileCompiler__9608cef93e7852d56d5c7ff61ad4870d', '{\"source\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/templates\\/layout\\/bootstrap.php\",\"hash\":\"6e003bdfe644330da54807e1c8c2f387\",\"size\":3229,\"time\":1670794404,\"ns\":\"ProcessWire\"},\"target\":{\"file\":\"\\/srv\\/http\\/praiadeseselle.artabro\\/site\\/assets\\/cache\\/FileCompiler\\/site\\/templates\\/layout\\/bootstrap.php\",\"hash\":\"6e003bdfe644330da54807e1c8c2f387\",\"size\":3229,\"time\":1670794404}}', '2010-04-08 03:10:10');
+
+DROP TABLE IF EXISTS `field_admin_theme`;
+CREATE TABLE `field_admin_theme` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` int(11) NOT NULL,
+ PRIMARY KEY (`pages_id`),
+ KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+
+DROP TABLE IF EXISTS `field_artigo`;
+CREATE TABLE `field_artigo` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` mediumtext NOT NULL,
+ `data1023` mediumtext DEFAULT NULL,
+ `data1024` mediumtext DEFAULT NULL,
+ PRIMARY KEY (`pages_id`),
+ KEY `data_exact` (`data`(250)),
+ FULLTEXT KEY `data` (`data`),
+ FULLTEXT KEY `data1023` (`data1023`),
+ FULLTEXT KEY `data1024` (`data1024`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1158', '
Apartamento accesible, adaptado y con acceso directo a la terraza.
\n\nUna habitación doble y dos plazas en cama convertible.
\n\nCuarto de baño accesible con plato de ducha.
\n\nCocina equipada con nevera, vitrocerámica y microondas con grill.
\n\nTodo el menage necesario para cocinar y sentirte como en tu casa.
', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1153', 'Lamentamos las molestias. Estamos trabajando para que todo este listo cuanto antes.
', 'Lamentamos as molestias. Estamos traballando para ter todo listo canto antes.
', 'Sorry for the inconvenience. We are working to get everything ready as soon as possible.
');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1080', 'Texto sin titular. Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce eget elit luctus elit ultricies ornare non eu lectus. Donec quis vehicula quam. Maecenas nulla sem, consectetur non lorem ut, egestas commodo nulla. Suspendisse eleifend orci et ornare posuere. Aenean bibendum at quam nec gravida. Nulla pulvinar enim justo, vitae tincidunt libero blandit sit amet. Proin nibh odio, consectetur ac pellentesque ut, pharetra feugiat ligula. Aliquam placerat mauris justo, a tincidunt urna convallis vitae. Integer ac massa a quam varius molestie.
', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1043', '', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1076', '', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1161', 'Apartamento amplio y luminoso.
\n\nDos habitacions dobles, más dos prazas en cama convertible.
\n\nIdeal para todo tipo de familias, pequeñas o numerosas.
\n\nEn seu amplio salón con cocina americana dispondreis de todo lo necesario para cociñar, descansar y disfrutar de una agradable estancia en grupo.
\n\nVitricerámica, frigorÃfico, forno microondas con grill y todo el menaje necesario.
', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1082', 'Donec in vulputate sapien. Vestibulum placerat enim vitae fermentum varius. Praesent tempus turpis eu luctus gravida. Etiam vitae arcu justo. Suspendisse potenti. Praesent quis mi placerat ex feugiat cursus eu vitae purus. Phasellus hendrerit tortor et enim finibus, ut fringilla orci efficitur. Pellentesque condimentum augue at lacinia vestibulum. Donec tincidunt mattis augue, sit amet sollicitudin odio euismod ac. Vivamus erat tellus, convallis id sodales ac, ultricies nec risus.
', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1084', 'Texto con imagen sin titular. Aliquam pretium, sem ut pretium rhoncus, mi mauris fringilla ligula, gravida posuere lacus dolor at magna. Maecenas vel mauris arcu. Nullam non nulla nisl. Pellentesque tincidunt lacinia blandit. Nam tristique nulla eu feugiat placerat. Mauris scelerisque ullamcorper porttitor. Donec feugiat odio eu metus posuere vehicula. In eu felis vitae justo consectetur ultricies ut eu quam. Donec nec velit sit amet tortor congue posuere. Curabitur a ornare tellus. Nulla accumsan iaculis nunc, eget blandit elit finibus vel. Quisque quis ornare lectus, nec bibendum lacus. Mauris nulla massa, facilisis nec mauris sed, lacinia pellentesque enim. Integer dignissim odio a rutrum volutpat.
', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1092', '', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1086', '', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1114', 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aliquam sed arcu et nisl pretium consequat in quis tellus. Nunc a tellus mi. Vestibulum congue faucibus ligula, vel tristique justo luctus non. Nunc commodo tristique tortor, sit amet pharetra orci rhoncus a. Nunc mollis mollis mollis. Donec egestas accumsan pharetra. Aliquam id pretium nunc. Nunc pulvinar commodo felis, eget interdum lectus vestibulum non. Sed nec lacinia libero. Nunc feugiat massa eget metus fermentum auctor. Proin feugiat ipsum non egestas imperdiet. Sed ligula nulla, luctus ut erat non, condimentum sodales sapien. Nam aliquet ante sem, consequat efficitur lorem tincidunt in. Donec purus augue, elementum sed massa et, euismod finibus mauris. Nam sit amet ultricies orci, ac aliquam enim.
', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1088', 'Nullam ac consequat sem, ultricies ultricies lectus. Nullam efficitur tortor ut sodales egestas. Curabitur quis elit vitae diam volutpat tempus. Proin aliquam sapien dolor, nec lobortis nibh ullamcorper a. Morbi efficitur massa non nulla dapibus, sit amet ullamcorper elit facilisis. In viverra vel diam quis sodales. Phasellus non magna semper, viverra dolor eget, viverra enim. Sed ac tempor orci. Ut ac iaculis purus, sed scelerisque nulla. Curabitur magna eros, pulvinar ultrices lectus sed, scelerisque eleifend lectus.
', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1090', 'Morbi sollicitudin, nunc in elementum semper, leo felis maximus risus, nec pellentesque eros lacus eget lacus. Proin euismod quam nunc, nec euismod nunc fringilla eget. Proin ac sem quis diam tristique sollicitudin. Suspendisse tincidunt commodo ex, sit amet rutrum nisl volutpat vitae. Curabitur tincidunt leo arcu, vitae malesuada lorem rhoncus et. In hendrerit mauris turpis, non euismod sapien tincidunt eu. Integer hendrerit dictum molestie. Proin vitae lobortis nunc. Duis condimentum nisl enim, eget efficitur sem efficitur quis. Donec tincidunt commodo ligula ut euismod.
', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1115', 'In vel dictum libero, ac efficitur odio. Donec quis nisi vitae nisl pellentesque bibendum id eu purus. Aliquam laoreet dolor eu ultrices semper. Cras congue a dolor a elementum. Ut tempor quam id ipsum faucibus, quis pharetra tortor finibus. Class aptent taciti sociosqu ad litora torquent per conubia nostra, per inceptos himenaeos. Cras velit nulla, fringilla a nibh eget, pharetra vulputate sem. Fusce vitae convallis neque. Ut sollicitudin, odio quis luctus feugiat, purus ipsum auctor urna, id tempor metus velit a neque. Integer bibendum nec ante nec feugiat. Suspendisse viverra augue eu risus porttitor, nec scelerisque mauris iaculis. Suspendisse potenti. Donec felis tortor, posuere sed ex sit amet, dapibus elementum lectus. Morbi neque felis, congue vel velit aliquam, rhoncus ornare est. Nulla quis porta tellus.
', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1116', '', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1119', '', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1132', '¡Esta es tu primera publicación!
\n\nCurabitur metus mauris, pharetra quis ornare id, ullamcorper quis turpis. Donec tincidunt tempor leo quis suscipit. Morbi pulvinar efficitur eleifend. Ut porttitor egestas massa ac pretium. Cras rhoncus auctor lectus laoreet varius. Nam aliquam tempus quam nec porta. Donec quis ligula blandit, consequat est non, convallis mi. Nulla imperdiet, tortor eget luctus tristique, massa lorem volutpat enim, sit amet euismod sem sem vitae mauris. In tincidunt gravida velit, pulvinar rutrum elit pellentesque tincidunt.
', '¡Esta é a túa primeira publicación!
', 'This is your first post!
');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1133', '', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1134', 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Integer bibendum, leo pellentesque vehicula sagittis, ante lorem hendrerit enim, vel faucibus ligula diam sed dui. Aliquam tincidunt dui at dolor interdum, eu lobortis enim ornare. Vivamus convallis, lectus non tincidunt maximus, magna nisl euismod sem, sed laoreet diam tellus ut libero. Fusce ac feugiat turpis. Fusce et ipsum lorem. In hac habitasse platea dictumst. Nulla bibendum posuere metus, accumsan vestibulum ipsum pellentesque blandit.
', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1135', 'Praesent blandit dignissim finibus. Fusce fermentum odio ut dapibus feugiat. Aenean imperdiet, purus vel laoreet facilisis, leo mi luctus ipsum, eu laoreet metus sapien faucibus ligula. Etiam mollis facilisis neque, eget ullamcorper diam faucibus a. Vivamus convallis mi urna, fermentum pulvinar erat ornare at. Nulla cursus eget lacus tristique porttitor. Phasellus id congue nulla. Mauris sollicitudin ex ac mi efficitur, ut bibendum nisi feugiat. Pellentesque luctus, ipsum sit amet ullamcorper dignissim, purus augue finibus neque, ut imperdiet elit neque sed magna. Donec aliquet congue elit eu tincidunt. Sed non mi hendrerit, porta diam sed, semper velit. Praesent mauris arcu, efficitur vitae erat ac, bibendum ultrices quam. Vivamus non placerat libero. Donec gravida est quis libero elementum vestibulum. Ut rhoncus aliquam mi sit amet convallis.
', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1136', 'Duis tincidunt erat et metus volutpat, eget dictum augue pulvinar. Morbi vehicula eget lacus suscipit vulputate. Ut quis arcu et nisl luctus lobortis in sit amet neque. Cras varius porttitor urna, ac ornare augue vehicula sit amet. Suspendisse varius libero id nunc consectetur, quis posuere velit tristique. Aliquam erat volutpat. Maecenas dignissim, enim vitae volutpat feugiat, sapien turpis elementum ipsum, eget dictum felis nibh ac urna. Integer eu nibh in libero commodo convallis et nec sem. Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia curae; Aliquam congue rhoncus fringilla. Phasellus viverra efficitur est, in fermentum arcu rutrum vitae. Integer vitae eros lacinia, fermentum ex quis, dictum orci. Vivamus lectus dui, convallis gravida purus ut, luctus feugiat diam.
', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1164', 'Cómodo y luminoso. \nUna habitación suit con baño más una plaza en sofá-cama. \nEl apartamento ideal para parejas o una pequeña familia.
\n\nEn su amplio salón con cocina americana dispondreis de lo necesario para cocinar y disfrutar de una relajante estancia.
\n\nEquipado con nevera, vitrocerámica y horno microondas con grill.Â
', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1168', 'Con mucho trabajo e ilusión rehabilitamos esta casa familiar para ofrecer un alojamiento cómodo y acogedor.
\n\nSe trata de unos apartamentos turÃsticos marineros y la obra se ha financiado con la colaboración del GALP Golfo Artabro Norte, Xunta de Galicia y el Fondo Europeo MarÃtimo, de Pesca y de Acuicultura.
\n\nEn los próximos dÃas os lo enseñamos.
', 'Con moito traballo e ilusión rehabilitamos esta casa familiar para ofrecer un aloxamento cómodo e acolledor.
\n\nTratase dun complexo de apartamentos túristicos mariñeiros e a obra financiouse coa axuda do GALP Golfo Artabro Norte, Xunta de Galicia e o Fondo Europeo MarÃtimo, de Pesca e de Acuicultura.
\n\nNos vindeiros dÃas volo amosamos.
', 'With a lot of work and enthusiasm we rehabilitate this family house to offer comfortable and cozy accommodation.
\n\nThese are tourist sailors apartments and the work has been financed with the collaboration of the GALP Golfo Artabro Norte, Xunta de Galicia and the European Maritime, Fisheries and Aquaculture Fund.
\n\nIn the next few days we will show you.
');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1170', '', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1173', '', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1175', '', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1177', '', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1179', '', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1181', '', '', '');
+INSERT INTO `field_artigo` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1183', '', '', '');
+
+DROP TABLE IF EXISTS `field_botons`;
+CREATE TABLE `field_botons` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` text NOT NULL,
+ `count` int(11) NOT NULL,
+ `parent_id` int(11) NOT NULL,
+ PRIMARY KEY (`pages_id`),
+ KEY `data_exact` (`data`(1)),
+ KEY `count` (`count`,`pages_id`),
+ KEY `parent_id` (`parent_id`,`pages_id`),
+ FULLTEXT KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_botons` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1158', '', '0', '1159');
+INSERT INTO `field_botons` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1161', '', '0', '1162');
+INSERT INTO `field_botons` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1164', '', '0', '1165');
+INSERT INTO `field_botons` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1168', '', '0', '1169');
+INSERT INTO `field_botons` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1170', '', '0', '1171');
+INSERT INTO `field_botons` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1173', '', '0', '1174');
+INSERT INTO `field_botons` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1175', '', '0', '1176');
+INSERT INTO `field_botons` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1177', '', '0', '1178');
+INSERT INTO `field_botons` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1179', '', '0', '1180');
+INSERT INTO `field_botons` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1181', '', '0', '1182');
+INSERT INTO `field_botons` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1183', '', '0', '1184');
+
+DROP TABLE IF EXISTS `field_botons_estilo`;
+CREATE TABLE `field_botons_estilo` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` int(10) unsigned NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ PRIMARY KEY (`pages_id`,`sort`),
+ KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+
+DROP TABLE IF EXISTS `field_categorias`;
+CREATE TABLE `field_categorias` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` int(11) NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ PRIMARY KEY (`pages_id`,`sort`),
+ KEY `data` (`data`,`pages_id`,`sort`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_categorias` (`pages_id`, `data`, `sort`) VALUES('1130', '1128', '0');
+INSERT INTO `field_categorias` (`pages_id`, `data`, `sort`) VALUES('1166', '1128', '0');
+
+DROP TABLE IF EXISTS `field_comentarios`;
+CREATE TABLE `field_comentarios` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` text NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+ `status` tinyint(3) NOT NULL DEFAULT 0,
+ `cite` varchar(128) NOT NULL DEFAULT '',
+ `email` varchar(128) NOT NULL DEFAULT '',
+ `created` int(10) unsigned NOT NULL,
+ `created_users_id` int(10) unsigned NOT NULL,
+ `ip` varchar(45) NOT NULL DEFAULT '',
+ `user_agent` varchar(250) NOT NULL DEFAULT '',
+ `website` varchar(250) NOT NULL DEFAULT '',
+ `parent_id` int(10) unsigned NOT NULL DEFAULT 0,
+ `flags` int(10) unsigned NOT NULL DEFAULT 0,
+ `code` varchar(128) DEFAULT NULL,
+ `subcode` varchar(40) DEFAULT NULL,
+ `upvotes` int(10) unsigned NOT NULL DEFAULT 0,
+ `downvotes` int(10) unsigned NOT NULL DEFAULT 0,
+ `stars` tinyint(3) unsigned DEFAULT NULL,
+ PRIMARY KEY (`id`),
+ KEY `pages_id_sort` (`pages_id`,`sort`),
+ KEY `status` (`status`,`email`),
+ KEY `pages_id` (`pages_id`,`status`,`created`),
+ KEY `created` (`created`,`status`),
+ KEY `code` (`code`),
+ KEY `subcode` (`subcode`),
+ FULLTEXT KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+
+DROP TABLE IF EXISTS `field_comentarios_votes`;
+CREATE TABLE `field_comentarios_votes` (
+ `comment_id` int(10) unsigned NOT NULL,
+ `vote` tinyint(4) NOT NULL,
+ `created` timestamp NOT NULL DEFAULT current_timestamp(),
+ `ip` varchar(45) NOT NULL DEFAULT '',
+ `user_id` int(10) unsigned NOT NULL DEFAULT 0,
+ PRIMARY KEY (`comment_id`,`ip`,`vote`),
+ KEY `created` (`created`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+
+DROP TABLE IF EXISTS `field_configuracion`;
+CREATE TABLE `field_configuracion` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` text NOT NULL,
+ `count` int(11) NOT NULL,
+ `parent_id` int(11) NOT NULL,
+ PRIMARY KEY (`pages_id`),
+ KEY `data_exact` (`data`(1)),
+ KEY `count` (`count`,`pages_id`),
+ KEY `parent_id` (`parent_id`,`pages_id`),
+ FULLTEXT KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_configuracion` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1121', '1142,1143,1144,1145,1146,1153', '6', '1140');
+
+DROP TABLE IF EXISTS `field_email`;
+CREATE TABLE `field_email` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` varchar(250) NOT NULL DEFAULT '',
+ PRIMARY KEY (`pages_id`),
+ KEY `data_exact` (`data`),
+ FULLTEXT KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_email` (`pages_id`, `data`) VALUES('41', 'laegnur@artabro.org');
+INSERT INTO `field_email` (`pages_id`, `data`) VALUES('1045', 'praiadeseselle@artabro.org');
+
+DROP TABLE IF EXISTS `field_etiquetas`;
+CREATE TABLE `field_etiquetas` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` int(11) NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ PRIMARY KEY (`pages_id`,`sort`),
+ KEY `data` (`data`,`pages_id`,`sort`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_etiquetas` (`pages_id`, `data`, `sort`) VALUES('1130', '1129', '0');
+INSERT INTO `field_etiquetas` (`pages_id`, `data`, `sort`) VALUES('1166', '1129', '0');
+
+DROP TABLE IF EXISTS `field_fecha_publicacion`;
+CREATE TABLE `field_fecha_publicacion` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` datetime NOT NULL,
+ PRIMARY KEY (`pages_id`),
+ KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_fecha_publicacion` (`pages_id`, `data`) VALUES('1130', '2022-10-25 00:00:00');
+INSERT INTO `field_fecha_publicacion` (`pages_id`, `data`) VALUES('1166', '2022-12-11 00:00:00');
+
+DROP TABLE IF EXISTS `field_imaxe`;
+CREATE TABLE `field_imaxe` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` varchar(250) NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ `description` text NOT NULL,
+ `modified` datetime DEFAULT NULL,
+ `created` datetime DEFAULT NULL,
+ `filedata` mediumtext DEFAULT NULL,
+ `filesize` int(11) DEFAULT NULL,
+ `created_users_id` int(10) unsigned NOT NULL DEFAULT 0,
+ `modified_users_id` int(10) unsigned NOT NULL DEFAULT 0,
+ `width` int(11) DEFAULT NULL,
+ `height` int(11) DEFAULT NULL,
+ `ratio` decimal(4,2) DEFAULT NULL,
+ PRIMARY KEY (`pages_id`,`sort`),
+ KEY `data` (`data`),
+ KEY `modified` (`modified`),
+ KEY `created` (`created`),
+ KEY `filesize` (`filesize`),
+ KEY `width` (`width`),
+ KEY `height` (`height`),
+ KEY `ratio` (`ratio`),
+ FULLTEXT KEY `description` (`description`),
+ FULLTEXT KEY `filedata` (`filedata`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_imaxe` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`) VALUES('1082', '6e0e6f99-047e-40f8-8859-91f0155f3442.jpeg', '0', '[\"Imagen con texto lateral sin titular\"]', '2022-04-08 11:34:07', '2022-04-07 14:55:47', '', '177427', '41', '41', '1600', '777', '2.06');
+INSERT INTO `field_imaxe` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`) VALUES('1134', 'd03e15bd-b46a-4894-8614-8c749a432b47.jpeg', '0', '[\"\"]', '2022-10-27 14:22:18', '2022-10-27 14:22:18', '', '168454', '41', '41', '1600', '1200', '1.33');
+INSERT INTO `field_imaxe` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`) VALUES('1153', 'mantemento.jpg', '0', '{\"0\":\"Página en mantenimiento\",\"1023\":\"Páxina en mantemento\",\"1024\":\"Page in maintenance\"}', '2022-11-21 14:19:05', '2022-11-21 14:19:05', '', '37829', '41', '41', '800', '381', '2.10');
+INSERT INTO `field_imaxe` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`) VALUES('1084', '78229d9b-5703-4da6-9509-5873c0b5aded.jpeg', '0', '[\"Imagen con texto lateral sin titular\"]', '2022-04-08 11:34:07', '2022-04-07 14:55:47', '', '271073', '41', '41', '1600', '900', '1.78');
+INSERT INTO `field_imaxe` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`) VALUES('1090', 'a27b7331-bb65-452b-b7ef-6f5850ab353f.jpeg', '0', '[\"Imagen con texto lateral con titular\"]', '2022-04-08 11:34:07', '2022-04-08 10:06:26', '', '172746', '41', '41', '1600', '777', '2.06');
+INSERT INTO `field_imaxe` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`) VALUES('1086', '8fd6e5cc-031a-4b42-94b7-65b717ad570f.jpeg', '0', '[\"Imagen con texto inferior, sin texto\"]', '2022-04-08 11:32:22', '2022-04-08 10:03:38', '', '169412', '41', '41', '1600', '1200', '1.33');
+INSERT INTO `field_imaxe` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`) VALUES('1112', 'dormitorio3.jpg', '0', '[\"O Mourón\"]', '2023-02-18 15:52:14', '2023-02-18 15:52:13', '', '39666', '41', '41', '480', '360', '1.33');
+INSERT INTO `field_imaxe` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`) VALUES('1111', 'dormitorio2.jpg', '0', '[\"A Cercada\"]', '2023-02-18 15:52:14', '2023-02-18 15:52:13', '', '43499', '41', '41', '480', '360', '1.33');
+INSERT INTO `field_imaxe` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`) VALUES('1114', '6e0e6f99-047e-40f8-8859-91f0155f3442.jpeg', '0', '[\"\"]', '2022-10-04 11:09:20', '2022-10-04 11:09:20', '', '177427', '41', '41', '1600', '777', '2.06');
+INSERT INTO `field_imaxe` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`) VALUES('1115', '8fd6e5cc-031a-4b42-94b7-65b717ad570f.jpeg', '0', '[\"\"]', '2022-10-04 11:10:48', '2022-10-04 11:10:48', '', '169412', '41', '41', '1600', '1200', '1.33');
+INSERT INTO `field_imaxe` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`) VALUES('1130', 'playa_chanteiro_ares.jpg', '0', '[\"\"]', '2022-10-25 13:48:31', '2022-10-25 13:48:31', '', '322165', '41', '41', '1200', '669', '1.79');
+INSERT INTO `field_imaxe` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`) VALUES('1135', '6e0e6f99-047e-40f8-8859-91f0155f3442.jpeg', '0', '[\"\"]', '2022-10-27 14:22:18', '2022-10-27 14:22:18', '', '177427', '41', '41', '1600', '777', '2.06');
+INSERT INTO `field_imaxe` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`) VALUES('1136', '78229d9b-5703-4da6-9509-5873c0b5aded.jpeg', '0', '[\"\"]', '2022-10-27 14:22:55', '2022-10-27 14:22:55', '', '271073', '41', '41', '1600', '900', '1.78');
+INSERT INTO `field_imaxe` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`) VALUES('1110', 'dormitorio1.jpg', '0', '[\"As Mirandas\"]', '2023-02-18 15:52:14', '2023-02-18 15:52:13', '', '38935', '41', '41', '480', '360', '1.33');
+
+DROP TABLE IF EXISTS `field_imaxe_posicion`;
+CREATE TABLE `field_imaxe_posicion` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` int(10) unsigned NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ PRIMARY KEY (`pages_id`,`sort`),
+ KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_imaxe_posicion` (`pages_id`, `data`, `sort`) VALUES('1084', '2', '0');
+INSERT INTO `field_imaxe_posicion` (`pages_id`, `data`, `sort`) VALUES('1082', '1', '0');
+INSERT INTO `field_imaxe_posicion` (`pages_id`, `data`, `sort`) VALUES('1086', '3', '0');
+INSERT INTO `field_imaxe_posicion` (`pages_id`, `data`, `sort`) VALUES('1090', '1', '0');
+INSERT INTO `field_imaxe_posicion` (`pages_id`, `data`, `sort`) VALUES('1114', '2', '0');
+INSERT INTO `field_imaxe_posicion` (`pages_id`, `data`, `sort`) VALUES('1115', '1', '0');
+INSERT INTO `field_imaxe_posicion` (`pages_id`, `data`, `sort`) VALUES('1134', '2', '0');
+INSERT INTO `field_imaxe_posicion` (`pages_id`, `data`, `sort`) VALUES('1135', '1', '0');
+INSERT INTO `field_imaxe_posicion` (`pages_id`, `data`, `sort`) VALUES('1136', '2', '0');
+
+DROP TABLE IF EXISTS `field_imaxes`;
+CREATE TABLE `field_imaxes` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` varchar(250) NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ `description` text NOT NULL,
+ `modified` datetime DEFAULT NULL,
+ `created` datetime DEFAULT NULL,
+ `filedata` mediumtext DEFAULT NULL,
+ `filesize` int(11) DEFAULT NULL,
+ `created_users_id` int(10) unsigned NOT NULL DEFAULT 0,
+ `modified_users_id` int(10) unsigned NOT NULL DEFAULT 0,
+ `width` int(11) DEFAULT NULL,
+ `height` int(11) DEFAULT NULL,
+ `ratio` decimal(4,2) DEFAULT NULL,
+ `tags` varchar(250) NOT NULL,
+ PRIMARY KEY (`pages_id`,`sort`),
+ KEY `data` (`data`),
+ KEY `modified` (`modified`),
+ KEY `created` (`created`),
+ KEY `filesize` (`filesize`),
+ KEY `width` (`width`),
+ KEY `height` (`height`),
+ KEY `ratio` (`ratio`),
+ FULLTEXT KEY `description` (`description`),
+ FULLTEXT KEY `filedata` (`filedata`),
+ FULLTEXT KEY `tags` (`tags`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1170', 'img-20220930-wa0005.jpg', '1', '[\"\"]', '2023-02-18 10:40:21', '2023-02-18 10:40:21', '', '519765', '41', '41', '1600', '1066', '1.50', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1170', 'img-20220930-wa0004.jpg', '0', '[\"\"]', '2023-02-18 10:40:21', '2023-02-18 10:40:21', '', '585341', '41', '41', '1600', '1067', '1.50', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1173', 'as-mirandas-6.jpg', '5', '[\"\"]', '2023-02-18 10:50:05', '2023-02-18 10:50:05', '', '719754', '41', '41', '1928', '1928', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1173', 'as-mirandas-5.jpg', '4', '[\"\"]', '2023-02-18 10:50:05', '2023-02-18 10:50:05', '', '841990', '41', '41', '1813', '1813', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1173', 'as-mirandas-4.jpg', '3', '[\"\"]', '2023-02-18 10:50:05', '2023-02-18 10:50:05', '', '644195', '41', '41', '1904', '1904', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1173', 'as-mirandas-3.jpg', '2', '[\"\"]', '2023-02-18 10:50:05', '2023-02-18 10:50:05', '', '798686', '41', '41', '1947', '1947', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1173', 'as-mirandas-1.jpg', '1', '[\"\"]', '2023-02-18 10:50:05', '2023-02-18 10:50:05', '', '768211', '41', '41', '2008', '2008', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1173', 'as-mirandas-2.jpg', '0', '[\"\"]', '2023-02-18 10:50:05', '2023-02-18 10:50:05', '', '731030', '41', '41', '1817', '1817', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1175', 'as-mirandas-6.jpg', '5', '[\"\"]', '2023-02-18 10:50:05', '2023-02-18 10:50:05', '', '719754', '41', '41', '1928', '1928', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1175', 'as-mirandas-4.jpg', '3', '[\"\"]', '2023-02-18 10:50:05', '2023-02-18 10:50:05', '', '644195', '41', '41', '1904', '1904', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1175', 'as-mirandas-5.jpg', '4', '[\"\"]', '2023-02-18 10:50:05', '2023-02-18 10:50:05', '', '841990', '41', '41', '1813', '1813', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1175', 'as-mirandas-3.jpg', '2', '[\"\"]', '2023-02-18 10:50:05', '2023-02-18 10:50:05', '', '798686', '41', '41', '1947', '1947', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1175', 'as-mirandas-1.jpg', '1', '[\"\"]', '2023-02-18 10:50:05', '2023-02-18 10:50:05', '', '768211', '41', '41', '2008', '2008', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1175', 'as-mirandas-2.jpg', '0', '[\"\"]', '2023-02-18 10:50:05', '2023-02-18 10:50:05', '', '731030', '41', '41', '1817', '1817', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1177', 'apartamento-o-mouron-4.jpg', '4', '[\"\"]', '2023-02-18 10:52:09', '2023-02-18 10:52:09', '', '622561', '41', '41', '1859', '1859', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1177', 'apartamento-o-mouron-5.jpg', '3', '[\"\"]', '2023-02-18 10:52:09', '2023-02-18 10:52:09', '', '626479', '41', '41', '1774', '1774', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1177', 'apartamento-o-mouron-2.jpg', '2', '[\"\"]', '2023-02-18 10:52:09', '2023-02-18 10:52:09', '', '574190', '41', '41', '1805', '1805', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1177', 'apartamento-o-mouron-3.jpg', '1', '[\"\"]', '2023-02-18 10:52:09', '2023-02-18 10:52:09', '', '811384', '41', '41', '2008', '2008', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1177', 'apartamento-o-mouron-1.jpg', '0', '[\"\"]', '2023-02-18 10:52:09', '2023-02-18 10:52:09', '', '713403', '41', '41', '2008', '2008', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1179', 'apartamento-o-mouron-6.jpg', '5', '[\"\"]', '2023-02-18 10:52:09', '2023-02-18 10:52:09', '', '650560', '41', '41', '1823', '1823', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1179', 'apartamento-o-mouron-4.jpg', '4', '[\"\"]', '2023-02-18 10:52:09', '2023-02-18 10:52:09', '', '622561', '41', '41', '1859', '1859', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1179', 'apartamento-o-mouron-5.jpg', '3', '[\"\"]', '2023-02-18 10:52:09', '2023-02-18 10:52:09', '', '626479', '41', '41', '1774', '1774', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1179', 'apartamento-o-mouron-2.jpg', '2', '[\"\"]', '2023-02-18 10:52:09', '2023-02-18 10:52:09', '', '574190', '41', '41', '1805', '1805', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1179', 'apartamento-o-mouron-3.jpg', '1', '[\"\"]', '2023-02-18 10:52:09', '2023-02-18 10:52:09', '', '811384', '41', '41', '2008', '2008', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1179', 'apartamento-o-mouron-1.jpg', '0', '[\"\"]', '2023-02-18 10:52:09', '2023-02-18 10:52:09', '', '713403', '41', '41', '2008', '2008', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1177', 'apartamento-o-mouron-6.jpg', '5', '[\"\"]', '2023-02-18 10:52:09', '2023-02-18 10:52:09', '', '650560', '41', '41', '1823', '1823', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1181', 'apartamento-a-cercada-4.jpg', '3', '[\"\"]', '2023-02-18 10:53:15', '2023-02-18 10:53:15', '', '820260', '41', '41', '1896', '1896', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1181', 'apartamento-a-cercada-3.jpg', '2', '[\"\"]', '2023-02-18 10:53:15', '2023-02-18 10:53:15', '', '849557', '41', '41', '2008', '2008', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1181', 'apartamento-a-cercada-2.jpg', '1', '[\"\"]', '2023-02-18 10:53:15', '2023-02-18 10:53:15', '', '717912', '41', '41', '1945', '1945', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1181', 'apartamento-a-cercada-1.jpg', '0', '[\"\"]', '2023-02-18 10:53:15', '2023-02-18 10:53:15', '', '740890', '41', '41', '2008', '2008', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1183', 'apartamento-a-cercada-4.jpg', '3', '[\"\"]', '2023-02-18 10:53:15', '2023-02-18 10:53:15', '', '820260', '41', '41', '1896', '1896', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1183', 'apartamento-a-cercada-3.jpg', '2', '[\"\"]', '2023-02-18 10:53:15', '2023-02-18 10:53:15', '', '849557', '41', '41', '2008', '2008', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1183', 'apartamento-a-cercada-2.jpg', '1', '[\"\"]', '2023-02-18 10:53:15', '2023-02-18 10:53:15', '', '717912', '41', '41', '1945', '1945', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1183', 'apartamento-a-cercada-1.jpg', '0', '[\"\"]', '2023-02-18 10:53:15', '2023-02-18 10:53:15', '', '740890', '41', '41', '2008', '2008', '1.00', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1076', 'playa_chanteiro_ares.jpg', '1', '{\"0\":\"Playa Chanteiro. Ares\",\"1023\":\"Praia Chanteiro. Ares\",\"1024\":\"Chanteiro beach. Ares\"}', '2022-04-07 12:56:37', '2022-04-07 12:56:15', '', '322165', '41', '41', '1200', '669', '1.79', '');
+INSERT INTO `field_imaxes` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`, `width`, `height`, `ratio`, `tags`) VALUES('1076', 'praia-de-seselle.jpg', '0', '{\"0\":\"Playa Seselle. Ares\",\"1023\":\"Praia Seselle. Ares\",\"1024\":\"Seselle beach. Ares\"}', '2023-02-18 12:06:11', '2023-02-18 11:32:08', '', '1414509', '41', '41', '2333', '1541', '1.51', '');
+
+DROP TABLE IF EXISTS `field_language`;
+CREATE TABLE `field_language` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` int(11) NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ PRIMARY KEY (`pages_id`,`sort`),
+ KEY `data` (`data`,`pages_id`,`sort`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_language` (`pages_id`, `data`, `sort`) VALUES('40', '1017', '0');
+INSERT INTO `field_language` (`pages_id`, `data`, `sort`) VALUES('41', '1017', '0');
+INSERT INTO `field_language` (`pages_id`, `data`, `sort`) VALUES('1045', '1017', '0');
+
+DROP TABLE IF EXISTS `field_language_files`;
+CREATE TABLE `field_language_files` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` varchar(250) NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ `description` text NOT NULL,
+ `modified` datetime DEFAULT NULL,
+ `created` datetime DEFAULT NULL,
+ `filedata` mediumtext DEFAULT NULL,
+ `filesize` int(11) DEFAULT NULL,
+ `created_users_id` int(10) unsigned NOT NULL DEFAULT 0,
+ `modified_users_id` int(10) unsigned NOT NULL DEFAULT 0,
+ PRIMARY KEY (`pages_id`,`sort`),
+ KEY `data` (`data`),
+ KEY `modified` (`modified`),
+ KEY `created` (`created`),
+ KEY `filesize` (`filesize`),
+ FULLTEXT KEY `description` (`description`),
+ FULLTEXT KEY `filedata` (`filedata`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_language_files` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1017', 'wire--modules--languagesupport--languagesupport-module.json', '0', '[\"\"]', '2022-10-26 11:05:31', '2022-10-26 11:05:31', '', '823', '41', '41');
+INSERT INTO `field_language_files` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1023', 'wire--modules--languagesupport--languagesupport-module.json', '0', '[\"\"]', '2022-10-26 11:09:09', '2022-10-26 11:09:09', '', '642', '41', '41');
+INSERT INTO `field_language_files` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1024', 'wire--modules--languagesupport--languagesupport-module.json', '0', '[\"\"]', '2022-10-26 11:10:33', '2022-10-26 11:10:33', '', '591', '41', '41');
+
+DROP TABLE IF EXISTS `field_language_files_site`;
+CREATE TABLE `field_language_files_site` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` varchar(250) NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ `description` text NOT NULL,
+ `modified` datetime DEFAULT NULL,
+ `created` datetime DEFAULT NULL,
+ `filedata` mediumtext DEFAULT NULL,
+ `filesize` int(11) DEFAULT NULL,
+ `created_users_id` int(10) unsigned NOT NULL DEFAULT 0,
+ `modified_users_id` int(10) unsigned NOT NULL DEFAULT 0,
+ PRIMARY KEY (`pages_id`,`sort`),
+ KEY `data` (`data`),
+ KEY `modified` (`modified`),
+ KEY `created` (`created`),
+ KEY `filesize` (`filesize`),
+ FULLTEXT KEY `description` (`description`),
+ FULLTEXT KEY `filedata` (`filedata`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1024', 'site--templates--xes-acceder-php.json', '3', '[\"\"]', '2022-10-25 11:13:55', '2022-10-25 11:13:55', '', '128', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1024', 'site--templates--_func-php.json', '2', '[\"\"]', '2022-04-06 12:14:09', '2022-04-06 12:14:09', '', '282', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1017', 'site--templates--_foot-php.json', '1', '[\"\"]', '2022-04-05 11:48:28', '2022-04-05 11:48:28', '', '540', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1017', 'site--templates--_head-php.json', '0', '[\"\"]', '2022-04-05 11:48:28', '2022-04-05 11:48:28', '', '922', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1023', 'site--templates--_xes-foot-php.json', '4', '[\"\"]', '2022-10-25 11:13:36', '2022-10-25 11:13:36', '', '435', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1023', 'site--templates--_xes-head-php.json', '5', '[\"\"]', '2022-10-25 11:13:36', '2022-10-25 11:13:36', '', '818', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1024', 'site--templates--_xes-foot-php.json', '4', '[\"\"]', '2022-10-25 11:13:55', '2022-10-25 11:13:55', '', '124', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1024', 'site--templates--_foot-php.json', '1', '[\"\"]', '2022-04-05 11:52:04', '2022-04-05 11:52:04', '', '363', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1024', 'site--templates--_head-php.json', '0', '[\"\"]', '2022-04-05 11:52:04', '2022-04-05 11:52:04', '', '525', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1024', 'site--templates--_xes-head-php.json', '5', '[\"\"]', '2022-10-25 11:13:55', '2022-10-25 11:13:55', '', '124', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1017', 'site--templates--_func-php.json', '2', '[\"\"]', '2022-04-06 12:09:25', '2022-04-06 12:09:25', '', '677', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1017', 'site--templates--xes-acceder-php.json', '3', '[\"\"]', '2022-10-25 11:11:43', '2022-10-25 11:11:43', '', '1272', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1017', 'site--templates--_xes-foot-php.json', '4', '[\"\"]', '2022-10-25 11:11:43', '2022-10-25 11:11:43', '', '432', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1017', 'site--templates--_xes-head-php.json', '5', '[\"\"]', '2022-10-25 11:11:43', '2022-10-25 11:11:43', '', '825', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1023', 'site--templates--_foot-php.json', '1', '[\"\"]', '2022-04-05 11:52:21', '2022-04-05 11:52:21', '', '427', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1023', 'site--templates--_func-php.json', '2', '[\"\"]', '2022-04-06 12:13:31', '2022-04-06 12:13:31', '', '304', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1023', 'site--templates--xes-acceder-php.json', '3', '[\"\"]', '2022-10-25 11:13:36', '2022-10-25 11:13:36', '', '1257', '41', '41');
+INSERT INTO `field_language_files_site` (`pages_id`, `data`, `sort`, `description`, `modified`, `created`, `filedata`, `filesize`, `created_users_id`, `modified_users_id`) VALUES('1023', 'site--templates--_head-php.json', '0', '[\"\"]', '2022-04-05 11:52:21', '2022-04-05 11:52:21', '', '915', '41', '41');
+
+DROP TABLE IF EXISTS `field_ligazon_imaxe`;
+CREATE TABLE `field_ligazon_imaxe` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` text NOT NULL,
+ `count` int(11) NOT NULL,
+ `parent_id` int(11) NOT NULL,
+ PRIMARY KEY (`pages_id`),
+ KEY `data_exact` (`data`(1)),
+ KEY `count` (`count`,`pages_id`),
+ KEY `parent_id` (`parent_id`,`pages_id`),
+ FULLTEXT KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_ligazon_imaxe` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1034', '1110,1112,1111', '3', '1109');
+
+DROP TABLE IF EXISTS `field_ligazon_interna`;
+CREATE TABLE `field_ligazon_interna` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` int(11) NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ PRIMARY KEY (`pages_id`,`sort`),
+ KEY `data` (`data`,`pages_id`,`sort`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_ligazon_interna` (`pages_id`, `data`, `sort`) VALUES('1110', '1097', '0');
+INSERT INTO `field_ligazon_interna` (`pages_id`, `data`, `sort`) VALUES('1111', '1099', '0');
+INSERT INTO `field_ligazon_interna` (`pages_id`, `data`, `sort`) VALUES('1112', '1101', '0');
+
+DROP TABLE IF EXISTS `field_mapa`;
+CREATE TABLE `field_mapa` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` varchar(255) NOT NULL DEFAULT '',
+ `lat` float(10,6) NOT NULL DEFAULT 0.000000,
+ `lng` float(10,6) NOT NULL DEFAULT 0.000000,
+ `status` tinyint(4) NOT NULL DEFAULT 0,
+ `zoom` tinyint(4) NOT NULL DEFAULT 0,
+ PRIMARY KEY (`pages_id`),
+ KEY `latlng` (`lat`,`lng`),
+ KEY `zoom` (`zoom`),
+ FULLTEXT KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+
+DROP TABLE IF EXISTS `field_parametro_cor`;
+CREATE TABLE `field_parametro_cor` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` char(6) NOT NULL,
+ PRIMARY KEY (`pages_id`),
+ KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_parametro_cor` (`pages_id`, `data`) VALUES('1146', '000000');
+INSERT INTO `field_parametro_cor` (`pages_id`, `data`) VALUES('1145', '00837C');
+INSERT INTO `field_parametro_cor` (`pages_id`, `data`) VALUES('1144', 'FFFFFF');
+
+DROP TABLE IF EXISTS `field_parametro_mantemento`;
+CREATE TABLE `field_parametro_mantemento` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` tinyint(4) NOT NULL,
+ PRIMARY KEY (`pages_id`),
+ KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_parametro_mantemento` (`pages_id`, `data`) VALUES('1153', '1');
+
+DROP TABLE IF EXISTS `field_parametro_nome`;
+CREATE TABLE `field_parametro_nome` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` text NOT NULL,
+ PRIMARY KEY (`pages_id`),
+ UNIQUE KEY `data_exact` (`data`(250)),
+ FULLTEXT KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_parametro_nome` (`pages_id`, `data`) VALUES('1146', 'cor_secundario');
+INSERT INTO `field_parametro_nome` (`pages_id`, `data`) VALUES('1145', 'cor_principal');
+INSERT INTO `field_parametro_nome` (`pages_id`, `data`) VALUES('1144', 'cor_fondo');
+INSERT INTO `field_parametro_nome` (`pages_id`, `data`) VALUES('1143', 'sitio_descripcion');
+INSERT INTO `field_parametro_nome` (`pages_id`, `data`) VALUES('1142', 'sitio_nome');
+
+DROP TABLE IF EXISTS `field_parametro_tipo`;
+CREATE TABLE `field_parametro_tipo` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` int(10) unsigned NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ PRIMARY KEY (`pages_id`,`sort`),
+ KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_parametro_tipo` (`pages_id`, `data`, `sort`) VALUES('1146', '2', '0');
+INSERT INTO `field_parametro_tipo` (`pages_id`, `data`, `sort`) VALUES('1145', '2', '0');
+INSERT INTO `field_parametro_tipo` (`pages_id`, `data`, `sort`) VALUES('1142', '1', '0');
+INSERT INTO `field_parametro_tipo` (`pages_id`, `data`, `sort`) VALUES('1143', '1', '0');
+INSERT INTO `field_parametro_tipo` (`pages_id`, `data`, `sort`) VALUES('1144', '2', '0');
+INSERT INTO `field_parametro_tipo` (`pages_id`, `data`, `sort`) VALUES('1153', '3', '0');
+
+DROP TABLE IF EXISTS `field_parametro_valor`;
+CREATE TABLE `field_parametro_valor` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` text NOT NULL,
+ `data1023` text DEFAULT NULL,
+ `data1024` text DEFAULT NULL,
+ PRIMARY KEY (`pages_id`),
+ KEY `data_exact` (`data`(250)),
+ KEY `data_exact1023` (`data1023`(250)),
+ KEY `data_exact1024` (`data1024`(250)),
+ FULLTEXT KEY `data` (`data`),
+ FULLTEXT KEY `data1023` (`data1023`),
+ FULLTEXT KEY `data1024` (`data1024`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_parametro_valor` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1153', '', '', '');
+INSERT INTO `field_parametro_valor` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1146', '', '', '');
+INSERT INTO `field_parametro_valor` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1145', '', '', '');
+INSERT INTO `field_parametro_valor` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1144', '', '', '');
+INSERT INTO `field_parametro_valor` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1143', 'Apartamentos turÃsticos', 'Apartamentos turÃsticos', 'Tourist apartments');
+INSERT INTO `field_parametro_valor` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1142', 'Praia de Seselle', '', '');
+
+DROP TABLE IF EXISTS `field_pass`;
+CREATE TABLE `field_pass` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` char(40) NOT NULL,
+ `salt` char(32) NOT NULL,
+ PRIMARY KEY (`pages_id`),
+ KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=ascii COLLATE=ascii_general_ci;
+
+INSERT INTO `field_pass` (`pages_id`, `data`, `salt`) VALUES('41', 'Hq3ay5w6P2go/mMzDl3bsYn/H9s1s8O', '$2y$11$PRXC3lpcd1lLflO/gFVTxe');
+INSERT INTO `field_pass` (`pages_id`, `data`, `salt`) VALUES('40', '', '');
+INSERT INTO `field_pass` (`pages_id`, `data`, `salt`) VALUES('1045', 'TaAJHjOmxiRq889r9N4ihMluz6wXxhq', '$2y$11$cRw11YnW5SRaZf7ZHXYLDe');
+
+DROP TABLE IF EXISTS `field_permissions`;
+CREATE TABLE `field_permissions` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` int(11) NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ PRIMARY KEY (`pages_id`,`sort`),
+ KEY `data` (`data`,`pages_id`,`sort`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('38', '32', '1');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('1120', '32', '1');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('38', '34', '2');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('1120', '34', '2');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('38', '35', '3');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('1120', '35', '4');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('37', '36', '0');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('38', '36', '0');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('1120', '36', '0');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('38', '50', '4');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('1120', '50', '5');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('38', '51', '5');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('38', '52', '7');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('38', '53', '8');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('38', '54', '6');
+INSERT INTO `field_permissions` (`pages_id`, `data`, `sort`) VALUES('1120', '54', '3');
+
+DROP TABLE IF EXISTS `field_process`;
+CREATE TABLE `field_process` (
+ `pages_id` int(11) NOT NULL DEFAULT 0,
+ `data` int(11) NOT NULL DEFAULT 0,
+ PRIMARY KEY (`pages_id`),
+ KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('6', '17');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('3', '12');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('8', '12');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('9', '14');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('10', '7');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('11', '47');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('16', '48');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('300', '104');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('21', '50');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('29', '66');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('23', '10');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('304', '138');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('31', '136');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('22', '76');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('30', '68');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('303', '129');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('2', '87');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('302', '121');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('301', '109');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('28', '76');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('1007', '150');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('1010', '159');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('1012', '161');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('1016', '164');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('1018', '165');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('1020', '181');
+INSERT INTO `field_process` (`pages_id`, `data`) VALUES('1022', '182');
+
+DROP TABLE IF EXISTS `field_roles`;
+CREATE TABLE `field_roles` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` int(11) NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ PRIMARY KEY (`pages_id`,`sort`),
+ KEY `data` (`data`,`pages_id`,`sort`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_roles` (`pages_id`, `data`, `sort`) VALUES('40', '37', '0');
+INSERT INTO `field_roles` (`pages_id`, `data`, `sort`) VALUES('41', '37', '0');
+INSERT INTO `field_roles` (`pages_id`, `data`, `sort`) VALUES('1045', '37', '0');
+INSERT INTO `field_roles` (`pages_id`, `data`, `sort`) VALUES('41', '38', '2');
+INSERT INTO `field_roles` (`pages_id`, `data`, `sort`) VALUES('1045', '38', '1');
+
+DROP TABLE IF EXISTS `field_seccion_tipo`;
+CREATE TABLE `field_seccion_tipo` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` int(10) unsigned NOT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ PRIMARY KEY (`pages_id`,`sort`),
+ KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1158', '1', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1082', '4', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1080', '1', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1084', '4', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1076', '2', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1086', '4', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1088', '1', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1090', '4', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1092', '3', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1114', '4', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1115', '4', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1132', '1', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1043', '3', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1133', '3', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1134', '4', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1135', '4', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1136', '4', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1161', '1', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1164', '1', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1168', '1', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1170', '3', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1173', '3', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1175', '2', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1177', '3', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1179', '2', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1181', '3', '0');
+INSERT INTO `field_seccion_tipo` (`pages_id`, `data`, `sort`) VALUES('1183', '2', '0');
+
+DROP TABLE IF EXISTS `field_seccions`;
+CREATE TABLE `field_seccions` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` text NOT NULL,
+ `count` int(11) NOT NULL,
+ `parent_id` int(11) NOT NULL,
+ PRIMARY KEY (`pages_id`),
+ KEY `data_exact` (`data`(1)),
+ KEY `count` (`count`,`pages_id`),
+ KEY `parent_id` (`parent_id`,`pages_id`),
+ FULLTEXT KEY `data` (`data`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_seccions` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1034', '', '0', '1035');
+INSERT INTO `field_seccions` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1036', '1043,1133', '2', '1037');
+INSERT INTO `field_seccions` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1038', '1134,1135,1136', '3', '1039');
+INSERT INTO `field_seccions` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1', '1076,1114,1115', '3', '1075');
+INSERT INTO `field_seccions` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1097', '1173,1158,1175', '3', '1117');
+INSERT INTO `field_seccions` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1078', '1086,1080,1082,1084,1088,1090,1092', '7', '1079');
+INSERT INTO `field_seccions` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1130', '1132', '1', '1131');
+INSERT INTO `field_seccions` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1101', '1177,1161,1179', '3', '1160');
+INSERT INTO `field_seccions` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1099', '1181,1164,1183', '3', '1163');
+INSERT INTO `field_seccions` (`pages_id`, `data`, `count`, `parent_id`) VALUES('1166', '1168,1170', '2', '1167');
+
+DROP TABLE IF EXISTS `field_title`;
+CREATE TABLE `field_title` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` text NOT NULL,
+ `data1023` text DEFAULT NULL,
+ `data1024` text DEFAULT NULL,
+ PRIMARY KEY (`pages_id`),
+ KEY `data_exact` (`data`(250)),
+ KEY `data_exact1023` (`data1023`(250)),
+ KEY `data_exact1024` (`data1024`(250)),
+ FULLTEXT KEY `data` (`data`),
+ FULLTEXT KEY `data1023` (`data1023`),
+ FULLTEXT KEY `data1024` (`data1024`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('11', 'Templates', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('16', 'Fields', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('22', 'Setup', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('3', 'Pages', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('6', 'Add Page', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('8', 'Tree', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('9', 'Save Sort', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('10', 'Edit', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('21', 'Modules', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('29', 'Users', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('30', 'Roles', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('2', 'Admin', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('7', 'Trash', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('27', '404 Not Found', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('302', 'Insert Link', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('23', 'Login', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('304', 'Profile', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('301', 'Empty Trash', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('300', 'Search', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('303', 'Insert Image', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('28', 'Access', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('31', 'Permissions', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('32', 'Edit pages', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('34', 'Delete pages', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('35', 'Move pages (change parent)', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('36', 'View pages', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('50', 'Sort child pages', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('51', 'Change templates on pages', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('52', 'Administer users', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('53', 'User can update profile/password', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('54', 'Lock or unlock a page', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1', 'inicio', 'inicio', 'home');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1006', 'Use Page Lister', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1007', 'Find', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1010', 'Recent', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1011', 'Can see recently edited pages', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1012', 'Logs', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1013', 'Can view system logs', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1014', 'Can manage system logs', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1015', 'Administer languages and static translation files', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1016', 'Languages', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1017', 'Castellano', 'Castelan', 'Spanish');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1018', 'Language Translator', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1019', 'Repeaters', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1020', 'DB Backups', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1021', 'Manage database backups (recommended for superuser only)', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1022', 'Upgrades', NULL, NULL);
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1023', 'Gallego', 'Galego', 'Galician');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1024', 'Ingles', 'Ingles', 'English');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1025', 'configuracion', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1078', 'prueba', 'proba', 'test');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1027', 'seccions', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1067', '1649320950-2273-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1033', 'http404', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1034', 'habitaciones', 'habitacións', 'rooms');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1035', 'habitaciones', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1036', 'servicios', 'servizos', 'services');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1037', 'servicios', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1038', 'entorno', 'arredores', 'surroundings');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1039', 'entorno', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1040', 'bitácora', 'bitácora', 'binnacle');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1042', 'contacto y reservas', 'contacto e reservas', 'contact and reservations');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1123', 'panel de gestion', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1066', 'ligazon_imaxe', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1126', 'etiquetas', 'etiquetas', 'tags');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1079', 'prueba', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1125', 'categorÃas', 'categorÃas', 'categories');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1122', 'acceder', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1157', 'botons', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1139', 'Use the front-end page editor', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1075', 'es', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1127', 'publicaciones', 'publicacións', 'posts');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1121', 'gestión', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1117', 'mirandas', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1109', 'habitaciones', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1095', '1647785951-306-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1097', 'As Mirandas', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1099', 'A Cercada', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1128', 'noticias', 'novas', 'news');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1101', 'O Mourón', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1129', 'general', 'xeral', 'general');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1130', '¡Hola Mundo!', '¡Ola mundo!', 'Hello world!');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1131', 'hola-mundo', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1156', 'BS Inicio', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1140', 'gestion', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1165', '1676712979-6649-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1163', 'cercada', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1162', '1676712913-8476-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1160', 'mouron', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1159', '1676712790-4027-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1166', '¡Esta todo listo!', '¡Xa está todo listo!', 'It\'s all set!');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1167', 'esta-todo-listo', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1169', '1676713133-8268-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1171', '1676713162-3392-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1172', '1665045015-5779-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1174', '1676713701-8855-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1176', '1676713764-8954-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1178', '1676713857-3392-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1180', '1676713907-3397-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1182', '1676713949-0583-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1184', '1676713976-5633-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1185', '1649328884-5892-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1186', '1664874598-772-1', '', '');
+INSERT INTO `field_title` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1187', '1664874462-0842-1', '', '');
+
+DROP TABLE IF EXISTS `field_titular`;
+CREATE TABLE `field_titular` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `data` text NOT NULL,
+ `data1023` text DEFAULT NULL,
+ `data1024` text DEFAULT NULL,
+ PRIMARY KEY (`pages_id`),
+ KEY `data_exact` (`data`(250)),
+ KEY `data_exact1023` (`data1023`(250)),
+ KEY `data_exact1024` (`data1024`(250)),
+ FULLTEXT KEY `data` (`data`),
+ FULLTEXT KEY `data1023` (`data1023`),
+ FULLTEXT KEY `data1024` (`data1024`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1153', 'Página en mantenimiento', 'Páxina en mantemento', 'Page in maintenance');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1076', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1161', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1080', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1082', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1084', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1086', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1088', 'Texto con titular', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1090', 'Imagen con texto lateral con titular', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1092', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1110', 'As Mirandas', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1111', 'A Cercada', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1112', 'O Mourón', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1158', 'As Mirandas', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1114', 'La casa', 'A casa', 'The house');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1115', 'Turismo activo', 'Turismo activo', 'Active turism');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1116', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1119', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1132', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1133', 'Servicios adicionales', 'Servizos adicionais', 'Additional services');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1043', 'Servicios incluidos', 'Servizos incluÃdos', 'Included services');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1134', 'La playa', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1135', 'Ares', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1136', 'Mugardos', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1164', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1168', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1170', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1173', 'As Mirandas', 'As Mirandas', 'As Mirandas');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1175', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1177', 'O Mourón', 'O Mourón', 'O Mourón');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1179', '', '', '');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1181', 'A Cercada', 'A Cercada', 'A Cercada');
+INSERT INTO `field_titular` (`pages_id`, `data`, `data1023`, `data1024`) VALUES('1183', '', '', '');
+
+DROP TABLE IF EXISTS `fieldgroups`;
+CREATE TABLE `fieldgroups` (
+ `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+ `name` varchar(250) CHARACTER SET ascii COLLATE ascii_general_ci NOT NULL,
+ PRIMARY KEY (`id`),
+ UNIQUE KEY `name` (`name`)
+) ENGINE=MyISAM AUTO_INCREMENT=118 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('2', 'admin');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('3', 'user');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('4', 'role');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('5', 'permission');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('1', 'inicio');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('83', 'paxina');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('97', 'language');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('98', 'repeater_configuracion');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('105', 'habitacion');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('100', 'repeater_seccions');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('101', 'contacto');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('102', 'blogue');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('103', 'repeater_ligazon_imaxe');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('117', 'repeater_botons');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('106', 'habitacions');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('108', 'xes-inicio');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('109', 'xes-acceder');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('110', 'xes-panel');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('111', 'publicacion');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('112', 'etiqueta');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('113', 'categoria');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('114', 'contedor');
+INSERT INTO `fieldgroups` (`id`, `name`) VALUES('116', 'bs-inicio');
+
+DROP TABLE IF EXISTS `fieldgroups_fields`;
+CREATE TABLE `fieldgroups_fields` (
+ `fieldgroups_id` int(10) unsigned NOT NULL DEFAULT 0,
+ `fields_id` int(10) unsigned NOT NULL DEFAULT 0,
+ `sort` int(11) unsigned NOT NULL DEFAULT 0,
+ `data` text DEFAULT NULL,
+ PRIMARY KEY (`fieldgroups_id`,`fields_id`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('2', '2', '1', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('3', '92', '1', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('4', '5', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('5', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('3', '4', '2', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('103', '117', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('3', '3', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('97', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('97', '98', '1', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('3', '97', '3', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('2', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('98', '102', '2', '{\"showIf\":\"parametro_tipo=1\"}');
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('98', '101', '1', '{\"showIf\":\"parametro_tipo=1|2\"}');
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('103', '123', '2', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('100', '117', '1', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('100', '110', '2', '{\"showIf\":\"seccion_tipo=2|3\"}');
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('100', '109', '3', '{\"showIf\":\"seccion_tipo=4\"}');
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('100', '104', '4', '{\"showIf\":\"seccion_tipo=4\"}');
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('100', '105', '5', '{\"showIf\":\"seccion_tipo=1|4\"}');
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('1', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('1', '111', '1', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('97', '99', '2', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('101', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('102', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('101', '112', '1', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('98', '122', '3', '{\"showIf\":\"parametro_tipo=2\"}');
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('83', '111', '1', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('116', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('108', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('103', '104', '1', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('100', '131', '6', '{\"showIf\":\"seccion_tipo=1|4\"}');
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('98', '117', '5', '{\"showIf\":\"parametro_tipo=3,parametro_mantemento=1\"}');
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('98', '105', '6', '{\"showIf\":\"parametro_tipo=3,parametro_mantemento=1\"}');
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('98', '104', '7', '{\"showIf\":\"parametro_tipo=3,parametro_mantemento=1\"}');
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('98', '110', '8', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('3', '100', '4', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('105', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('106', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('106', '111', '1', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('106', '115', '2', '{\"label\":\"Habitaciones\",\"label1023\":\"Habitacions\",\"label1024\":\"Bedrooms\"}');
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('105', '111', '1', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('83', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('108', '103', '1', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('109', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('110', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('111', '125', '4', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('112', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('113', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('114', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('111', '127', '1', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('111', '104', '2', '{\"label\":\"Imagen destacada\",\"label1023\":\"Imaxe destacada\",\"label1024\":\"Featured Image\"}');
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('111', '111', '3', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('111', '1', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('111', '126', '5', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('111', '128', '6', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('98', '107', '4', '{\"showIf\":\"parametro_tipo=3\"}');
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('98', '120', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('117', '132', '0', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('117', '123', '1', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('117', '102', '2', NULL);
+INSERT INTO `fieldgroups_fields` (`fieldgroups_id`, `fields_id`, `sort`, `data`) VALUES('100', '108', '0', NULL);
+
+DROP TABLE IF EXISTS `fields`;
+CREATE TABLE `fields` (
+ `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+ `type` varchar(128) CHARACTER SET ascii COLLATE ascii_general_ci NOT NULL,
+ `name` varchar(250) CHARACTER SET ascii COLLATE ascii_general_ci NOT NULL,
+ `flags` int(11) NOT NULL DEFAULT 0,
+ `label` varchar(250) NOT NULL DEFAULT '',
+ `data` text NOT NULL,
+ PRIMARY KEY (`id`),
+ UNIQUE KEY `name` (`name`),
+ KEY `type` (`type`)
+) ENGINE=MyISAM AUTO_INCREMENT=133 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('1', 'FieldtypePageTitleLanguage', 'title', '13', 'Titulo', '{\"required\":1,\"textformatters\":[\"TextformatterEntities\"],\"size\":0,\"maxlength\":255,\"minlength\":0,\"showCount\":0,\"label1023\":\"T\\u00edtulo\",\"label1024\":\"Title\",\"langBlankInherit\":0,\"tags\":\"paxinas\"}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('2', 'FieldtypeModule', 'process', '25', 'Process', '{\"description\":\"The process that is executed on this page. Since this is mostly used by ProcessWire internally, it is recommended that you don\'t change the value of this unless adding your own pages in the admin.\",\"collapsed\":1,\"required\":1,\"moduleTypes\":[\"Process\"],\"permanent\":1}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('3', 'FieldtypePassword', 'pass', '24', 'Set Password', '{\"collapsed\":1,\"size\":50,\"maxlength\":128}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('5', 'FieldtypePage', 'permissions', '24', 'Permissions', '{\"derefAsPage\":0,\"parent_id\":31,\"labelFieldName\":\"title\",\"inputfield\":\"InputfieldCheckboxes\"}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('4', 'FieldtypePage', 'roles', '24', 'Roles', '{\"derefAsPage\":0,\"parent_id\":30,\"labelFieldName\":\"name\",\"inputfield\":\"InputfieldCheckboxes\",\"description\":\"User will inherit the permissions assigned to each role. You may assign multiple roles to a user. When accessing a page, the user will only inherit permissions from the roles that are also assigned to the page\'s template.\"}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('92', 'FieldtypeEmail', 'email', '9', 'Dirección de correo electrónico', '{\"size\":70,\"maxlength\":255,\"tags\":\"usuarios\",\"label1023\":\"Enderezo electr\\u00f3nico\",\"label1024\":\"E-Mail Address\",\"collapsed\":0,\"minlength\":0,\"showCount\":0}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('97', 'FieldtypeModule', 'admin_theme', '8', 'Admin Theme', '{\"moduleTypes\":[\"AdminTheme\"],\"labelField\":\"title\",\"inputfieldClass\":\"InputfieldRadios\"}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('98', 'FieldtypeFile', 'language_files_site', '24', 'Site Translation Files', '{\"extensions\":\"json csv\",\"maxFiles\":0,\"inputfieldClass\":\"InputfieldFile\",\"unzip\":1,\"description\":\"Use this field for translations specific to your site (like files in \\/site\\/templates\\/ for example).\",\"descriptionRows\":0,\"fileSchema\":14}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('99', 'FieldtypeFile', 'language_files', '24', 'Core Translation Files', '{\"extensions\":\"json csv\",\"maxFiles\":0,\"inputfieldClass\":\"InputfieldFile\",\"unzip\":1,\"description\":\"Use this field for [language packs](http:\\/\\/modules.processwire.com\\/categories\\/language-pack\\/). To delete all files, double-click the trash can for any file, then save.\",\"descriptionRows\":0,\"fileSchema\":14}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('100', 'FieldtypePage', 'language', '24', 'Language', '{\"derefAsPage\":1,\"parent_id\":1016,\"labelFieldName\":\"title\",\"inputfield\":\"InputfieldRadios\",\"required\":1}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('101', 'FieldtypeTextUnique', 'parametro_nome', '256', 'Parámetro', '{\"label1023\":\"Par\\u00e1metro\",\"label1024\":\"Parameter\",\"minlength\":0,\"maxlength\":2048,\"showCount\":0,\"size\":0,\"tags\":\"configuracion_sitio\",\"collapsed\":0}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('102', 'FieldtypeTextLanguage', 'parametro_valor', '0', 'Valor', '{\"label1023\":\"Valor\",\"label1024\":\"Value\",\"tags\":\"configuracion_sitio\",\"langBlankInherit\":0,\"collapsed\":0,\"minlength\":0,\"maxlength\":2048,\"showCount\":0,\"size\":0}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('103', 'FieldtypeRepeater', 'configuracion', '0', 'Configuración', '{\"label1023\":\"Configuraci\\u00f3n\",\"label1024\":\"Settings\",\"template_id\":44,\"parent_id\":1025,\"tags\":\"configuracion_sitio\",\"repeaterCollapse\":0,\"repeaterLoading\":1,\"familyFriendly\":0,\"collapsed\":0,\"repeaterFields\":[120,101,102,122,107,117,105,104,110],\"rememberOpen\":0,\"accordionMode\":0,\"loudControls\":0}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('104', 'FieldtypeImage', 'imaxe', '0', 'Imagen', '{\"label1023\":\"Imaxe\",\"label1024\":\"Image\",\"fileSchema\":270,\"tags\":\"paxinas\",\"extensions\":\"gif jpg jpeg png svg\",\"maxFiles\":1,\"outputFormat\":2,\"descriptionRows\":1,\"useTags\":0,\"gridMode\":\"grid\",\"focusMode\":\"on\",\"resizeServer\":0,\"clientQuality\":90,\"maxReject\":0,\"dimensionsByAspectRatio\":0,\"defaultValuePage\":0,\"inputfieldClass\":\"InputfieldImage\",\"collapsed\":0}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('105', 'FieldtypeTextareaLanguage', 'artigo', '0', 'Articulo', '{\"label1023\":\"Artigo\",\"label1024\":\"Article\",\"tags\":\"paxinas\",\"inputfieldClass\":\"InputfieldCKEditor\",\"contentType\":1,\"htmlOptions\":[2,4,8,16],\"langBlankInherit\":0,\"collapsed\":0,\"minlength\":0,\"maxlength\":0,\"showCount\":0,\"rows\":5}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('107', 'FieldtypeCheckbox', 'parametro_mantemento', '0', 'Mantenimiento', '{\"label1023\":\"Mantemento\",\"label1024\":\"Maintenance\",\"tags\":\"configuracion_sitio\",\"collapsed\":0}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('131', 'FieldtypeRepeater', 'botons', '0', 'Botones', '{\"label1023\":\"Bot\\u00f3ns\",\"label1024\":\"Buttons\",\"template_id\":63,\"parent_id\":1157,\"tags\":\"paxinas\",\"familyFriendly\":0,\"repeaterCollapse\":0,\"repeaterLoading\":1,\"rememberOpen\":0,\"accordionMode\":0,\"loudControls\":0,\"collapsed\":0,\"repeaterFields\":[132,123,102]}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('108', 'FieldtypeOptions', 'seccion_tipo', '0', 'Tipo Sección', '{\"label1023\":\"Tipo Secci\\u00f3n\",\"label1024\":\"Section Type\",\"inputfieldClass\":\"InputfieldSelect\",\"collapsed\":0,\"tags\":\"paxinas\"}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('109', 'FieldtypeOptions', 'imaxe_posicion', '0', 'Posición de la imagen', '{\"label1023\":\"Posici\\u00f3n da imaxe\",\"label1024\":\"Image position\",\"inputfieldClass\":\"InputfieldSelect\",\"collapsed\":0,\"tags\":\"paxinas\"}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('110', 'FieldtypeImage', 'imaxes', '0', 'Imagenes', '{\"label1023\":\"Imaxes\",\"label1024\":\"Images\",\"fileSchema\":271,\"tags\":\"paxinas\",\"extensions\":\"gif jpg jpeg png\",\"maxFiles\":0,\"outputFormat\":0,\"descriptionRows\":1,\"useTags\":9,\"gridMode\":\"grid\",\"focusMode\":\"on\",\"resizeServer\":0,\"clientQuality\":90,\"maxReject\":0,\"dimensionsByAspectRatio\":0,\"defaultValuePage\":0,\"inputfieldClass\":\"InputfieldImage\",\"collapsed\":0}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('111', 'FieldtypeRepeater', 'seccions', '0', 'Secciones', '{\"label1023\":\"Secci\\u00f3ns\",\"label1024\":\"Sections\",\"template_id\":46,\"parent_id\":1027,\"tags\":\"paxinas\",\"repeaterFields\":{\"0\":108,\"1\":117,\"2\":110,\"4\":109,\"5\":104,\"6\":105,\"7\":131},\"repeaterCollapse\":0,\"repeaterLoading\":1,\"familyFriendly\":0,\"collapsed\":0,\"rememberOpen\":0,\"accordionMode\":0,\"loudControls\":0}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('112', 'FieldtypeMapMarker', 'mapa', '0', 'Mapa', '{\"label1023\":\"Mapa\",\"label1024\":\"Map\",\"schemaVersion\":1,\"collapsed\":0,\"defaultAddr\":\"Lugar de Seselle, 34 15623 Ares La Coru\\u00f1a\",\"defaultType\":\"SATELLITE\",\"height\":300,\"defaultZoom\":12,\"tags\":\"paxinas\"}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('123', 'FieldtypePage', 'ligazon_interna', '0', 'Enlace interno', '{\"label1023\":\"Ligaz\\u00f3n interna\",\"label1024\":\"Internal link\",\"derefAsPage\":1,\"inputfield\":\"InputfieldSelect\",\"parent_id\":0,\"labelFieldName\":\"title\",\"collapsed\":0,\"tags\":\"paxinas\",\"template_id\":51,\"template_ids\":[29]}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('115', 'FieldtypeRepeater', 'ligazon_imaxe', '0', 'Imagen con enlace', '{\"label1023\":\"Imaxe con ligaz\\u00f3n\",\"label1024\":\"Image with link\",\"template_id\":49,\"parent_id\":1066,\"repeaterFields\":[117,104,123],\"repeaterCollapse\":0,\"repeaterLoading\":1,\"familyFriendly\":0,\"collapsed\":0,\"tags\":\"paxinas\",\"rememberOpen\":0,\"accordionMode\":0,\"loudControls\":0}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('132', 'FieldtypeOptions', 'botons_estilo', '0', 'Estilo', '{\"label1023\":\"Estilo\",\"label1024\":\"Style\",\"inputfieldClass\":\"InputfieldSelect\",\"collapsed\":0,\"tags\":\"paxinas\"}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('117', 'FieldtypeTextLanguage', 'titular', '0', 'Titular', '{\"label1023\":\"Titular\",\"label1024\":\"Headline\",\"langBlankInherit\":0,\"collapsed\":0,\"minlength\":0,\"maxlength\":2048,\"showCount\":0,\"size\":0,\"tags\":\"paxinas\"}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('120', 'FieldtypeOptions', 'parametro_tipo', '0', 'Tipo de parámetro', '{\"label1023\":\"Tipo de par\\u00e1metro\",\"label1024\":\"Parameter type\",\"inputfieldClass\":\"InputfieldSelect\",\"collapsed\":0,\"tags\":\"configuracion_sitio\"}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('122', 'FieldtypeColorPicker', 'parametro_cor', '0', 'Color', '{\"label1023\":\"Cor\",\"label1024\":\"Colour\",\"collapsed\":0,\"tags\":\"configuracion_sitio\"}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('125', 'FieldtypePage', 'categorias', '0', 'CategorÃas', '{\"label1023\":\"Categor\\u00edas\",\"label1024\":\"Categories\",\"tags\":\"blog\",\"derefAsPage\":1,\"inputfield\":\"InputfieldSelect\",\"parent_id\":1125,\"labelFieldName\":\"title\",\"addable\":1,\"collapsed\":0,\"template_id\":59}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('126', 'FieldtypePage', 'etiquetas', '0', 'Etiquetas', '{\"label1023\":\"Etiquetas\",\"label1024\":\"Tags\",\"tags\":\"blog\",\"derefAsPage\":0,\"inputfield\":\"InputfieldAsmSelect\",\"parent_id\":1126,\"labelFieldName\":\"title\",\"addable\":1,\"collapsed\":0,\"usePageEdit\":0,\"template_id\":58}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('127', 'FieldtypeDatetime', 'fecha_publicacion', '0', 'Fecha de Publicación', '{\"label1023\":\"Data de Publicaci\\u00f3n\",\"label1024\":\"Publication Date\",\"tags\":\"blog\",\"dateOutputFormat\":\"Y-m-d\",\"collapsed\":0,\"inputType\":\"text\",\"htmlType\":\"date\",\"dateSelectFormat\":\"yMd\",\"yearFrom\":1922,\"yearTo\":2042,\"yearLock\":0,\"datepicker\":3,\"timeInputSelect\":0,\"dateInputFormat\":\"Y\\/m\\/d\",\"size\":25,\"defaultToday\":1}');
+INSERT INTO `fields` (`id`, `type`, `name`, `flags`, `label`, `data`) VALUES('128', 'FieldtypeComments', 'comentarios', '0', 'Comentarios', '{\"label1023\":\"Comentarios\",\"label1024\":\"Comments\",\"tags\":\"blog\",\"moderate\":1,\"redirectAfterPost\":1,\"quietSave\":1,\"useNotify\":0,\"useNotifyText\":1,\"deleteSpamDays\":3,\"depth\":0,\"dateFormat\":\"relative\",\"useVotes\":0,\"useStars\":0,\"useGravatar\":\"g\",\"schemaVersion\":7}');
+
+DROP TABLE IF EXISTS `fieldtype_options`;
+CREATE TABLE `fieldtype_options` (
+ `fields_id` int(10) unsigned NOT NULL,
+ `option_id` int(10) unsigned NOT NULL,
+ `title` text DEFAULT NULL,
+ `value` varchar(230) DEFAULT NULL,
+ `sort` int(10) unsigned NOT NULL,
+ `title1023` text DEFAULT NULL,
+ `value1023` varchar(230) DEFAULT NULL,
+ `title1024` text DEFAULT NULL,
+ `value1024` varchar(230) DEFAULT NULL,
+ PRIMARY KEY (`fields_id`,`option_id`),
+ UNIQUE KEY `title` (`title`(230),`fields_id`),
+ UNIQUE KEY `title1023` (`title1023`(230),`fields_id`),
+ UNIQUE KEY `title1024` (`title1024`(230),`fields_id`),
+ KEY `value` (`value`,`fields_id`),
+ KEY `sort` (`sort`,`fields_id`),
+ KEY `value1023` (`value1023`,`fields_id`),
+ KEY `value1024` (`value1024`,`fields_id`),
+ FULLTEXT KEY `title_ft` (`title`),
+ FULLTEXT KEY `value_ft` (`value`),
+ FULLTEXT KEY `title1023_ft` (`title1023`),
+ FULLTEXT KEY `value1023_ft` (`value1023`),
+ FULLTEXT KEY `title1024_ft` (`title1024`),
+ FULLTEXT KEY `value1024_ft` (`value1024`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('108', '1', 'Texto', 'texto', '0', 'Texto', 'texto', 'Texto', 'texto');
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('108', '4', 'Imagen con texto lateral', 'imaxe_texto_lateral', '3', 'Imaxe con texto lateral', 'imaxe_texto_lateral', 'Image with side text', 'imaxe_texto_lateral');
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('108', '3', 'Cuadricula de imágenes', 'reixa', '2', 'Reixa de imaxes', 'reixa', 'Image grid', 'reixa');
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('120', '1', 'Texto', 'texto', '0', 'Texto', 'texto', 'Texto', 'texto');
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('108', '2', 'GalerÃa de imágenes', 'galeria', '1', 'GalerÃa de imaxes', 'galeria', 'Image gallery', 'galeria');
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('109', '1', 'Izquierda', 'esquerda', '0', 'Esquerda', 'esquerda', 'Left', 'esquerda');
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('109', '2', 'Derecha', 'dereita', '1', 'Dereita', 'dereita', 'Right', 'dereita');
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('120', '2', 'Color', 'cor', '1', 'Cor', 'cor', 'Colour', 'cor');
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('120', '3', 'Mantenimiento', 'mantemento', '2', NULL, NULL, NULL, NULL);
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('132', '1', 'Activo', 'activo', '0', 'Activo', 'activo', 'Active', 'activo');
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('132', '2', 'Secundario', 'secundario', '1', 'Secundario', 'secundario', 'Secondary', 'secundario');
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('109', '3', 'Superior', 'superior', '2', NULL, NULL, NULL, NULL);
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('132', '3', 'Inactivo', 'inactivo', '2', 'Inactivo', 'inactivo', 'Inactive', 'inactivo');
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('132', '4', 'Enlace', 'ligazon', '3', 'Ligazón', 'ligazon', 'Link', 'ligazon');
+INSERT INTO `fieldtype_options` (`fields_id`, `option_id`, `title`, `value`, `sort`, `title1023`, `value1023`, `title1024`, `value1024`) VALUES('132', '5', 'Aviso', 'aviso', '4', 'Aviso', 'aviso', 'Warning', 'aviso');
+
+DROP TABLE IF EXISTS `modules`;
+CREATE TABLE `modules` (
+ `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+ `class` varchar(128) CHARACTER SET ascii COLLATE ascii_general_ci NOT NULL,
+ `flags` int(11) NOT NULL DEFAULT 0,
+ `data` text NOT NULL,
+ `created` timestamp NOT NULL DEFAULT current_timestamp(),
+ PRIMARY KEY (`id`),
+ UNIQUE KEY `class` (`class`)
+) ENGINE=MyISAM AUTO_INCREMENT=193 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('1', 'FieldtypeTextarea', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('164', 'ProcessLanguage', '1', '', '2022-03-08 13:36:17');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('3', 'FieldtypeText', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('4', 'FieldtypePage', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('30', 'InputfieldForm', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('6', 'FieldtypeFile', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('7', 'ProcessPageEdit', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('10', 'ProcessLogin', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('12', 'ProcessPageList', '0', '{\"pageLabelField\":\"title\",\"paginationLimit\":25,\"limit\":50}', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('121', 'ProcessPageEditLink', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('14', 'ProcessPageSort', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('15', 'InputfieldPageListSelect', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('117', 'JqueryUI', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('17', 'ProcessPageAdd', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('125', 'SessionLoginThrottle', '11', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('122', 'InputfieldPassword', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('25', 'InputfieldAsmSelect', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('116', 'JqueryCore', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('27', 'FieldtypeModule', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('28', 'FieldtypeDatetime', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('29', 'FieldtypeEmail', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('108', 'InputfieldURL', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('32', 'InputfieldSubmit', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('34', 'InputfieldText', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('35', 'InputfieldTextarea', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('36', 'InputfieldSelect', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('37', 'InputfieldCheckbox', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('38', 'InputfieldCheckboxes', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('39', 'InputfieldRadios', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('40', 'InputfieldHidden', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('41', 'InputfieldName', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('43', 'InputfieldSelectMultiple', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('45', 'JqueryWireTabs', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('165', 'ProcessLanguageTranslator', '1', '', '2022-03-08 13:36:18');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('47', 'ProcessTemplate', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('48', 'ProcessField', '32', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('50', 'ProcessModule', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('114', 'PagePermissions', '3', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('97', 'FieldtypeCheckbox', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('115', 'PageRender', '3', '{\"clearCache\":1}', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('55', 'InputfieldFile', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('56', 'InputfieldImage', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('57', 'FieldtypeImage', '32', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('60', 'InputfieldPage', '0', '{\"inputfieldClasses\":[\"InputfieldSelect\",\"InputfieldSelectMultiple\",\"InputfieldCheckboxes\",\"InputfieldRadios\",\"InputfieldAsmSelect\",\"InputfieldPageListSelect\",\"InputfieldPageListSelectMultiple\",\"InputfieldPageAutocomplete\"]}', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('61', 'TextformatterEntities', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('66', 'ProcessUser', '0', '{\"showFields\":[\"name\",\"email\",\"roles\"]}', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('67', 'MarkupAdminDataTable', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('68', 'ProcessRole', '0', '{\"showFields\":[\"name\"]}', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('76', 'ProcessList', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('78', 'InputfieldFieldset', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('79', 'InputfieldMarkup', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('80', 'InputfieldEmail', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('89', 'FieldtypeFloat', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('83', 'ProcessPageView', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('84', 'FieldtypeInteger', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('85', 'InputfieldInteger', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('86', 'InputfieldPageName', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('87', 'ProcessHome', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('90', 'InputfieldFloat', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('94', 'InputfieldDatetime', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('98', 'MarkupPagerNav', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('129', 'ProcessPageEditImageSelect', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('103', 'JqueryTableSorter', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('104', 'ProcessPageSearch', '1', '{\"searchFields\":\"title\",\"displayField\":\"title path\"}', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('105', 'FieldtypeFieldsetOpen', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('106', 'FieldtypeFieldsetClose', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('107', 'FieldtypeFieldsetTabOpen', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('109', 'ProcessPageTrash', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('111', 'FieldtypePageTitle', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('112', 'InputfieldPageTitle', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('113', 'MarkupPageArray', '3', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('131', 'InputfieldButton', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('133', 'FieldtypePassword', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('134', 'ProcessPageType', '33', '{\"showFields\":[]}', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('135', 'FieldtypeURL', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('136', 'ProcessPermission', '1', '{\"showFields\":[\"name\",\"title\"]}', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('137', 'InputfieldPageListSelectMultiple', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('138', 'ProcessProfile', '1', '{\"profileFields\":[\"pass\",\"email\",\"admin_theme\",\"language\"]}', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('139', 'SystemUpdater', '1', '{\"systemVersion\":20,\"coreVersion\":\"3.0.200\"}', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('148', 'AdminThemeDefault', '10', '{\"colors\":\"classic\"}', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('149', 'InputfieldSelector', '42', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('150', 'ProcessPageLister', '32', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('151', 'JqueryMagnific', '1', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('155', 'InputfieldCKEditor', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('156', 'MarkupHTMLPurifier', '0', '', '2022-03-08 13:14:32');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('163', 'LanguageSupport', '35', '{\"languagesPageID\":1016,\"defaultLanguagePageID\":1017,\"otherLanguagePageIDs\":[1023,1024],\"languageTranslatorPageID\":1018}', '2022-03-08 13:36:17');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('159', 'ProcessRecentPages', '1', '', '2022-03-08 13:15:20');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('160', 'AdminThemeUikit', '10', '', '2022-03-08 13:15:20');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('161', 'ProcessLogger', '1', '', '2022-03-08 13:15:53');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('162', 'InputfieldIcon', '0', '', '2022-03-08 13:15:53');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('166', 'LanguageTabs', '11', '', '2022-03-08 13:36:48');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('167', 'LanguageSupportFields', '3', '', '2022-03-08 13:36:51');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('168', 'FieldtypeTextLanguage', '1', '', '2022-03-08 13:36:51');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('169', 'FieldtypePageTitleLanguage', '1', '', '2022-03-08 13:36:51');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('170', 'FieldtypeTextareaLanguage', '1', '', '2022-03-08 13:36:51');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('171', 'LanguageSupportPageNames', '3', '{\"moduleVersion\":13}', '2022-03-08 13:37:02');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('172', 'FieldtypeOptions', '1', '', '2022-03-08 13:41:16');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('173', 'FieldtypeRepeater', '35', '{\"repeatersRootPageID\":1019,\"uninstall\":\"\",\"submit_save_module\":\"Submit\"}', '2022-03-08 13:41:44');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('174', 'InputfieldRepeater', '0', '', '2022-03-08 13:41:44');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('175', 'InputfieldTextTags', '0', '', '2022-03-08 13:44:25');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('176', 'InputfieldToggle', '0', '', '2022-03-08 13:44:44');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('177', 'FieldtypeMapMarker', '1', '{\"googleApiKey\":\"AIzaSyAe20rnfPBmOKweyK9JXMj8QNZkc0LS6ng\",\"uninstall\":\"\",\"submit_save_module\":\"Submit\"}', '2022-03-08 13:51:34');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('178', 'InputfieldMapMarker', '0', '', '2022-03-08 13:51:34');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('179', 'FieldtypeTextUnique', '1', '', '2022-03-08 13:51:49');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('180', 'MarkupGoogleMap', '0', '', '2022-03-08 13:52:09');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('181', 'ProcessDatabaseBackups', '1', '', '2022-03-08 13:52:16');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('182', 'ProcessWireUpgrade', '1', '', '2022-03-08 13:52:20');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('183', 'ProcessWireUpgradeCheck', '11', '{\"useLoginHook\":\"0\",\"uninstall\":\"\",\"submit_save_module\":\"Submit\"}', '2022-03-08 13:52:20');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('184', 'FileValidatorSvgSanitizer', '0', '', '2022-04-05 11:06:56');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('185', 'FieldtypeColorPicker', '1', '', '2022-05-02 13:19:14');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('186', 'InputfieldColorPicker', '0', '', '2022-05-02 13:19:14');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('187', 'InputfieldPageAutocomplete', '0', '', '2022-05-02 15:59:50');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('189', 'FieldtypeComments', '1', '', '2022-10-25 12:14:55');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('190', 'InputfieldCommentsAdmin', '0', '', '2022-10-25 12:14:55');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('191', 'CommentFilterAkismet', '0', '{\"apiKey\":\"\",\"uninstall\":\"\",\"submit_save_module\":\"Submit\"}', '2022-10-25 12:15:06');
+INSERT INTO `modules` (`id`, `class`, `flags`, `data`, `created`) VALUES('192', 'PageFrontEdit', '2', '{\"inlineEditFields\":[],\"inlineLimitPage\":1,\"buttonLocation\":\"auto\",\"buttonType\":\"auto\"}', '2022-11-21 13:22:40');
+
+DROP TABLE IF EXISTS `pages`;
+CREATE TABLE `pages` (
+ `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+ `parent_id` int(11) unsigned NOT NULL DEFAULT 0,
+ `templates_id` int(11) unsigned NOT NULL DEFAULT 0,
+ `name` varchar(128) CHARACTER SET ascii COLLATE ascii_general_ci NOT NULL,
+ `status` int(10) unsigned NOT NULL DEFAULT 1,
+ `modified` timestamp NOT NULL DEFAULT current_timestamp(),
+ `modified_users_id` int(10) unsigned NOT NULL DEFAULT 2,
+ `created` timestamp NOT NULL DEFAULT '2015-12-18 06:09:00',
+ `created_users_id` int(10) unsigned NOT NULL DEFAULT 2,
+ `published` datetime DEFAULT NULL,
+ `sort` int(11) NOT NULL DEFAULT 0,
+ `name1023` varchar(128) CHARACTER SET ascii COLLATE ascii_general_ci DEFAULT NULL,
+ `status1023` int(10) unsigned NOT NULL DEFAULT 1,
+ `name1024` varchar(128) CHARACTER SET ascii COLLATE ascii_general_ci DEFAULT NULL,
+ `status1024` int(10) unsigned NOT NULL DEFAULT 1,
+ PRIMARY KEY (`id`),
+ UNIQUE KEY `name_parent_id` (`name`,`parent_id`),
+ KEY `parent_id` (`parent_id`),
+ KEY `templates_id` (`templates_id`),
+ KEY `modified` (`modified`),
+ KEY `created` (`created`),
+ KEY `status` (`status`),
+ KEY `published` (`published`),
+ KEY `parent_name1023` (`parent_id`,`name1023`),
+ KEY `parent_name1024` (`parent_id`,`name1024`)
+) ENGINE=MyISAM AUTO_INCREMENT=1188 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1', '0', '1', 'es', '9', '2023-02-18 12:06:11', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '0', 'gl', '1', 'en', '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('2', '1', '2', 'pwadmin', '1035', '2022-03-08 13:15:20', '40', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '12', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('3', '2', '2', 'page', '21', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('6', '3', '2', 'add', '21', '2022-03-08 13:15:56', '40', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('7', '1', '2', 'trash', '1039', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '13', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('8', '3', '2', 'list', '21', '2022-03-08 13:16:18', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('9', '3', '2', 'sort', '1047', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '3', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('10', '3', '2', 'edit', '1045', '2022-03-08 13:16:18', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '4', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('11', '22', '2', 'template', '21', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('16', '22', '2', 'field', '21', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('21', '2', '2', 'module', '21', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('22', '2', '2', 'setup', '21', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('23', '2', '2', 'login', '1035', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '4', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('27', '1', '29', 'http404', '1035', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '3', '2022-03-08 13:14:32', '11', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('28', '2', '2', 'access', '13', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '3', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('29', '28', '2', 'users', '29', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('30', '28', '2', 'roles', '29', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('31', '28', '2', 'permissions', '29', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('32', '31', '5', 'page-edit', '25', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('34', '31', '5', 'page-delete', '25', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '3', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('35', '31', '5', 'page-move', '25', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '4', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('36', '31', '5', 'page-view', '25', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('37', '30', '4', 'guest', '25', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('38', '30', '4', 'superuser', '25', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('41', '29', '3', 'laegnur', '1', '2022-03-08 13:36:18', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('40', '29', '3', 'guest', '25', '2022-03-08 13:36:18', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('50', '31', '5', 'page-sort', '25', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '5', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('51', '31', '5', 'page-template', '25', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '6', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('52', '31', '5', 'user-admin', '25', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '10', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('53', '31', '5', 'profile-edit', '1', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '13', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('54', '31', '5', 'page-lock', '1', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '8', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('300', '3', '2', 'search', '1045', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '6', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('301', '3', '2', 'trash', '1047', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '6', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('302', '3', '2', 'link', '1041', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '7', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('303', '3', '2', 'image', '1041', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '8', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('304', '2', '2', 'profile', '1025', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '41', '2022-03-08 13:14:32', '5', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1006', '31', '5', 'page-lister', '1', '2022-03-08 13:14:32', '40', '2022-03-08 13:14:32', '40', '2022-03-08 13:14:32', '9', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1007', '3', '2', 'lister', '1', '2022-03-08 13:14:32', '40', '2022-03-08 13:14:32', '40', '2022-03-08 13:14:32', '9', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1010', '3', '2', 'recent-pages', '1', '2022-03-08 13:15:20', '40', '2022-03-08 13:15:20', '40', '2022-03-08 13:15:20', '10', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1011', '31', '5', 'page-edit-recent', '1', '2022-03-08 13:15:20', '40', '2022-03-08 13:15:20', '40', '2022-03-08 13:15:20', '10', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1012', '22', '2', 'logs', '1', '2022-03-08 13:15:53', '40', '2022-03-08 13:15:53', '40', '2022-03-08 13:15:53', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1013', '31', '5', 'logs-view', '1', '2022-03-08 13:15:53', '40', '2022-03-08 13:15:53', '40', '2022-03-08 13:15:53', '11', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1014', '31', '5', 'logs-edit', '1', '2022-03-08 13:15:53', '40', '2022-03-08 13:15:53', '40', '2022-03-08 13:15:53', '12', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1015', '31', '5', 'lang-edit', '1', '2022-03-08 13:36:17', '41', '2022-03-08 13:36:17', '41', '2022-03-08 13:36:17', '13', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1016', '22', '2', 'languages', '16', '2022-03-08 13:36:17', '41', '2022-03-08 13:36:17', '41', '2022-03-08 13:36:17', '3', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1017', '1016', '43', 'default', '16', '2022-10-27 14:04:32', '41', '2022-03-08 13:36:18', '41', '2022-03-08 13:36:18', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1018', '22', '2', 'language-translator', '1040', '2022-03-08 13:36:18', '41', '2022-03-08 13:36:18', '41', '2022-03-08 13:36:18', '4', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1019', '2', '2', 'repeaters', '1036', '2022-03-08 13:41:44', '41', '2022-03-08 13:41:44', '41', '2022-03-08 13:41:44', '6', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1020', '22', '2', 'db-backups', '1', '2022-03-08 13:52:16', '41', '2022-03-08 13:52:16', '41', '2022-03-08 13:52:16', '5', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1021', '31', '5', 'db-backup', '1', '2022-03-08 13:52:16', '41', '2022-03-08 13:52:16', '41', '2022-03-08 13:52:16', '14', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1022', '22', '2', 'upgrades', '1', '2022-03-08 13:52:20', '41', '2022-03-08 13:52:20', '41', '2022-03-08 13:52:20', '6', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1023', '1016', '43', 'gl', '1', '2022-10-27 14:05:04', '41', '2022-03-08 17:06:01', '41', '2022-03-08 17:06:01', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1024', '1016', '43', 'en', '1', '2022-10-27 14:06:52', '41', '2022-03-08 17:08:22', '41', '2022-03-08 17:08:22', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1025', '1019', '2', 'for-field-103', '17', '2022-03-08 17:30:20', '41', '2022-03-08 17:30:20', '41', '2022-03-08 17:30:20', '0', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1075', '1027', '2', 'for-page-1', '17', '2022-04-07 12:54:39', '41', '2022-04-07 12:54:39', '41', '2022-04-07 12:54:39', '4', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1027', '1019', '2', 'for-field-111', '17', '2022-11-21 13:00:25', '41', '2022-03-08 18:03:26', '41', '2022-03-08 18:03:26', '2', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1142', '1140', '44', '1669033522-4897-1', '1', '2022-11-21 13:40:40', '41', '2022-11-21 13:25:22', '41', '2022-11-21 13:28:01', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1115', '1075', '46', '1664874598-772-1', '1', '2022-10-25 11:28:11', '41', '2022-10-04 11:09:58', '41', '2022-10-04 11:10:48', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1160', '1027', '2', 'for-page-1101', '17', '2023-02-18 10:34:10', '41', '2023-02-18 10:34:10', '41', '2023-02-18 10:34:10', '8', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1033', '1027', '2', 'for-page-27', '17', '2022-03-08 23:27:44', '41', '2022-03-08 23:27:44', '41', '2022-03-08 23:27:44', '0', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1146', '1140', '44', '1669033598-8439-1', '1', '2022-11-21 13:40:40', '41', '2022-11-21 13:26:38', '41', '2022-11-21 13:28:01', '4', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1034', '1', '52', 'habitaciones', '1', '2023-02-18 15:52:14', '41', '2022-03-14 12:49:50', '41', '2022-03-14 12:50:00', '3', 'habitacions', '1', 'rooms', '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1035', '1027', '2', 'for-page-1034', '17', '2022-03-14 12:49:50', '41', '2022-03-14 12:49:50', '41', '2022-03-14 12:49:50', '1', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1036', '1', '29', 'servicios', '1', '2022-10-27 14:19:38', '41', '2022-03-14 12:50:44', '41', '2022-03-14 12:50:52', '4', 'servizos', '1', 'services', '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1037', '1027', '2', 'for-page-1036', '17', '2022-03-14 12:50:44', '41', '2022-03-14 12:50:44', '41', '2022-03-14 12:50:44', '2', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1038', '1', '29', 'entorno', '1', '2022-10-27 14:22:55', '41', '2022-03-14 12:51:13', '41', '2022-03-14 12:51:15', '5', 'arredores', '1', 'surroundings', '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1039', '1027', '2', 'for-page-1038', '17', '2022-03-14 12:51:13', '41', '2022-03-14 12:51:13', '41', '2022-03-14 12:51:13', '3', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1040', '1', '48', 'noticias', '1', '2022-04-03 15:51:47', '1045', '2022-03-14 12:51:46', '41', '2022-03-14 12:51:47', '6', 'novidades', '1', 'news', '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1042', '1', '47', 'contacto', '1', '2022-03-14 12:53:17', '41', '2022-03-14 12:53:15', '41', '2022-03-14 12:53:17', '8', NULL, '1', 'contact', '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1043', '1037', '46', '1647785951-306-1', '1', '2022-10-27 14:19:38', '41', '2022-03-20 15:19:11', '41', '2022-10-27 14:19:38', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1045', '29', '3', 'aldara', '1', '2022-03-20 15:20:59', '41', '2022-03-20 15:19:36', '41', '2022-03-20 15:20:59', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1079', '1027', '2', 'for-page-1078', '17', '2022-04-07 14:44:32', '41', '2022-04-07 14:44:32', '41', '2022-04-07 14:44:32', '5', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1066', '1019', '2', 'for-field-115', '17', '2023-02-18 10:18:11', '41', '2022-04-07 11:03:35', '41', '2022-04-07 11:03:35', '3', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1067', '1066', '2', 'for-page-1064', '17', '2022-04-07 11:09:22', '41', '2022-04-07 11:09:22', '41', '2022-04-07 11:09:22', '0', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1078', '1', '29', 'prueba', '1025', '2022-10-27 12:45:46', '41', '2022-04-07 14:44:32', '41', '2022-10-04 11:16:40', '9', 'proba', '1', 'test', '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1145', '1140', '44', '1669033584-5486-1', '1', '2022-11-21 13:40:40', '41', '2022-11-21 13:26:24', '41', '2022-11-21 13:28:01', '3', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1144', '1140', '44', '1669033567-9816-1', '1', '2022-11-21 13:40:40', '41', '2022-11-21 13:26:07', '41', '2022-11-21 13:28:01', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1143', '1140', '44', '1669033535-5421-1', '1', '2022-11-21 13:40:40', '41', '2022-11-21 13:25:35', '41', '2022-11-21 13:28:01', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1158', '1117', '46', '1676712790-4027-1', '1', '2023-02-18 10:50:40', '41', '2023-02-18 10:33:10', '41', '2023-02-18 10:34:05', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1139', '31', '5', 'page-edit-front', '1', '2022-11-21 13:22:40', '41', '2022-11-21 13:22:40', '41', '2022-11-21 13:22:40', '15', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1076', '1075', '46', '1649328884-5892-1', '1', '2023-02-18 12:06:11', '41', '2022-04-07 12:54:44', '41', '2022-04-07 12:56:15', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1114', '1075', '46', '1664874462-0842-1', '1', '2022-10-04 11:09:45', '41', '2022-10-04 11:07:42', '41', '2022-10-04 11:09:20', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1080', '1079', '46', '1649335502-3146-1', '1', '2022-04-08 10:43:43', '41', '2022-04-07 14:45:02', '41', '2022-04-07 14:55:47', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1140', '1025', '2', 'for-page-1121', '17', '2022-11-21 13:25:19', '41', '2022-11-21 13:25:19', '41', '2022-11-21 13:25:19', '0', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1082', '1079', '46', '1649335797-5075-1', '1', '2022-04-08 11:34:07', '41', '2022-04-07 14:49:57', '41', '2022-04-07 14:55:47', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1084', '1079', '46', '1649335851-9084-1', '1', '2022-04-08 11:34:07', '41', '2022-04-07 14:50:51', '41', '2022-04-07 14:55:47', '3', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1112', '1109', '49', '1651503685-3888-1', '1', '2023-02-18 15:52:14', '41', '2022-05-02 17:01:25', '41', '2022-05-02 17:01:40', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1086', '1079', '46', '1649404954-5838-1', '1', '2022-04-08 11:32:22', '41', '2022-04-08 10:02:34', '41', '2022-04-08 10:03:38', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1088', '1079', '46', '1649405052-0877-1', '1', '2022-04-08 10:06:26', '41', '2022-04-08 10:04:12', '41', '2022-04-08 10:04:37', '4', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1111', '1109', '49', '1651503663-8353-1', '1', '2023-02-18 15:52:14', '41', '2022-05-02 17:01:03', '41', '2022-05-02 17:01:23', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1090', '1079', '46', '1649405151-65-1', '1', '2022-04-08 11:34:07', '41', '2022-04-08 10:05:51', '41', '2022-04-08 10:06:26', '5', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1092', '1079', '46', '1649410966-4865-1', '1', '2022-10-04 11:01:27', '41', '2022-04-08 11:42:46', '41', '2022-04-08 11:44:00', '6', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1109', '1066', '2', 'for-page-1034', '17', '2022-05-02 16:59:22', '41', '2022-05-02 16:59:22', '41', '2022-05-02 16:59:22', '2', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1110', '1109', '49', '1651503580-206-1', '1', '2023-02-18 15:52:14', '41', '2022-05-02 16:59:40', '41', '2022-05-02 17:01:01', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1095', '1066', '2', 'for-page-1043', '17', '2022-05-02 13:49:36', '41', '2022-05-02 13:49:36', '41', '2022-05-02 13:49:36', '10', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1097', '1034', '51', 'mirandas', '1', '2023-02-18 16:36:42', '41', '2022-05-02 15:46:45', '41', '2022-05-02 15:47:00', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1116', '1075', '46', '1664874960-2759-1', '3073', '2022-10-06 10:28:39', '41', '2022-10-04 11:16:00', '41', NULL, '3', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1099', '1034', '51', 'cercada', '1', '2023-02-18 10:53:18', '41', '2022-05-02 15:48:20', '41', '2022-05-02 15:48:42', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1101', '1034', '51', 'mouron', '1', '2023-02-18 10:52:12', '41', '2022-05-02 15:50:08', '41', '2022-05-02 15:50:11', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1117', '1027', '2', 'for-page-1097', '17', '2022-10-06 10:23:11', '41', '2022-10-06 10:23:11', '41', '2022-10-06 10:23:11', '6', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1161', '1160', '46', '1676712913-8476-1', '1', '2023-02-18 10:52:12', '41', '2023-02-18 10:35:13', '41', '2023-02-18 10:35:20', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1119', '1035', '46', '1665045015-5779-1', '3073', '2022-10-06 10:30:15', '41', '2022-10-06 10:30:15', '41', NULL, '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1120', '30', '4', 'xestion', '1', '2022-10-06 11:17:26', '41', '2022-10-06 11:12:54', '41', '2022-10-06 11:15:35', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1121', '1', '54', 'gestion', '1025', '2022-11-21 15:18:36', '41', '2022-10-06 11:20:37', '41', '2022-10-06 11:21:23', '10', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1122', '1121', '55', 'acceder', '1', '2022-10-06 13:16:05', '41', '2022-10-06 11:29:46', '41', '2022-10-06 11:29:46', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1123', '1121', '56', 'panel', '1', '2022-10-06 13:16:14', '41', '2022-10-06 11:31:33', '41', '2022-10-06 11:31:33', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1125', '1040', '60', 'categorias', '1', '2022-10-27 13:10:56', '41', '2022-10-25 12:30:06', '41', '2022-10-25 12:30:06', '0', NULL, '1', 'categories', '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1133', '1037', '46', '1666872972-2616-1', '1', '2022-10-27 14:19:38', '41', '2022-10-27 14:16:12', '41', '2022-10-27 14:19:38', '3', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1126', '1040', '60', 'etiquetas', '1', '2022-10-27 13:11:08', '41', '2022-10-25 12:31:01', '41', '2022-10-25 12:31:01', '1', NULL, '1', 'tags', '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1127', '1040', '60', 'publicaciones', '1', '2022-10-27 13:11:20', '41', '2022-10-25 12:31:37', '41', '2022-10-25 12:31:37', '2', 'publicacions', '1', 'posts', '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1128', '1125', '59', 'noticias', '1', '2022-10-27 13:11:32', '41', '2022-10-25 12:33:25', '41', '2022-10-25 12:33:25', '0', 'novas', '1', 'news', '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1129', '1126', '58', 'general', '1', '2022-10-27 13:11:47', '41', '2022-10-25 12:34:06', '41', '2022-10-25 12:34:06', '0', 'xeral', '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1130', '1127', '57', 'hola-mundo', '1', '2022-10-25 14:40:38', '41', '2022-10-25 12:36:05', '41', '2022-10-25 12:41:17', '0', 'ola-mundo', '1', 'hello-world', '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1131', '1027', '2', 'for-page-1130', '17', '2022-10-25 12:36:05', '41', '2022-10-25 12:36:05', '41', '2022-10-25 12:36:05', '7', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1132', '1131', '46', '1666694184-9693-1', '1', '2022-10-25 14:40:38', '41', '2022-10-25 12:36:24', '41', '2022-10-25 12:37:58', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1134', '1039', '46', '1666873253-7855-1', '1', '2022-10-27 14:22:55', '41', '2022-10-27 14:20:53', '41', '2022-10-27 14:22:18', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1135', '1039', '46', '1666873287-0253-1', '1', '2022-10-27 14:22:55', '41', '2022-10-27 14:21:27', '41', '2022-10-27 14:22:18', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1136', '1039', '46', '1666873341-4159-1', '1', '2022-10-27 14:22:55', '41', '2022-10-27 14:22:21', '41', '2022-10-27 14:22:55', '4', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1156', '1', '62', 'bs-inicio', '1025', '2022-12-06 10:34:33', '41', '2022-12-06 10:34:26', '41', '2022-12-06 10:34:26', '10', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1157', '1019', '2', 'for-field-131', '17', '2023-02-18 10:11:06', '41', '2023-02-18 10:11:06', '41', '2023-02-18 10:11:06', '3', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1159', '1157', '2', 'for-page-1158', '17', '2023-02-18 10:33:10', '41', '2023-02-18 10:33:10', '41', '2023-02-18 10:33:10', '0', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1153', '1140', '44', '1669034827-6812-1', '1', '2022-11-21 14:19:05', '41', '2022-11-21 13:47:07', '41', '2022-11-21 13:51:59', '5', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1162', '1157', '2', 'for-page-1161', '17', '2023-02-18 10:35:13', '41', '2023-02-18 10:35:13', '41', '2023-02-18 10:35:13', '1', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1163', '1027', '2', 'for-page-1099', '17', '2023-02-18 10:35:34', '41', '2023-02-18 10:35:34', '41', '2023-02-18 10:35:34', '9', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1164', '1163', '46', '1676712979-6649-1', '1', '2023-02-18 10:53:18', '41', '2023-02-18 10:36:19', '41', '2023-02-18 10:36:25', '1', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1165', '1157', '2', 'for-page-1164', '17', '2023-02-18 10:36:19', '41', '2023-02-18 10:36:19', '41', '2023-02-18 10:36:19', '2', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1166', '1127', '57', 'esta-todo-listo', '1', '2023-02-18 10:40:21', '41', '2023-02-18 10:38:31', '41', '2023-02-18 10:40:21', '1', 'xa-esta-todo-listo', '1', 'its-all-set', '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1167', '1027', '2', 'for-page-1166', '17', '2023-02-18 10:38:31', '41', '2023-02-18 10:38:31', '41', '2023-02-18 10:38:31', '10', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1168', '1167', '46', '1676713133-8268-1', '1', '2023-02-18 10:40:21', '41', '2023-02-18 10:38:53', '41', '2023-02-18 10:40:21', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1169', '1157', '2', 'for-page-1168', '17', '2023-02-18 10:38:53', '41', '2023-02-18 10:38:53', '41', '2023-02-18 10:38:53', '3', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1170', '1167', '46', '1676713162-3392-1', '1', '2023-02-18 10:40:21', '41', '2023-02-18 10:39:22', '41', '2023-02-18 10:40:21', '3', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1171', '1157', '2', 'for-page-1170', '17', '2023-02-18 10:39:22', '41', '2023-02-18 10:39:22', '41', '2023-02-18 10:39:22', '4', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1172', '1157', '2', 'for-page-1119', '17', '2023-02-18 10:40:27', '41', '2023-02-18 10:40:27', '41', '2023-02-18 10:40:27', '5', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1173', '1117', '46', '1676713701-8855-1', '1', '2023-02-18 10:50:21', '41', '2023-02-18 10:48:21', '41', '2023-02-18 10:50:05', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1174', '1157', '2', 'for-page-1173', '17', '2023-02-18 10:48:21', '41', '2023-02-18 10:48:21', '41', '2023-02-18 10:48:21', '6', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1175', '1117', '46', '1676713764-8954-1', '1', '2023-02-18 16:36:43', '41', '2023-02-18 10:49:24', '41', '2023-02-18 16:36:43', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1176', '1157', '2', 'for-page-1175', '17', '2023-02-18 10:49:24', '41', '2023-02-18 10:49:24', '41', '2023-02-18 10:49:24', '7', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1177', '1160', '46', '1676713857-3392-1', '1', '2023-02-18 10:52:12', '41', '2023-02-18 10:50:57', '41', '2023-02-18 10:52:09', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1178', '1157', '2', 'for-page-1177', '17', '2023-02-18 10:50:57', '41', '2023-02-18 10:50:57', '41', '2023-02-18 10:50:57', '8', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1179', '1160', '46', '1676713907-3397-1', '1', '2023-02-18 10:52:12', '41', '2023-02-18 10:51:47', '41', '2023-02-18 10:52:09', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1180', '1157', '2', 'for-page-1179', '17', '2023-02-18 10:51:47', '41', '2023-02-18 10:51:47', '41', '2023-02-18 10:51:47', '9', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1181', '1163', '46', '1676713949-0583-1', '1', '2023-02-18 10:53:18', '41', '2023-02-18 10:52:29', '41', '2023-02-18 10:53:15', '0', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1182', '1157', '2', 'for-page-1181', '17', '2023-02-18 10:52:29', '41', '2023-02-18 10:52:29', '41', '2023-02-18 10:52:29', '10', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1183', '1163', '46', '1676713976-5633-1', '1', '2023-02-18 10:53:18', '41', '2023-02-18 10:52:56', '41', '2023-02-18 10:53:15', '2', NULL, '1', NULL, '1');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1184', '1157', '2', 'for-page-1183', '17', '2023-02-18 10:52:56', '41', '2023-02-18 10:52:56', '41', '2023-02-18 10:52:56', '11', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1185', '1157', '2', 'for-page-1076', '17', '2023-02-18 11:31:11', '41', '2023-02-18 11:31:11', '41', '2023-02-18 11:31:11', '12', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1186', '1157', '2', 'for-page-1115', '17', '2023-02-18 12:05:21', '41', '2023-02-18 12:05:21', '41', '2023-02-18 12:05:21', '13', NULL, '0', NULL, '0');
+INSERT INTO `pages` (`id`, `parent_id`, `templates_id`, `name`, `status`, `modified`, `modified_users_id`, `created`, `created_users_id`, `published`, `sort`, `name1023`, `status1023`, `name1024`, `status1024`) VALUES('1187', '1157', '2', 'for-page-1114', '17', '2023-02-18 12:05:22', '41', '2023-02-18 12:05:22', '41', '2023-02-18 12:05:22', '14', NULL, '0', NULL, '0');
+
+DROP TABLE IF EXISTS `pages_access`;
+CREATE TABLE `pages_access` (
+ `pages_id` int(11) NOT NULL,
+ `templates_id` int(11) NOT NULL,
+ `ts` timestamp NOT NULL DEFAULT current_timestamp() ON UPDATE current_timestamp(),
+ PRIMARY KEY (`pages_id`),
+ KEY `templates_id` (`templates_id`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1017', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1023', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1024', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('37', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('38', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1120', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('32', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('34', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('35', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('36', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('50', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('51', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('52', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('53', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('54', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1006', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1011', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1013', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1014', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1015', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1021', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1158', '2', '2023-02-18 10:33:10');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1153', '2', '2022-11-21 13:47:07');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1146', '2', '2022-11-21 13:26:38');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1145', '2', '2022-11-21 13:26:24');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1144', '2', '2022-11-21 13:26:07');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1142', '2', '2022-11-21 13:25:22');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1156', '1', '2022-12-06 10:34:26');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1119', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1043', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1076', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1114', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1115', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1116', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1080', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1082', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1084', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1086', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1088', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1090', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1092', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1110', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1111', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1112', '2', '2022-10-06 11:16:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1143', '2', '2022-11-21 13:25:35');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1139', '2', '2022-11-21 13:22:40');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1123', '54', '2022-10-06 11:31:33');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1122', '54', '2022-10-06 11:31:59');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1125', '1', '2022-10-25 12:30:06');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1126', '1', '2022-10-25 12:31:01');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1127', '1', '2022-10-25 12:31:37');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1128', '1', '2022-10-25 12:33:25');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1129', '1', '2022-10-25 12:34:06');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1130', '1', '2022-10-25 12:36:08');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1132', '2', '2022-10-25 12:36:24');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1133', '2', '2022-10-27 14:16:12');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1134', '2', '2022-10-27 14:20:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1135', '2', '2022-10-27 14:21:27');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1136', '2', '2022-10-27 14:22:21');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1161', '2', '2023-02-18 10:35:13');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1164', '2', '2023-02-18 10:36:19');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1166', '1', '2023-02-18 10:38:31');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1168', '2', '2023-02-18 10:38:53');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1170', '2', '2023-02-18 10:39:22');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1173', '2', '2023-02-18 10:48:21');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1175', '2', '2023-02-18 10:49:24');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1177', '2', '2023-02-18 10:50:57');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1179', '2', '2023-02-18 10:51:47');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1181', '2', '2023-02-18 10:52:29');
+INSERT INTO `pages_access` (`pages_id`, `templates_id`, `ts`) VALUES('1183', '2', '2023-02-18 10:52:56');
+
+DROP TABLE IF EXISTS `pages_parents`;
+CREATE TABLE `pages_parents` (
+ `pages_id` int(10) unsigned NOT NULL,
+ `parents_id` int(10) unsigned NOT NULL,
+ PRIMARY KEY (`pages_id`,`parents_id`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('3', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('22', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('28', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('29', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('29', '28');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('30', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('30', '28');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('31', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('31', '28');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1016', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1016', '22');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1019', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1025', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1025', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1027', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1027', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1035', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1035', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1035', '1027');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1037', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1037', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1037', '1027');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1039', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1039', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1039', '1027');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1066', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1066', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1075', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1075', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1075', '1027');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1079', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1079', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1079', '1027');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1109', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1109', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1109', '1066');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1117', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1117', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1117', '1027');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1125', '1040');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1126', '1040');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1127', '1040');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1131', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1131', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1131', '1027');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1140', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1140', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1140', '1025');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1157', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1157', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1160', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1160', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1160', '1027');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1163', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1163', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1163', '1027');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1167', '2');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1167', '1019');
+INSERT INTO `pages_parents` (`pages_id`, `parents_id`) VALUES('1167', '1027');
+
+DROP TABLE IF EXISTS `pages_sortfields`;
+CREATE TABLE `pages_sortfields` (
+ `pages_id` int(10) unsigned NOT NULL DEFAULT 0,
+ `sortfield` varchar(20) NOT NULL DEFAULT '',
+ PRIMARY KEY (`pages_id`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+
+DROP TABLE IF EXISTS `session_login_throttle`;
+CREATE TABLE `session_login_throttle` (
+ `name` varchar(128) NOT NULL,
+ `attempts` int(10) unsigned NOT NULL DEFAULT 0,
+ `last_attempt` int(10) unsigned NOT NULL,
+ PRIMARY KEY (`name`)
+) ENGINE=MyISAM DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `session_login_throttle` (`name`, `attempts`, `last_attempt`) VALUES('laegnur', '1', '1676740644');
+
+DROP TABLE IF EXISTS `templates`;
+CREATE TABLE `templates` (
+ `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
+ `name` varchar(250) CHARACTER SET ascii COLLATE ascii_general_ci NOT NULL,
+ `fieldgroups_id` int(10) unsigned NOT NULL DEFAULT 0,
+ `flags` int(11) NOT NULL DEFAULT 0,
+ `cache_time` mediumint(9) NOT NULL DEFAULT 0,
+ `data` text NOT NULL,
+ PRIMARY KEY (`id`),
+ UNIQUE KEY `name` (`name`),
+ KEY `fieldgroups_id` (`fieldgroups_id`)
+) ENGINE=MyISAM AUTO_INCREMENT=64 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
+
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('2', 'admin', '2', '8', '0', '{\"useRoles\":1,\"parentTemplates\":[2],\"allowPageNum\":1,\"redirectLogin\":23,\"slashUrls\":1,\"noGlobal\":1,\"compile\":3,\"modified\":1630086528,\"ns\":\"ProcessWire\"}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('3', 'user', '3', '8', '0', '{\"useRoles\":1,\"noChildren\":1,\"parentTemplates\":[2],\"slashUrls\":1,\"pageClass\":\"User\",\"noGlobal\":1,\"noMove\":1,\"noTrash\":1,\"noSettings\":1,\"noChangeTemplate\":1,\"nameContentTab\":1}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('4', 'role', '4', '8', '0', '{\"noChildren\":1,\"parentTemplates\":[2],\"slashUrls\":1,\"pageClass\":\"Role\",\"noGlobal\":1,\"noMove\":1,\"noTrash\":1,\"noSettings\":1,\"noChangeTemplate\":1,\"nameContentTab\":1}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('5', 'permission', '5', '8', '0', '{\"noChildren\":1,\"parentTemplates\":[2],\"slashUrls\":1,\"guestSearchable\":1,\"pageClass\":\"Permission\",\"noGlobal\":1,\"noMove\":1,\"noTrash\":1,\"noSettings\":1,\"noChangeTemplate\":1,\"nameContentTab\":1}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('1', 'inicio', '1', '0', '0', '{\"useRoles\":1,\"editRoles\":[1120],\"addRoles\":[1120],\"createRoles\":[1120],\"noParents\":1,\"slashUrls\":1,\"compile\":3,\"tags\":\"paxinas\",\"modified\":1676722623,\"ns\":\"ProcessWire\",\"roles\":[37,1120]}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('29', 'paxina', '83', '0', '0', '{\"slashUrls\":1,\"compile\":3,\"tags\":\"paxinas\",\"modified\":1676708744,\"ns\":\"ProcessWire\"}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('43', 'language', '97', '8', '0', '{\"parentTemplates\":[2],\"slashUrls\":1,\"pageClass\":\"Language\",\"pageLabelField\":\"name\",\"noGlobal\":1,\"noMove\":1,\"noTrash\":1,\"noChangeTemplate\":1,\"noUnpublish\":1,\"compile\":3,\"nameContentTab\":1,\"modified\":1646742978}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('44', 'repeater_configuracion', '98', '8', '0', '{\"noChildren\":1,\"noParents\":1,\"slashUrls\":1,\"pageClass\":\"RepeaterPage\",\"noGlobal\":1,\"compile\":3,\"modified\":1669034698}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('51', 'habitacion', '105', '0', '0', '{\"slashUrls\":1,\"compile\":3,\"tags\":\"paxinas\",\"modified\":1676734043,\"ns\":\"ProcessWire\"}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('52', 'habitacions', '106', '0', '0', '{\"childTemplates\":[51],\"slashUrls\":1,\"compile\":3,\"tags\":\"paxinas\",\"modified\":1676733294,\"ns\":\"ProcessWire\"}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('46', 'repeater_seccions', '100', '8', '0', '{\"noChildren\":1,\"noParents\":1,\"slashUrls\":1,\"pageClass\":\"RepeaterPage\",\"noGlobal\":1,\"compile\":3,\"modified\":1646759849}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('47', 'contacto', '101', '0', '0', '{\"slashUrls\":1,\"compile\":3,\"tags\":\"paxinas\",\"modified\":1676708744,\"ns\":\"ProcessWire\"}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('48', 'blogue', '102', '0', '0', '{\"noParents\":1,\"slashUrls\":1,\"compile\":3,\"tags\":\"blogue\",\"modified\":1676708744,\"ns\":\"ProcessWire\"}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('49', 'repeater_ligazon_imaxe', '103', '8', '0', '{\"noChildren\":1,\"noParents\":1,\"slashUrls\":1,\"pageClass\":\"RepeaterPage\",\"noGlobal\":1,\"compile\":3,\"modified\":1676711891}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('63', 'repeater_botons', '117', '8', '0', '{\"noChildren\":1,\"noParents\":1,\"slashUrls\":1,\"pageClass\":\"RepeaterPage\",\"noGlobal\":1,\"compile\":3,\"modified\":1676711466}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('54', 'xes-inicio', '108', '0', '0', '{\"useRoles\":1,\"editRoles\":[1120],\"addRoles\":[1120],\"createRoles\":[1120],\"redirectLogin\":1122,\"urlSegments\":1,\"slashUrls\":1,\"compile\":3,\"tags\":\"xestion\",\"modified\":1669034648,\"noAppendTemplateFile\":1,\"appendFile\":\"layout\\/xes.php\",\"ns\":\"ProcessWire\",\"roles\":[1120]}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('55', 'xes-acceder', '109', '0', '0', '{\"noParents\":-1,\"slashUrls\":1,\"compile\":3,\"tags\":\"xestion\",\"modified\":1666556712,\"noAppendTemplateFile\":1,\"ns\":\"ProcessWire\"}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('56', 'xes-panel', '110', '0', '0', '{\"noParents\":-1,\"slashUrls\":1,\"compile\":3,\"tags\":\"xestion\",\"modified\":1669374461,\"noAppendTemplateFile\":1,\"appendFile\":\"layout\\/xes.php\",\"ns\":\"ProcessWire\"}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('57', 'publicacion', '111', '0', '0', '{\"noChildren\":1,\"parentTemplates\":[60],\"slashUrls\":1,\"compile\":3,\"tags\":\"blogue\",\"modified\":1676708744,\"ns\":\"ProcessWire\"}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('58', 'etiqueta', '112', '0', '0', '{\"noChildren\":1,\"parentTemplates\":[60],\"allowPageNum\":1,\"slashUrls\":1,\"compile\":3,\"tags\":\"blogue\",\"modified\":1676708744,\"ns\":\"ProcessWire\"}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('59', 'categoria', '113', '0', '0', '{\"noChildren\":1,\"parentTemplates\":[60],\"allowPageNum\":1,\"slashUrls\":1,\"compile\":3,\"tags\":\"blogue\",\"modified\":1676708744,\"ns\":\"ProcessWire\"}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('60', 'contedor', '114', '0', '0', '{\"childTemplates\":[59,58,57],\"slashUrls\":1,\"compile\":3,\"tags\":\"blogue\",\"modified\":1666861831,\"ns\":\"ProcessWire\"}');
+INSERT INTO `templates` (`id`, `name`, `fieldgroups_id`, `flags`, `cache_time`, `data`) VALUES('62', 'bs-inicio', '116', '0', '0', '{\"slashUrls\":1,\"compile\":3,\"tags\":\"bootstrap\",\"modified\":1676708744,\"noAppendTemplateFile\":1,\"appendFile\":\"layout\\/bootstrap.php\",\"ns\":\"ProcessWire\"}');
+
+# --- /WireDatabaseBackup {"numTables":45,"numCreateTables":45,"numInserts":1000,"numSeconds":0}
\ No newline at end of file
diff --git a/site/assets/files/1043/6e0e6f99-047e-40f8-8859-91f0155f3442.0x260.jpeg b/site/assets/files/1043/6e0e6f99-047e-40f8-8859-91f0155f3442.0x260.jpeg
deleted file mode 100644
index 770d52e..0000000
Binary files a/site/assets/files/1043/6e0e6f99-047e-40f8-8859-91f0155f3442.0x260.jpeg and /dev/null differ
diff --git a/site/assets/files/1043/6e0e6f99-047e-40f8-8859-91f0155f3442.jpeg b/site/assets/files/1043/6e0e6f99-047e-40f8-8859-91f0155f3442.jpeg
deleted file mode 100644
index b31da04..0000000
Binary files a/site/assets/files/1043/6e0e6f99-047e-40f8-8859-91f0155f3442.jpeg and /dev/null differ
diff --git a/site/assets/files/1043/78229d9b-5703-4da6-9509-5873c0b5aded.0x260.jpeg b/site/assets/files/1043/78229d9b-5703-4da6-9509-5873c0b5aded.0x260.jpeg
deleted file mode 100644
index 9de6da7..0000000
Binary files a/site/assets/files/1043/78229d9b-5703-4da6-9509-5873c0b5aded.0x260.jpeg and /dev/null differ
diff --git a/site/assets/files/1043/78229d9b-5703-4da6-9509-5873c0b5aded.jpeg b/site/assets/files/1043/78229d9b-5703-4da6-9509-5873c0b5aded.jpeg
deleted file mode 100644
index 2616e75..0000000
Binary files a/site/assets/files/1043/78229d9b-5703-4da6-9509-5873c0b5aded.jpeg and /dev/null differ
diff --git a/site/assets/files/1043/8fd6e5cc-031a-4b42-94b7-65b717ad570f.0x260.jpeg b/site/assets/files/1043/8fd6e5cc-031a-4b42-94b7-65b717ad570f.0x260.jpeg
deleted file mode 100644
index 01c3d30..0000000
Binary files a/site/assets/files/1043/8fd6e5cc-031a-4b42-94b7-65b717ad570f.0x260.jpeg and /dev/null differ
diff --git a/site/assets/files/1043/8fd6e5cc-031a-4b42-94b7-65b717ad570f.jpeg b/site/assets/files/1043/8fd6e5cc-031a-4b42-94b7-65b717ad570f.jpeg
deleted file mode 100644
index 6f54277..0000000
Binary files a/site/assets/files/1043/8fd6e5cc-031a-4b42-94b7-65b717ad570f.jpeg and /dev/null differ
diff --git a/site/assets/files/1043/d03e15bd-b46a-4894-8614-8c749a432b47.0x260.jpeg b/site/assets/files/1043/d03e15bd-b46a-4894-8614-8c749a432b47.0x260.jpeg
deleted file mode 100644
index 0f95a3a..0000000
Binary files a/site/assets/files/1043/d03e15bd-b46a-4894-8614-8c749a432b47.0x260.jpeg and /dev/null differ
diff --git a/site/assets/files/1043/d03e15bd-b46a-4894-8614-8c749a432b47.jpeg b/site/assets/files/1043/d03e15bd-b46a-4894-8614-8c749a432b47.jpeg
deleted file mode 100644
index d2fe6b3..0000000
Binary files a/site/assets/files/1043/d03e15bd-b46a-4894-8614-8c749a432b47.jpeg and /dev/null differ
diff --git a/site/assets/files/1076/praia-de-seselle.0x260.jpg b/site/assets/files/1076/praia-de-seselle.0x260.jpg
new file mode 100644
index 0000000..f1f7b06
Binary files /dev/null and b/site/assets/files/1076/praia-de-seselle.0x260.jpg differ
diff --git a/site/assets/files/1076/praia-de-seselle.jpg b/site/assets/files/1076/praia-de-seselle.jpg
new file mode 100644
index 0000000..a62b513
Binary files /dev/null and b/site/assets/files/1076/praia-de-seselle.jpg differ
diff --git a/site/assets/files/1092/6e0e6f99-047e-40f8-8859-91f0155f3442.0x260.jpeg b/site/assets/files/1092/6e0e6f99-047e-40f8-8859-91f0155f3442.0x260.jpeg
deleted file mode 100644
index 770d52e..0000000
Binary files a/site/assets/files/1092/6e0e6f99-047e-40f8-8859-91f0155f3442.0x260.jpeg and /dev/null differ
diff --git a/site/assets/files/1092/6e0e6f99-047e-40f8-8859-91f0155f3442.jpeg b/site/assets/files/1092/6e0e6f99-047e-40f8-8859-91f0155f3442.jpeg
deleted file mode 100644
index b31da04..0000000
Binary files a/site/assets/files/1092/6e0e6f99-047e-40f8-8859-91f0155f3442.jpeg and /dev/null differ
diff --git a/site/assets/files/1092/78229d9b-5703-4da6-9509-5873c0b5aded.0x260.jpeg b/site/assets/files/1092/78229d9b-5703-4da6-9509-5873c0b5aded.0x260.jpeg
deleted file mode 100644
index 9de6da7..0000000
Binary files a/site/assets/files/1092/78229d9b-5703-4da6-9509-5873c0b5aded.0x260.jpeg and /dev/null differ
diff --git a/site/assets/files/1092/78229d9b-5703-4da6-9509-5873c0b5aded.jpeg b/site/assets/files/1092/78229d9b-5703-4da6-9509-5873c0b5aded.jpeg
deleted file mode 100644
index 2616e75..0000000
Binary files a/site/assets/files/1092/78229d9b-5703-4da6-9509-5873c0b5aded.jpeg and /dev/null differ
diff --git a/site/assets/files/1092/8fd6e5cc-031a-4b42-94b7-65b717ad570f.0x260.jpeg b/site/assets/files/1092/8fd6e5cc-031a-4b42-94b7-65b717ad570f.0x260.jpeg
deleted file mode 100644
index 01c3d30..0000000
Binary files a/site/assets/files/1092/8fd6e5cc-031a-4b42-94b7-65b717ad570f.0x260.jpeg and /dev/null differ
diff --git a/site/assets/files/1092/8fd6e5cc-031a-4b42-94b7-65b717ad570f.jpeg b/site/assets/files/1092/8fd6e5cc-031a-4b42-94b7-65b717ad570f.jpeg
deleted file mode 100644
index 6f54277..0000000
Binary files a/site/assets/files/1092/8fd6e5cc-031a-4b42-94b7-65b717ad570f.jpeg and /dev/null differ
diff --git a/site/assets/files/1092/a27b7331-bb65-452b-b7ef-6f5850ab353f.0x260.jpeg b/site/assets/files/1092/a27b7331-bb65-452b-b7ef-6f5850ab353f.0x260.jpeg
deleted file mode 100644
index 5decd52..0000000
Binary files a/site/assets/files/1092/a27b7331-bb65-452b-b7ef-6f5850ab353f.0x260.jpeg and /dev/null differ
diff --git a/site/assets/files/1092/a27b7331-bb65-452b-b7ef-6f5850ab353f.jpeg b/site/assets/files/1092/a27b7331-bb65-452b-b7ef-6f5850ab353f.jpeg
deleted file mode 100644
index 9bbb071..0000000
Binary files a/site/assets/files/1092/a27b7331-bb65-452b-b7ef-6f5850ab353f.jpeg and /dev/null differ
diff --git a/site/assets/files/1092/d03e15bd-b46a-4894-8614-8c749a432b47.0x260.jpeg b/site/assets/files/1092/d03e15bd-b46a-4894-8614-8c749a432b47.0x260.jpeg
deleted file mode 100644
index 0f95a3a..0000000
Binary files a/site/assets/files/1092/d03e15bd-b46a-4894-8614-8c749a432b47.0x260.jpeg and /dev/null differ
diff --git a/site/assets/files/1092/d03e15bd-b46a-4894-8614-8c749a432b47.jpeg b/site/assets/files/1092/d03e15bd-b46a-4894-8614-8c749a432b47.jpeg
deleted file mode 100644
index d2fe6b3..0000000
Binary files a/site/assets/files/1092/d03e15bd-b46a-4894-8614-8c749a432b47.jpeg and /dev/null differ
diff --git a/site/assets/files/1110/boton_mirandas.jpg b/site/assets/files/1110/boton_mirandas.jpg
deleted file mode 100644
index bb14479..0000000
Binary files a/site/assets/files/1110/boton_mirandas.jpg and /dev/null differ
diff --git a/site/assets/files/1110/dormitorio1.0x260.jpg b/site/assets/files/1110/dormitorio1.0x260.jpg
new file mode 100644
index 0000000..fbaf1c1
Binary files /dev/null and b/site/assets/files/1110/dormitorio1.0x260.jpg differ
diff --git a/site/assets/files/1110/dormitorio1.jpg b/site/assets/files/1110/dormitorio1.jpg
new file mode 100644
index 0000000..e4fa763
Binary files /dev/null and b/site/assets/files/1110/dormitorio1.jpg differ
diff --git a/site/assets/files/1111/boton_mirandas.jpg b/site/assets/files/1111/boton_mirandas.jpg
deleted file mode 100644
index bb14479..0000000
Binary files a/site/assets/files/1111/boton_mirandas.jpg and /dev/null differ
diff --git a/site/assets/files/1111/dormitorio2.0x260.jpg b/site/assets/files/1111/dormitorio2.0x260.jpg
new file mode 100644
index 0000000..9e88069
Binary files /dev/null and b/site/assets/files/1111/dormitorio2.0x260.jpg differ
diff --git a/site/assets/files/1111/dormitorio2.jpg b/site/assets/files/1111/dormitorio2.jpg
new file mode 100644
index 0000000..8de3736
Binary files /dev/null and b/site/assets/files/1111/dormitorio2.jpg differ
diff --git a/site/assets/files/1112/boton_mouron.jpg b/site/assets/files/1112/boton_mouron.jpg
deleted file mode 100644
index 4bb8826..0000000
Binary files a/site/assets/files/1112/boton_mouron.jpg and /dev/null differ
diff --git a/site/assets/files/1112/dormitorio3.0x260.jpg b/site/assets/files/1112/dormitorio3.0x260.jpg
new file mode 100644
index 0000000..e836e49
Binary files /dev/null and b/site/assets/files/1112/dormitorio3.0x260.jpg differ
diff --git a/site/assets/files/1112/dormitorio3.jpg b/site/assets/files/1112/dormitorio3.jpg
new file mode 100644
index 0000000..b552e79
Binary files /dev/null and b/site/assets/files/1112/dormitorio3.jpg differ
diff --git a/site/assets/files/1133/6e0e6f99-047e-40f8-8859-91f0155f3442.0x260.jpeg b/site/assets/files/1133/6e0e6f99-047e-40f8-8859-91f0155f3442.0x260.jpeg
deleted file mode 100644
index 770d52e..0000000
Binary files a/site/assets/files/1133/6e0e6f99-047e-40f8-8859-91f0155f3442.0x260.jpeg and /dev/null differ
diff --git a/site/assets/files/1133/6e0e6f99-047e-40f8-8859-91f0155f3442.jpeg b/site/assets/files/1133/6e0e6f99-047e-40f8-8859-91f0155f3442.jpeg
deleted file mode 100644
index b31da04..0000000
Binary files a/site/assets/files/1133/6e0e6f99-047e-40f8-8859-91f0155f3442.jpeg and /dev/null differ
diff --git a/site/assets/files/1133/78229d9b-5703-4da6-9509-5873c0b5aded.0x260.jpeg b/site/assets/files/1133/78229d9b-5703-4da6-9509-5873c0b5aded.0x260.jpeg
deleted file mode 100644
index 9de6da7..0000000
Binary files a/site/assets/files/1133/78229d9b-5703-4da6-9509-5873c0b5aded.0x260.jpeg and /dev/null differ
diff --git a/site/assets/files/1133/78229d9b-5703-4da6-9509-5873c0b5aded.jpeg b/site/assets/files/1133/78229d9b-5703-4da6-9509-5873c0b5aded.jpeg
deleted file mode 100644
index 2616e75..0000000
Binary files a/site/assets/files/1133/78229d9b-5703-4da6-9509-5873c0b5aded.jpeg and /dev/null differ
diff --git a/site/assets/files/1133/8fd6e5cc-031a-4b42-94b7-65b717ad570f.0x260.jpeg b/site/assets/files/1133/8fd6e5cc-031a-4b42-94b7-65b717ad570f.0x260.jpeg
deleted file mode 100644
index 01c3d30..0000000
Binary files a/site/assets/files/1133/8fd6e5cc-031a-4b42-94b7-65b717ad570f.0x260.jpeg and /dev/null differ
diff --git a/site/assets/files/1133/8fd6e5cc-031a-4b42-94b7-65b717ad570f.jpeg b/site/assets/files/1133/8fd6e5cc-031a-4b42-94b7-65b717ad570f.jpeg
deleted file mode 100644
index 6f54277..0000000
Binary files a/site/assets/files/1133/8fd6e5cc-031a-4b42-94b7-65b717ad570f.jpeg and /dev/null differ
diff --git a/site/assets/files/1133/d03e15bd-b46a-4894-8614-8c749a432b47.0x260.jpeg b/site/assets/files/1133/d03e15bd-b46a-4894-8614-8c749a432b47.0x260.jpeg
deleted file mode 100644
index 0f95a3a..0000000
Binary files a/site/assets/files/1133/d03e15bd-b46a-4894-8614-8c749a432b47.0x260.jpeg and /dev/null differ
diff --git a/site/assets/files/1133/d03e15bd-b46a-4894-8614-8c749a432b47.jpeg b/site/assets/files/1133/d03e15bd-b46a-4894-8614-8c749a432b47.jpeg
deleted file mode 100644
index d2fe6b3..0000000
Binary files a/site/assets/files/1133/d03e15bd-b46a-4894-8614-8c749a432b47.jpeg and /dev/null differ
diff --git a/site/assets/files/1170/img-20220930-wa0004.0x260.jpg b/site/assets/files/1170/img-20220930-wa0004.0x260.jpg
new file mode 100644
index 0000000..7a6be87
Binary files /dev/null and b/site/assets/files/1170/img-20220930-wa0004.0x260.jpg differ
diff --git a/site/assets/files/1170/img-20220930-wa0004.jpg b/site/assets/files/1170/img-20220930-wa0004.jpg
new file mode 100644
index 0000000..be16e1d
Binary files /dev/null and b/site/assets/files/1170/img-20220930-wa0004.jpg differ
diff --git a/site/assets/files/1170/img-20220930-wa0005.0x260.jpg b/site/assets/files/1170/img-20220930-wa0005.0x260.jpg
new file mode 100644
index 0000000..a332f48
Binary files /dev/null and b/site/assets/files/1170/img-20220930-wa0005.0x260.jpg differ
diff --git a/site/assets/files/1170/img-20220930-wa0005.jpg b/site/assets/files/1170/img-20220930-wa0005.jpg
new file mode 100644
index 0000000..c74793f
Binary files /dev/null and b/site/assets/files/1170/img-20220930-wa0005.jpg differ
diff --git a/site/assets/files/1173/as-mirandas-1.0x260.jpg b/site/assets/files/1173/as-mirandas-1.0x260.jpg
new file mode 100644
index 0000000..872fc4b
Binary files /dev/null and b/site/assets/files/1173/as-mirandas-1.0x260.jpg differ
diff --git a/site/assets/files/1173/as-mirandas-1.jpg b/site/assets/files/1173/as-mirandas-1.jpg
new file mode 100644
index 0000000..d6646f7
Binary files /dev/null and b/site/assets/files/1173/as-mirandas-1.jpg differ
diff --git a/site/assets/files/1173/as-mirandas-2.0x260.jpg b/site/assets/files/1173/as-mirandas-2.0x260.jpg
new file mode 100644
index 0000000..c632c6a
Binary files /dev/null and b/site/assets/files/1173/as-mirandas-2.0x260.jpg differ
diff --git a/site/assets/files/1173/as-mirandas-2.jpg b/site/assets/files/1173/as-mirandas-2.jpg
new file mode 100644
index 0000000..6050bc4
Binary files /dev/null and b/site/assets/files/1173/as-mirandas-2.jpg differ
diff --git a/site/assets/files/1173/as-mirandas-3.0x260.jpg b/site/assets/files/1173/as-mirandas-3.0x260.jpg
new file mode 100644
index 0000000..9dad56a
Binary files /dev/null and b/site/assets/files/1173/as-mirandas-3.0x260.jpg differ
diff --git a/site/assets/files/1173/as-mirandas-3.jpg b/site/assets/files/1173/as-mirandas-3.jpg
new file mode 100644
index 0000000..4c098a3
Binary files /dev/null and b/site/assets/files/1173/as-mirandas-3.jpg differ
diff --git a/site/assets/files/1173/as-mirandas-4.0x260.jpg b/site/assets/files/1173/as-mirandas-4.0x260.jpg
new file mode 100644
index 0000000..c1813f0
Binary files /dev/null and b/site/assets/files/1173/as-mirandas-4.0x260.jpg differ
diff --git a/site/assets/files/1173/as-mirandas-4.jpg b/site/assets/files/1173/as-mirandas-4.jpg
new file mode 100644
index 0000000..abd6d8f
Binary files /dev/null and b/site/assets/files/1173/as-mirandas-4.jpg differ
diff --git a/site/assets/files/1173/as-mirandas-5.0x260.jpg b/site/assets/files/1173/as-mirandas-5.0x260.jpg
new file mode 100644
index 0000000..a8065d4
Binary files /dev/null and b/site/assets/files/1173/as-mirandas-5.0x260.jpg differ
diff --git a/site/assets/files/1173/as-mirandas-5.jpg b/site/assets/files/1173/as-mirandas-5.jpg
new file mode 100644
index 0000000..961945e
Binary files /dev/null and b/site/assets/files/1173/as-mirandas-5.jpg differ
diff --git a/site/assets/files/1173/as-mirandas-6.0x260.jpg b/site/assets/files/1173/as-mirandas-6.0x260.jpg
new file mode 100644
index 0000000..37564b6
Binary files /dev/null and b/site/assets/files/1173/as-mirandas-6.0x260.jpg differ
diff --git a/site/assets/files/1173/as-mirandas-6.jpg b/site/assets/files/1173/as-mirandas-6.jpg
new file mode 100644
index 0000000..79ba11f
Binary files /dev/null and b/site/assets/files/1173/as-mirandas-6.jpg differ
diff --git a/site/assets/files/1175/as-mirandas-1.0x260.jpg b/site/assets/files/1175/as-mirandas-1.0x260.jpg
new file mode 100644
index 0000000..872fc4b
Binary files /dev/null and b/site/assets/files/1175/as-mirandas-1.0x260.jpg differ
diff --git a/site/assets/files/1175/as-mirandas-1.jpg b/site/assets/files/1175/as-mirandas-1.jpg
new file mode 100644
index 0000000..d6646f7
Binary files /dev/null and b/site/assets/files/1175/as-mirandas-1.jpg differ
diff --git a/site/assets/files/1175/as-mirandas-2.0x260.jpg b/site/assets/files/1175/as-mirandas-2.0x260.jpg
new file mode 100644
index 0000000..c632c6a
Binary files /dev/null and b/site/assets/files/1175/as-mirandas-2.0x260.jpg differ
diff --git a/site/assets/files/1175/as-mirandas-2.jpg b/site/assets/files/1175/as-mirandas-2.jpg
new file mode 100644
index 0000000..6050bc4
Binary files /dev/null and b/site/assets/files/1175/as-mirandas-2.jpg differ
diff --git a/site/assets/files/1175/as-mirandas-3.0x260.jpg b/site/assets/files/1175/as-mirandas-3.0x260.jpg
new file mode 100644
index 0000000..9dad56a
Binary files /dev/null and b/site/assets/files/1175/as-mirandas-3.0x260.jpg differ
diff --git a/site/assets/files/1175/as-mirandas-3.jpg b/site/assets/files/1175/as-mirandas-3.jpg
new file mode 100644
index 0000000..4c098a3
Binary files /dev/null and b/site/assets/files/1175/as-mirandas-3.jpg differ
diff --git a/site/assets/files/1175/as-mirandas-4.0x260.jpg b/site/assets/files/1175/as-mirandas-4.0x260.jpg
new file mode 100644
index 0000000..c1813f0
Binary files /dev/null and b/site/assets/files/1175/as-mirandas-4.0x260.jpg differ
diff --git a/site/assets/files/1175/as-mirandas-4.jpg b/site/assets/files/1175/as-mirandas-4.jpg
new file mode 100644
index 0000000..abd6d8f
Binary files /dev/null and b/site/assets/files/1175/as-mirandas-4.jpg differ
diff --git a/site/assets/files/1175/as-mirandas-5.0x260.jpg b/site/assets/files/1175/as-mirandas-5.0x260.jpg
new file mode 100644
index 0000000..a8065d4
Binary files /dev/null and b/site/assets/files/1175/as-mirandas-5.0x260.jpg differ
diff --git a/site/assets/files/1175/as-mirandas-5.jpg b/site/assets/files/1175/as-mirandas-5.jpg
new file mode 100644
index 0000000..961945e
Binary files /dev/null and b/site/assets/files/1175/as-mirandas-5.jpg differ
diff --git a/site/assets/files/1175/as-mirandas-6.0x260.jpg b/site/assets/files/1175/as-mirandas-6.0x260.jpg
new file mode 100644
index 0000000..37564b6
Binary files /dev/null and b/site/assets/files/1175/as-mirandas-6.0x260.jpg differ
diff --git a/site/assets/files/1175/as-mirandas-6.jpg b/site/assets/files/1175/as-mirandas-6.jpg
new file mode 100644
index 0000000..79ba11f
Binary files /dev/null and b/site/assets/files/1175/as-mirandas-6.jpg differ
diff --git a/site/assets/files/1177/apartamento-o-mouron-1.0x260.jpg b/site/assets/files/1177/apartamento-o-mouron-1.0x260.jpg
new file mode 100644
index 0000000..c051d72
Binary files /dev/null and b/site/assets/files/1177/apartamento-o-mouron-1.0x260.jpg differ
diff --git a/site/assets/files/1177/apartamento-o-mouron-1.jpg b/site/assets/files/1177/apartamento-o-mouron-1.jpg
new file mode 100644
index 0000000..4c652cb
Binary files /dev/null and b/site/assets/files/1177/apartamento-o-mouron-1.jpg differ
diff --git a/site/assets/files/1177/apartamento-o-mouron-2.0x260.jpg b/site/assets/files/1177/apartamento-o-mouron-2.0x260.jpg
new file mode 100644
index 0000000..15551ea
Binary files /dev/null and b/site/assets/files/1177/apartamento-o-mouron-2.0x260.jpg differ
diff --git a/site/assets/files/1177/apartamento-o-mouron-2.jpg b/site/assets/files/1177/apartamento-o-mouron-2.jpg
new file mode 100644
index 0000000..3e031e7
Binary files /dev/null and b/site/assets/files/1177/apartamento-o-mouron-2.jpg differ
diff --git a/site/assets/files/1177/apartamento-o-mouron-3.0x260.jpg b/site/assets/files/1177/apartamento-o-mouron-3.0x260.jpg
new file mode 100644
index 0000000..a7d012d
Binary files /dev/null and b/site/assets/files/1177/apartamento-o-mouron-3.0x260.jpg differ
diff --git a/site/assets/files/1177/apartamento-o-mouron-3.jpg b/site/assets/files/1177/apartamento-o-mouron-3.jpg
new file mode 100644
index 0000000..163f999
Binary files /dev/null and b/site/assets/files/1177/apartamento-o-mouron-3.jpg differ
diff --git a/site/assets/files/1177/apartamento-o-mouron-4.0x260.jpg b/site/assets/files/1177/apartamento-o-mouron-4.0x260.jpg
new file mode 100644
index 0000000..3855108
Binary files /dev/null and b/site/assets/files/1177/apartamento-o-mouron-4.0x260.jpg differ
diff --git a/site/assets/files/1177/apartamento-o-mouron-4.jpg b/site/assets/files/1177/apartamento-o-mouron-4.jpg
new file mode 100644
index 0000000..86ea2e6
Binary files /dev/null and b/site/assets/files/1177/apartamento-o-mouron-4.jpg differ
diff --git a/site/assets/files/1177/apartamento-o-mouron-5.0x260.jpg b/site/assets/files/1177/apartamento-o-mouron-5.0x260.jpg
new file mode 100644
index 0000000..606641f
Binary files /dev/null and b/site/assets/files/1177/apartamento-o-mouron-5.0x260.jpg differ
diff --git a/site/assets/files/1177/apartamento-o-mouron-5.jpg b/site/assets/files/1177/apartamento-o-mouron-5.jpg
new file mode 100644
index 0000000..b1a7dd3
Binary files /dev/null and b/site/assets/files/1177/apartamento-o-mouron-5.jpg differ
diff --git a/site/assets/files/1177/apartamento-o-mouron-6.0x260.jpg b/site/assets/files/1177/apartamento-o-mouron-6.0x260.jpg
new file mode 100644
index 0000000..c8dd09e
Binary files /dev/null and b/site/assets/files/1177/apartamento-o-mouron-6.0x260.jpg differ
diff --git a/site/assets/files/1177/apartamento-o-mouron-6.jpg b/site/assets/files/1177/apartamento-o-mouron-6.jpg
new file mode 100644
index 0000000..3fb4a44
Binary files /dev/null and b/site/assets/files/1177/apartamento-o-mouron-6.jpg differ
diff --git a/site/assets/files/1179/apartamento-o-mouron-1.0x260.jpg b/site/assets/files/1179/apartamento-o-mouron-1.0x260.jpg
new file mode 100644
index 0000000..c051d72
Binary files /dev/null and b/site/assets/files/1179/apartamento-o-mouron-1.0x260.jpg differ
diff --git a/site/assets/files/1179/apartamento-o-mouron-1.jpg b/site/assets/files/1179/apartamento-o-mouron-1.jpg
new file mode 100644
index 0000000..4c652cb
Binary files /dev/null and b/site/assets/files/1179/apartamento-o-mouron-1.jpg differ
diff --git a/site/assets/files/1179/apartamento-o-mouron-2.0x260.jpg b/site/assets/files/1179/apartamento-o-mouron-2.0x260.jpg
new file mode 100644
index 0000000..15551ea
Binary files /dev/null and b/site/assets/files/1179/apartamento-o-mouron-2.0x260.jpg differ
diff --git a/site/assets/files/1179/apartamento-o-mouron-2.jpg b/site/assets/files/1179/apartamento-o-mouron-2.jpg
new file mode 100644
index 0000000..3e031e7
Binary files /dev/null and b/site/assets/files/1179/apartamento-o-mouron-2.jpg differ
diff --git a/site/assets/files/1179/apartamento-o-mouron-3.0x260.jpg b/site/assets/files/1179/apartamento-o-mouron-3.0x260.jpg
new file mode 100644
index 0000000..a7d012d
Binary files /dev/null and b/site/assets/files/1179/apartamento-o-mouron-3.0x260.jpg differ
diff --git a/site/assets/files/1179/apartamento-o-mouron-3.jpg b/site/assets/files/1179/apartamento-o-mouron-3.jpg
new file mode 100644
index 0000000..163f999
Binary files /dev/null and b/site/assets/files/1179/apartamento-o-mouron-3.jpg differ
diff --git a/site/assets/files/1179/apartamento-o-mouron-4.0x260.jpg b/site/assets/files/1179/apartamento-o-mouron-4.0x260.jpg
new file mode 100644
index 0000000..3855108
Binary files /dev/null and b/site/assets/files/1179/apartamento-o-mouron-4.0x260.jpg differ
diff --git a/site/assets/files/1179/apartamento-o-mouron-4.jpg b/site/assets/files/1179/apartamento-o-mouron-4.jpg
new file mode 100644
index 0000000..86ea2e6
Binary files /dev/null and b/site/assets/files/1179/apartamento-o-mouron-4.jpg differ
diff --git a/site/assets/files/1179/apartamento-o-mouron-5.0x260.jpg b/site/assets/files/1179/apartamento-o-mouron-5.0x260.jpg
new file mode 100644
index 0000000..606641f
Binary files /dev/null and b/site/assets/files/1179/apartamento-o-mouron-5.0x260.jpg differ
diff --git a/site/assets/files/1179/apartamento-o-mouron-5.jpg b/site/assets/files/1179/apartamento-o-mouron-5.jpg
new file mode 100644
index 0000000..b1a7dd3
Binary files /dev/null and b/site/assets/files/1179/apartamento-o-mouron-5.jpg differ
diff --git a/site/assets/files/1179/apartamento-o-mouron-6.0x260.jpg b/site/assets/files/1179/apartamento-o-mouron-6.0x260.jpg
new file mode 100644
index 0000000..c8dd09e
Binary files /dev/null and b/site/assets/files/1179/apartamento-o-mouron-6.0x260.jpg differ
diff --git a/site/assets/files/1179/apartamento-o-mouron-6.jpg b/site/assets/files/1179/apartamento-o-mouron-6.jpg
new file mode 100644
index 0000000..3fb4a44
Binary files /dev/null and b/site/assets/files/1179/apartamento-o-mouron-6.jpg differ
diff --git a/site/assets/files/1181/apartamento-a-cercada-1.0x260.jpg b/site/assets/files/1181/apartamento-a-cercada-1.0x260.jpg
new file mode 100644
index 0000000..2c27010
Binary files /dev/null and b/site/assets/files/1181/apartamento-a-cercada-1.0x260.jpg differ
diff --git a/site/assets/files/1181/apartamento-a-cercada-1.jpg b/site/assets/files/1181/apartamento-a-cercada-1.jpg
new file mode 100644
index 0000000..3e776ff
Binary files /dev/null and b/site/assets/files/1181/apartamento-a-cercada-1.jpg differ
diff --git a/site/assets/files/1181/apartamento-a-cercada-2.0x260.jpg b/site/assets/files/1181/apartamento-a-cercada-2.0x260.jpg
new file mode 100644
index 0000000..6a550d0
Binary files /dev/null and b/site/assets/files/1181/apartamento-a-cercada-2.0x260.jpg differ
diff --git a/site/assets/files/1181/apartamento-a-cercada-2.jpg b/site/assets/files/1181/apartamento-a-cercada-2.jpg
new file mode 100644
index 0000000..dbe5d36
Binary files /dev/null and b/site/assets/files/1181/apartamento-a-cercada-2.jpg differ
diff --git a/site/assets/files/1181/apartamento-a-cercada-3.0x260.jpg b/site/assets/files/1181/apartamento-a-cercada-3.0x260.jpg
new file mode 100644
index 0000000..9639346
Binary files /dev/null and b/site/assets/files/1181/apartamento-a-cercada-3.0x260.jpg differ
diff --git a/site/assets/files/1181/apartamento-a-cercada-3.jpg b/site/assets/files/1181/apartamento-a-cercada-3.jpg
new file mode 100644
index 0000000..06125ef
Binary files /dev/null and b/site/assets/files/1181/apartamento-a-cercada-3.jpg differ
diff --git a/site/assets/files/1181/apartamento-a-cercada-4.0x260.jpg b/site/assets/files/1181/apartamento-a-cercada-4.0x260.jpg
new file mode 100644
index 0000000..7fc891b
Binary files /dev/null and b/site/assets/files/1181/apartamento-a-cercada-4.0x260.jpg differ
diff --git a/site/assets/files/1181/apartamento-a-cercada-4.jpg b/site/assets/files/1181/apartamento-a-cercada-4.jpg
new file mode 100644
index 0000000..f9dc9de
Binary files /dev/null and b/site/assets/files/1181/apartamento-a-cercada-4.jpg differ
diff --git a/site/assets/files/1183/apartamento-a-cercada-1.0x260.jpg b/site/assets/files/1183/apartamento-a-cercada-1.0x260.jpg
new file mode 100644
index 0000000..2c27010
Binary files /dev/null and b/site/assets/files/1183/apartamento-a-cercada-1.0x260.jpg differ
diff --git a/site/assets/files/1183/apartamento-a-cercada-1.jpg b/site/assets/files/1183/apartamento-a-cercada-1.jpg
new file mode 100644
index 0000000..3e776ff
Binary files /dev/null and b/site/assets/files/1183/apartamento-a-cercada-1.jpg differ
diff --git a/site/assets/files/1183/apartamento-a-cercada-2.0x260.jpg b/site/assets/files/1183/apartamento-a-cercada-2.0x260.jpg
new file mode 100644
index 0000000..6a550d0
Binary files /dev/null and b/site/assets/files/1183/apartamento-a-cercada-2.0x260.jpg differ
diff --git a/site/assets/files/1183/apartamento-a-cercada-2.jpg b/site/assets/files/1183/apartamento-a-cercada-2.jpg
new file mode 100644
index 0000000..dbe5d36
Binary files /dev/null and b/site/assets/files/1183/apartamento-a-cercada-2.jpg differ
diff --git a/site/assets/files/1183/apartamento-a-cercada-3.0x260.jpg b/site/assets/files/1183/apartamento-a-cercada-3.0x260.jpg
new file mode 100644
index 0000000..9639346
Binary files /dev/null and b/site/assets/files/1183/apartamento-a-cercada-3.0x260.jpg differ
diff --git a/site/assets/files/1183/apartamento-a-cercada-3.jpg b/site/assets/files/1183/apartamento-a-cercada-3.jpg
new file mode 100644
index 0000000..06125ef
Binary files /dev/null and b/site/assets/files/1183/apartamento-a-cercada-3.jpg differ
diff --git a/site/assets/files/1183/apartamento-a-cercada-4.0x260.jpg b/site/assets/files/1183/apartamento-a-cercada-4.0x260.jpg
new file mode 100644
index 0000000..7fc891b
Binary files /dev/null and b/site/assets/files/1183/apartamento-a-cercada-4.0x260.jpg differ
diff --git a/site/assets/files/1183/apartamento-a-cercada-4.jpg b/site/assets/files/1183/apartamento-a-cercada-4.jpg
new file mode 100644
index 0000000..f9dc9de
Binary files /dev/null and b/site/assets/files/1183/apartamento-a-cercada-4.jpg differ
diff --git a/site/templates/css/style.css b/site/templates/css/style.css
index 8b98820..a2094df 100644
--- a/site/templates/css/style.css
+++ b/site/templates/css/style.css
@@ -3,6 +3,312 @@
box-sizing: border-box;
}
+html,
+body
+{
+ position: relative;
+ height: 100%;
+}
+
+body
+{
+ color: rgb(var(--cor_10));
+ font-family: 'Source Sans Pro', sans-serif;
+ font-size: 1rem;
+}
+
+a
+{
+ color: rgba(var(--cor_30), var(--bs-link-opacity, 1));
+ text-decoration-line: underline;
+ text-decoration-style: dotted;
+}
+
+h1, h2, h3, h4, h5, h6
+{
+ color: rgb(var(--cor_30));
+ font-family: 'Libre Baskerville', serif;
+}
+
+img
+{
+ width: 100%;
+}
+
+figure
+{
+ margin: 0;
+}
+
+figure figcaption
+{
+ padding: 10px 40px 20px;
+
+ color: rgb(var(--cor_30));
+ font-family: 'Source Sans Pro', sans-serif;
+ font-weight: normal;
+ font-size: 1rem;
+ text-align: center;
+}
+
+figure img
+{
+ display: block;
+
+ width: 100%;
+ height: auto;
+ object-fit: cover;
+
+ background-color: rgb(var(--cor_60));
+}
+
+figure.effect-ming
+{
+ background: #030c17;
+
+ position: relative;
+ float: left;
+ overflow: hidden;
+ margin: 10px 1%;
+ padding: 0;
+ min-width: 320px;
+ max-width: 480px;
+ max-height: 360px;
+ width: 100%;
+ height: auto;
+ background: rgb(var(--cor_30));
+ text-align: center;
+ cursor: pointer;
+}
+
+figure.effect-ming img
+{
+ position: relative;
+ display: block;
+ min-height: 100%;
+ max-width: 100%;
+ opacity: 0.9;
+ transition: opacity 0.35s;
+}
+
+figure.effect-ming:hover img
+{
+ opacity: 0.4;
+}
+
+figure.effect-ming figcaption
+{
+ padding: 2em;
+ color: #fff;
+ text-transform: uppercase;
+ font-size: 1.25em;
+ backface-visibility: hidden;
+}
+
+figure.effect-ming figcaption > a
+{
+ z-index: 1000;
+ text-indent: 200%;
+ white-space: nowrap;
+ font-size: 0;
+ opacity: 0;
+}
+
+figure.effect-ming figcaption,
+figure.effect-ming figcaption > a
+{
+ position: absolute;
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 100%;
+}
+
+figure.effect-ming h3
+{
+ margin: 20% 0 10px 0;
+ word-spacing: -0.15em;
+ font-weight: 300;
+ transition: transform 0.35s;
+ background: rgba(255,255,255,0.5);
+ color: rgb(var(--cor_30));
+}
+
+figure.effect-ming:hover h3
+{
+ transform: scale(0.9);
+}
+
+figure.effect-ming p
+{
+ padding: 1em;
+ opacity: 0;
+ letter-spacing: 1px;
+ font-size: 68.5%;
+ transition: opacity 0.35s, transform 0.35s;
+ transform: scale(1.5);
+}
+
+figure.effect-ming figcaption::before
+{
+ position: absolute;
+ top: 30px;
+ right: 30px;
+ bottom: 30px;
+ left: 30px;
+ border: 2px solid #fff;
+ box-shadow: 0 0 0 30px rgba(255,255,255,0.2);
+ content: '';
+ opacity: 0;
+ transition: opacity 0.35s, transform 0.35s;
+ transform: scale3d(1.4,1.4,1);
+}
+
+figure.effect-ming:hover figcaption::before,
+figure.effect-ming:hover p
+{
+ opacity: 1;
+ transform: scale3d(1,1,1);
+}
+
+figure.effect-ming figcaption::before, figure.effect-ming figcaption::after
+{
+ pointer-events: none;
+}
+
+.btn-primary
+{
+ --bs-btn-bg: rgb(var(--cor_30));
+ --bs-btn-border-color: rgb(var(--cor_30));
+ --bs-btn-hover-bg: rgb(var(--cor_30));
+ --bs-btn-hover-border-color: rgb(var(--cor_30));
+ --bs-btn-active-bg: rgb(var(--cor_30));
+ --bs-btn-active-border-color: rgb(var(--cor_30));
+ --bs-btn-disabled-bg: rgb(var(--cor_30));
+ --bs-btn-disabled-border-color: rgb(var(--cor_30));
+}
+
+.form-floating > .form-control,
+.form-floating > .form-control-plaintext,
+.form-floating > .form-select
+{
+ height: calc(2.25rem + 2px);
+ line-height: 1.25;
+}
+
+.form-floating > .form-control:focus ~ label,
+.form-floating > .form-control:not(:placeholder-shown) ~ label,
+.form-floating > .form-control-plaintext ~ label,
+.form-floating > .form-select ~ label
+{
+ height: unset;
+ width: unset;
+
+ padding: 0 !important;
+
+ background-color: #fff;
+
+ opacity: unset;
+
+ transform: scale(0.85) translateY(-0.8rem) translateX(0.15rem);
+}
+
+.nav-link.active,
+.nav-link:hover
+{
+ text-decoration-line: underline;
+ text-decoration-style: dotted;
+}
+
+.swiper
+{
+ width: 100%;
+ height: auto;
+
+ margin-left: auto;
+ margin-right: auto;
+}
+
+.galeria .swiper-slide
+{
+ display: flex;
+ justify-content: center;
+ align-items: center;
+
+ padding: 10px;
+
+ text-align: center;
+ font-size: 18px;
+
+ background: #fff;
+}
+
+.reixa .swiper-slide
+{
+ text-align: center;
+ font-size: 18px;
+ background: #fff;
+ height: calc((100% - 30px) / 2) !important;
+
+ display: flex;
+ justify-content: center;
+ align-items: center;
+}
+
+.swiper-button-prev,
+.swiper-button-next
+{
+ bottom: 15px;
+ top: unset;
+
+ color: rgb(var(--cor_10));
+}
+
+.swiper-pagination-bullet-active
+{
+ background: rgb(var(--cor_30));
+}
+
+.text-bg-primary
+{
+
+ background-color: rgba(var(--cor_30), var(--bs-bg-opacity, 1)) !important;
+}
+
+.visually-hidden
+{
+ position: absolute;
+ width: 1px;
+ height: 1px;
+ padding: 0;
+ margin: -1px;
+ white-space: nowrap;
+ overflow: hidden;
+ clip: rect(1px, 1px, 1px, 1px);
+ border: 0;
+}
+
+.element-focusable:focus
+{
+ clip: auto;
+ overflow: visible;
+ height: auto;
+}
+
+.bypass-to-main:focus
+{
+ top: 0;
+ left: 0;
+ width: 100%;
+ height: 40px;
+ line-height: 40px;
+ text-align: center;
+ background: rgb(var(--cor_30));
+ color: rgb(var(--cor_60));
+}
+
+/*
+
body
{
display: flex;
@@ -101,53 +407,16 @@ dd
padding: 0;
}
-img
-{
- width: 100%;
-}
-figure
-{
- margin: 0;
-}
+
+
ul li
{
list-style: none;
}
-figure figcaption
-{
- padding: 10px 40px 20px;
- color: rgb(var(--cor_30));
- font-family: 'Source Sans Pro', sans-serif;
- font-weight: normal;
- font-size: 1rem;
-}
-
-figure figcaption
-{
- text-align: center;
-}
-
-figure img
-{
- display: block;
-
- width: 100%;
- height: auto;
- object-fit: cover;
-
- background-color: rgb(var(--cor_60));
-}
-
-picture
-{
- align-items: center;
- display: flex;
- justify-content: center;
-}
section
{
@@ -514,37 +783,7 @@ footer#pe a
color: rgb(var(--cor_60));
}
-section.swiper
-{
- width: 100%;
- height: auto;
- margin-left: auto;
- margin-right: auto;
-}
-
-div.swiper-slide
-{
- display: flex;
- justify-content: center;
- align-items: center;
-
- padding: 10px;
-
- text-align: center;
- font-size: 18px;
-
- background: #fff;
-}
-
-.swiper-button-prev,
-.swiper-button-next
-{
- bottom: 15px;
- top: unset;
-
- color: rgb(var(--cor_10));
-}
div.celda
{
@@ -655,7 +894,7 @@ form#inicio-sesion div#notificacions.erro
{
color: #D8000C;
- background-color: #FFBABA;
+ background-color: #FFBABA;
}
form#inicio-sesion div#notificacions.alerta
diff --git a/site/templates/css/swiper.css b/site/templates/css/swiper.css
deleted file mode 100644
index 7619e5b..0000000
--- a/site/templates/css/swiper.css
+++ /dev/null
@@ -1,624 +0,0 @@
-/**
- * Swiper 8.0.7
- * Most modern mobile touch slider and framework with hardware accelerated transitions
- * https://swiperjs.com
- *
- * Copyright 2014-2022 Vladimir Kharlampidi
- *
- * Released under the MIT License
- *
- * Released on: March 4, 2022
- */
-
-@font-face {
- font-family: 'swiper-icons';
- src: url('data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA');
- font-weight: 400;
- font-style: normal;
-}
-:root {
- --swiper-theme-color: #007aff;
-}
-.swiper {
- margin-left: auto;
- margin-right: auto;
- position: relative;
- overflow: hidden;
- list-style: none;
- padding: 0;
- /* Fix of Webkit flickering */
- z-index: 1;
-}
-.swiper-vertical > .swiper-wrapper {
- flex-direction: column;
-}
-.swiper-wrapper {
- position: relative;
- width: 100%;
- height: 100%;
- z-index: 1;
- display: flex;
- transition-property: transform;
- box-sizing: content-box;
-}
-.swiper-android .swiper-slide,
-.swiper-wrapper {
- transform: translate3d(0px, 0, 0);
-}
-.swiper-pointer-events {
- touch-action: pan-y;
-}
-.swiper-pointer-events.swiper-vertical {
- touch-action: pan-x;
-}
-.swiper-slide {
- flex-shrink: 0;
- width: 100%;
- height: 100%;
- position: relative;
- transition-property: transform;
-}
-.swiper-slide-invisible-blank {
- visibility: hidden;
-}
-/* Auto Height */
-.swiper-autoheight,
-.swiper-autoheight .swiper-slide {
- height: auto;
-}
-.swiper-autoheight .swiper-wrapper {
- align-items: flex-start;
- transition-property: transform, height;
-}
-.swiper-backface-hidden .swiper-slide {
- transform: translateZ(0);
- -webkit-backface-visibility: hidden;
- backface-visibility: hidden;
-}
-/* 3D Effects */
-.swiper-3d,
-.swiper-3d.swiper-css-mode .swiper-wrapper {
- perspective: 1200px;
-}
-.swiper-3d .swiper-wrapper,
-.swiper-3d .swiper-slide,
-.swiper-3d .swiper-slide-shadow,
-.swiper-3d .swiper-slide-shadow-left,
-.swiper-3d .swiper-slide-shadow-right,
-.swiper-3d .swiper-slide-shadow-top,
-.swiper-3d .swiper-slide-shadow-bottom,
-.swiper-3d .swiper-cube-shadow {
- transform-style: preserve-3d;
-}
-.swiper-3d .swiper-slide-shadow,
-.swiper-3d .swiper-slide-shadow-left,
-.swiper-3d .swiper-slide-shadow-right,
-.swiper-3d .swiper-slide-shadow-top,
-.swiper-3d .swiper-slide-shadow-bottom {
- position: absolute;
- left: 0;
- top: 0;
- width: 100%;
- height: 100%;
- pointer-events: none;
- z-index: 10;
-}
-.swiper-3d .swiper-slide-shadow {
- background: rgba(0, 0, 0, 0.15);
-}
-.swiper-3d .swiper-slide-shadow-left {
- background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
-}
-.swiper-3d .swiper-slide-shadow-right {
- background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
-}
-.swiper-3d .swiper-slide-shadow-top {
- background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
-}
-.swiper-3d .swiper-slide-shadow-bottom {
- background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
-}
-/* CSS Mode */
-.swiper-css-mode > .swiper-wrapper {
- overflow: auto;
- scrollbar-width: none;
- /* For Firefox */
- -ms-overflow-style: none;
- /* For Internet Explorer and Edge */
-}
-.swiper-css-mode > .swiper-wrapper::-webkit-scrollbar {
- display: none;
-}
-.swiper-css-mode > .swiper-wrapper > .swiper-slide {
- scroll-snap-align: start start;
-}
-.swiper-horizontal.swiper-css-mode > .swiper-wrapper {
- scroll-snap-type: x mandatory;
-}
-.swiper-vertical.swiper-css-mode > .swiper-wrapper {
- scroll-snap-type: y mandatory;
-}
-.swiper-centered > .swiper-wrapper::before {
- content: '';
- flex-shrink: 0;
- order: 9999;
-}
-.swiper-centered.swiper-horizontal > .swiper-wrapper > .swiper-slide:first-child {
- margin-inline-start: var(--swiper-centered-offset-before);
-}
-.swiper-centered.swiper-horizontal > .swiper-wrapper::before {
- height: 100%;
- min-height: 1px;
- width: var(--swiper-centered-offset-after);
-}
-.swiper-centered.swiper-vertical > .swiper-wrapper > .swiper-slide:first-child {
- margin-block-start: var(--swiper-centered-offset-before);
-}
-.swiper-centered.swiper-vertical > .swiper-wrapper::before {
- width: 100%;
- min-width: 1px;
- height: var(--swiper-centered-offset-after);
-}
-.swiper-centered > .swiper-wrapper > .swiper-slide {
- scroll-snap-align: center center;
-}
-.swiper-virtual .swiper-slide {
- -webkit-backface-visibility: hidden;
- transform: translateZ(0);
-}
-.swiper-virtual.swiper-css-mode .swiper-wrapper::after {
- content: '';
- position: absolute;
- left: 0;
- top: 0;
- pointer-events: none;
-}
-.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after {
- height: 1px;
- width: var(--swiper-virtual-size);
-}
-.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after {
- width: 1px;
- height: var(--swiper-virtual-size);
-}
-:root {
- --swiper-navigation-size: 44px;
- /*
- --swiper-navigation-color: var(--swiper-theme-color);
- */
-}
-.swiper-button-prev,
-.swiper-button-next {
- position: absolute;
- top: 50%;
- width: calc(var(--swiper-navigation-size) / 44 * 27);
- height: var(--swiper-navigation-size);
- margin-top: calc(0px - (var(--swiper-navigation-size) / 2));
- z-index: 10;
- cursor: pointer;
- display: flex;
- align-items: center;
- justify-content: center;
- color: var(--swiper-navigation-color, var(--swiper-theme-color));
-}
-.swiper-button-prev.swiper-button-disabled,
-.swiper-button-next.swiper-button-disabled {
- opacity: 0.35;
- cursor: auto;
- pointer-events: none;
-}
-.swiper-button-prev:after,
-.swiper-button-next:after {
- font-family: swiper-icons;
- font-size: var(--swiper-navigation-size);
- text-transform: none !important;
- letter-spacing: 0;
- text-transform: none;
- font-variant: initial;
- line-height: 1;
-}
-.swiper-button-prev,
-.swiper-rtl .swiper-button-next {
- left: 10px;
- right: auto;
-}
-.swiper-button-prev:after,
-.swiper-rtl .swiper-button-next:after {
- content: 'prev';
-}
-.swiper-button-next,
-.swiper-rtl .swiper-button-prev {
- right: 10px;
- left: auto;
-}
-.swiper-button-next:after,
-.swiper-rtl .swiper-button-prev:after {
- content: 'next';
-}
-.swiper-button-lock {
- display: none;
-}
-:root {
- /*
- --swiper-pagination-color: var(--swiper-theme-color);
- --swiper-pagination-bullet-size: 8px;
- --swiper-pagination-bullet-width: 8px;
- --swiper-pagination-bullet-height: 8px;
- --swiper-pagination-bullet-inactive-color: #000;
- --swiper-pagination-bullet-inactive-opacity: 0.2;
- --swiper-pagination-bullet-opacity: 1;
- --swiper-pagination-bullet-horizontal-gap: 4px;
- --swiper-pagination-bullet-vertical-gap: 6px;
- */
-}
-.swiper-pagination {
- position: absolute;
- text-align: center;
- transition: 300ms opacity;
- transform: translate3d(0, 0, 0);
- z-index: 10;
-}
-.swiper-pagination.swiper-pagination-hidden {
- opacity: 0;
-}
-/* Common Styles */
-.swiper-pagination-fraction,
-.swiper-pagination-custom,
-.swiper-horizontal > .swiper-pagination-bullets,
-.swiper-pagination-bullets.swiper-pagination-horizontal {
- bottom: 10px;
- left: 0;
- width: 100%;
-}
-/* Bullets */
-.swiper-pagination-bullets-dynamic {
- overflow: hidden;
- font-size: 0;
-}
-.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
- transform: scale(0.33);
- position: relative;
-}
-.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
- transform: scale(1);
-}
-.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
- transform: scale(1);
-}
-.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
- transform: scale(0.66);
-}
-.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
- transform: scale(0.33);
-}
-.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
- transform: scale(0.66);
-}
-.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
- transform: scale(0.33);
-}
-.swiper-pagination-bullet {
- width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
- height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
- display: inline-block;
- border-radius: 50%;
- background: var(--swiper-pagination-bullet-inactive-color, #000);
- opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2);
-}
-button.swiper-pagination-bullet {
- border: none;
- margin: 0;
- padding: 0;
- box-shadow: none;
- -webkit-appearance: none;
- appearance: none;
-}
-.swiper-pagination-clickable .swiper-pagination-bullet {
- cursor: pointer;
-}
-.swiper-pagination-bullet:only-child {
- display: none !important;
-}
-.swiper-pagination-bullet-active {
- opacity: var(--swiper-pagination-bullet-opacity, 1);
- background: var(--swiper-pagination-color, var(--swiper-theme-color));
-}
-.swiper-vertical > .swiper-pagination-bullets,
-.swiper-pagination-vertical.swiper-pagination-bullets {
- right: 10px;
- top: 50%;
- transform: translate3d(0px, -50%, 0);
-}
-.swiper-vertical > .swiper-pagination-bullets .swiper-pagination-bullet,
-.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet {
- margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
- display: block;
-}
-.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
-.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
- top: 50%;
- transform: translateY(-50%);
- width: 8px;
-}
-.swiper-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
-.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
- display: inline-block;
- transition: 200ms transform, 200ms top;
-}
-.swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
-.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
- margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px);
-}
-.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
-.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
- left: 50%;
- transform: translateX(-50%);
- white-space: nowrap;
-}
-.swiper-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
-.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
- transition: 200ms transform, 200ms left;
-}
-.swiper-horizontal.swiper-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
- transition: 200ms transform, 200ms right;
-}
-/* Progress */
-.swiper-pagination-progressbar {
- background: rgba(0, 0, 0, 0.25);
- position: absolute;
-}
-.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
- background: var(--swiper-pagination-color, var(--swiper-theme-color));
- position: absolute;
- left: 0;
- top: 0;
- width: 100%;
- height: 100%;
- transform: scale(0);
- transform-origin: left top;
-}
-.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
- transform-origin: right top;
-}
-.swiper-horizontal > .swiper-pagination-progressbar,
-.swiper-pagination-progressbar.swiper-pagination-horizontal,
-.swiper-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
-.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite {
- width: 100%;
- height: 4px;
- left: 0;
- top: 0;
-}
-.swiper-vertical > .swiper-pagination-progressbar,
-.swiper-pagination-progressbar.swiper-pagination-vertical,
-.swiper-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
-.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite {
- width: 4px;
- height: 100%;
- left: 0;
- top: 0;
-}
-.swiper-pagination-lock {
- display: none;
-}
-/* Scrollbar */
-.swiper-scrollbar {
- border-radius: 10px;
- position: relative;
- -ms-touch-action: none;
- background: rgba(0, 0, 0, 0.1);
-}
-.swiper-horizontal > .swiper-scrollbar {
- position: absolute;
- left: 1%;
- bottom: 3px;
- z-index: 50;
- height: 5px;
- width: 98%;
-}
-.swiper-vertical > .swiper-scrollbar {
- position: absolute;
- right: 3px;
- top: 1%;
- z-index: 50;
- width: 5px;
- height: 98%;
-}
-.swiper-scrollbar-drag {
- height: 100%;
- width: 100%;
- position: relative;
- background: rgba(0, 0, 0, 0.5);
- border-radius: 10px;
- left: 0;
- top: 0;
-}
-.swiper-scrollbar-cursor-drag {
- cursor: move;
-}
-.swiper-scrollbar-lock {
- display: none;
-}
-.swiper-zoom-container {
- width: 100%;
- height: 100%;
- display: flex;
- justify-content: center;
- align-items: center;
- text-align: center;
-}
-.swiper-zoom-container > img,
-.swiper-zoom-container > svg,
-.swiper-zoom-container > canvas {
- max-width: 100%;
- max-height: 100%;
- object-fit: contain;
-}
-.swiper-slide-zoomed {
- cursor: move;
-}
-/* Preloader */
-:root {
- /*
- --swiper-preloader-color: var(--swiper-theme-color);
- */
-}
-.swiper-lazy-preloader {
- width: 42px;
- height: 42px;
- position: absolute;
- left: 50%;
- top: 50%;
- margin-left: -21px;
- margin-top: -21px;
- z-index: 10;
- transform-origin: 50%;
- box-sizing: border-box;
- border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
- border-radius: 50%;
- border-top-color: transparent;
-}
-.swiper-slide-visible .swiper-lazy-preloader {
- animation: swiper-preloader-spin 1s infinite linear;
-}
-.swiper-lazy-preloader-white {
- --swiper-preloader-color: #fff;
-}
-.swiper-lazy-preloader-black {
- --swiper-preloader-color: #000;
-}
-@keyframes swiper-preloader-spin {
- 100% {
- transform: rotate(360deg);
- }
-}
-/* a11y */
-.swiper .swiper-notification {
- position: absolute;
- left: 0;
- top: 0;
- pointer-events: none;
- opacity: 0;
- z-index: -1000;
-}
-.swiper-free-mode > .swiper-wrapper {
- transition-timing-function: ease-out;
- margin: 0 auto;
-}
-.swiper-grid > .swiper-wrapper {
- flex-wrap: wrap;
-}
-.swiper-grid-column > .swiper-wrapper {
- flex-wrap: wrap;
- flex-direction: column;
-}
-.swiper-fade.swiper-free-mode .swiper-slide {
- transition-timing-function: ease-out;
-}
-.swiper-fade .swiper-slide {
- pointer-events: none;
- transition-property: opacity;
-}
-.swiper-fade .swiper-slide .swiper-slide {
- pointer-events: none;
-}
-.swiper-fade .swiper-slide-active,
-.swiper-fade .swiper-slide-active .swiper-slide-active {
- pointer-events: auto;
-}
-.swiper-cube {
- overflow: visible;
-}
-.swiper-cube .swiper-slide {
- pointer-events: none;
- -webkit-backface-visibility: hidden;
- backface-visibility: hidden;
- z-index: 1;
- visibility: hidden;
- transform-origin: 0 0;
- width: 100%;
- height: 100%;
-}
-.swiper-cube .swiper-slide .swiper-slide {
- pointer-events: none;
-}
-.swiper-cube.swiper-rtl .swiper-slide {
- transform-origin: 100% 0;
-}
-.swiper-cube .swiper-slide-active,
-.swiper-cube .swiper-slide-active .swiper-slide-active {
- pointer-events: auto;
-}
-.swiper-cube .swiper-slide-active,
-.swiper-cube .swiper-slide-next,
-.swiper-cube .swiper-slide-prev,
-.swiper-cube .swiper-slide-next + .swiper-slide {
- pointer-events: auto;
- visibility: visible;
-}
-.swiper-cube .swiper-slide-shadow-top,
-.swiper-cube .swiper-slide-shadow-bottom,
-.swiper-cube .swiper-slide-shadow-left,
-.swiper-cube .swiper-slide-shadow-right {
- z-index: 0;
- -webkit-backface-visibility: hidden;
- backface-visibility: hidden;
-}
-.swiper-cube .swiper-cube-shadow {
- position: absolute;
- left: 0;
- bottom: 0px;
- width: 100%;
- height: 100%;
- opacity: 0.6;
- z-index: 0;
-}
-.swiper-cube .swiper-cube-shadow:before {
- content: '';
- background: #000;
- position: absolute;
- left: 0;
- top: 0;
- bottom: 0;
- right: 0;
- filter: blur(50px);
-}
-.swiper-flip {
- overflow: visible;
-}
-.swiper-flip .swiper-slide {
- pointer-events: none;
- -webkit-backface-visibility: hidden;
- backface-visibility: hidden;
- z-index: 1;
-}
-.swiper-flip .swiper-slide .swiper-slide {
- pointer-events: none;
-}
-.swiper-flip .swiper-slide-active,
-.swiper-flip .swiper-slide-active .swiper-slide-active {
- pointer-events: auto;
-}
-.swiper-flip .swiper-slide-shadow-top,
-.swiper-flip .swiper-slide-shadow-bottom,
-.swiper-flip .swiper-slide-shadow-left,
-.swiper-flip .swiper-slide-shadow-right {
- z-index: 0;
- -webkit-backface-visibility: hidden;
- backface-visibility: hidden;
-}
-.swiper-creative .swiper-slide {
- -webkit-backface-visibility: hidden;
- backface-visibility: hidden;
- overflow: hidden;
- transition-property: transform, opacity, height;
-}
-.swiper-cards {
- overflow: visible;
-}
-.swiper-cards .swiper-slide {
- transform-origin: center bottom;
- -webkit-backface-visibility: hidden;
- backface-visibility: hidden;
- overflow: hidden;
-}
diff --git a/site/templates/habitacion.php b/site/templates/habitacion.php
index 90ba360..1fbb2bc 100644
--- a/site/templates/habitacion.php
+++ b/site/templates/habitacion.php
@@ -1,27 +1,22 @@
mantemento;
-
-if($mantemento && !$user->isLoggedin())
+if($configuracion['mantemento']['activo'] && !$user->isLoggedin())
{
$session->redirect($inicio->url);
}
else
{
- $menu = renderMenu($inicio->and($inicio->children), 0, 'paxinas');
+ $menu = renderMenu($inicio->children);
$contido .= renderMigasPan($page) . "\n";
- $contido .= '' . "\n";
- $contido .= '' . "\n";
- $contido .= '
' . ucfirst($page->title) . ' ' . "\n";
- if(count($page->seccions))
- {
- $contido .= getSeccions($page->seccions) . "\n";
- }
- $contido .= '' . "\n";
+ $contido .= '' . "\n";
+ $contido .= '' . ucfirst($inicio->title) . ' ' . "\n";
+ $contido .= getSeccions($page->seccions) . "\n";
$contido .= ' ' . "\n";
}
\ No newline at end of file
diff --git a/site/templates/habitacions.php b/site/templates/habitacions.php
index 9723e60..de9c117 100644
--- a/site/templates/habitacions.php
+++ b/site/templates/habitacions.php
@@ -1,34 +1,31 @@
mantemento;
-
-if($mantemento && !$user->isLoggedin())
+if($configuracion['mantemento']['activo'] && !$user->isLoggedin())
{
$session->redirect($inicio->url);
}
else
{
- $menu = renderMenu($inicio->and($inicio->children), 0, 'paxinas');
+ $menu = renderMenu($inicio->children);
$contido .= renderMigasPan($page) . "\n";
- $contido .= '' . "\n";
- $contido .= '' . "\n";
- $contido .= '
' . ucfirst($page->title) . ' ' . "\n";
- if(count($page->seccions))
- {
- $contido .= getSeccions($page->seccions) . "\n";
- }
+ $contido .= '
' . "\n";
+ $contido .= '' . ucfirst($inicio->title) . ' ' . "\n";
+ $contido .= getSeccions($page->seccions) . "\n";
$contido .= '' . "\n";
$contido .= '' . $page->title . ' ' . "\n";
- if(count($page->imaxe_ligazon))
+ $contido .= '' . "\n";
+ if(count($page->ligazon_imaxe))
{
- $contido .= getSeccions($page->imaxe_ligazon) . "\n";
+ $contido .= getSeccions($page->ligazon_imaxe) . "\n";
}
- $contido .= '' . "\n";
$contido .= '
' . "\n";
+ $contido .= ' ' . "\n";
$contido .= ' ' . "\n";
}
\ No newline at end of file
diff --git a/site/templates/images/edlp.jpg b/site/templates/images/edlp.jpg
deleted file mode 100644
index 3104ea7..0000000
Binary files a/site/templates/images/edlp.jpg and /dev/null differ
diff --git a/site/templates/images/logo_golfo_artabro.png b/site/templates/images/logo_golfo_artabro.png
new file mode 100644
index 0000000..1cf0453
Binary files /dev/null and b/site/templates/images/logo_golfo_artabro.png differ
diff --git a/site/templates/images/logo_unioneuropea.png b/site/templates/images/logo_unioneuropea.png
new file mode 100644
index 0000000..5ec7d1e
Binary files /dev/null and b/site/templates/images/logo_unioneuropea.png differ
diff --git a/site/templates/images/logo_xuntafalicia.png b/site/templates/images/logo_xuntafalicia.png
new file mode 100644
index 0000000..acdf4c4
Binary files /dev/null and b/site/templates/images/logo_xuntafalicia.png differ
diff --git a/site/templates/inicio.php b/site/templates/inicio.php
index 49caf44..8ff69de 100644
--- a/site/templates/inicio.php
+++ b/site/templates/inicio.php
@@ -1,23 +1,23 @@
' . "\n";
-$contido .= '
' . "\n";
+$contido .= '
' . "\n";
$contido .= '' . ucfirst($inicio->title) . ' ' . "\n";
if($configuracion['mantemento']['activo'] && !$user->isLoggedin())
{
- $menu = renderMenu($inicio, 0, 'paxinas');
+ $menu = renderMenu($pages->get('/noticias'));
$contido .= renderTextoMantemento($configuracion['mantemento']['titular'], $configuracion['mantemento']['artigo'], $configuracion['mantemento']['imaxe']) . "\n";
}
else
{
- $menu = renderMenu($inicio->and($inicio->children), 0, 'paxinas');
+ $menu = renderMenu($inicio->children);
- $contido .= getSeccions($inicio->seccions) . "\n";
+ $contido .= getSeccions($page->seccions) . "\n";
}
-$contido .= ' ' . "\n";
$contido .= '' . "\n";
\ No newline at end of file
diff --git a/site/templates/js/main.js b/site/templates/js/main.js
index af039e0..e69de29 100644
--- a/site/templates/js/main.js
+++ b/site/templates/js/main.js
@@ -1,30 +0,0 @@
-function getToken(event)
-{
- event.preventDefault();
-
- grecaptcha.ready(function()
- {
- grecaptcha.execute('6LexXqYiAAAAACwDpMGIg1OMnAXVJU0VmbEMQUD8', { action: 'submit' }).then(function(token)
- {
- var form = document.getElementById("inicio-sesion");
-
-
- var boton_token = document.createElement('input');
- boton_token.type = 'hidden';
- boton_token.name = 'token';
- boton_token.id = 'token';
- boton_token.value = token;
-
- var boton_action = document.createElement('input');
- boton_action.type = 'hidden';
- boton_action.name = 'action';
- boton_action.id = 'action';
- boton_action.value = 'submit';
-
- form.appendChild(boton_token);
- form.appendChild(boton_action);
-
- form.submit();
- });;
- });
-}
\ No newline at end of file
diff --git a/site/templates/js/swiper.js b/site/templates/js/swiper.js
deleted file mode 100644
index ec24c02..0000000
--- a/site/templates/js/swiper.js
+++ /dev/null
@@ -1,10420 +0,0 @@
-/**
- * Swiper 8.0.7
- * Most modern mobile touch slider and framework with hardware accelerated transitions
- * https://swiperjs.com
- *
- * Copyright 2014-2022 Vladimir Kharlampidi
- *
- * Released under the MIT License
- *
- * Released on: March 4, 2022
- */
-
-(function (global, factory) {
- typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
- typeof define === 'function' && define.amd ? define(factory) :
- (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.Swiper = factory());
-})(this, (function () { 'use strict';
-
- /**
- * SSR Window 4.0.2
- * Better handling for window object in SSR environment
- * https://github.com/nolimits4web/ssr-window
- *
- * Copyright 2021, Vladimir Kharlampidi
- *
- * Licensed under MIT
- *
- * Released on: December 13, 2021
- */
-
- /* eslint-disable no-param-reassign */
- function isObject$1(obj) {
- return obj !== null && typeof obj === 'object' && 'constructor' in obj && obj.constructor === Object;
- }
-
- function extend$1(target, src) {
- if (target === void 0) {
- target = {};
- }
-
- if (src === void 0) {
- src = {};
- }
-
- Object.keys(src).forEach(key => {
- if (typeof target[key] === 'undefined') target[key] = src[key];else if (isObject$1(src[key]) && isObject$1(target[key]) && Object.keys(src[key]).length > 0) {
- extend$1(target[key], src[key]);
- }
- });
- }
-
- const ssrDocument = {
- body: {},
-
- addEventListener() {},
-
- removeEventListener() {},
-
- activeElement: {
- blur() {},
-
- nodeName: ''
- },
-
- querySelector() {
- return null;
- },
-
- querySelectorAll() {
- return [];
- },
-
- getElementById() {
- return null;
- },
-
- createEvent() {
- return {
- initEvent() {}
-
- };
- },
-
- createElement() {
- return {
- children: [],
- childNodes: [],
- style: {},
-
- setAttribute() {},
-
- getElementsByTagName() {
- return [];
- }
-
- };
- },
-
- createElementNS() {
- return {};
- },
-
- importNode() {
- return null;
- },
-
- location: {
- hash: '',
- host: '',
- hostname: '',
- href: '',
- origin: '',
- pathname: '',
- protocol: '',
- search: ''
- }
- };
-
- function getDocument() {
- const doc = typeof document !== 'undefined' ? document : {};
- extend$1(doc, ssrDocument);
- return doc;
- }
-
- const ssrWindow = {
- document: ssrDocument,
- navigator: {
- userAgent: ''
- },
- location: {
- hash: '',
- host: '',
- hostname: '',
- href: '',
- origin: '',
- pathname: '',
- protocol: '',
- search: ''
- },
- history: {
- replaceState() {},
-
- pushState() {},
-
- go() {},
-
- back() {}
-
- },
- CustomEvent: function CustomEvent() {
- return this;
- },
-
- addEventListener() {},
-
- removeEventListener() {},
-
- getComputedStyle() {
- return {
- getPropertyValue() {
- return '';
- }
-
- };
- },
-
- Image() {},
-
- Date() {},
-
- screen: {},
-
- setTimeout() {},
-
- clearTimeout() {},
-
- matchMedia() {
- return {};
- },
-
- requestAnimationFrame(callback) {
- if (typeof setTimeout === 'undefined') {
- callback();
- return null;
- }
-
- return setTimeout(callback, 0);
- },
-
- cancelAnimationFrame(id) {
- if (typeof setTimeout === 'undefined') {
- return;
- }
-
- clearTimeout(id);
- }
-
- };
-
- function getWindow() {
- const win = typeof window !== 'undefined' ? window : {};
- extend$1(win, ssrWindow);
- return win;
- }
-
- /**
- * Dom7 4.0.4
- * Minimalistic JavaScript library for DOM manipulation, with a jQuery-compatible API
- * https://framework7.io/docs/dom7.html
- *
- * Copyright 2022, Vladimir Kharlampidi
- *
- * Licensed under MIT
- *
- * Released on: January 11, 2022
- */
- /* eslint-disable no-proto */
-
- function makeReactive(obj) {
- const proto = obj.__proto__;
- Object.defineProperty(obj, '__proto__', {
- get() {
- return proto;
- },
-
- set(value) {
- proto.__proto__ = value;
- }
-
- });
- }
-
- class Dom7 extends Array {
- constructor(items) {
- if (typeof items === 'number') {
- super(items);
- } else {
- super(...(items || []));
- makeReactive(this);
- }
- }
-
- }
-
- function arrayFlat(arr) {
- if (arr === void 0) {
- arr = [];
- }
-
- const res = [];
- arr.forEach(el => {
- if (Array.isArray(el)) {
- res.push(...arrayFlat(el));
- } else {
- res.push(el);
- }
- });
- return res;
- }
-
- function arrayFilter(arr, callback) {
- return Array.prototype.filter.call(arr, callback);
- }
-
- function arrayUnique(arr) {
- const uniqueArray = [];
-
- for (let i = 0; i < arr.length; i += 1) {
- if (uniqueArray.indexOf(arr[i]) === -1) uniqueArray.push(arr[i]);
- }
-
- return uniqueArray;
- }
-
-
- function qsa(selector, context) {
- if (typeof selector !== 'string') {
- return [selector];
- }
-
- const a = [];
- const res = context.querySelectorAll(selector);
-
- for (let i = 0; i < res.length; i += 1) {
- a.push(res[i]);
- }
-
- return a;
- }
-
- function $(selector, context) {
- const window = getWindow();
- const document = getDocument();
- let arr = [];
-
- if (!context && selector instanceof Dom7) {
- return selector;
- }
-
- if (!selector) {
- return new Dom7(arr);
- }
-
- if (typeof selector === 'string') {
- const html = selector.trim();
-
- if (html.indexOf('<') >= 0 && html.indexOf('>') >= 0) {
- let toCreate = 'div';
- if (html.indexOf('
c.split(' ')));
- this.forEach(el => {
- el.classList.add(...classNames);
- });
- return this;
- }
-
- function removeClass() {
- for (var _len2 = arguments.length, classes = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
- classes[_key2] = arguments[_key2];
- }
-
- const classNames = arrayFlat(classes.map(c => c.split(' ')));
- this.forEach(el => {
- el.classList.remove(...classNames);
- });
- return this;
- }
-
- function toggleClass() {
- for (var _len3 = arguments.length, classes = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
- classes[_key3] = arguments[_key3];
- }
-
- const classNames = arrayFlat(classes.map(c => c.split(' ')));
- this.forEach(el => {
- classNames.forEach(className => {
- el.classList.toggle(className);
- });
- });
- }
-
- function hasClass() {
- for (var _len4 = arguments.length, classes = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {
- classes[_key4] = arguments[_key4];
- }
-
- const classNames = arrayFlat(classes.map(c => c.split(' ')));
- return arrayFilter(this, el => {
- return classNames.filter(className => el.classList.contains(className)).length > 0;
- }).length > 0;
- }
-
- function attr(attrs, value) {
- if (arguments.length === 1 && typeof attrs === 'string') {
- // Get attr
- if (this[0]) return this[0].getAttribute(attrs);
- return undefined;
- } // Set attrs
-
-
- for (let i = 0; i < this.length; i += 1) {
- if (arguments.length === 2) {
- // String
- this[i].setAttribute(attrs, value);
- } else {
- // Object
- for (const attrName in attrs) {
- this[i][attrName] = attrs[attrName];
- this[i].setAttribute(attrName, attrs[attrName]);
- }
- }
- }
-
- return this;
- }
-
- function removeAttr(attr) {
- for (let i = 0; i < this.length; i += 1) {
- this[i].removeAttribute(attr);
- }
-
- return this;
- }
-
- function transform(transform) {
- for (let i = 0; i < this.length; i += 1) {
- this[i].style.transform = transform;
- }
-
- return this;
- }
-
- function transition$1(duration) {
- for (let i = 0; i < this.length; i += 1) {
- this[i].style.transitionDuration = typeof duration !== 'string' ? `${duration}ms` : duration;
- }
-
- return this;
- }
-
- function on() {
- for (var _len5 = arguments.length, args = new Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {
- args[_key5] = arguments[_key5];
- }
-
- let [eventType, targetSelector, listener, capture] = args;
-
- if (typeof args[1] === 'function') {
- [eventType, listener, capture] = args;
- targetSelector = undefined;
- }
-
- if (!capture) capture = false;
-
- function handleLiveEvent(e) {
- const target = e.target;
- if (!target) return;
- const eventData = e.target.dom7EventData || [];
-
- if (eventData.indexOf(e) < 0) {
- eventData.unshift(e);
- }
-
- if ($(target).is(targetSelector)) listener.apply(target, eventData);else {
- const parents = $(target).parents(); // eslint-disable-line
-
- for (let k = 0; k < parents.length; k += 1) {
- if ($(parents[k]).is(targetSelector)) listener.apply(parents[k], eventData);
- }
- }
- }
-
- function handleEvent(e) {
- const eventData = e && e.target ? e.target.dom7EventData || [] : [];
-
- if (eventData.indexOf(e) < 0) {
- eventData.unshift(e);
- }
-
- listener.apply(this, eventData);
- }
-
- const events = eventType.split(' ');
- let j;
-
- for (let i = 0; i < this.length; i += 1) {
- const el = this[i];
-
- if (!targetSelector) {
- for (j = 0; j < events.length; j += 1) {
- const event = events[j];
- if (!el.dom7Listeners) el.dom7Listeners = {};
- if (!el.dom7Listeners[event]) el.dom7Listeners[event] = [];
- el.dom7Listeners[event].push({
- listener,
- proxyListener: handleEvent
- });
- el.addEventListener(event, handleEvent, capture);
- }
- } else {
- // Live events
- for (j = 0; j < events.length; j += 1) {
- const event = events[j];
- if (!el.dom7LiveListeners) el.dom7LiveListeners = {};
- if (!el.dom7LiveListeners[event]) el.dom7LiveListeners[event] = [];
- el.dom7LiveListeners[event].push({
- listener,
- proxyListener: handleLiveEvent
- });
- el.addEventListener(event, handleLiveEvent, capture);
- }
- }
- }
-
- return this;
- }
-
- function off() {
- for (var _len6 = arguments.length, args = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) {
- args[_key6] = arguments[_key6];
- }
-
- let [eventType, targetSelector, listener, capture] = args;
-
- if (typeof args[1] === 'function') {
- [eventType, listener, capture] = args;
- targetSelector = undefined;
- }
-
- if (!capture) capture = false;
- const events = eventType.split(' ');
-
- for (let i = 0; i < events.length; i += 1) {
- const event = events[i];
-
- for (let j = 0; j < this.length; j += 1) {
- const el = this[j];
- let handlers;
-
- if (!targetSelector && el.dom7Listeners) {
- handlers = el.dom7Listeners[event];
- } else if (targetSelector && el.dom7LiveListeners) {
- handlers = el.dom7LiveListeners[event];
- }
-
- if (handlers && handlers.length) {
- for (let k = handlers.length - 1; k >= 0; k -= 1) {
- const handler = handlers[k];
-
- if (listener && handler.listener === listener) {
- el.removeEventListener(event, handler.proxyListener, capture);
- handlers.splice(k, 1);
- } else if (listener && handler.listener && handler.listener.dom7proxy && handler.listener.dom7proxy === listener) {
- el.removeEventListener(event, handler.proxyListener, capture);
- handlers.splice(k, 1);
- } else if (!listener) {
- el.removeEventListener(event, handler.proxyListener, capture);
- handlers.splice(k, 1);
- }
- }
- }
- }
- }
-
- return this;
- }
-
- function trigger() {
- const window = getWindow();
-
- for (var _len9 = arguments.length, args = new Array(_len9), _key9 = 0; _key9 < _len9; _key9++) {
- args[_key9] = arguments[_key9];
- }
-
- const events = args[0].split(' ');
- const eventData = args[1];
-
- for (let i = 0; i < events.length; i += 1) {
- const event = events[i];
-
- for (let j = 0; j < this.length; j += 1) {
- const el = this[j];
-
- if (window.CustomEvent) {
- const evt = new window.CustomEvent(event, {
- detail: eventData,
- bubbles: true,
- cancelable: true
- });
- el.dom7EventData = args.filter((data, dataIndex) => dataIndex > 0);
- el.dispatchEvent(evt);
- el.dom7EventData = [];
- delete el.dom7EventData;
- }
- }
- }
-
- return this;
- }
-
- function transitionEnd$1(callback) {
- const dom = this;
-
- function fireCallBack(e) {
- if (e.target !== this) return;
- callback.call(this, e);
- dom.off('transitionend', fireCallBack);
- }
-
- if (callback) {
- dom.on('transitionend', fireCallBack);
- }
-
- return this;
- }
-
- function outerWidth(includeMargins) {
- if (this.length > 0) {
- if (includeMargins) {
- const styles = this.styles();
- return this[0].offsetWidth + parseFloat(styles.getPropertyValue('margin-right')) + parseFloat(styles.getPropertyValue('margin-left'));
- }
-
- return this[0].offsetWidth;
- }
-
- return null;
- }
-
- function outerHeight(includeMargins) {
- if (this.length > 0) {
- if (includeMargins) {
- const styles = this.styles();
- return this[0].offsetHeight + parseFloat(styles.getPropertyValue('margin-top')) + parseFloat(styles.getPropertyValue('margin-bottom'));
- }
-
- return this[0].offsetHeight;
- }
-
- return null;
- }
-
- function offset() {
- if (this.length > 0) {
- const window = getWindow();
- const document = getDocument();
- const el = this[0];
- const box = el.getBoundingClientRect();
- const body = document.body;
- const clientTop = el.clientTop || body.clientTop || 0;
- const clientLeft = el.clientLeft || body.clientLeft || 0;
- const scrollTop = el === window ? window.scrollY : el.scrollTop;
- const scrollLeft = el === window ? window.scrollX : el.scrollLeft;
- return {
- top: box.top + scrollTop - clientTop,
- left: box.left + scrollLeft - clientLeft
- };
- }
-
- return null;
- }
-
- function styles() {
- const window = getWindow();
- if (this[0]) return window.getComputedStyle(this[0], null);
- return {};
- }
-
- function css(props, value) {
- const window = getWindow();
- let i;
-
- if (arguments.length === 1) {
- if (typeof props === 'string') {
- // .css('width')
- if (this[0]) return window.getComputedStyle(this[0], null).getPropertyValue(props);
- } else {
- // .css({ width: '100px' })
- for (i = 0; i < this.length; i += 1) {
- for (const prop in props) {
- this[i].style[prop] = props[prop];
- }
- }
-
- return this;
- }
- }
-
- if (arguments.length === 2 && typeof props === 'string') {
- // .css('width', '100px')
- for (i = 0; i < this.length; i += 1) {
- this[i].style[props] = value;
- }
-
- return this;
- }
-
- return this;
- }
-
- function each(callback) {
- if (!callback) return this;
- this.forEach((el, index) => {
- callback.apply(el, [el, index]);
- });
- return this;
- }
-
- function filter(callback) {
- const result = arrayFilter(this, callback);
- return $(result);
- }
-
- function html(html) {
- if (typeof html === 'undefined') {
- return this[0] ? this[0].innerHTML : null;
- }
-
- for (let i = 0; i < this.length; i += 1) {
- this[i].innerHTML = html;
- }
-
- return this;
- }
-
- function text(text) {
- if (typeof text === 'undefined') {
- return this[0] ? this[0].textContent.trim() : null;
- }
-
- for (let i = 0; i < this.length; i += 1) {
- this[i].textContent = text;
- }
-
- return this;
- }
-
- function is(selector) {
- const window = getWindow();
- const document = getDocument();
- const el = this[0];
- let compareWith;
- let i;
- if (!el || typeof selector === 'undefined') return false;
-
- if (typeof selector === 'string') {
- if (el.matches) return el.matches(selector);
- if (el.webkitMatchesSelector) return el.webkitMatchesSelector(selector);
- if (el.msMatchesSelector) return el.msMatchesSelector(selector);
- compareWith = $(selector);
-
- for (i = 0; i < compareWith.length; i += 1) {
- if (compareWith[i] === el) return true;
- }
-
- return false;
- }
-
- if (selector === document) {
- return el === document;
- }
-
- if (selector === window) {
- return el === window;
- }
-
- if (selector.nodeType || selector instanceof Dom7) {
- compareWith = selector.nodeType ? [selector] : selector;
-
- for (i = 0; i < compareWith.length; i += 1) {
- if (compareWith[i] === el) return true;
- }
-
- return false;
- }
-
- return false;
- }
-
- function index() {
- let child = this[0];
- let i;
-
- if (child) {
- i = 0; // eslint-disable-next-line
-
- while ((child = child.previousSibling) !== null) {
- if (child.nodeType === 1) i += 1;
- }
-
- return i;
- }
-
- return undefined;
- }
-
- function eq(index) {
- if (typeof index === 'undefined') return this;
- const length = this.length;
-
- if (index > length - 1) {
- return $([]);
- }
-
- if (index < 0) {
- const returnIndex = length + index;
- if (returnIndex < 0) return $([]);
- return $([this[returnIndex]]);
- }
-
- return $([this[index]]);
- }
-
- function append() {
- let newChild;
- const document = getDocument();
-
- for (let k = 0; k < arguments.length; k += 1) {
- newChild = k < 0 || arguments.length <= k ? undefined : arguments[k];
-
- for (let i = 0; i < this.length; i += 1) {
- if (typeof newChild === 'string') {
- const tempDiv = document.createElement('div');
- tempDiv.innerHTML = newChild;
-
- while (tempDiv.firstChild) {
- this[i].appendChild(tempDiv.firstChild);
- }
- } else if (newChild instanceof Dom7) {
- for (let j = 0; j < newChild.length; j += 1) {
- this[i].appendChild(newChild[j]);
- }
- } else {
- this[i].appendChild(newChild);
- }
- }
- }
-
- return this;
- }
-
- function prepend(newChild) {
- const document = getDocument();
- let i;
- let j;
-
- for (i = 0; i < this.length; i += 1) {
- if (typeof newChild === 'string') {
- const tempDiv = document.createElement('div');
- tempDiv.innerHTML = newChild;
-
- for (j = tempDiv.childNodes.length - 1; j >= 0; j -= 1) {
- this[i].insertBefore(tempDiv.childNodes[j], this[i].childNodes[0]);
- }
- } else if (newChild instanceof Dom7) {
- for (j = 0; j < newChild.length; j += 1) {
- this[i].insertBefore(newChild[j], this[i].childNodes[0]);
- }
- } else {
- this[i].insertBefore(newChild, this[i].childNodes[0]);
- }
- }
-
- return this;
- }
-
- function next(selector) {
- if (this.length > 0) {
- if (selector) {
- if (this[0].nextElementSibling && $(this[0].nextElementSibling).is(selector)) {
- return $([this[0].nextElementSibling]);
- }
-
- return $([]);
- }
-
- if (this[0].nextElementSibling) return $([this[0].nextElementSibling]);
- return $([]);
- }
-
- return $([]);
- }
-
- function nextAll(selector) {
- const nextEls = [];
- let el = this[0];
- if (!el) return $([]);
-
- while (el.nextElementSibling) {
- const next = el.nextElementSibling; // eslint-disable-line
-
- if (selector) {
- if ($(next).is(selector)) nextEls.push(next);
- } else nextEls.push(next);
-
- el = next;
- }
-
- return $(nextEls);
- }
-
- function prev(selector) {
- if (this.length > 0) {
- const el = this[0];
-
- if (selector) {
- if (el.previousElementSibling && $(el.previousElementSibling).is(selector)) {
- return $([el.previousElementSibling]);
- }
-
- return $([]);
- }
-
- if (el.previousElementSibling) return $([el.previousElementSibling]);
- return $([]);
- }
-
- return $([]);
- }
-
- function prevAll(selector) {
- const prevEls = [];
- let el = this[0];
- if (!el) return $([]);
-
- while (el.previousElementSibling) {
- const prev = el.previousElementSibling; // eslint-disable-line
-
- if (selector) {
- if ($(prev).is(selector)) prevEls.push(prev);
- } else prevEls.push(prev);
-
- el = prev;
- }
-
- return $(prevEls);
- }
-
- function parent(selector) {
- const parents = []; // eslint-disable-line
-
- for (let i = 0; i < this.length; i += 1) {
- if (this[i].parentNode !== null) {
- if (selector) {
- if ($(this[i].parentNode).is(selector)) parents.push(this[i].parentNode);
- } else {
- parents.push(this[i].parentNode);
- }
- }
- }
-
- return $(parents);
- }
-
- function parents(selector) {
- const parents = []; // eslint-disable-line
-
- for (let i = 0; i < this.length; i += 1) {
- let parent = this[i].parentNode; // eslint-disable-line
-
- while (parent) {
- if (selector) {
- if ($(parent).is(selector)) parents.push(parent);
- } else {
- parents.push(parent);
- }
-
- parent = parent.parentNode;
- }
- }
-
- return $(parents);
- }
-
- function closest(selector) {
- let closest = this; // eslint-disable-line
-
- if (typeof selector === 'undefined') {
- return $([]);
- }
-
- if (!closest.is(selector)) {
- closest = closest.parents(selector).eq(0);
- }
-
- return closest;
- }
-
- function find(selector) {
- const foundElements = [];
-
- for (let i = 0; i < this.length; i += 1) {
- const found = this[i].querySelectorAll(selector);
-
- for (let j = 0; j < found.length; j += 1) {
- foundElements.push(found[j]);
- }
- }
-
- return $(foundElements);
- }
-
- function children(selector) {
- const children = []; // eslint-disable-line
-
- for (let i = 0; i < this.length; i += 1) {
- const childNodes = this[i].children;
-
- for (let j = 0; j < childNodes.length; j += 1) {
- if (!selector || $(childNodes[j]).is(selector)) {
- children.push(childNodes[j]);
- }
- }
- }
-
- return $(children);
- }
-
- function remove() {
- for (let i = 0; i < this.length; i += 1) {
- if (this[i].parentNode) this[i].parentNode.removeChild(this[i]);
- }
-
- return this;
- }
-
- const Methods = {
- addClass,
- removeClass,
- hasClass,
- toggleClass,
- attr,
- removeAttr,
- transform,
- transition: transition$1,
- on,
- off,
- trigger,
- transitionEnd: transitionEnd$1,
- outerWidth,
- outerHeight,
- styles,
- offset,
- css,
- each,
- html,
- text,
- is,
- index,
- eq,
- append,
- prepend,
- next,
- nextAll,
- prev,
- prevAll,
- parent,
- parents,
- closest,
- find,
- children,
- filter,
- remove
- };
- Object.keys(Methods).forEach(methodName => {
- Object.defineProperty($.fn, methodName, {
- value: Methods[methodName],
- writable: true
- });
- });
-
- function deleteProps(obj) {
- const object = obj;
- Object.keys(object).forEach(key => {
- try {
- object[key] = null;
- } catch (e) {// no getter for object
- }
-
- try {
- delete object[key];
- } catch (e) {// something got wrong
- }
- });
- }
-
- function nextTick(callback, delay) {
- if (delay === void 0) {
- delay = 0;
- }
-
- return setTimeout(callback, delay);
- }
-
- function now() {
- return Date.now();
- }
-
- function getComputedStyle$1(el) {
- const window = getWindow();
- let style;
-
- if (window.getComputedStyle) {
- style = window.getComputedStyle(el, null);
- }
-
- if (!style && el.currentStyle) {
- style = el.currentStyle;
- }
-
- if (!style) {
- style = el.style;
- }
-
- return style;
- }
-
- function getTranslate(el, axis) {
- if (axis === void 0) {
- axis = 'x';
- }
-
- const window = getWindow();
- let matrix;
- let curTransform;
- let transformMatrix;
- const curStyle = getComputedStyle$1(el);
-
- if (window.WebKitCSSMatrix) {
- curTransform = curStyle.transform || curStyle.webkitTransform;
-
- if (curTransform.split(',').length > 6) {
- curTransform = curTransform.split(', ').map(a => a.replace(',', '.')).join(', ');
- } // Some old versions of Webkit choke when 'none' is passed; pass
- // empty string instead in this case
-
-
- transformMatrix = new window.WebKitCSSMatrix(curTransform === 'none' ? '' : curTransform);
- } else {
- transformMatrix = curStyle.MozTransform || curStyle.OTransform || curStyle.MsTransform || curStyle.msTransform || curStyle.transform || curStyle.getPropertyValue('transform').replace('translate(', 'matrix(1, 0, 0, 1,');
- matrix = transformMatrix.toString().split(',');
- }
-
- if (axis === 'x') {
- // Latest Chrome and webkits Fix
- if (window.WebKitCSSMatrix) curTransform = transformMatrix.m41; // Crazy IE10 Matrix
- else if (matrix.length === 16) curTransform = parseFloat(matrix[12]); // Normal Browsers
- else curTransform = parseFloat(matrix[4]);
- }
-
- if (axis === 'y') {
- // Latest Chrome and webkits Fix
- if (window.WebKitCSSMatrix) curTransform = transformMatrix.m42; // Crazy IE10 Matrix
- else if (matrix.length === 16) curTransform = parseFloat(matrix[13]); // Normal Browsers
- else curTransform = parseFloat(matrix[5]);
- }
-
- return curTransform || 0;
- }
-
- function isObject(o) {
- return typeof o === 'object' && o !== null && o.constructor && Object.prototype.toString.call(o).slice(8, -1) === 'Object';
- }
-
- function isNode(node) {
- // eslint-disable-next-line
- if (typeof window !== 'undefined' && typeof window.HTMLElement !== 'undefined') {
- return node instanceof HTMLElement;
- }
-
- return node && (node.nodeType === 1 || node.nodeType === 11);
- }
-
- function extend() {
- const to = Object(arguments.length <= 0 ? undefined : arguments[0]);
- const noExtend = ['__proto__', 'constructor', 'prototype'];
-
- for (let i = 1; i < arguments.length; i += 1) {
- const nextSource = i < 0 || arguments.length <= i ? undefined : arguments[i];
-
- if (nextSource !== undefined && nextSource !== null && !isNode(nextSource)) {
- const keysArray = Object.keys(Object(nextSource)).filter(key => noExtend.indexOf(key) < 0);
-
- for (let nextIndex = 0, len = keysArray.length; nextIndex < len; nextIndex += 1) {
- const nextKey = keysArray[nextIndex];
- const desc = Object.getOwnPropertyDescriptor(nextSource, nextKey);
-
- if (desc !== undefined && desc.enumerable) {
- if (isObject(to[nextKey]) && isObject(nextSource[nextKey])) {
- if (nextSource[nextKey].__swiper__) {
- to[nextKey] = nextSource[nextKey];
- } else {
- extend(to[nextKey], nextSource[nextKey]);
- }
- } else if (!isObject(to[nextKey]) && isObject(nextSource[nextKey])) {
- to[nextKey] = {};
-
- if (nextSource[nextKey].__swiper__) {
- to[nextKey] = nextSource[nextKey];
- } else {
- extend(to[nextKey], nextSource[nextKey]);
- }
- } else {
- to[nextKey] = nextSource[nextKey];
- }
- }
- }
- }
- }
-
- return to;
- }
-
- function setCSSProperty(el, varName, varValue) {
- el.style.setProperty(varName, varValue);
- }
-
- function animateCSSModeScroll(_ref) {
- let {
- swiper,
- targetPosition,
- side
- } = _ref;
- const window = getWindow();
- const startPosition = -swiper.translate;
- let startTime = null;
- let time;
- const duration = swiper.params.speed;
- swiper.wrapperEl.style.scrollSnapType = 'none';
- window.cancelAnimationFrame(swiper.cssModeFrameID);
- const dir = targetPosition > startPosition ? 'next' : 'prev';
-
- const isOutOfBound = (current, target) => {
- return dir === 'next' && current >= target || dir === 'prev' && current <= target;
- };
-
- const animate = () => {
- time = new Date().getTime();
-
- if (startTime === null) {
- startTime = time;
- }
-
- const progress = Math.max(Math.min((time - startTime) / duration, 1), 0);
- const easeProgress = 0.5 - Math.cos(progress * Math.PI) / 2;
- let currentPosition = startPosition + easeProgress * (targetPosition - startPosition);
-
- if (isOutOfBound(currentPosition, targetPosition)) {
- currentPosition = targetPosition;
- }
-
- swiper.wrapperEl.scrollTo({
- [side]: currentPosition
- });
-
- if (isOutOfBound(currentPosition, targetPosition)) {
- swiper.wrapperEl.style.overflow = 'hidden';
- swiper.wrapperEl.style.scrollSnapType = '';
- setTimeout(() => {
- swiper.wrapperEl.style.overflow = '';
- swiper.wrapperEl.scrollTo({
- [side]: currentPosition
- });
- });
- window.cancelAnimationFrame(swiper.cssModeFrameID);
- return;
- }
-
- swiper.cssModeFrameID = window.requestAnimationFrame(animate);
- };
-
- animate();
- }
-
- let support;
-
- function calcSupport() {
- const window = getWindow();
- const document = getDocument();
- return {
- smoothScroll: document.documentElement && 'scrollBehavior' in document.documentElement.style,
- touch: !!('ontouchstart' in window || window.DocumentTouch && document instanceof window.DocumentTouch),
- passiveListener: function checkPassiveListener() {
- let supportsPassive = false;
-
- try {
- const opts = Object.defineProperty({}, 'passive', {
- // eslint-disable-next-line
- get() {
- supportsPassive = true;
- }
-
- });
- window.addEventListener('testPassiveListener', null, opts);
- } catch (e) {// No support
- }
-
- return supportsPassive;
- }(),
- gestures: function checkGestures() {
- return 'ongesturestart' in window;
- }()
- };
- }
-
- function getSupport() {
- if (!support) {
- support = calcSupport();
- }
-
- return support;
- }
-
- let deviceCached;
-
- function calcDevice(_temp) {
- let {
- userAgent
- } = _temp === void 0 ? {} : _temp;
- const support = getSupport();
- const window = getWindow();
- const platform = window.navigator.platform;
- const ua = userAgent || window.navigator.userAgent;
- const device = {
- ios: false,
- android: false
- };
- const screenWidth = window.screen.width;
- const screenHeight = window.screen.height;
- const android = ua.match(/(Android);?[\s\/]+([\d.]+)?/); // eslint-disable-line
-
- let ipad = ua.match(/(iPad).*OS\s([\d_]+)/);
- const ipod = ua.match(/(iPod)(.*OS\s([\d_]+))?/);
- const iphone = !ipad && ua.match(/(iPhone\sOS|iOS)\s([\d_]+)/);
- const windows = platform === 'Win32';
- let macos = platform === 'MacIntel'; // iPadOs 13 fix
-
- const iPadScreens = ['1024x1366', '1366x1024', '834x1194', '1194x834', '834x1112', '1112x834', '768x1024', '1024x768', '820x1180', '1180x820', '810x1080', '1080x810'];
-
- if (!ipad && macos && support.touch && iPadScreens.indexOf(`${screenWidth}x${screenHeight}`) >= 0) {
- ipad = ua.match(/(Version)\/([\d.]+)/);
- if (!ipad) ipad = [0, 1, '13_0_0'];
- macos = false;
- } // Android
-
-
- if (android && !windows) {
- device.os = 'android';
- device.android = true;
- }
-
- if (ipad || iphone || ipod) {
- device.os = 'ios';
- device.ios = true;
- } // Export object
-
-
- return device;
- }
-
- function getDevice(overrides) {
- if (overrides === void 0) {
- overrides = {};
- }
-
- if (!deviceCached) {
- deviceCached = calcDevice(overrides);
- }
-
- return deviceCached;
- }
-
- let browser;
-
- function calcBrowser() {
- const window = getWindow();
-
- function isSafari() {
- const ua = window.navigator.userAgent.toLowerCase();
- return ua.indexOf('safari') >= 0 && ua.indexOf('chrome') < 0 && ua.indexOf('android') < 0;
- }
-
- return {
- isSafari: isSafari(),
- isWebView: /(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/i.test(window.navigator.userAgent)
- };
- }
-
- function getBrowser() {
- if (!browser) {
- browser = calcBrowser();
- }
-
- return browser;
- }
-
- function Resize(_ref) {
- let {
- swiper,
- on,
- emit
- } = _ref;
- const window = getWindow();
- let observer = null;
- let animationFrame = null;
-
- const resizeHandler = () => {
- if (!swiper || swiper.destroyed || !swiper.initialized) return;
- emit('beforeResize');
- emit('resize');
- };
-
- const createObserver = () => {
- if (!swiper || swiper.destroyed || !swiper.initialized) return;
- observer = new ResizeObserver(entries => {
- animationFrame = window.requestAnimationFrame(() => {
- const {
- width,
- height
- } = swiper;
- let newWidth = width;
- let newHeight = height;
- entries.forEach(_ref2 => {
- let {
- contentBoxSize,
- contentRect,
- target
- } = _ref2;
- if (target && target !== swiper.el) return;
- newWidth = contentRect ? contentRect.width : (contentBoxSize[0] || contentBoxSize).inlineSize;
- newHeight = contentRect ? contentRect.height : (contentBoxSize[0] || contentBoxSize).blockSize;
- });
-
- if (newWidth !== width || newHeight !== height) {
- resizeHandler();
- }
- });
- });
- observer.observe(swiper.el);
- };
-
- const removeObserver = () => {
- if (animationFrame) {
- window.cancelAnimationFrame(animationFrame);
- }
-
- if (observer && observer.unobserve && swiper.el) {
- observer.unobserve(swiper.el);
- observer = null;
- }
- };
-
- const orientationChangeHandler = () => {
- if (!swiper || swiper.destroyed || !swiper.initialized) return;
- emit('orientationchange');
- };
-
- on('init', () => {
- if (swiper.params.resizeObserver && typeof window.ResizeObserver !== 'undefined') {
- createObserver();
- return;
- }
-
- window.addEventListener('resize', resizeHandler);
- window.addEventListener('orientationchange', orientationChangeHandler);
- });
- on('destroy', () => {
- removeObserver();
- window.removeEventListener('resize', resizeHandler);
- window.removeEventListener('orientationchange', orientationChangeHandler);
- });
- }
-
- function Observer(_ref) {
- let {
- swiper,
- extendParams,
- on,
- emit
- } = _ref;
- const observers = [];
- const window = getWindow();
-
- const attach = function (target, options) {
- if (options === void 0) {
- options = {};
- }
-
- const ObserverFunc = window.MutationObserver || window.WebkitMutationObserver;
- const observer = new ObserverFunc(mutations => {
- // The observerUpdate event should only be triggered
- // once despite the number of mutations. Additional
- // triggers are redundant and are very costly
- if (mutations.length === 1) {
- emit('observerUpdate', mutations[0]);
- return;
- }
-
- const observerUpdate = function observerUpdate() {
- emit('observerUpdate', mutations[0]);
- };
-
- if (window.requestAnimationFrame) {
- window.requestAnimationFrame(observerUpdate);
- } else {
- window.setTimeout(observerUpdate, 0);
- }
- });
- observer.observe(target, {
- attributes: typeof options.attributes === 'undefined' ? true : options.attributes,
- childList: typeof options.childList === 'undefined' ? true : options.childList,
- characterData: typeof options.characterData === 'undefined' ? true : options.characterData
- });
- observers.push(observer);
- };
-
- const init = () => {
- if (!swiper.params.observer) return;
-
- if (swiper.params.observeParents) {
- const containerParents = swiper.$el.parents();
-
- for (let i = 0; i < containerParents.length; i += 1) {
- attach(containerParents[i]);
- }
- } // Observe container
-
-
- attach(swiper.$el[0], {
- childList: swiper.params.observeSlideChildren
- }); // Observe wrapper
-
- attach(swiper.$wrapperEl[0], {
- attributes: false
- });
- };
-
- const destroy = () => {
- observers.forEach(observer => {
- observer.disconnect();
- });
- observers.splice(0, observers.length);
- };
-
- extendParams({
- observer: false,
- observeParents: false,
- observeSlideChildren: false
- });
- on('init', init);
- on('destroy', destroy);
- }
-
- /* eslint-disable no-underscore-dangle */
- var eventsEmitter = {
- on(events, handler, priority) {
- const self = this;
- if (typeof handler !== 'function') return self;
- const method = priority ? 'unshift' : 'push';
- events.split(' ').forEach(event => {
- if (!self.eventsListeners[event]) self.eventsListeners[event] = [];
- self.eventsListeners[event][method](handler);
- });
- return self;
- },
-
- once(events, handler, priority) {
- const self = this;
- if (typeof handler !== 'function') return self;
-
- function onceHandler() {
- self.off(events, onceHandler);
-
- if (onceHandler.__emitterProxy) {
- delete onceHandler.__emitterProxy;
- }
-
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
- args[_key] = arguments[_key];
- }
-
- handler.apply(self, args);
- }
-
- onceHandler.__emitterProxy = handler;
- return self.on(events, onceHandler, priority);
- },
-
- onAny(handler, priority) {
- const self = this;
- if (typeof handler !== 'function') return self;
- const method = priority ? 'unshift' : 'push';
-
- if (self.eventsAnyListeners.indexOf(handler) < 0) {
- self.eventsAnyListeners[method](handler);
- }
-
- return self;
- },
-
- offAny(handler) {
- const self = this;
- if (!self.eventsAnyListeners) return self;
- const index = self.eventsAnyListeners.indexOf(handler);
-
- if (index >= 0) {
- self.eventsAnyListeners.splice(index, 1);
- }
-
- return self;
- },
-
- off(events, handler) {
- const self = this;
- if (!self.eventsListeners) return self;
- events.split(' ').forEach(event => {
- if (typeof handler === 'undefined') {
- self.eventsListeners[event] = [];
- } else if (self.eventsListeners[event]) {
- self.eventsListeners[event].forEach((eventHandler, index) => {
- if (eventHandler === handler || eventHandler.__emitterProxy && eventHandler.__emitterProxy === handler) {
- self.eventsListeners[event].splice(index, 1);
- }
- });
- }
- });
- return self;
- },
-
- emit() {
- const self = this;
- if (!self.eventsListeners) return self;
- let events;
- let data;
- let context;
-
- for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
- args[_key2] = arguments[_key2];
- }
-
- if (typeof args[0] === 'string' || Array.isArray(args[0])) {
- events = args[0];
- data = args.slice(1, args.length);
- context = self;
- } else {
- events = args[0].events;
- data = args[0].data;
- context = args[0].context || self;
- }
-
- data.unshift(context);
- const eventsArray = Array.isArray(events) ? events : events.split(' ');
- eventsArray.forEach(event => {
- if (self.eventsAnyListeners && self.eventsAnyListeners.length) {
- self.eventsAnyListeners.forEach(eventHandler => {
- eventHandler.apply(context, [event, ...data]);
- });
- }
-
- if (self.eventsListeners && self.eventsListeners[event]) {
- self.eventsListeners[event].forEach(eventHandler => {
- eventHandler.apply(context, data);
- });
- }
- });
- return self;
- }
-
- };
-
- function updateSize() {
- const swiper = this;
- let width;
- let height;
- const $el = swiper.$el;
-
- if (typeof swiper.params.width !== 'undefined' && swiper.params.width !== null) {
- width = swiper.params.width;
- } else {
- width = $el[0].clientWidth;
- }
-
- if (typeof swiper.params.height !== 'undefined' && swiper.params.height !== null) {
- height = swiper.params.height;
- } else {
- height = $el[0].clientHeight;
- }
-
- if (width === 0 && swiper.isHorizontal() || height === 0 && swiper.isVertical()) {
- return;
- } // Subtract paddings
-
-
- width = width - parseInt($el.css('padding-left') || 0, 10) - parseInt($el.css('padding-right') || 0, 10);
- height = height - parseInt($el.css('padding-top') || 0, 10) - parseInt($el.css('padding-bottom') || 0, 10);
- if (Number.isNaN(width)) width = 0;
- if (Number.isNaN(height)) height = 0;
- Object.assign(swiper, {
- width,
- height,
- size: swiper.isHorizontal() ? width : height
- });
- }
-
- function updateSlides() {
- const swiper = this;
-
- function getDirectionLabel(property) {
- if (swiper.isHorizontal()) {
- return property;
- } // prettier-ignore
-
-
- return {
- 'width': 'height',
- 'margin-top': 'margin-left',
- 'margin-bottom ': 'margin-right',
- 'margin-left': 'margin-top',
- 'margin-right': 'margin-bottom',
- 'padding-left': 'padding-top',
- 'padding-right': 'padding-bottom',
- 'marginRight': 'marginBottom'
- }[property];
- }
-
- function getDirectionPropertyValue(node, label) {
- return parseFloat(node.getPropertyValue(getDirectionLabel(label)) || 0);
- }
-
- const params = swiper.params;
- const {
- $wrapperEl,
- size: swiperSize,
- rtlTranslate: rtl,
- wrongRTL
- } = swiper;
- const isVirtual = swiper.virtual && params.virtual.enabled;
- const previousSlidesLength = isVirtual ? swiper.virtual.slides.length : swiper.slides.length;
- const slides = $wrapperEl.children(`.${swiper.params.slideClass}`);
- const slidesLength = isVirtual ? swiper.virtual.slides.length : slides.length;
- let snapGrid = [];
- const slidesGrid = [];
- const slidesSizesGrid = [];
- let offsetBefore = params.slidesOffsetBefore;
-
- if (typeof offsetBefore === 'function') {
- offsetBefore = params.slidesOffsetBefore.call(swiper);
- }
-
- let offsetAfter = params.slidesOffsetAfter;
-
- if (typeof offsetAfter === 'function') {
- offsetAfter = params.slidesOffsetAfter.call(swiper);
- }
-
- const previousSnapGridLength = swiper.snapGrid.length;
- const previousSlidesGridLength = swiper.slidesGrid.length;
- let spaceBetween = params.spaceBetween;
- let slidePosition = -offsetBefore;
- let prevSlideSize = 0;
- let index = 0;
-
- if (typeof swiperSize === 'undefined') {
- return;
- }
-
- if (typeof spaceBetween === 'string' && spaceBetween.indexOf('%') >= 0) {
- spaceBetween = parseFloat(spaceBetween.replace('%', '')) / 100 * swiperSize;
- }
-
- swiper.virtualSize = -spaceBetween; // reset margins
-
- if (rtl) slides.css({
- marginLeft: '',
- marginBottom: '',
- marginTop: ''
- });else slides.css({
- marginRight: '',
- marginBottom: '',
- marginTop: ''
- }); // reset cssMode offsets
-
- if (params.centeredSlides && params.cssMode) {
- setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-before', '');
- setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-after', '');
- }
-
- const gridEnabled = params.grid && params.grid.rows > 1 && swiper.grid;
-
- if (gridEnabled) {
- swiper.grid.initSlides(slidesLength);
- } // Calc slides
-
-
- let slideSize;
- const shouldResetSlideSize = params.slidesPerView === 'auto' && params.breakpoints && Object.keys(params.breakpoints).filter(key => {
- return typeof params.breakpoints[key].slidesPerView !== 'undefined';
- }).length > 0;
-
- for (let i = 0; i < slidesLength; i += 1) {
- slideSize = 0;
- const slide = slides.eq(i);
-
- if (gridEnabled) {
- swiper.grid.updateSlide(i, slide, slidesLength, getDirectionLabel);
- }
-
- if (slide.css('display') === 'none') continue; // eslint-disable-line
-
- if (params.slidesPerView === 'auto') {
- if (shouldResetSlideSize) {
- slides[i].style[getDirectionLabel('width')] = ``;
- }
-
- const slideStyles = getComputedStyle(slide[0]);
- const currentTransform = slide[0].style.transform;
- const currentWebKitTransform = slide[0].style.webkitTransform;
-
- if (currentTransform) {
- slide[0].style.transform = 'none';
- }
-
- if (currentWebKitTransform) {
- slide[0].style.webkitTransform = 'none';
- }
-
- if (params.roundLengths) {
- slideSize = swiper.isHorizontal() ? slide.outerWidth(true) : slide.outerHeight(true);
- } else {
- // eslint-disable-next-line
- const width = getDirectionPropertyValue(slideStyles, 'width');
- const paddingLeft = getDirectionPropertyValue(slideStyles, 'padding-left');
- const paddingRight = getDirectionPropertyValue(slideStyles, 'padding-right');
- const marginLeft = getDirectionPropertyValue(slideStyles, 'margin-left');
- const marginRight = getDirectionPropertyValue(slideStyles, 'margin-right');
- const boxSizing = slideStyles.getPropertyValue('box-sizing');
-
- if (boxSizing && boxSizing === 'border-box') {
- slideSize = width + marginLeft + marginRight;
- } else {
- const {
- clientWidth,
- offsetWidth
- } = slide[0];
- slideSize = width + paddingLeft + paddingRight + marginLeft + marginRight + (offsetWidth - clientWidth);
- }
- }
-
- if (currentTransform) {
- slide[0].style.transform = currentTransform;
- }
-
- if (currentWebKitTransform) {
- slide[0].style.webkitTransform = currentWebKitTransform;
- }
-
- if (params.roundLengths) slideSize = Math.floor(slideSize);
- } else {
- slideSize = (swiperSize - (params.slidesPerView - 1) * spaceBetween) / params.slidesPerView;
- if (params.roundLengths) slideSize = Math.floor(slideSize);
-
- if (slides[i]) {
- slides[i].style[getDirectionLabel('width')] = `${slideSize}px`;
- }
- }
-
- if (slides[i]) {
- slides[i].swiperSlideSize = slideSize;
- }
-
- slidesSizesGrid.push(slideSize);
-
- if (params.centeredSlides) {
- slidePosition = slidePosition + slideSize / 2 + prevSlideSize / 2 + spaceBetween;
- if (prevSlideSize === 0 && i !== 0) slidePosition = slidePosition - swiperSize / 2 - spaceBetween;
- if (i === 0) slidePosition = slidePosition - swiperSize / 2 - spaceBetween;
- if (Math.abs(slidePosition) < 1 / 1000) slidePosition = 0;
- if (params.roundLengths) slidePosition = Math.floor(slidePosition);
- if (index % params.slidesPerGroup === 0) snapGrid.push(slidePosition);
- slidesGrid.push(slidePosition);
- } else {
- if (params.roundLengths) slidePosition = Math.floor(slidePosition);
- if ((index - Math.min(swiper.params.slidesPerGroupSkip, index)) % swiper.params.slidesPerGroup === 0) snapGrid.push(slidePosition);
- slidesGrid.push(slidePosition);
- slidePosition = slidePosition + slideSize + spaceBetween;
- }
-
- swiper.virtualSize += slideSize + spaceBetween;
- prevSlideSize = slideSize;
- index += 1;
- }
-
- swiper.virtualSize = Math.max(swiper.virtualSize, swiperSize) + offsetAfter;
-
- if (rtl && wrongRTL && (params.effect === 'slide' || params.effect === 'coverflow')) {
- $wrapperEl.css({
- width: `${swiper.virtualSize + params.spaceBetween}px`
- });
- }
-
- if (params.setWrapperSize) {
- $wrapperEl.css({
- [getDirectionLabel('width')]: `${swiper.virtualSize + params.spaceBetween}px`
- });
- }
-
- if (gridEnabled) {
- swiper.grid.updateWrapperSize(slideSize, snapGrid, getDirectionLabel);
- } // Remove last grid elements depending on width
-
-
- if (!params.centeredSlides) {
- const newSlidesGrid = [];
-
- for (let i = 0; i < snapGrid.length; i += 1) {
- let slidesGridItem = snapGrid[i];
- if (params.roundLengths) slidesGridItem = Math.floor(slidesGridItem);
-
- if (snapGrid[i] <= swiper.virtualSize - swiperSize) {
- newSlidesGrid.push(slidesGridItem);
- }
- }
-
- snapGrid = newSlidesGrid;
-
- if (Math.floor(swiper.virtualSize - swiperSize) - Math.floor(snapGrid[snapGrid.length - 1]) > 1) {
- snapGrid.push(swiper.virtualSize - swiperSize);
- }
- }
-
- if (snapGrid.length === 0) snapGrid = [0];
-
- if (params.spaceBetween !== 0) {
- const key = swiper.isHorizontal() && rtl ? 'marginLeft' : getDirectionLabel('marginRight');
- slides.filter((_, slideIndex) => {
- if (!params.cssMode) return true;
-
- if (slideIndex === slides.length - 1) {
- return false;
- }
-
- return true;
- }).css({
- [key]: `${spaceBetween}px`
- });
- }
-
- if (params.centeredSlides && params.centeredSlidesBounds) {
- let allSlidesSize = 0;
- slidesSizesGrid.forEach(slideSizeValue => {
- allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0);
- });
- allSlidesSize -= params.spaceBetween;
- const maxSnap = allSlidesSize - swiperSize;
- snapGrid = snapGrid.map(snap => {
- if (snap < 0) return -offsetBefore;
- if (snap > maxSnap) return maxSnap + offsetAfter;
- return snap;
- });
- }
-
- if (params.centerInsufficientSlides) {
- let allSlidesSize = 0;
- slidesSizesGrid.forEach(slideSizeValue => {
- allSlidesSize += slideSizeValue + (params.spaceBetween ? params.spaceBetween : 0);
- });
- allSlidesSize -= params.spaceBetween;
-
- if (allSlidesSize < swiperSize) {
- const allSlidesOffset = (swiperSize - allSlidesSize) / 2;
- snapGrid.forEach((snap, snapIndex) => {
- snapGrid[snapIndex] = snap - allSlidesOffset;
- });
- slidesGrid.forEach((snap, snapIndex) => {
- slidesGrid[snapIndex] = snap + allSlidesOffset;
- });
- }
- }
-
- Object.assign(swiper, {
- slides,
- snapGrid,
- slidesGrid,
- slidesSizesGrid
- });
-
- if (params.centeredSlides && params.cssMode && !params.centeredSlidesBounds) {
- setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-before', `${-snapGrid[0]}px`);
- setCSSProperty(swiper.wrapperEl, '--swiper-centered-offset-after', `${swiper.size / 2 - slidesSizesGrid[slidesSizesGrid.length - 1] / 2}px`);
- const addToSnapGrid = -swiper.snapGrid[0];
- const addToSlidesGrid = -swiper.slidesGrid[0];
- swiper.snapGrid = swiper.snapGrid.map(v => v + addToSnapGrid);
- swiper.slidesGrid = swiper.slidesGrid.map(v => v + addToSlidesGrid);
- }
-
- if (slidesLength !== previousSlidesLength) {
- swiper.emit('slidesLengthChange');
- }
-
- if (snapGrid.length !== previousSnapGridLength) {
- if (swiper.params.watchOverflow) swiper.checkOverflow();
- swiper.emit('snapGridLengthChange');
- }
-
- if (slidesGrid.length !== previousSlidesGridLength) {
- swiper.emit('slidesGridLengthChange');
- }
-
- if (params.watchSlidesProgress) {
- swiper.updateSlidesOffset();
- }
-
- if (!isVirtual && !params.cssMode && (params.effect === 'slide' || params.effect === 'fade')) {
- const backFaceHiddenClass = `${params.containerModifierClass}backface-hidden`;
- const hasClassBackfaceClassAdded = swiper.$el.hasClass(backFaceHiddenClass);
-
- if (slidesLength <= params.maxBackfaceHiddenSlides) {
- if (!hasClassBackfaceClassAdded) swiper.$el.addClass(backFaceHiddenClass);
- } else if (hasClassBackfaceClassAdded) {
- swiper.$el.removeClass(backFaceHiddenClass);
- }
- }
- }
-
- function updateAutoHeight(speed) {
- const swiper = this;
- const activeSlides = [];
- const isVirtual = swiper.virtual && swiper.params.virtual.enabled;
- let newHeight = 0;
- let i;
-
- if (typeof speed === 'number') {
- swiper.setTransition(speed);
- } else if (speed === true) {
- swiper.setTransition(swiper.params.speed);
- }
-
- const getSlideByIndex = index => {
- if (isVirtual) {
- return swiper.slides.filter(el => parseInt(el.getAttribute('data-swiper-slide-index'), 10) === index)[0];
- }
-
- return swiper.slides.eq(index)[0];
- }; // Find slides currently in view
-
-
- if (swiper.params.slidesPerView !== 'auto' && swiper.params.slidesPerView > 1) {
- if (swiper.params.centeredSlides) {
- swiper.visibleSlides.each(slide => {
- activeSlides.push(slide);
- });
- } else {
- for (i = 0; i < Math.ceil(swiper.params.slidesPerView); i += 1) {
- const index = swiper.activeIndex + i;
- if (index > swiper.slides.length && !isVirtual) break;
- activeSlides.push(getSlideByIndex(index));
- }
- }
- } else {
- activeSlides.push(getSlideByIndex(swiper.activeIndex));
- } // Find new height from highest slide in view
-
-
- for (i = 0; i < activeSlides.length; i += 1) {
- if (typeof activeSlides[i] !== 'undefined') {
- const height = activeSlides[i].offsetHeight;
- newHeight = height > newHeight ? height : newHeight;
- }
- } // Update Height
-
-
- if (newHeight || newHeight === 0) swiper.$wrapperEl.css('height', `${newHeight}px`);
- }
-
- function updateSlidesOffset() {
- const swiper = this;
- const slides = swiper.slides;
-
- for (let i = 0; i < slides.length; i += 1) {
- slides[i].swiperSlideOffset = swiper.isHorizontal() ? slides[i].offsetLeft : slides[i].offsetTop;
- }
- }
-
- function updateSlidesProgress(translate) {
- if (translate === void 0) {
- translate = this && this.translate || 0;
- }
-
- const swiper = this;
- const params = swiper.params;
- const {
- slides,
- rtlTranslate: rtl,
- snapGrid
- } = swiper;
- if (slides.length === 0) return;
- if (typeof slides[0].swiperSlideOffset === 'undefined') swiper.updateSlidesOffset();
- let offsetCenter = -translate;
- if (rtl) offsetCenter = translate; // Visible Slides
-
- slides.removeClass(params.slideVisibleClass);
- swiper.visibleSlidesIndexes = [];
- swiper.visibleSlides = [];
-
- for (let i = 0; i < slides.length; i += 1) {
- const slide = slides[i];
- let slideOffset = slide.swiperSlideOffset;
-
- if (params.cssMode && params.centeredSlides) {
- slideOffset -= slides[0].swiperSlideOffset;
- }
-
- const slideProgress = (offsetCenter + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + params.spaceBetween);
- const originalSlideProgress = (offsetCenter - snapGrid[0] + (params.centeredSlides ? swiper.minTranslate() : 0) - slideOffset) / (slide.swiperSlideSize + params.spaceBetween);
- const slideBefore = -(offsetCenter - slideOffset);
- const slideAfter = slideBefore + swiper.slidesSizesGrid[i];
- const isVisible = slideBefore >= 0 && slideBefore < swiper.size - 1 || slideAfter > 1 && slideAfter <= swiper.size || slideBefore <= 0 && slideAfter >= swiper.size;
-
- if (isVisible) {
- swiper.visibleSlides.push(slide);
- swiper.visibleSlidesIndexes.push(i);
- slides.eq(i).addClass(params.slideVisibleClass);
- }
-
- slide.progress = rtl ? -slideProgress : slideProgress;
- slide.originalProgress = rtl ? -originalSlideProgress : originalSlideProgress;
- }
-
- swiper.visibleSlides = $(swiper.visibleSlides);
- }
-
- function updateProgress(translate) {
- const swiper = this;
-
- if (typeof translate === 'undefined') {
- const multiplier = swiper.rtlTranslate ? -1 : 1; // eslint-disable-next-line
-
- translate = swiper && swiper.translate && swiper.translate * multiplier || 0;
- }
-
- const params = swiper.params;
- const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();
- let {
- progress,
- isBeginning,
- isEnd
- } = swiper;
- const wasBeginning = isBeginning;
- const wasEnd = isEnd;
-
- if (translatesDiff === 0) {
- progress = 0;
- isBeginning = true;
- isEnd = true;
- } else {
- progress = (translate - swiper.minTranslate()) / translatesDiff;
- isBeginning = progress <= 0;
- isEnd = progress >= 1;
- }
-
- Object.assign(swiper, {
- progress,
- isBeginning,
- isEnd
- });
- if (params.watchSlidesProgress || params.centeredSlides && params.autoHeight) swiper.updateSlidesProgress(translate);
-
- if (isBeginning && !wasBeginning) {
- swiper.emit('reachBeginning toEdge');
- }
-
- if (isEnd && !wasEnd) {
- swiper.emit('reachEnd toEdge');
- }
-
- if (wasBeginning && !isBeginning || wasEnd && !isEnd) {
- swiper.emit('fromEdge');
- }
-
- swiper.emit('progress', progress);
- }
-
- function updateSlidesClasses() {
- const swiper = this;
- const {
- slides,
- params,
- $wrapperEl,
- activeIndex,
- realIndex
- } = swiper;
- const isVirtual = swiper.virtual && params.virtual.enabled;
- slides.removeClass(`${params.slideActiveClass} ${params.slideNextClass} ${params.slidePrevClass} ${params.slideDuplicateActiveClass} ${params.slideDuplicateNextClass} ${params.slideDuplicatePrevClass}`);
- let activeSlide;
-
- if (isVirtual) {
- activeSlide = swiper.$wrapperEl.find(`.${params.slideClass}[data-swiper-slide-index="${activeIndex}"]`);
- } else {
- activeSlide = slides.eq(activeIndex);
- } // Active classes
-
-
- activeSlide.addClass(params.slideActiveClass);
-
- if (params.loop) {
- // Duplicate to all looped slides
- if (activeSlide.hasClass(params.slideDuplicateClass)) {
- $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index="${realIndex}"]`).addClass(params.slideDuplicateActiveClass);
- } else {
- $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index="${realIndex}"]`).addClass(params.slideDuplicateActiveClass);
- }
- } // Next Slide
-
-
- let nextSlide = activeSlide.nextAll(`.${params.slideClass}`).eq(0).addClass(params.slideNextClass);
-
- if (params.loop && nextSlide.length === 0) {
- nextSlide = slides.eq(0);
- nextSlide.addClass(params.slideNextClass);
- } // Prev Slide
-
-
- let prevSlide = activeSlide.prevAll(`.${params.slideClass}`).eq(0).addClass(params.slidePrevClass);
-
- if (params.loop && prevSlide.length === 0) {
- prevSlide = slides.eq(-1);
- prevSlide.addClass(params.slidePrevClass);
- }
-
- if (params.loop) {
- // Duplicate to all looped slides
- if (nextSlide.hasClass(params.slideDuplicateClass)) {
- $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index="${nextSlide.attr('data-swiper-slide-index')}"]`).addClass(params.slideDuplicateNextClass);
- } else {
- $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index="${nextSlide.attr('data-swiper-slide-index')}"]`).addClass(params.slideDuplicateNextClass);
- }
-
- if (prevSlide.hasClass(params.slideDuplicateClass)) {
- $wrapperEl.children(`.${params.slideClass}:not(.${params.slideDuplicateClass})[data-swiper-slide-index="${prevSlide.attr('data-swiper-slide-index')}"]`).addClass(params.slideDuplicatePrevClass);
- } else {
- $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass}[data-swiper-slide-index="${prevSlide.attr('data-swiper-slide-index')}"]`).addClass(params.slideDuplicatePrevClass);
- }
- }
-
- swiper.emitSlidesClasses();
- }
-
- function updateActiveIndex(newActiveIndex) {
- const swiper = this;
- const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;
- const {
- slidesGrid,
- snapGrid,
- params,
- activeIndex: previousIndex,
- realIndex: previousRealIndex,
- snapIndex: previousSnapIndex
- } = swiper;
- let activeIndex = newActiveIndex;
- let snapIndex;
-
- if (typeof activeIndex === 'undefined') {
- for (let i = 0; i < slidesGrid.length; i += 1) {
- if (typeof slidesGrid[i + 1] !== 'undefined') {
- if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1] - (slidesGrid[i + 1] - slidesGrid[i]) / 2) {
- activeIndex = i;
- } else if (translate >= slidesGrid[i] && translate < slidesGrid[i + 1]) {
- activeIndex = i + 1;
- }
- } else if (translate >= slidesGrid[i]) {
- activeIndex = i;
- }
- } // Normalize slideIndex
-
-
- if (params.normalizeSlideIndex) {
- if (activeIndex < 0 || typeof activeIndex === 'undefined') activeIndex = 0;
- }
- }
-
- if (snapGrid.indexOf(translate) >= 0) {
- snapIndex = snapGrid.indexOf(translate);
- } else {
- const skip = Math.min(params.slidesPerGroupSkip, activeIndex);
- snapIndex = skip + Math.floor((activeIndex - skip) / params.slidesPerGroup);
- }
-
- if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;
-
- if (activeIndex === previousIndex) {
- if (snapIndex !== previousSnapIndex) {
- swiper.snapIndex = snapIndex;
- swiper.emit('snapIndexChange');
- }
-
- return;
- } // Get real index
-
-
- const realIndex = parseInt(swiper.slides.eq(activeIndex).attr('data-swiper-slide-index') || activeIndex, 10);
- Object.assign(swiper, {
- snapIndex,
- realIndex,
- previousIndex,
- activeIndex
- });
- swiper.emit('activeIndexChange');
- swiper.emit('snapIndexChange');
-
- if (previousRealIndex !== realIndex) {
- swiper.emit('realIndexChange');
- }
-
- if (swiper.initialized || swiper.params.runCallbacksOnInit) {
- swiper.emit('slideChange');
- }
- }
-
- function updateClickedSlide(e) {
- const swiper = this;
- const params = swiper.params;
- const slide = $(e).closest(`.${params.slideClass}`)[0];
- let slideFound = false;
- let slideIndex;
-
- if (slide) {
- for (let i = 0; i < swiper.slides.length; i += 1) {
- if (swiper.slides[i] === slide) {
- slideFound = true;
- slideIndex = i;
- break;
- }
- }
- }
-
- if (slide && slideFound) {
- swiper.clickedSlide = slide;
-
- if (swiper.virtual && swiper.params.virtual.enabled) {
- swiper.clickedIndex = parseInt($(slide).attr('data-swiper-slide-index'), 10);
- } else {
- swiper.clickedIndex = slideIndex;
- }
- } else {
- swiper.clickedSlide = undefined;
- swiper.clickedIndex = undefined;
- return;
- }
-
- if (params.slideToClickedSlide && swiper.clickedIndex !== undefined && swiper.clickedIndex !== swiper.activeIndex) {
- swiper.slideToClickedSlide();
- }
- }
-
- var update = {
- updateSize,
- updateSlides,
- updateAutoHeight,
- updateSlidesOffset,
- updateSlidesProgress,
- updateProgress,
- updateSlidesClasses,
- updateActiveIndex,
- updateClickedSlide
- };
-
- function getSwiperTranslate(axis) {
- if (axis === void 0) {
- axis = this.isHorizontal() ? 'x' : 'y';
- }
-
- const swiper = this;
- const {
- params,
- rtlTranslate: rtl,
- translate,
- $wrapperEl
- } = swiper;
-
- if (params.virtualTranslate) {
- return rtl ? -translate : translate;
- }
-
- if (params.cssMode) {
- return translate;
- }
-
- let currentTranslate = getTranslate($wrapperEl[0], axis);
- if (rtl) currentTranslate = -currentTranslate;
- return currentTranslate || 0;
- }
-
- function setTranslate(translate, byController) {
- const swiper = this;
- const {
- rtlTranslate: rtl,
- params,
- $wrapperEl,
- wrapperEl,
- progress
- } = swiper;
- let x = 0;
- let y = 0;
- const z = 0;
-
- if (swiper.isHorizontal()) {
- x = rtl ? -translate : translate;
- } else {
- y = translate;
- }
-
- if (params.roundLengths) {
- x = Math.floor(x);
- y = Math.floor(y);
- }
-
- if (params.cssMode) {
- wrapperEl[swiper.isHorizontal() ? 'scrollLeft' : 'scrollTop'] = swiper.isHorizontal() ? -x : -y;
- } else if (!params.virtualTranslate) {
- $wrapperEl.transform(`translate3d(${x}px, ${y}px, ${z}px)`);
- }
-
- swiper.previousTranslate = swiper.translate;
- swiper.translate = swiper.isHorizontal() ? x : y; // Check if we need to update progress
-
- let newProgress;
- const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();
-
- if (translatesDiff === 0) {
- newProgress = 0;
- } else {
- newProgress = (translate - swiper.minTranslate()) / translatesDiff;
- }
-
- if (newProgress !== progress) {
- swiper.updateProgress(translate);
- }
-
- swiper.emit('setTranslate', swiper.translate, byController);
- }
-
- function minTranslate() {
- return -this.snapGrid[0];
- }
-
- function maxTranslate() {
- return -this.snapGrid[this.snapGrid.length - 1];
- }
-
- function translateTo(translate, speed, runCallbacks, translateBounds, internal) {
- if (translate === void 0) {
- translate = 0;
- }
-
- if (speed === void 0) {
- speed = this.params.speed;
- }
-
- if (runCallbacks === void 0) {
- runCallbacks = true;
- }
-
- if (translateBounds === void 0) {
- translateBounds = true;
- }
-
- const swiper = this;
- const {
- params,
- wrapperEl
- } = swiper;
-
- if (swiper.animating && params.preventInteractionOnTransition) {
- return false;
- }
-
- const minTranslate = swiper.minTranslate();
- const maxTranslate = swiper.maxTranslate();
- let newTranslate;
- if (translateBounds && translate > minTranslate) newTranslate = minTranslate;else if (translateBounds && translate < maxTranslate) newTranslate = maxTranslate;else newTranslate = translate; // Update progress
-
- swiper.updateProgress(newTranslate);
-
- if (params.cssMode) {
- const isH = swiper.isHorizontal();
-
- if (speed === 0) {
- wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = -newTranslate;
- } else {
- if (!swiper.support.smoothScroll) {
- animateCSSModeScroll({
- swiper,
- targetPosition: -newTranslate,
- side: isH ? 'left' : 'top'
- });
- return true;
- }
-
- wrapperEl.scrollTo({
- [isH ? 'left' : 'top']: -newTranslate,
- behavior: 'smooth'
- });
- }
-
- return true;
- }
-
- if (speed === 0) {
- swiper.setTransition(0);
- swiper.setTranslate(newTranslate);
-
- if (runCallbacks) {
- swiper.emit('beforeTransitionStart', speed, internal);
- swiper.emit('transitionEnd');
- }
- } else {
- swiper.setTransition(speed);
- swiper.setTranslate(newTranslate);
-
- if (runCallbacks) {
- swiper.emit('beforeTransitionStart', speed, internal);
- swiper.emit('transitionStart');
- }
-
- if (!swiper.animating) {
- swiper.animating = true;
-
- if (!swiper.onTranslateToWrapperTransitionEnd) {
- swiper.onTranslateToWrapperTransitionEnd = function transitionEnd(e) {
- if (!swiper || swiper.destroyed) return;
- if (e.target !== this) return;
- swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);
- swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.onTranslateToWrapperTransitionEnd);
- swiper.onTranslateToWrapperTransitionEnd = null;
- delete swiper.onTranslateToWrapperTransitionEnd;
-
- if (runCallbacks) {
- swiper.emit('transitionEnd');
- }
- };
- }
-
- swiper.$wrapperEl[0].addEventListener('transitionend', swiper.onTranslateToWrapperTransitionEnd);
- swiper.$wrapperEl[0].addEventListener('webkitTransitionEnd', swiper.onTranslateToWrapperTransitionEnd);
- }
- }
-
- return true;
- }
-
- var translate = {
- getTranslate: getSwiperTranslate,
- setTranslate,
- minTranslate,
- maxTranslate,
- translateTo
- };
-
- function setTransition(duration, byController) {
- const swiper = this;
-
- if (!swiper.params.cssMode) {
- swiper.$wrapperEl.transition(duration);
- }
-
- swiper.emit('setTransition', duration, byController);
- }
-
- function transitionEmit(_ref) {
- let {
- swiper,
- runCallbacks,
- direction,
- step
- } = _ref;
- const {
- activeIndex,
- previousIndex
- } = swiper;
- let dir = direction;
-
- if (!dir) {
- if (activeIndex > previousIndex) dir = 'next';else if (activeIndex < previousIndex) dir = 'prev';else dir = 'reset';
- }
-
- swiper.emit(`transition${step}`);
-
- if (runCallbacks && activeIndex !== previousIndex) {
- if (dir === 'reset') {
- swiper.emit(`slideResetTransition${step}`);
- return;
- }
-
- swiper.emit(`slideChangeTransition${step}`);
-
- if (dir === 'next') {
- swiper.emit(`slideNextTransition${step}`);
- } else {
- swiper.emit(`slidePrevTransition${step}`);
- }
- }
- }
-
- function transitionStart(runCallbacks, direction) {
- if (runCallbacks === void 0) {
- runCallbacks = true;
- }
-
- const swiper = this;
- const {
- params
- } = swiper;
- if (params.cssMode) return;
-
- if (params.autoHeight) {
- swiper.updateAutoHeight();
- }
-
- transitionEmit({
- swiper,
- runCallbacks,
- direction,
- step: 'Start'
- });
- }
-
- function transitionEnd(runCallbacks, direction) {
- if (runCallbacks === void 0) {
- runCallbacks = true;
- }
-
- const swiper = this;
- const {
- params
- } = swiper;
- swiper.animating = false;
- if (params.cssMode) return;
- swiper.setTransition(0);
- transitionEmit({
- swiper,
- runCallbacks,
- direction,
- step: 'End'
- });
- }
-
- var transition = {
- setTransition,
- transitionStart,
- transitionEnd
- };
-
- function slideTo(index, speed, runCallbacks, internal, initial) {
- if (index === void 0) {
- index = 0;
- }
-
- if (speed === void 0) {
- speed = this.params.speed;
- }
-
- if (runCallbacks === void 0) {
- runCallbacks = true;
- }
-
- if (typeof index !== 'number' && typeof index !== 'string') {
- throw new Error(`The 'index' argument cannot have type other than 'number' or 'string'. [${typeof index}] given.`);
- }
-
- if (typeof index === 'string') {
- /**
- * The `index` argument converted from `string` to `number`.
- * @type {number}
- */
- const indexAsNumber = parseInt(index, 10);
- /**
- * Determines whether the `index` argument is a valid `number`
- * after being converted from the `string` type.
- * @type {boolean}
- */
-
- const isValidNumber = isFinite(indexAsNumber);
-
- if (!isValidNumber) {
- throw new Error(`The passed-in 'index' (string) couldn't be converted to 'number'. [${index}] given.`);
- } // Knowing that the converted `index` is a valid number,
- // we can update the original argument's value.
-
-
- index = indexAsNumber;
- }
-
- const swiper = this;
- let slideIndex = index;
- if (slideIndex < 0) slideIndex = 0;
- const {
- params,
- snapGrid,
- slidesGrid,
- previousIndex,
- activeIndex,
- rtlTranslate: rtl,
- wrapperEl,
- enabled
- } = swiper;
-
- if (swiper.animating && params.preventInteractionOnTransition || !enabled && !internal && !initial) {
- return false;
- }
-
- const skip = Math.min(swiper.params.slidesPerGroupSkip, slideIndex);
- let snapIndex = skip + Math.floor((slideIndex - skip) / swiper.params.slidesPerGroup);
- if (snapIndex >= snapGrid.length) snapIndex = snapGrid.length - 1;
-
- if ((activeIndex || params.initialSlide || 0) === (previousIndex || 0) && runCallbacks) {
- swiper.emit('beforeSlideChangeStart');
- }
-
- const translate = -snapGrid[snapIndex]; // Update progress
-
- swiper.updateProgress(translate); // Normalize slideIndex
-
- if (params.normalizeSlideIndex) {
- for (let i = 0; i < slidesGrid.length; i += 1) {
- const normalizedTranslate = -Math.floor(translate * 100);
- const normalizedGrid = Math.floor(slidesGrid[i] * 100);
- const normalizedGridNext = Math.floor(slidesGrid[i + 1] * 100);
-
- if (typeof slidesGrid[i + 1] !== 'undefined') {
- if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext - (normalizedGridNext - normalizedGrid) / 2) {
- slideIndex = i;
- } else if (normalizedTranslate >= normalizedGrid && normalizedTranslate < normalizedGridNext) {
- slideIndex = i + 1;
- }
- } else if (normalizedTranslate >= normalizedGrid) {
- slideIndex = i;
- }
- }
- } // Directions locks
-
-
- if (swiper.initialized && slideIndex !== activeIndex) {
- if (!swiper.allowSlideNext && translate < swiper.translate && translate < swiper.minTranslate()) {
- return false;
- }
-
- if (!swiper.allowSlidePrev && translate > swiper.translate && translate > swiper.maxTranslate()) {
- if ((activeIndex || 0) !== slideIndex) return false;
- }
- }
-
- let direction;
- if (slideIndex > activeIndex) direction = 'next';else if (slideIndex < activeIndex) direction = 'prev';else direction = 'reset'; // Update Index
-
- if (rtl && -translate === swiper.translate || !rtl && translate === swiper.translate) {
- swiper.updateActiveIndex(slideIndex); // Update Height
-
- if (params.autoHeight) {
- swiper.updateAutoHeight();
- }
-
- swiper.updateSlidesClasses();
-
- if (params.effect !== 'slide') {
- swiper.setTranslate(translate);
- }
-
- if (direction !== 'reset') {
- swiper.transitionStart(runCallbacks, direction);
- swiper.transitionEnd(runCallbacks, direction);
- }
-
- return false;
- }
-
- if (params.cssMode) {
- const isH = swiper.isHorizontal();
- const t = rtl ? translate : -translate;
-
- if (speed === 0) {
- const isVirtual = swiper.virtual && swiper.params.virtual.enabled;
-
- if (isVirtual) {
- swiper.wrapperEl.style.scrollSnapType = 'none';
- swiper._immediateVirtual = true;
- }
-
- wrapperEl[isH ? 'scrollLeft' : 'scrollTop'] = t;
-
- if (isVirtual) {
- requestAnimationFrame(() => {
- swiper.wrapperEl.style.scrollSnapType = '';
- swiper._swiperImmediateVirtual = false;
- });
- }
- } else {
- if (!swiper.support.smoothScroll) {
- animateCSSModeScroll({
- swiper,
- targetPosition: t,
- side: isH ? 'left' : 'top'
- });
- return true;
- }
-
- wrapperEl.scrollTo({
- [isH ? 'left' : 'top']: t,
- behavior: 'smooth'
- });
- }
-
- return true;
- }
-
- swiper.setTransition(speed);
- swiper.setTranslate(translate);
- swiper.updateActiveIndex(slideIndex);
- swiper.updateSlidesClasses();
- swiper.emit('beforeTransitionStart', speed, internal);
- swiper.transitionStart(runCallbacks, direction);
-
- if (speed === 0) {
- swiper.transitionEnd(runCallbacks, direction);
- } else if (!swiper.animating) {
- swiper.animating = true;
-
- if (!swiper.onSlideToWrapperTransitionEnd) {
- swiper.onSlideToWrapperTransitionEnd = function transitionEnd(e) {
- if (!swiper || swiper.destroyed) return;
- if (e.target !== this) return;
- swiper.$wrapperEl[0].removeEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);
- swiper.$wrapperEl[0].removeEventListener('webkitTransitionEnd', swiper.onSlideToWrapperTransitionEnd);
- swiper.onSlideToWrapperTransitionEnd = null;
- delete swiper.onSlideToWrapperTransitionEnd;
- swiper.transitionEnd(runCallbacks, direction);
- };
- }
-
- swiper.$wrapperEl[0].addEventListener('transitionend', swiper.onSlideToWrapperTransitionEnd);
- swiper.$wrapperEl[0].addEventListener('webkitTransitionEnd', swiper.onSlideToWrapperTransitionEnd);
- }
-
- return true;
- }
-
- function slideToLoop(index, speed, runCallbacks, internal) {
- if (index === void 0) {
- index = 0;
- }
-
- if (speed === void 0) {
- speed = this.params.speed;
- }
-
- if (runCallbacks === void 0) {
- runCallbacks = true;
- }
-
- const swiper = this;
- let newIndex = index;
-
- if (swiper.params.loop) {
- newIndex += swiper.loopedSlides;
- }
-
- return swiper.slideTo(newIndex, speed, runCallbacks, internal);
- }
-
- /* eslint no-unused-vars: "off" */
- function slideNext(speed, runCallbacks, internal) {
- if (speed === void 0) {
- speed = this.params.speed;
- }
-
- if (runCallbacks === void 0) {
- runCallbacks = true;
- }
-
- const swiper = this;
- const {
- animating,
- enabled,
- params
- } = swiper;
- if (!enabled) return swiper;
- let perGroup = params.slidesPerGroup;
-
- if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {
- perGroup = Math.max(swiper.slidesPerViewDynamic('current', true), 1);
- }
-
- const increment = swiper.activeIndex < params.slidesPerGroupSkip ? 1 : perGroup;
-
- if (params.loop) {
- if (animating && params.loopPreventsSlide) return false;
- swiper.loopFix(); // eslint-disable-next-line
-
- swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;
- }
-
- if (params.rewind && swiper.isEnd) {
- return swiper.slideTo(0, speed, runCallbacks, internal);
- }
-
- return swiper.slideTo(swiper.activeIndex + increment, speed, runCallbacks, internal);
- }
-
- /* eslint no-unused-vars: "off" */
- function slidePrev(speed, runCallbacks, internal) {
- if (speed === void 0) {
- speed = this.params.speed;
- }
-
- if (runCallbacks === void 0) {
- runCallbacks = true;
- }
-
- const swiper = this;
- const {
- params,
- animating,
- snapGrid,
- slidesGrid,
- rtlTranslate,
- enabled
- } = swiper;
- if (!enabled) return swiper;
-
- if (params.loop) {
- if (animating && params.loopPreventsSlide) return false;
- swiper.loopFix(); // eslint-disable-next-line
-
- swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;
- }
-
- const translate = rtlTranslate ? swiper.translate : -swiper.translate;
-
- function normalize(val) {
- if (val < 0) return -Math.floor(Math.abs(val));
- return Math.floor(val);
- }
-
- const normalizedTranslate = normalize(translate);
- const normalizedSnapGrid = snapGrid.map(val => normalize(val));
- let prevSnap = snapGrid[normalizedSnapGrid.indexOf(normalizedTranslate) - 1];
-
- if (typeof prevSnap === 'undefined' && params.cssMode) {
- let prevSnapIndex;
- snapGrid.forEach((snap, snapIndex) => {
- if (normalizedTranslate >= snap) {
- // prevSnap = snap;
- prevSnapIndex = snapIndex;
- }
- });
-
- if (typeof prevSnapIndex !== 'undefined') {
- prevSnap = snapGrid[prevSnapIndex > 0 ? prevSnapIndex - 1 : prevSnapIndex];
- }
- }
-
- let prevIndex = 0;
-
- if (typeof prevSnap !== 'undefined') {
- prevIndex = slidesGrid.indexOf(prevSnap);
- if (prevIndex < 0) prevIndex = swiper.activeIndex - 1;
-
- if (params.slidesPerView === 'auto' && params.slidesPerGroup === 1 && params.slidesPerGroupAuto) {
- prevIndex = prevIndex - swiper.slidesPerViewDynamic('previous', true) + 1;
- prevIndex = Math.max(prevIndex, 0);
- }
- }
-
- if (params.rewind && swiper.isBeginning) {
- const lastIndex = swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual ? swiper.virtual.slides.length - 1 : swiper.slides.length - 1;
- return swiper.slideTo(lastIndex, speed, runCallbacks, internal);
- }
-
- return swiper.slideTo(prevIndex, speed, runCallbacks, internal);
- }
-
- /* eslint no-unused-vars: "off" */
- function slideReset(speed, runCallbacks, internal) {
- if (speed === void 0) {
- speed = this.params.speed;
- }
-
- if (runCallbacks === void 0) {
- runCallbacks = true;
- }
-
- const swiper = this;
- return swiper.slideTo(swiper.activeIndex, speed, runCallbacks, internal);
- }
-
- /* eslint no-unused-vars: "off" */
- function slideToClosest(speed, runCallbacks, internal, threshold) {
- if (speed === void 0) {
- speed = this.params.speed;
- }
-
- if (runCallbacks === void 0) {
- runCallbacks = true;
- }
-
- if (threshold === void 0) {
- threshold = 0.5;
- }
-
- const swiper = this;
- let index = swiper.activeIndex;
- const skip = Math.min(swiper.params.slidesPerGroupSkip, index);
- const snapIndex = skip + Math.floor((index - skip) / swiper.params.slidesPerGroup);
- const translate = swiper.rtlTranslate ? swiper.translate : -swiper.translate;
-
- if (translate >= swiper.snapGrid[snapIndex]) {
- // The current translate is on or after the current snap index, so the choice
- // is between the current index and the one after it.
- const currentSnap = swiper.snapGrid[snapIndex];
- const nextSnap = swiper.snapGrid[snapIndex + 1];
-
- if (translate - currentSnap > (nextSnap - currentSnap) * threshold) {
- index += swiper.params.slidesPerGroup;
- }
- } else {
- // The current translate is before the current snap index, so the choice
- // is between the current index and the one before it.
- const prevSnap = swiper.snapGrid[snapIndex - 1];
- const currentSnap = swiper.snapGrid[snapIndex];
-
- if (translate - prevSnap <= (currentSnap - prevSnap) * threshold) {
- index -= swiper.params.slidesPerGroup;
- }
- }
-
- index = Math.max(index, 0);
- index = Math.min(index, swiper.slidesGrid.length - 1);
- return swiper.slideTo(index, speed, runCallbacks, internal);
- }
-
- function slideToClickedSlide() {
- const swiper = this;
- const {
- params,
- $wrapperEl
- } = swiper;
- const slidesPerView = params.slidesPerView === 'auto' ? swiper.slidesPerViewDynamic() : params.slidesPerView;
- let slideToIndex = swiper.clickedIndex;
- let realIndex;
-
- if (params.loop) {
- if (swiper.animating) return;
- realIndex = parseInt($(swiper.clickedSlide).attr('data-swiper-slide-index'), 10);
-
- if (params.centeredSlides) {
- if (slideToIndex < swiper.loopedSlides - slidesPerView / 2 || slideToIndex > swiper.slides.length - swiper.loopedSlides + slidesPerView / 2) {
- swiper.loopFix();
- slideToIndex = $wrapperEl.children(`.${params.slideClass}[data-swiper-slide-index="${realIndex}"]:not(.${params.slideDuplicateClass})`).eq(0).index();
- nextTick(() => {
- swiper.slideTo(slideToIndex);
- });
- } else {
- swiper.slideTo(slideToIndex);
- }
- } else if (slideToIndex > swiper.slides.length - slidesPerView) {
- swiper.loopFix();
- slideToIndex = $wrapperEl.children(`.${params.slideClass}[data-swiper-slide-index="${realIndex}"]:not(.${params.slideDuplicateClass})`).eq(0).index();
- nextTick(() => {
- swiper.slideTo(slideToIndex);
- });
- } else {
- swiper.slideTo(slideToIndex);
- }
- } else {
- swiper.slideTo(slideToIndex);
- }
- }
-
- var slide = {
- slideTo,
- slideToLoop,
- slideNext,
- slidePrev,
- slideReset,
- slideToClosest,
- slideToClickedSlide
- };
-
- function loopCreate() {
- const swiper = this;
- const document = getDocument();
- const {
- params,
- $wrapperEl
- } = swiper; // Remove duplicated slides
-
- const $selector = $wrapperEl.children().length > 0 ? $($wrapperEl.children()[0].parentNode) : $wrapperEl;
- $selector.children(`.${params.slideClass}.${params.slideDuplicateClass}`).remove();
- let slides = $selector.children(`.${params.slideClass}`);
-
- if (params.loopFillGroupWithBlank) {
- const blankSlidesNum = params.slidesPerGroup - slides.length % params.slidesPerGroup;
-
- if (blankSlidesNum !== params.slidesPerGroup) {
- for (let i = 0; i < blankSlidesNum; i += 1) {
- const blankNode = $(document.createElement('div')).addClass(`${params.slideClass} ${params.slideBlankClass}`);
- $selector.append(blankNode);
- }
-
- slides = $selector.children(`.${params.slideClass}`);
- }
- }
-
- if (params.slidesPerView === 'auto' && !params.loopedSlides) params.loopedSlides = slides.length;
- swiper.loopedSlides = Math.ceil(parseFloat(params.loopedSlides || params.slidesPerView, 10));
- swiper.loopedSlides += params.loopAdditionalSlides;
-
- if (swiper.loopedSlides > slides.length) {
- swiper.loopedSlides = slides.length;
- }
-
- const prependSlides = [];
- const appendSlides = [];
- slides.each((el, index) => {
- const slide = $(el);
-
- if (index < swiper.loopedSlides) {
- appendSlides.push(el);
- }
-
- if (index < slides.length && index >= slides.length - swiper.loopedSlides) {
- prependSlides.push(el);
- }
-
- slide.attr('data-swiper-slide-index', index);
- });
-
- for (let i = 0; i < appendSlides.length; i += 1) {
- $selector.append($(appendSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));
- }
-
- for (let i = prependSlides.length - 1; i >= 0; i -= 1) {
- $selector.prepend($(prependSlides[i].cloneNode(true)).addClass(params.slideDuplicateClass));
- }
- }
-
- function loopFix() {
- const swiper = this;
- swiper.emit('beforeLoopFix');
- const {
- activeIndex,
- slides,
- loopedSlides,
- allowSlidePrev,
- allowSlideNext,
- snapGrid,
- rtlTranslate: rtl
- } = swiper;
- let newIndex;
- swiper.allowSlidePrev = true;
- swiper.allowSlideNext = true;
- const snapTranslate = -snapGrid[activeIndex];
- const diff = snapTranslate - swiper.getTranslate(); // Fix For Negative Oversliding
-
- if (activeIndex < loopedSlides) {
- newIndex = slides.length - loopedSlides * 3 + activeIndex;
- newIndex += loopedSlides;
- const slideChanged = swiper.slideTo(newIndex, 0, false, true);
-
- if (slideChanged && diff !== 0) {
- swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);
- }
- } else if (activeIndex >= slides.length - loopedSlides) {
- // Fix For Positive Oversliding
- newIndex = -slides.length + activeIndex + loopedSlides;
- newIndex += loopedSlides;
- const slideChanged = swiper.slideTo(newIndex, 0, false, true);
-
- if (slideChanged && diff !== 0) {
- swiper.setTranslate((rtl ? -swiper.translate : swiper.translate) - diff);
- }
- }
-
- swiper.allowSlidePrev = allowSlidePrev;
- swiper.allowSlideNext = allowSlideNext;
- swiper.emit('loopFix');
- }
-
- function loopDestroy() {
- const swiper = this;
- const {
- $wrapperEl,
- params,
- slides
- } = swiper;
- $wrapperEl.children(`.${params.slideClass}.${params.slideDuplicateClass},.${params.slideClass}.${params.slideBlankClass}`).remove();
- slides.removeAttr('data-swiper-slide-index');
- }
-
- var loop = {
- loopCreate,
- loopFix,
- loopDestroy
- };
-
- function setGrabCursor(moving) {
- const swiper = this;
- if (swiper.support.touch || !swiper.params.simulateTouch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) return;
- const el = swiper.params.touchEventsTarget === 'container' ? swiper.el : swiper.wrapperEl;
- el.style.cursor = 'move';
- el.style.cursor = moving ? '-webkit-grabbing' : '-webkit-grab';
- el.style.cursor = moving ? '-moz-grabbin' : '-moz-grab';
- el.style.cursor = moving ? 'grabbing' : 'grab';
- }
-
- function unsetGrabCursor() {
- const swiper = this;
-
- if (swiper.support.touch || swiper.params.watchOverflow && swiper.isLocked || swiper.params.cssMode) {
- return;
- }
-
- swiper[swiper.params.touchEventsTarget === 'container' ? 'el' : 'wrapperEl'].style.cursor = '';
- }
-
- var grabCursor = {
- setGrabCursor,
- unsetGrabCursor
- };
-
- function closestElement(selector, base) {
- if (base === void 0) {
- base = this;
- }
-
- function __closestFrom(el) {
- if (!el || el === getDocument() || el === getWindow()) return null;
- if (el.assignedSlot) el = el.assignedSlot;
- const found = el.closest(selector);
- return found || __closestFrom(el.getRootNode().host);
- }
-
- return __closestFrom(base);
- }
-
- function onTouchStart(event) {
- const swiper = this;
- const document = getDocument();
- const window = getWindow();
- const data = swiper.touchEventsData;
- const {
- params,
- touches,
- enabled
- } = swiper;
- if (!enabled) return;
-
- if (swiper.animating && params.preventInteractionOnTransition) {
- return;
- }
-
- if (!swiper.animating && params.cssMode && params.loop) {
- swiper.loopFix();
- }
-
- let e = event;
- if (e.originalEvent) e = e.originalEvent;
- let $targetEl = $(e.target);
-
- if (params.touchEventsTarget === 'wrapper') {
- if (!$targetEl.closest(swiper.wrapperEl).length) return;
- }
-
- data.isTouchEvent = e.type === 'touchstart';
- if (!data.isTouchEvent && 'which' in e && e.which === 3) return;
- if (!data.isTouchEvent && 'button' in e && e.button > 0) return;
- if (data.isTouched && data.isMoved) return; // change target el for shadow root component
-
- const swipingClassHasValue = !!params.noSwipingClass && params.noSwipingClass !== '';
-
- if (swipingClassHasValue && e.target && e.target.shadowRoot && event.path && event.path[0]) {
- $targetEl = $(event.path[0]);
- }
-
- const noSwipingSelector = params.noSwipingSelector ? params.noSwipingSelector : `.${params.noSwipingClass}`;
- const isTargetShadow = !!(e.target && e.target.shadowRoot); // use closestElement for shadow root element to get the actual closest for nested shadow root element
-
- if (params.noSwiping && (isTargetShadow ? closestElement(noSwipingSelector, e.target) : $targetEl.closest(noSwipingSelector)[0])) {
- swiper.allowClick = true;
- return;
- }
-
- if (params.swipeHandler) {
- if (!$targetEl.closest(params.swipeHandler)[0]) return;
- }
-
- touches.currentX = e.type === 'touchstart' ? e.targetTouches[0].pageX : e.pageX;
- touches.currentY = e.type === 'touchstart' ? e.targetTouches[0].pageY : e.pageY;
- const startX = touches.currentX;
- const startY = touches.currentY; // Do NOT start if iOS edge swipe is detected. Otherwise iOS app cannot swipe-to-go-back anymore
-
- const edgeSwipeDetection = params.edgeSwipeDetection || params.iOSEdgeSwipeDetection;
- const edgeSwipeThreshold = params.edgeSwipeThreshold || params.iOSEdgeSwipeThreshold;
-
- if (edgeSwipeDetection && (startX <= edgeSwipeThreshold || startX >= window.innerWidth - edgeSwipeThreshold)) {
- if (edgeSwipeDetection === 'prevent') {
- event.preventDefault();
- } else {
- return;
- }
- }
-
- Object.assign(data, {
- isTouched: true,
- isMoved: false,
- allowTouchCallbacks: true,
- isScrolling: undefined,
- startMoving: undefined
- });
- touches.startX = startX;
- touches.startY = startY;
- data.touchStartTime = now();
- swiper.allowClick = true;
- swiper.updateSize();
- swiper.swipeDirection = undefined;
- if (params.threshold > 0) data.allowThresholdMove = false;
-
- if (e.type !== 'touchstart') {
- let preventDefault = true;
-
- if ($targetEl.is(data.focusableElements)) {
- preventDefault = false;
-
- if ($targetEl[0].nodeName === 'SELECT') {
- data.isTouched = false;
- }
- }
-
- if (document.activeElement && $(document.activeElement).is(data.focusableElements) && document.activeElement !== $targetEl[0]) {
- document.activeElement.blur();
- }
-
- const shouldPreventDefault = preventDefault && swiper.allowTouchMove && params.touchStartPreventDefault;
-
- if ((params.touchStartForcePreventDefault || shouldPreventDefault) && !$targetEl[0].isContentEditable) {
- e.preventDefault();
- }
- }
-
- if (swiper.params.freeMode && swiper.params.freeMode.enabled && swiper.freeMode && swiper.animating && !params.cssMode) {
- swiper.freeMode.onTouchStart();
- }
-
- swiper.emit('touchStart', e);
- }
-
- function onTouchMove(event) {
- const document = getDocument();
- const swiper = this;
- const data = swiper.touchEventsData;
- const {
- params,
- touches,
- rtlTranslate: rtl,
- enabled
- } = swiper;
- if (!enabled) return;
- let e = event;
- if (e.originalEvent) e = e.originalEvent;
-
- if (!data.isTouched) {
- if (data.startMoving && data.isScrolling) {
- swiper.emit('touchMoveOpposite', e);
- }
-
- return;
- }
-
- if (data.isTouchEvent && e.type !== 'touchmove') return;
- const targetTouch = e.type === 'touchmove' && e.targetTouches && (e.targetTouches[0] || e.changedTouches[0]);
- const pageX = e.type === 'touchmove' ? targetTouch.pageX : e.pageX;
- const pageY = e.type === 'touchmove' ? targetTouch.pageY : e.pageY;
-
- if (e.preventedByNestedSwiper) {
- touches.startX = pageX;
- touches.startY = pageY;
- return;
- }
-
- if (!swiper.allowTouchMove) {
- if (!$(e.target).is(data.focusableElements)) {
- swiper.allowClick = false;
- }
-
- if (data.isTouched) {
- Object.assign(touches, {
- startX: pageX,
- startY: pageY,
- currentX: pageX,
- currentY: pageY
- });
- data.touchStartTime = now();
- }
-
- return;
- }
-
- if (data.isTouchEvent && params.touchReleaseOnEdges && !params.loop) {
- if (swiper.isVertical()) {
- // Vertical
- if (pageY < touches.startY && swiper.translate <= swiper.maxTranslate() || pageY > touches.startY && swiper.translate >= swiper.minTranslate()) {
- data.isTouched = false;
- data.isMoved = false;
- return;
- }
- } else if (pageX < touches.startX && swiper.translate <= swiper.maxTranslate() || pageX > touches.startX && swiper.translate >= swiper.minTranslate()) {
- return;
- }
- }
-
- if (data.isTouchEvent && document.activeElement) {
- if (e.target === document.activeElement && $(e.target).is(data.focusableElements)) {
- data.isMoved = true;
- swiper.allowClick = false;
- return;
- }
- }
-
- if (data.allowTouchCallbacks) {
- swiper.emit('touchMove', e);
- }
-
- if (e.targetTouches && e.targetTouches.length > 1) return;
- touches.currentX = pageX;
- touches.currentY = pageY;
- const diffX = touches.currentX - touches.startX;
- const diffY = touches.currentY - touches.startY;
- if (swiper.params.threshold && Math.sqrt(diffX ** 2 + diffY ** 2) < swiper.params.threshold) return;
-
- if (typeof data.isScrolling === 'undefined') {
- let touchAngle;
-
- if (swiper.isHorizontal() && touches.currentY === touches.startY || swiper.isVertical() && touches.currentX === touches.startX) {
- data.isScrolling = false;
- } else {
- // eslint-disable-next-line
- if (diffX * diffX + diffY * diffY >= 25) {
- touchAngle = Math.atan2(Math.abs(diffY), Math.abs(diffX)) * 180 / Math.PI;
- data.isScrolling = swiper.isHorizontal() ? touchAngle > params.touchAngle : 90 - touchAngle > params.touchAngle;
- }
- }
- }
-
- if (data.isScrolling) {
- swiper.emit('touchMoveOpposite', e);
- }
-
- if (typeof data.startMoving === 'undefined') {
- if (touches.currentX !== touches.startX || touches.currentY !== touches.startY) {
- data.startMoving = true;
- }
- }
-
- if (data.isScrolling) {
- data.isTouched = false;
- return;
- }
-
- if (!data.startMoving) {
- return;
- }
-
- swiper.allowClick = false;
-
- if (!params.cssMode && e.cancelable) {
- e.preventDefault();
- }
-
- if (params.touchMoveStopPropagation && !params.nested) {
- e.stopPropagation();
- }
-
- if (!data.isMoved) {
- if (params.loop && !params.cssMode) {
- swiper.loopFix();
- }
-
- data.startTranslate = swiper.getTranslate();
- swiper.setTransition(0);
-
- if (swiper.animating) {
- swiper.$wrapperEl.trigger('webkitTransitionEnd transitionend');
- }
-
- data.allowMomentumBounce = false; // Grab Cursor
-
- if (params.grabCursor && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {
- swiper.setGrabCursor(true);
- }
-
- swiper.emit('sliderFirstMove', e);
- }
-
- swiper.emit('sliderMove', e);
- data.isMoved = true;
- let diff = swiper.isHorizontal() ? diffX : diffY;
- touches.diff = diff;
- diff *= params.touchRatio;
- if (rtl) diff = -diff;
- swiper.swipeDirection = diff > 0 ? 'prev' : 'next';
- data.currentTranslate = diff + data.startTranslate;
- let disableParentSwiper = true;
- let resistanceRatio = params.resistanceRatio;
-
- if (params.touchReleaseOnEdges) {
- resistanceRatio = 0;
- }
-
- if (diff > 0 && data.currentTranslate > swiper.minTranslate()) {
- disableParentSwiper = false;
- if (params.resistance) data.currentTranslate = swiper.minTranslate() - 1 + (-swiper.minTranslate() + data.startTranslate + diff) ** resistanceRatio;
- } else if (diff < 0 && data.currentTranslate < swiper.maxTranslate()) {
- disableParentSwiper = false;
- if (params.resistance) data.currentTranslate = swiper.maxTranslate() + 1 - (swiper.maxTranslate() - data.startTranslate - diff) ** resistanceRatio;
- }
-
- if (disableParentSwiper) {
- e.preventedByNestedSwiper = true;
- } // Directions locks
-
-
- if (!swiper.allowSlideNext && swiper.swipeDirection === 'next' && data.currentTranslate < data.startTranslate) {
- data.currentTranslate = data.startTranslate;
- }
-
- if (!swiper.allowSlidePrev && swiper.swipeDirection === 'prev' && data.currentTranslate > data.startTranslate) {
- data.currentTranslate = data.startTranslate;
- }
-
- if (!swiper.allowSlidePrev && !swiper.allowSlideNext) {
- data.currentTranslate = data.startTranslate;
- } // Threshold
-
-
- if (params.threshold > 0) {
- if (Math.abs(diff) > params.threshold || data.allowThresholdMove) {
- if (!data.allowThresholdMove) {
- data.allowThresholdMove = true;
- touches.startX = touches.currentX;
- touches.startY = touches.currentY;
- data.currentTranslate = data.startTranslate;
- touches.diff = swiper.isHorizontal() ? touches.currentX - touches.startX : touches.currentY - touches.startY;
- return;
- }
- } else {
- data.currentTranslate = data.startTranslate;
- return;
- }
- }
-
- if (!params.followFinger || params.cssMode) return; // Update active index in free mode
-
- if (params.freeMode && params.freeMode.enabled && swiper.freeMode || params.watchSlidesProgress) {
- swiper.updateActiveIndex();
- swiper.updateSlidesClasses();
- }
-
- if (swiper.params.freeMode && params.freeMode.enabled && swiper.freeMode) {
- swiper.freeMode.onTouchMove();
- } // Update progress
-
-
- swiper.updateProgress(data.currentTranslate); // Update translate
-
- swiper.setTranslate(data.currentTranslate);
- }
-
- function onTouchEnd(event) {
- const swiper = this;
- const data = swiper.touchEventsData;
- const {
- params,
- touches,
- rtlTranslate: rtl,
- slidesGrid,
- enabled
- } = swiper;
- if (!enabled) return;
- let e = event;
- if (e.originalEvent) e = e.originalEvent;
-
- if (data.allowTouchCallbacks) {
- swiper.emit('touchEnd', e);
- }
-
- data.allowTouchCallbacks = false;
-
- if (!data.isTouched) {
- if (data.isMoved && params.grabCursor) {
- swiper.setGrabCursor(false);
- }
-
- data.isMoved = false;
- data.startMoving = false;
- return;
- } // Return Grab Cursor
-
-
- if (params.grabCursor && data.isMoved && data.isTouched && (swiper.allowSlideNext === true || swiper.allowSlidePrev === true)) {
- swiper.setGrabCursor(false);
- } // Time diff
-
-
- const touchEndTime = now();
- const timeDiff = touchEndTime - data.touchStartTime; // Tap, doubleTap, Click
-
- if (swiper.allowClick) {
- const pathTree = e.path || e.composedPath && e.composedPath();
- swiper.updateClickedSlide(pathTree && pathTree[0] || e.target);
- swiper.emit('tap click', e);
-
- if (timeDiff < 300 && touchEndTime - data.lastClickTime < 300) {
- swiper.emit('doubleTap doubleClick', e);
- }
- }
-
- data.lastClickTime = now();
- nextTick(() => {
- if (!swiper.destroyed) swiper.allowClick = true;
- });
-
- if (!data.isTouched || !data.isMoved || !swiper.swipeDirection || touches.diff === 0 || data.currentTranslate === data.startTranslate) {
- data.isTouched = false;
- data.isMoved = false;
- data.startMoving = false;
- return;
- }
-
- data.isTouched = false;
- data.isMoved = false;
- data.startMoving = false;
- let currentPos;
-
- if (params.followFinger) {
- currentPos = rtl ? swiper.translate : -swiper.translate;
- } else {
- currentPos = -data.currentTranslate;
- }
-
- if (params.cssMode) {
- return;
- }
-
- if (swiper.params.freeMode && params.freeMode.enabled) {
- swiper.freeMode.onTouchEnd({
- currentPos
- });
- return;
- } // Find current slide
-
-
- let stopIndex = 0;
- let groupSize = swiper.slidesSizesGrid[0];
-
- for (let i = 0; i < slidesGrid.length; i += i < params.slidesPerGroupSkip ? 1 : params.slidesPerGroup) {
- const increment = i < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;
-
- if (typeof slidesGrid[i + increment] !== 'undefined') {
- if (currentPos >= slidesGrid[i] && currentPos < slidesGrid[i + increment]) {
- stopIndex = i;
- groupSize = slidesGrid[i + increment] - slidesGrid[i];
- }
- } else if (currentPos >= slidesGrid[i]) {
- stopIndex = i;
- groupSize = slidesGrid[slidesGrid.length - 1] - slidesGrid[slidesGrid.length - 2];
- }
- }
-
- let rewindFirstIndex = null;
- let rewindLastIndex = null;
-
- if (params.rewind) {
- if (swiper.isBeginning) {
- rewindLastIndex = swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual ? swiper.virtual.slides.length - 1 : swiper.slides.length - 1;
- } else if (swiper.isEnd) {
- rewindFirstIndex = 0;
- }
- } // Find current slide size
-
-
- const ratio = (currentPos - slidesGrid[stopIndex]) / groupSize;
- const increment = stopIndex < params.slidesPerGroupSkip - 1 ? 1 : params.slidesPerGroup;
-
- if (timeDiff > params.longSwipesMs) {
- // Long touches
- if (!params.longSwipes) {
- swiper.slideTo(swiper.activeIndex);
- return;
- }
-
- if (swiper.swipeDirection === 'next') {
- if (ratio >= params.longSwipesRatio) swiper.slideTo(params.rewind && swiper.isEnd ? rewindFirstIndex : stopIndex + increment);else swiper.slideTo(stopIndex);
- }
-
- if (swiper.swipeDirection === 'prev') {
- if (ratio > 1 - params.longSwipesRatio) {
- swiper.slideTo(stopIndex + increment);
- } else if (rewindLastIndex !== null && ratio < 0 && Math.abs(ratio) > params.longSwipesRatio) {
- swiper.slideTo(rewindLastIndex);
- } else {
- swiper.slideTo(stopIndex);
- }
- }
- } else {
- // Short swipes
- if (!params.shortSwipes) {
- swiper.slideTo(swiper.activeIndex);
- return;
- }
-
- const isNavButtonTarget = swiper.navigation && (e.target === swiper.navigation.nextEl || e.target === swiper.navigation.prevEl);
-
- if (!isNavButtonTarget) {
- if (swiper.swipeDirection === 'next') {
- swiper.slideTo(rewindFirstIndex !== null ? rewindFirstIndex : stopIndex + increment);
- }
-
- if (swiper.swipeDirection === 'prev') {
- swiper.slideTo(rewindLastIndex !== null ? rewindLastIndex : stopIndex);
- }
- } else if (e.target === swiper.navigation.nextEl) {
- swiper.slideTo(stopIndex + increment);
- } else {
- swiper.slideTo(stopIndex);
- }
- }
- }
-
- function onResize() {
- const swiper = this;
- const {
- params,
- el
- } = swiper;
- if (el && el.offsetWidth === 0) return; // Breakpoints
-
- if (params.breakpoints) {
- swiper.setBreakpoint();
- } // Save locks
-
-
- const {
- allowSlideNext,
- allowSlidePrev,
- snapGrid
- } = swiper; // Disable locks on resize
-
- swiper.allowSlideNext = true;
- swiper.allowSlidePrev = true;
- swiper.updateSize();
- swiper.updateSlides();
- swiper.updateSlidesClasses();
-
- if ((params.slidesPerView === 'auto' || params.slidesPerView > 1) && swiper.isEnd && !swiper.isBeginning && !swiper.params.centeredSlides) {
- swiper.slideTo(swiper.slides.length - 1, 0, false, true);
- } else {
- swiper.slideTo(swiper.activeIndex, 0, false, true);
- }
-
- if (swiper.autoplay && swiper.autoplay.running && swiper.autoplay.paused) {
- swiper.autoplay.run();
- } // Return locks after resize
-
-
- swiper.allowSlidePrev = allowSlidePrev;
- swiper.allowSlideNext = allowSlideNext;
-
- if (swiper.params.watchOverflow && snapGrid !== swiper.snapGrid) {
- swiper.checkOverflow();
- }
- }
-
- function onClick(e) {
- const swiper = this;
- if (!swiper.enabled) return;
-
- if (!swiper.allowClick) {
- if (swiper.params.preventClicks) e.preventDefault();
-
- if (swiper.params.preventClicksPropagation && swiper.animating) {
- e.stopPropagation();
- e.stopImmediatePropagation();
- }
- }
- }
-
- function onScroll() {
- const swiper = this;
- const {
- wrapperEl,
- rtlTranslate,
- enabled
- } = swiper;
- if (!enabled) return;
- swiper.previousTranslate = swiper.translate;
-
- if (swiper.isHorizontal()) {
- swiper.translate = -wrapperEl.scrollLeft;
- } else {
- swiper.translate = -wrapperEl.scrollTop;
- } // eslint-disable-next-line
-
-
- if (swiper.translate === -0) swiper.translate = 0;
- swiper.updateActiveIndex();
- swiper.updateSlidesClasses();
- let newProgress;
- const translatesDiff = swiper.maxTranslate() - swiper.minTranslate();
-
- if (translatesDiff === 0) {
- newProgress = 0;
- } else {
- newProgress = (swiper.translate - swiper.minTranslate()) / translatesDiff;
- }
-
- if (newProgress !== swiper.progress) {
- swiper.updateProgress(rtlTranslate ? -swiper.translate : swiper.translate);
- }
-
- swiper.emit('setTranslate', swiper.translate, false);
- }
-
- let dummyEventAttached = false;
-
- function dummyEventListener() {}
-
- const events = (swiper, method) => {
- const document = getDocument();
- const {
- params,
- touchEvents,
- el,
- wrapperEl,
- device,
- support
- } = swiper;
- const capture = !!params.nested;
- const domMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';
- const swiperMethod = method; // Touch Events
-
- if (!support.touch) {
- el[domMethod](touchEvents.start, swiper.onTouchStart, false);
- document[domMethod](touchEvents.move, swiper.onTouchMove, capture);
- document[domMethod](touchEvents.end, swiper.onTouchEnd, false);
- } else {
- const passiveListener = touchEvents.start === 'touchstart' && support.passiveListener && params.passiveListeners ? {
- passive: true,
- capture: false
- } : false;
- el[domMethod](touchEvents.start, swiper.onTouchStart, passiveListener);
- el[domMethod](touchEvents.move, swiper.onTouchMove, support.passiveListener ? {
- passive: false,
- capture
- } : capture);
- el[domMethod](touchEvents.end, swiper.onTouchEnd, passiveListener);
-
- if (touchEvents.cancel) {
- el[domMethod](touchEvents.cancel, swiper.onTouchEnd, passiveListener);
- }
- } // Prevent Links Clicks
-
-
- if (params.preventClicks || params.preventClicksPropagation) {
- el[domMethod]('click', swiper.onClick, true);
- }
-
- if (params.cssMode) {
- wrapperEl[domMethod]('scroll', swiper.onScroll);
- } // Resize handler
-
-
- if (params.updateOnWindowResize) {
- swiper[swiperMethod](device.ios || device.android ? 'resize orientationchange observerUpdate' : 'resize observerUpdate', onResize, true);
- } else {
- swiper[swiperMethod]('observerUpdate', onResize, true);
- }
- };
-
- function attachEvents() {
- const swiper = this;
- const document = getDocument();
- const {
- params,
- support
- } = swiper;
- swiper.onTouchStart = onTouchStart.bind(swiper);
- swiper.onTouchMove = onTouchMove.bind(swiper);
- swiper.onTouchEnd = onTouchEnd.bind(swiper);
-
- if (params.cssMode) {
- swiper.onScroll = onScroll.bind(swiper);
- }
-
- swiper.onClick = onClick.bind(swiper);
-
- if (support.touch && !dummyEventAttached) {
- document.addEventListener('touchstart', dummyEventListener);
- dummyEventAttached = true;
- }
-
- events(swiper, 'on');
- }
-
- function detachEvents() {
- const swiper = this;
- events(swiper, 'off');
- }
-
- var events$1 = {
- attachEvents,
- detachEvents
- };
-
- const isGridEnabled = (swiper, params) => {
- return swiper.grid && params.grid && params.grid.rows > 1;
- };
-
- function setBreakpoint() {
- const swiper = this;
- const {
- activeIndex,
- initialized,
- loopedSlides = 0,
- params,
- $el
- } = swiper;
- const breakpoints = params.breakpoints;
- if (!breakpoints || breakpoints && Object.keys(breakpoints).length === 0) return; // Get breakpoint for window width and update parameters
-
- const breakpoint = swiper.getBreakpoint(breakpoints, swiper.params.breakpointsBase, swiper.el);
- if (!breakpoint || swiper.currentBreakpoint === breakpoint) return;
- const breakpointOnlyParams = breakpoint in breakpoints ? breakpoints[breakpoint] : undefined;
- const breakpointParams = breakpointOnlyParams || swiper.originalParams;
- const wasMultiRow = isGridEnabled(swiper, params);
- const isMultiRow = isGridEnabled(swiper, breakpointParams);
- const wasEnabled = params.enabled;
-
- if (wasMultiRow && !isMultiRow) {
- $el.removeClass(`${params.containerModifierClass}grid ${params.containerModifierClass}grid-column`);
- swiper.emitContainerClasses();
- } else if (!wasMultiRow && isMultiRow) {
- $el.addClass(`${params.containerModifierClass}grid`);
-
- if (breakpointParams.grid.fill && breakpointParams.grid.fill === 'column' || !breakpointParams.grid.fill && params.grid.fill === 'column') {
- $el.addClass(`${params.containerModifierClass}grid-column`);
- }
-
- swiper.emitContainerClasses();
- }
-
- const directionChanged = breakpointParams.direction && breakpointParams.direction !== params.direction;
- const needsReLoop = params.loop && (breakpointParams.slidesPerView !== params.slidesPerView || directionChanged);
-
- if (directionChanged && initialized) {
- swiper.changeDirection();
- }
-
- extend(swiper.params, breakpointParams);
- const isEnabled = swiper.params.enabled;
- Object.assign(swiper, {
- allowTouchMove: swiper.params.allowTouchMove,
- allowSlideNext: swiper.params.allowSlideNext,
- allowSlidePrev: swiper.params.allowSlidePrev
- });
-
- if (wasEnabled && !isEnabled) {
- swiper.disable();
- } else if (!wasEnabled && isEnabled) {
- swiper.enable();
- }
-
- swiper.currentBreakpoint = breakpoint;
- swiper.emit('_beforeBreakpoint', breakpointParams);
-
- if (needsReLoop && initialized) {
- swiper.loopDestroy();
- swiper.loopCreate();
- swiper.updateSlides();
- swiper.slideTo(activeIndex - loopedSlides + swiper.loopedSlides, 0, false);
- }
-
- swiper.emit('breakpoint', breakpointParams);
- }
-
- function getBreakpoint(breakpoints, base, containerEl) {
- if (base === void 0) {
- base = 'window';
- }
-
- if (!breakpoints || base === 'container' && !containerEl) return undefined;
- let breakpoint = false;
- const window = getWindow();
- const currentHeight = base === 'window' ? window.innerHeight : containerEl.clientHeight;
- const points = Object.keys(breakpoints).map(point => {
- if (typeof point === 'string' && point.indexOf('@') === 0) {
- const minRatio = parseFloat(point.substr(1));
- const value = currentHeight * minRatio;
- return {
- value,
- point
- };
- }
-
- return {
- value: point,
- point
- };
- });
- points.sort((a, b) => parseInt(a.value, 10) - parseInt(b.value, 10));
-
- for (let i = 0; i < points.length; i += 1) {
- const {
- point,
- value
- } = points[i];
-
- if (base === 'window') {
- if (window.matchMedia(`(min-width: ${value}px)`).matches) {
- breakpoint = point;
- }
- } else if (value <= containerEl.clientWidth) {
- breakpoint = point;
- }
- }
-
- return breakpoint || 'max';
- }
-
- var breakpoints = {
- setBreakpoint,
- getBreakpoint
- };
-
- function prepareClasses(entries, prefix) {
- const resultClasses = [];
- entries.forEach(item => {
- if (typeof item === 'object') {
- Object.keys(item).forEach(classNames => {
- if (item[classNames]) {
- resultClasses.push(prefix + classNames);
- }
- });
- } else if (typeof item === 'string') {
- resultClasses.push(prefix + item);
- }
- });
- return resultClasses;
- }
-
- function addClasses() {
- const swiper = this;
- const {
- classNames,
- params,
- rtl,
- $el,
- device,
- support
- } = swiper; // prettier-ignore
-
- const suffixes = prepareClasses(['initialized', params.direction, {
- 'pointer-events': !support.touch
- }, {
- 'free-mode': swiper.params.freeMode && params.freeMode.enabled
- }, {
- 'autoheight': params.autoHeight
- }, {
- 'rtl': rtl
- }, {
- 'grid': params.grid && params.grid.rows > 1
- }, {
- 'grid-column': params.grid && params.grid.rows > 1 && params.grid.fill === 'column'
- }, {
- 'android': device.android
- }, {
- 'ios': device.ios
- }, {
- 'css-mode': params.cssMode
- }, {
- 'centered': params.cssMode && params.centeredSlides
- }], params.containerModifierClass);
- classNames.push(...suffixes);
- $el.addClass([...classNames].join(' '));
- swiper.emitContainerClasses();
- }
-
- function removeClasses() {
- const swiper = this;
- const {
- $el,
- classNames
- } = swiper;
- $el.removeClass(classNames.join(' '));
- swiper.emitContainerClasses();
- }
-
- var classes = {
- addClasses,
- removeClasses
- };
-
- function loadImage(imageEl, src, srcset, sizes, checkForComplete, callback) {
- const window = getWindow();
- let image;
-
- function onReady() {
- if (callback) callback();
- }
-
- const isPicture = $(imageEl).parent('picture')[0];
-
- if (!isPicture && (!imageEl.complete || !checkForComplete)) {
- if (src) {
- image = new window.Image();
- image.onload = onReady;
- image.onerror = onReady;
-
- if (sizes) {
- image.sizes = sizes;
- }
-
- if (srcset) {
- image.srcset = srcset;
- }
-
- if (src) {
- image.src = src;
- }
- } else {
- onReady();
- }
- } else {
- // image already loaded...
- onReady();
- }
- }
-
- function preloadImages() {
- const swiper = this;
- swiper.imagesToLoad = swiper.$el.find('img');
-
- function onReady() {
- if (typeof swiper === 'undefined' || swiper === null || !swiper || swiper.destroyed) return;
- if (swiper.imagesLoaded !== undefined) swiper.imagesLoaded += 1;
-
- if (swiper.imagesLoaded === swiper.imagesToLoad.length) {
- if (swiper.params.updateOnImagesReady) swiper.update();
- swiper.emit('imagesReady');
- }
- }
-
- for (let i = 0; i < swiper.imagesToLoad.length; i += 1) {
- const imageEl = swiper.imagesToLoad[i];
- swiper.loadImage(imageEl, imageEl.currentSrc || imageEl.getAttribute('src'), imageEl.srcset || imageEl.getAttribute('srcset'), imageEl.sizes || imageEl.getAttribute('sizes'), true, onReady);
- }
- }
-
- var images = {
- loadImage,
- preloadImages
- };
-
- function checkOverflow() {
- const swiper = this;
- const {
- isLocked: wasLocked,
- params
- } = swiper;
- const {
- slidesOffsetBefore
- } = params;
-
- if (slidesOffsetBefore) {
- const lastSlideIndex = swiper.slides.length - 1;
- const lastSlideRightEdge = swiper.slidesGrid[lastSlideIndex] + swiper.slidesSizesGrid[lastSlideIndex] + slidesOffsetBefore * 2;
- swiper.isLocked = swiper.size > lastSlideRightEdge;
- } else {
- swiper.isLocked = swiper.snapGrid.length === 1;
- }
-
- if (params.allowSlideNext === true) {
- swiper.allowSlideNext = !swiper.isLocked;
- }
-
- if (params.allowSlidePrev === true) {
- swiper.allowSlidePrev = !swiper.isLocked;
- }
-
- if (wasLocked && wasLocked !== swiper.isLocked) {
- swiper.isEnd = false;
- }
-
- if (wasLocked !== swiper.isLocked) {
- swiper.emit(swiper.isLocked ? 'lock' : 'unlock');
- }
- }
-
- var checkOverflow$1 = {
- checkOverflow
- };
-
- var defaults = {
- init: true,
- direction: 'horizontal',
- touchEventsTarget: 'wrapper',
- initialSlide: 0,
- speed: 300,
- cssMode: false,
- updateOnWindowResize: true,
- resizeObserver: true,
- nested: false,
- createElements: false,
- enabled: true,
- focusableElements: 'input, select, option, textarea, button, video, label',
- // Overrides
- width: null,
- height: null,
- //
- preventInteractionOnTransition: false,
- // ssr
- userAgent: null,
- url: null,
- // To support iOS's swipe-to-go-back gesture (when being used in-app).
- edgeSwipeDetection: false,
- edgeSwipeThreshold: 20,
- // Autoheight
- autoHeight: false,
- // Set wrapper width
- setWrapperSize: false,
- // Virtual Translate
- virtualTranslate: false,
- // Effects
- effect: 'slide',
- // 'slide' or 'fade' or 'cube' or 'coverflow' or 'flip'
- // Breakpoints
- breakpoints: undefined,
- breakpointsBase: 'window',
- // Slides grid
- spaceBetween: 0,
- slidesPerView: 1,
- slidesPerGroup: 1,
- slidesPerGroupSkip: 0,
- slidesPerGroupAuto: false,
- centeredSlides: false,
- centeredSlidesBounds: false,
- slidesOffsetBefore: 0,
- // in px
- slidesOffsetAfter: 0,
- // in px
- normalizeSlideIndex: true,
- centerInsufficientSlides: false,
- // Disable swiper and hide navigation when container not overflow
- watchOverflow: true,
- // Round length
- roundLengths: false,
- // Touches
- touchRatio: 1,
- touchAngle: 45,
- simulateTouch: true,
- shortSwipes: true,
- longSwipes: true,
- longSwipesRatio: 0.5,
- longSwipesMs: 300,
- followFinger: true,
- allowTouchMove: true,
- threshold: 0,
- touchMoveStopPropagation: false,
- touchStartPreventDefault: true,
- touchStartForcePreventDefault: false,
- touchReleaseOnEdges: false,
- // Unique Navigation Elements
- uniqueNavElements: true,
- // Resistance
- resistance: true,
- resistanceRatio: 0.85,
- // Progress
- watchSlidesProgress: false,
- // Cursor
- grabCursor: false,
- // Clicks
- preventClicks: true,
- preventClicksPropagation: true,
- slideToClickedSlide: false,
- // Images
- preloadImages: true,
- updateOnImagesReady: true,
- // loop
- loop: false,
- loopAdditionalSlides: 0,
- loopedSlides: null,
- loopFillGroupWithBlank: false,
- loopPreventsSlide: true,
- // rewind
- rewind: false,
- // Swiping/no swiping
- allowSlidePrev: true,
- allowSlideNext: true,
- swipeHandler: null,
- // '.swipe-handler',
- noSwiping: true,
- noSwipingClass: 'swiper-no-swiping',
- noSwipingSelector: null,
- // Passive Listeners
- passiveListeners: true,
- maxBackfaceHiddenSlides: 10,
- // NS
- containerModifierClass: 'swiper-',
- // NEW
- slideClass: 'swiper-slide',
- slideBlankClass: 'swiper-slide-invisible-blank',
- slideActiveClass: 'swiper-slide-active',
- slideDuplicateActiveClass: 'swiper-slide-duplicate-active',
- slideVisibleClass: 'swiper-slide-visible',
- slideDuplicateClass: 'swiper-slide-duplicate',
- slideNextClass: 'swiper-slide-next',
- slideDuplicateNextClass: 'swiper-slide-duplicate-next',
- slidePrevClass: 'swiper-slide-prev',
- slideDuplicatePrevClass: 'swiper-slide-duplicate-prev',
- wrapperClass: 'swiper-wrapper',
- // Callbacks
- runCallbacksOnInit: true,
- // Internals
- _emitClasses: false
- };
-
- function moduleExtendParams(params, allModulesParams) {
- return function extendParams(obj) {
- if (obj === void 0) {
- obj = {};
- }
-
- const moduleParamName = Object.keys(obj)[0];
- const moduleParams = obj[moduleParamName];
-
- if (typeof moduleParams !== 'object' || moduleParams === null) {
- extend(allModulesParams, obj);
- return;
- }
-
- if (['navigation', 'pagination', 'scrollbar'].indexOf(moduleParamName) >= 0 && params[moduleParamName] === true) {
- params[moduleParamName] = {
- auto: true
- };
- }
-
- if (!(moduleParamName in params && 'enabled' in moduleParams)) {
- extend(allModulesParams, obj);
- return;
- }
-
- if (params[moduleParamName] === true) {
- params[moduleParamName] = {
- enabled: true
- };
- }
-
- if (typeof params[moduleParamName] === 'object' && !('enabled' in params[moduleParamName])) {
- params[moduleParamName].enabled = true;
- }
-
- if (!params[moduleParamName]) params[moduleParamName] = {
- enabled: false
- };
- extend(allModulesParams, obj);
- };
- }
-
- /* eslint no-param-reassign: "off" */
- const prototypes = {
- eventsEmitter,
- update,
- translate,
- transition,
- slide,
- loop,
- grabCursor,
- events: events$1,
- breakpoints,
- checkOverflow: checkOverflow$1,
- classes,
- images
- };
- const extendedDefaults = {};
-
- class Swiper {
- constructor() {
- let el;
- let params;
-
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
- args[_key] = arguments[_key];
- }
-
- if (args.length === 1 && args[0].constructor && Object.prototype.toString.call(args[0]).slice(8, -1) === 'Object') {
- params = args[0];
- } else {
- [el, params] = args;
- }
-
- if (!params) params = {};
- params = extend({}, params);
- if (el && !params.el) params.el = el;
-
- if (params.el && $(params.el).length > 1) {
- const swipers = [];
- $(params.el).each(containerEl => {
- const newParams = extend({}, params, {
- el: containerEl
- });
- swipers.push(new Swiper(newParams));
- });
- return swipers;
- } // Swiper Instance
-
-
- const swiper = this;
- swiper.__swiper__ = true;
- swiper.support = getSupport();
- swiper.device = getDevice({
- userAgent: params.userAgent
- });
- swiper.browser = getBrowser();
- swiper.eventsListeners = {};
- swiper.eventsAnyListeners = [];
- swiper.modules = [...swiper.__modules__];
-
- if (params.modules && Array.isArray(params.modules)) {
- swiper.modules.push(...params.modules);
- }
-
- const allModulesParams = {};
- swiper.modules.forEach(mod => {
- mod({
- swiper,
- extendParams: moduleExtendParams(params, allModulesParams),
- on: swiper.on.bind(swiper),
- once: swiper.once.bind(swiper),
- off: swiper.off.bind(swiper),
- emit: swiper.emit.bind(swiper)
- });
- }); // Extend defaults with modules params
-
- const swiperParams = extend({}, defaults, allModulesParams); // Extend defaults with passed params
-
- swiper.params = extend({}, swiperParams, extendedDefaults, params);
- swiper.originalParams = extend({}, swiper.params);
- swiper.passedParams = extend({}, params); // add event listeners
-
- if (swiper.params && swiper.params.on) {
- Object.keys(swiper.params.on).forEach(eventName => {
- swiper.on(eventName, swiper.params.on[eventName]);
- });
- }
-
- if (swiper.params && swiper.params.onAny) {
- swiper.onAny(swiper.params.onAny);
- } // Save Dom lib
-
-
- swiper.$ = $; // Extend Swiper
-
- Object.assign(swiper, {
- enabled: swiper.params.enabled,
- el,
- // Classes
- classNames: [],
- // Slides
- slides: $(),
- slidesGrid: [],
- snapGrid: [],
- slidesSizesGrid: [],
-
- // isDirection
- isHorizontal() {
- return swiper.params.direction === 'horizontal';
- },
-
- isVertical() {
- return swiper.params.direction === 'vertical';
- },
-
- // Indexes
- activeIndex: 0,
- realIndex: 0,
- //
- isBeginning: true,
- isEnd: false,
- // Props
- translate: 0,
- previousTranslate: 0,
- progress: 0,
- velocity: 0,
- animating: false,
- // Locks
- allowSlideNext: swiper.params.allowSlideNext,
- allowSlidePrev: swiper.params.allowSlidePrev,
- // Touch Events
- touchEvents: function touchEvents() {
- const touch = ['touchstart', 'touchmove', 'touchend', 'touchcancel'];
- const desktop = ['pointerdown', 'pointermove', 'pointerup'];
- swiper.touchEventsTouch = {
- start: touch[0],
- move: touch[1],
- end: touch[2],
- cancel: touch[3]
- };
- swiper.touchEventsDesktop = {
- start: desktop[0],
- move: desktop[1],
- end: desktop[2]
- };
- return swiper.support.touch || !swiper.params.simulateTouch ? swiper.touchEventsTouch : swiper.touchEventsDesktop;
- }(),
- touchEventsData: {
- isTouched: undefined,
- isMoved: undefined,
- allowTouchCallbacks: undefined,
- touchStartTime: undefined,
- isScrolling: undefined,
- currentTranslate: undefined,
- startTranslate: undefined,
- allowThresholdMove: undefined,
- // Form elements to match
- focusableElements: swiper.params.focusableElements,
- // Last click time
- lastClickTime: now(),
- clickTimeout: undefined,
- // Velocities
- velocities: [],
- allowMomentumBounce: undefined,
- isTouchEvent: undefined,
- startMoving: undefined
- },
- // Clicks
- allowClick: true,
- // Touches
- allowTouchMove: swiper.params.allowTouchMove,
- touches: {
- startX: 0,
- startY: 0,
- currentX: 0,
- currentY: 0,
- diff: 0
- },
- // Images
- imagesToLoad: [],
- imagesLoaded: 0
- });
- swiper.emit('_swiper'); // Init
-
- if (swiper.params.init) {
- swiper.init();
- } // Return app instance
-
-
- return swiper;
- }
-
- enable() {
- const swiper = this;
- if (swiper.enabled) return;
- swiper.enabled = true;
-
- if (swiper.params.grabCursor) {
- swiper.setGrabCursor();
- }
-
- swiper.emit('enable');
- }
-
- disable() {
- const swiper = this;
- if (!swiper.enabled) return;
- swiper.enabled = false;
-
- if (swiper.params.grabCursor) {
- swiper.unsetGrabCursor();
- }
-
- swiper.emit('disable');
- }
-
- setProgress(progress, speed) {
- const swiper = this;
- progress = Math.min(Math.max(progress, 0), 1);
- const min = swiper.minTranslate();
- const max = swiper.maxTranslate();
- const current = (max - min) * progress + min;
- swiper.translateTo(current, typeof speed === 'undefined' ? 0 : speed);
- swiper.updateActiveIndex();
- swiper.updateSlidesClasses();
- }
-
- emitContainerClasses() {
- const swiper = this;
- if (!swiper.params._emitClasses || !swiper.el) return;
- const cls = swiper.el.className.split(' ').filter(className => {
- return className.indexOf('swiper') === 0 || className.indexOf(swiper.params.containerModifierClass) === 0;
- });
- swiper.emit('_containerClasses', cls.join(' '));
- }
-
- getSlideClasses(slideEl) {
- const swiper = this;
- return slideEl.className.split(' ').filter(className => {
- return className.indexOf('swiper-slide') === 0 || className.indexOf(swiper.params.slideClass) === 0;
- }).join(' ');
- }
-
- emitSlidesClasses() {
- const swiper = this;
- if (!swiper.params._emitClasses || !swiper.el) return;
- const updates = [];
- swiper.slides.each(slideEl => {
- const classNames = swiper.getSlideClasses(slideEl);
- updates.push({
- slideEl,
- classNames
- });
- swiper.emit('_slideClass', slideEl, classNames);
- });
- swiper.emit('_slideClasses', updates);
- }
-
- slidesPerViewDynamic(view, exact) {
- if (view === void 0) {
- view = 'current';
- }
-
- if (exact === void 0) {
- exact = false;
- }
-
- const swiper = this;
- const {
- params,
- slides,
- slidesGrid,
- slidesSizesGrid,
- size: swiperSize,
- activeIndex
- } = swiper;
- let spv = 1;
-
- if (params.centeredSlides) {
- let slideSize = slides[activeIndex].swiperSlideSize;
- let breakLoop;
-
- for (let i = activeIndex + 1; i < slides.length; i += 1) {
- if (slides[i] && !breakLoop) {
- slideSize += slides[i].swiperSlideSize;
- spv += 1;
- if (slideSize > swiperSize) breakLoop = true;
- }
- }
-
- for (let i = activeIndex - 1; i >= 0; i -= 1) {
- if (slides[i] && !breakLoop) {
- slideSize += slides[i].swiperSlideSize;
- spv += 1;
- if (slideSize > swiperSize) breakLoop = true;
- }
- }
- } else {
- // eslint-disable-next-line
- if (view === 'current') {
- for (let i = activeIndex + 1; i < slides.length; i += 1) {
- const slideInView = exact ? slidesGrid[i] + slidesSizesGrid[i] - slidesGrid[activeIndex] < swiperSize : slidesGrid[i] - slidesGrid[activeIndex] < swiperSize;
-
- if (slideInView) {
- spv += 1;
- }
- }
- } else {
- // previous
- for (let i = activeIndex - 1; i >= 0; i -= 1) {
- const slideInView = slidesGrid[activeIndex] - slidesGrid[i] < swiperSize;
-
- if (slideInView) {
- spv += 1;
- }
- }
- }
- }
-
- return spv;
- }
-
- update() {
- const swiper = this;
- if (!swiper || swiper.destroyed) return;
- const {
- snapGrid,
- params
- } = swiper; // Breakpoints
-
- if (params.breakpoints) {
- swiper.setBreakpoint();
- }
-
- swiper.updateSize();
- swiper.updateSlides();
- swiper.updateProgress();
- swiper.updateSlidesClasses();
-
- function setTranslate() {
- const translateValue = swiper.rtlTranslate ? swiper.translate * -1 : swiper.translate;
- const newTranslate = Math.min(Math.max(translateValue, swiper.maxTranslate()), swiper.minTranslate());
- swiper.setTranslate(newTranslate);
- swiper.updateActiveIndex();
- swiper.updateSlidesClasses();
- }
-
- let translated;
-
- if (swiper.params.freeMode && swiper.params.freeMode.enabled) {
- setTranslate();
-
- if (swiper.params.autoHeight) {
- swiper.updateAutoHeight();
- }
- } else {
- if ((swiper.params.slidesPerView === 'auto' || swiper.params.slidesPerView > 1) && swiper.isEnd && !swiper.params.centeredSlides) {
- translated = swiper.slideTo(swiper.slides.length - 1, 0, false, true);
- } else {
- translated = swiper.slideTo(swiper.activeIndex, 0, false, true);
- }
-
- if (!translated) {
- setTranslate();
- }
- }
-
- if (params.watchOverflow && snapGrid !== swiper.snapGrid) {
- swiper.checkOverflow();
- }
-
- swiper.emit('update');
- }
-
- changeDirection(newDirection, needUpdate) {
- if (needUpdate === void 0) {
- needUpdate = true;
- }
-
- const swiper = this;
- const currentDirection = swiper.params.direction;
-
- if (!newDirection) {
- // eslint-disable-next-line
- newDirection = currentDirection === 'horizontal' ? 'vertical' : 'horizontal';
- }
-
- if (newDirection === currentDirection || newDirection !== 'horizontal' && newDirection !== 'vertical') {
- return swiper;
- }
-
- swiper.$el.removeClass(`${swiper.params.containerModifierClass}${currentDirection}`).addClass(`${swiper.params.containerModifierClass}${newDirection}`);
- swiper.emitContainerClasses();
- swiper.params.direction = newDirection;
- swiper.slides.each(slideEl => {
- if (newDirection === 'vertical') {
- slideEl.style.width = '';
- } else {
- slideEl.style.height = '';
- }
- });
- swiper.emit('changeDirection');
- if (needUpdate) swiper.update();
- return swiper;
- }
-
- mount(el) {
- const swiper = this;
- if (swiper.mounted) return true; // Find el
-
- const $el = $(el || swiper.params.el);
- el = $el[0];
-
- if (!el) {
- return false;
- }
-
- el.swiper = swiper;
-
- const getWrapperSelector = () => {
- return `.${(swiper.params.wrapperClass || '').trim().split(' ').join('.')}`;
- };
-
- const getWrapper = () => {
- if (el && el.shadowRoot && el.shadowRoot.querySelector) {
- const res = $(el.shadowRoot.querySelector(getWrapperSelector())); // Children needs to return slot items
-
- res.children = options => $el.children(options);
-
- return res;
- }
-
- return $el.children(getWrapperSelector());
- }; // Find Wrapper
-
-
- let $wrapperEl = getWrapper();
-
- if ($wrapperEl.length === 0 && swiper.params.createElements) {
- const document = getDocument();
- const wrapper = document.createElement('div');
- $wrapperEl = $(wrapper);
- wrapper.className = swiper.params.wrapperClass;
- $el.append(wrapper);
- $el.children(`.${swiper.params.slideClass}`).each(slideEl => {
- $wrapperEl.append(slideEl);
- });
- }
-
- Object.assign(swiper, {
- $el,
- el,
- $wrapperEl,
- wrapperEl: $wrapperEl[0],
- mounted: true,
- // RTL
- rtl: el.dir.toLowerCase() === 'rtl' || $el.css('direction') === 'rtl',
- rtlTranslate: swiper.params.direction === 'horizontal' && (el.dir.toLowerCase() === 'rtl' || $el.css('direction') === 'rtl'),
- wrongRTL: $wrapperEl.css('display') === '-webkit-box'
- });
- return true;
- }
-
- init(el) {
- const swiper = this;
- if (swiper.initialized) return swiper;
- const mounted = swiper.mount(el);
- if (mounted === false) return swiper;
- swiper.emit('beforeInit'); // Set breakpoint
-
- if (swiper.params.breakpoints) {
- swiper.setBreakpoint();
- } // Add Classes
-
-
- swiper.addClasses(); // Create loop
-
- if (swiper.params.loop) {
- swiper.loopCreate();
- } // Update size
-
-
- swiper.updateSize(); // Update slides
-
- swiper.updateSlides();
-
- if (swiper.params.watchOverflow) {
- swiper.checkOverflow();
- } // Set Grab Cursor
-
-
- if (swiper.params.grabCursor && swiper.enabled) {
- swiper.setGrabCursor();
- }
-
- if (swiper.params.preloadImages) {
- swiper.preloadImages();
- } // Slide To Initial Slide
-
-
- if (swiper.params.loop) {
- swiper.slideTo(swiper.params.initialSlide + swiper.loopedSlides, 0, swiper.params.runCallbacksOnInit, false, true);
- } else {
- swiper.slideTo(swiper.params.initialSlide, 0, swiper.params.runCallbacksOnInit, false, true);
- } // Attach events
-
-
- swiper.attachEvents(); // Init Flag
-
- swiper.initialized = true; // Emit
-
- swiper.emit('init');
- swiper.emit('afterInit');
- return swiper;
- }
-
- destroy(deleteInstance, cleanStyles) {
- if (deleteInstance === void 0) {
- deleteInstance = true;
- }
-
- if (cleanStyles === void 0) {
- cleanStyles = true;
- }
-
- const swiper = this;
- const {
- params,
- $el,
- $wrapperEl,
- slides
- } = swiper;
-
- if (typeof swiper.params === 'undefined' || swiper.destroyed) {
- return null;
- }
-
- swiper.emit('beforeDestroy'); // Init Flag
-
- swiper.initialized = false; // Detach events
-
- swiper.detachEvents(); // Destroy loop
-
- if (params.loop) {
- swiper.loopDestroy();
- } // Cleanup styles
-
-
- if (cleanStyles) {
- swiper.removeClasses();
- $el.removeAttr('style');
- $wrapperEl.removeAttr('style');
-
- if (slides && slides.length) {
- slides.removeClass([params.slideVisibleClass, params.slideActiveClass, params.slideNextClass, params.slidePrevClass].join(' ')).removeAttr('style').removeAttr('data-swiper-slide-index');
- }
- }
-
- swiper.emit('destroy'); // Detach emitter events
-
- Object.keys(swiper.eventsListeners).forEach(eventName => {
- swiper.off(eventName);
- });
-
- if (deleteInstance !== false) {
- swiper.$el[0].swiper = null;
- deleteProps(swiper);
- }
-
- swiper.destroyed = true;
- return null;
- }
-
- static extendDefaults(newDefaults) {
- extend(extendedDefaults, newDefaults);
- }
-
- static get extendedDefaults() {
- return extendedDefaults;
- }
-
- static get defaults() {
- return defaults;
- }
-
- static installModule(mod) {
- if (!Swiper.prototype.__modules__) Swiper.prototype.__modules__ = [];
- const modules = Swiper.prototype.__modules__;
-
- if (typeof mod === 'function' && modules.indexOf(mod) < 0) {
- modules.push(mod);
- }
- }
-
- static use(module) {
- if (Array.isArray(module)) {
- module.forEach(m => Swiper.installModule(m));
- return Swiper;
- }
-
- Swiper.installModule(module);
- return Swiper;
- }
-
- }
-
- Object.keys(prototypes).forEach(prototypeGroup => {
- Object.keys(prototypes[prototypeGroup]).forEach(protoMethod => {
- Swiper.prototype[protoMethod] = prototypes[prototypeGroup][protoMethod];
- });
- });
- Swiper.use([Resize, Observer]);
-
- function Virtual(_ref) {
- let {
- swiper,
- extendParams,
- on,
- emit
- } = _ref;
- extendParams({
- virtual: {
- enabled: false,
- slides: [],
- cache: true,
- renderSlide: null,
- renderExternal: null,
- renderExternalUpdate: true,
- addSlidesBefore: 0,
- addSlidesAfter: 0
- }
- });
- let cssModeTimeout;
- swiper.virtual = {
- cache: {},
- from: undefined,
- to: undefined,
- slides: [],
- offset: 0,
- slidesGrid: []
- };
-
- function renderSlide(slide, index) {
- const params = swiper.params.virtual;
-
- if (params.cache && swiper.virtual.cache[index]) {
- return swiper.virtual.cache[index];
- }
-
- const $slideEl = params.renderSlide ? $(params.renderSlide.call(swiper, slide, index)) : $(`${slide}
`);
- if (!$slideEl.attr('data-swiper-slide-index')) $slideEl.attr('data-swiper-slide-index', index);
- if (params.cache) swiper.virtual.cache[index] = $slideEl;
- return $slideEl;
- }
-
- function update(force) {
- const {
- slidesPerView,
- slidesPerGroup,
- centeredSlides
- } = swiper.params;
- const {
- addSlidesBefore,
- addSlidesAfter
- } = swiper.params.virtual;
- const {
- from: previousFrom,
- to: previousTo,
- slides,
- slidesGrid: previousSlidesGrid,
- offset: previousOffset
- } = swiper.virtual;
-
- if (!swiper.params.cssMode) {
- swiper.updateActiveIndex();
- }
-
- const activeIndex = swiper.activeIndex || 0;
- let offsetProp;
- if (swiper.rtlTranslate) offsetProp = 'right';else offsetProp = swiper.isHorizontal() ? 'left' : 'top';
- let slidesAfter;
- let slidesBefore;
-
- if (centeredSlides) {
- slidesAfter = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesAfter;
- slidesBefore = Math.floor(slidesPerView / 2) + slidesPerGroup + addSlidesBefore;
- } else {
- slidesAfter = slidesPerView + (slidesPerGroup - 1) + addSlidesAfter;
- slidesBefore = slidesPerGroup + addSlidesBefore;
- }
-
- const from = Math.max((activeIndex || 0) - slidesBefore, 0);
- const to = Math.min((activeIndex || 0) + slidesAfter, slides.length - 1);
- const offset = (swiper.slidesGrid[from] || 0) - (swiper.slidesGrid[0] || 0);
- Object.assign(swiper.virtual, {
- from,
- to,
- offset,
- slidesGrid: swiper.slidesGrid
- });
-
- function onRendered() {
- swiper.updateSlides();
- swiper.updateProgress();
- swiper.updateSlidesClasses();
-
- if (swiper.lazy && swiper.params.lazy.enabled) {
- swiper.lazy.load();
- }
-
- emit('virtualUpdate');
- }
-
- if (previousFrom === from && previousTo === to && !force) {
- if (swiper.slidesGrid !== previousSlidesGrid && offset !== previousOffset) {
- swiper.slides.css(offsetProp, `${offset}px`);
- }
-
- swiper.updateProgress();
- emit('virtualUpdate');
- return;
- }
-
- if (swiper.params.virtual.renderExternal) {
- swiper.params.virtual.renderExternal.call(swiper, {
- offset,
- from,
- to,
- slides: function getSlides() {
- const slidesToRender = [];
-
- for (let i = from; i <= to; i += 1) {
- slidesToRender.push(slides[i]);
- }
-
- return slidesToRender;
- }()
- });
-
- if (swiper.params.virtual.renderExternalUpdate) {
- onRendered();
- } else {
- emit('virtualUpdate');
- }
-
- return;
- }
-
- const prependIndexes = [];
- const appendIndexes = [];
-
- if (force) {
- swiper.$wrapperEl.find(`.${swiper.params.slideClass}`).remove();
- } else {
- for (let i = previousFrom; i <= previousTo; i += 1) {
- if (i < from || i > to) {
- swiper.$wrapperEl.find(`.${swiper.params.slideClass}[data-swiper-slide-index="${i}"]`).remove();
- }
- }
- }
-
- for (let i = 0; i < slides.length; i += 1) {
- if (i >= from && i <= to) {
- if (typeof previousTo === 'undefined' || force) {
- appendIndexes.push(i);
- } else {
- if (i > previousTo) appendIndexes.push(i);
- if (i < previousFrom) prependIndexes.push(i);
- }
- }
- }
-
- appendIndexes.forEach(index => {
- swiper.$wrapperEl.append(renderSlide(slides[index], index));
- });
- prependIndexes.sort((a, b) => b - a).forEach(index => {
- swiper.$wrapperEl.prepend(renderSlide(slides[index], index));
- });
- swiper.$wrapperEl.children('.swiper-slide').css(offsetProp, `${offset}px`);
- onRendered();
- }
-
- function appendSlide(slides) {
- if (typeof slides === 'object' && 'length' in slides) {
- for (let i = 0; i < slides.length; i += 1) {
- if (slides[i]) swiper.virtual.slides.push(slides[i]);
- }
- } else {
- swiper.virtual.slides.push(slides);
- }
-
- update(true);
- }
-
- function prependSlide(slides) {
- const activeIndex = swiper.activeIndex;
- let newActiveIndex = activeIndex + 1;
- let numberOfNewSlides = 1;
-
- if (Array.isArray(slides)) {
- for (let i = 0; i < slides.length; i += 1) {
- if (slides[i]) swiper.virtual.slides.unshift(slides[i]);
- }
-
- newActiveIndex = activeIndex + slides.length;
- numberOfNewSlides = slides.length;
- } else {
- swiper.virtual.slides.unshift(slides);
- }
-
- if (swiper.params.virtual.cache) {
- const cache = swiper.virtual.cache;
- const newCache = {};
- Object.keys(cache).forEach(cachedIndex => {
- const $cachedEl = cache[cachedIndex];
- const cachedElIndex = $cachedEl.attr('data-swiper-slide-index');
-
- if (cachedElIndex) {
- $cachedEl.attr('data-swiper-slide-index', parseInt(cachedElIndex, 10) + numberOfNewSlides);
- }
-
- newCache[parseInt(cachedIndex, 10) + numberOfNewSlides] = $cachedEl;
- });
- swiper.virtual.cache = newCache;
- }
-
- update(true);
- swiper.slideTo(newActiveIndex, 0);
- }
-
- function removeSlide(slidesIndexes) {
- if (typeof slidesIndexes === 'undefined' || slidesIndexes === null) return;
- let activeIndex = swiper.activeIndex;
-
- if (Array.isArray(slidesIndexes)) {
- for (let i = slidesIndexes.length - 1; i >= 0; i -= 1) {
- swiper.virtual.slides.splice(slidesIndexes[i], 1);
-
- if (swiper.params.virtual.cache) {
- delete swiper.virtual.cache[slidesIndexes[i]];
- }
-
- if (slidesIndexes[i] < activeIndex) activeIndex -= 1;
- activeIndex = Math.max(activeIndex, 0);
- }
- } else {
- swiper.virtual.slides.splice(slidesIndexes, 1);
-
- if (swiper.params.virtual.cache) {
- delete swiper.virtual.cache[slidesIndexes];
- }
-
- if (slidesIndexes < activeIndex) activeIndex -= 1;
- activeIndex = Math.max(activeIndex, 0);
- }
-
- update(true);
- swiper.slideTo(activeIndex, 0);
- }
-
- function removeAllSlides() {
- swiper.virtual.slides = [];
-
- if (swiper.params.virtual.cache) {
- swiper.virtual.cache = {};
- }
-
- update(true);
- swiper.slideTo(0, 0);
- }
-
- on('beforeInit', () => {
- if (!swiper.params.virtual.enabled) return;
- swiper.virtual.slides = swiper.params.virtual.slides;
- swiper.classNames.push(`${swiper.params.containerModifierClass}virtual`);
- swiper.params.watchSlidesProgress = true;
- swiper.originalParams.watchSlidesProgress = true;
-
- if (!swiper.params.initialSlide) {
- update();
- }
- });
- on('setTranslate', () => {
- if (!swiper.params.virtual.enabled) return;
-
- if (swiper.params.cssMode && !swiper._immediateVirtual) {
- clearTimeout(cssModeTimeout);
- cssModeTimeout = setTimeout(() => {
- update();
- }, 100);
- } else {
- update();
- }
- });
- on('init update resize', () => {
- if (!swiper.params.virtual.enabled) return;
-
- if (swiper.params.cssMode) {
- setCSSProperty(swiper.wrapperEl, '--swiper-virtual-size', `${swiper.virtualSize}px`);
- }
- });
- Object.assign(swiper.virtual, {
- appendSlide,
- prependSlide,
- removeSlide,
- removeAllSlides,
- update
- });
- }
-
- /* eslint-disable consistent-return */
- function Keyboard(_ref) {
- let {
- swiper,
- extendParams,
- on,
- emit
- } = _ref;
- const document = getDocument();
- const window = getWindow();
- swiper.keyboard = {
- enabled: false
- };
- extendParams({
- keyboard: {
- enabled: false,
- onlyInViewport: true,
- pageUpDown: true
- }
- });
-
- function handle(event) {
- if (!swiper.enabled) return;
- const {
- rtlTranslate: rtl
- } = swiper;
- let e = event;
- if (e.originalEvent) e = e.originalEvent; // jquery fix
-
- const kc = e.keyCode || e.charCode;
- const pageUpDown = swiper.params.keyboard.pageUpDown;
- const isPageUp = pageUpDown && kc === 33;
- const isPageDown = pageUpDown && kc === 34;
- const isArrowLeft = kc === 37;
- const isArrowRight = kc === 39;
- const isArrowUp = kc === 38;
- const isArrowDown = kc === 40; // Directions locks
-
- if (!swiper.allowSlideNext && (swiper.isHorizontal() && isArrowRight || swiper.isVertical() && isArrowDown || isPageDown)) {
- return false;
- }
-
- if (!swiper.allowSlidePrev && (swiper.isHorizontal() && isArrowLeft || swiper.isVertical() && isArrowUp || isPageUp)) {
- return false;
- }
-
- if (e.shiftKey || e.altKey || e.ctrlKey || e.metaKey) {
- return undefined;
- }
-
- if (document.activeElement && document.activeElement.nodeName && (document.activeElement.nodeName.toLowerCase() === 'input' || document.activeElement.nodeName.toLowerCase() === 'textarea')) {
- return undefined;
- }
-
- if (swiper.params.keyboard.onlyInViewport && (isPageUp || isPageDown || isArrowLeft || isArrowRight || isArrowUp || isArrowDown)) {
- let inView = false; // Check that swiper should be inside of visible area of window
-
- if (swiper.$el.parents(`.${swiper.params.slideClass}`).length > 0 && swiper.$el.parents(`.${swiper.params.slideActiveClass}`).length === 0) {
- return undefined;
- }
-
- const $el = swiper.$el;
- const swiperWidth = $el[0].clientWidth;
- const swiperHeight = $el[0].clientHeight;
- const windowWidth = window.innerWidth;
- const windowHeight = window.innerHeight;
- const swiperOffset = swiper.$el.offset();
- if (rtl) swiperOffset.left -= swiper.$el[0].scrollLeft;
- const swiperCoord = [[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiperWidth, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiperHeight], [swiperOffset.left + swiperWidth, swiperOffset.top + swiperHeight]];
-
- for (let i = 0; i < swiperCoord.length; i += 1) {
- const point = swiperCoord[i];
-
- if (point[0] >= 0 && point[0] <= windowWidth && point[1] >= 0 && point[1] <= windowHeight) {
- if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line
-
- inView = true;
- }
- }
-
- if (!inView) return undefined;
- }
-
- if (swiper.isHorizontal()) {
- if (isPageUp || isPageDown || isArrowLeft || isArrowRight) {
- if (e.preventDefault) e.preventDefault();else e.returnValue = false;
- }
-
- if ((isPageDown || isArrowRight) && !rtl || (isPageUp || isArrowLeft) && rtl) swiper.slideNext();
- if ((isPageUp || isArrowLeft) && !rtl || (isPageDown || isArrowRight) && rtl) swiper.slidePrev();
- } else {
- if (isPageUp || isPageDown || isArrowUp || isArrowDown) {
- if (e.preventDefault) e.preventDefault();else e.returnValue = false;
- }
-
- if (isPageDown || isArrowDown) swiper.slideNext();
- if (isPageUp || isArrowUp) swiper.slidePrev();
- }
-
- emit('keyPress', kc);
- return undefined;
- }
-
- function enable() {
- if (swiper.keyboard.enabled) return;
- $(document).on('keydown', handle);
- swiper.keyboard.enabled = true;
- }
-
- function disable() {
- if (!swiper.keyboard.enabled) return;
- $(document).off('keydown', handle);
- swiper.keyboard.enabled = false;
- }
-
- on('init', () => {
- if (swiper.params.keyboard.enabled) {
- enable();
- }
- });
- on('destroy', () => {
- if (swiper.keyboard.enabled) {
- disable();
- }
- });
- Object.assign(swiper.keyboard, {
- enable,
- disable
- });
- }
-
- /* eslint-disable consistent-return */
- function Mousewheel(_ref) {
- let {
- swiper,
- extendParams,
- on,
- emit
- } = _ref;
- const window = getWindow();
- extendParams({
- mousewheel: {
- enabled: false,
- releaseOnEdges: false,
- invert: false,
- forceToAxis: false,
- sensitivity: 1,
- eventsTarget: 'container',
- thresholdDelta: null,
- thresholdTime: null
- }
- });
- swiper.mousewheel = {
- enabled: false
- };
- let timeout;
- let lastScrollTime = now();
- let lastEventBeforeSnap;
- const recentWheelEvents = [];
-
- function normalize(e) {
- // Reasonable defaults
- const PIXEL_STEP = 10;
- const LINE_HEIGHT = 40;
- const PAGE_HEIGHT = 800;
- let sX = 0;
- let sY = 0; // spinX, spinY
-
- let pX = 0;
- let pY = 0; // pixelX, pixelY
- // Legacy
-
- if ('detail' in e) {
- sY = e.detail;
- }
-
- if ('wheelDelta' in e) {
- sY = -e.wheelDelta / 120;
- }
-
- if ('wheelDeltaY' in e) {
- sY = -e.wheelDeltaY / 120;
- }
-
- if ('wheelDeltaX' in e) {
- sX = -e.wheelDeltaX / 120;
- } // side scrolling on FF with DOMMouseScroll
-
-
- if ('axis' in e && e.axis === e.HORIZONTAL_AXIS) {
- sX = sY;
- sY = 0;
- }
-
- pX = sX * PIXEL_STEP;
- pY = sY * PIXEL_STEP;
-
- if ('deltaY' in e) {
- pY = e.deltaY;
- }
-
- if ('deltaX' in e) {
- pX = e.deltaX;
- }
-
- if (e.shiftKey && !pX) {
- // if user scrolls with shift he wants horizontal scroll
- pX = pY;
- pY = 0;
- }
-
- if ((pX || pY) && e.deltaMode) {
- if (e.deltaMode === 1) {
- // delta in LINE units
- pX *= LINE_HEIGHT;
- pY *= LINE_HEIGHT;
- } else {
- // delta in PAGE units
- pX *= PAGE_HEIGHT;
- pY *= PAGE_HEIGHT;
- }
- } // Fall-back if spin cannot be determined
-
-
- if (pX && !sX) {
- sX = pX < 1 ? -1 : 1;
- }
-
- if (pY && !sY) {
- sY = pY < 1 ? -1 : 1;
- }
-
- return {
- spinX: sX,
- spinY: sY,
- pixelX: pX,
- pixelY: pY
- };
- }
-
- function handleMouseEnter() {
- if (!swiper.enabled) return;
- swiper.mouseEntered = true;
- }
-
- function handleMouseLeave() {
- if (!swiper.enabled) return;
- swiper.mouseEntered = false;
- }
-
- function animateSlider(newEvent) {
- if (swiper.params.mousewheel.thresholdDelta && newEvent.delta < swiper.params.mousewheel.thresholdDelta) {
- // Prevent if delta of wheel scroll delta is below configured threshold
- return false;
- }
-
- if (swiper.params.mousewheel.thresholdTime && now() - lastScrollTime < swiper.params.mousewheel.thresholdTime) {
- // Prevent if time between scrolls is below configured threshold
- return false;
- } // If the movement is NOT big enough and
- // if the last time the user scrolled was too close to the current one (avoid continuously triggering the slider):
- // Don't go any further (avoid insignificant scroll movement).
-
-
- if (newEvent.delta >= 6 && now() - lastScrollTime < 60) {
- // Return false as a default
- return true;
- } // If user is scrolling towards the end:
- // If the slider hasn't hit the latest slide or
- // if the slider is a loop and
- // if the slider isn't moving right now:
- // Go to next slide and
- // emit a scroll event.
- // Else (the user is scrolling towards the beginning) and
- // if the slider hasn't hit the first slide or
- // if the slider is a loop and
- // if the slider isn't moving right now:
- // Go to prev slide and
- // emit a scroll event.
-
-
- if (newEvent.direction < 0) {
- if ((!swiper.isEnd || swiper.params.loop) && !swiper.animating) {
- swiper.slideNext();
- emit('scroll', newEvent.raw);
- }
- } else if ((!swiper.isBeginning || swiper.params.loop) && !swiper.animating) {
- swiper.slidePrev();
- emit('scroll', newEvent.raw);
- } // If you got here is because an animation has been triggered so store the current time
-
-
- lastScrollTime = new window.Date().getTime(); // Return false as a default
-
- return false;
- }
-
- function releaseScroll(newEvent) {
- const params = swiper.params.mousewheel;
-
- if (newEvent.direction < 0) {
- if (swiper.isEnd && !swiper.params.loop && params.releaseOnEdges) {
- // Return true to animate scroll on edges
- return true;
- }
- } else if (swiper.isBeginning && !swiper.params.loop && params.releaseOnEdges) {
- // Return true to animate scroll on edges
- return true;
- }
-
- return false;
- }
-
- function handle(event) {
- let e = event;
- let disableParentSwiper = true;
- if (!swiper.enabled) return;
- const params = swiper.params.mousewheel;
-
- if (swiper.params.cssMode) {
- e.preventDefault();
- }
-
- let target = swiper.$el;
-
- if (swiper.params.mousewheel.eventsTarget !== 'container') {
- target = $(swiper.params.mousewheel.eventsTarget);
- }
-
- if (!swiper.mouseEntered && !target[0].contains(e.target) && !params.releaseOnEdges) return true;
- if (e.originalEvent) e = e.originalEvent; // jquery fix
-
- let delta = 0;
- const rtlFactor = swiper.rtlTranslate ? -1 : 1;
- const data = normalize(e);
-
- if (params.forceToAxis) {
- if (swiper.isHorizontal()) {
- if (Math.abs(data.pixelX) > Math.abs(data.pixelY)) delta = -data.pixelX * rtlFactor;else return true;
- } else if (Math.abs(data.pixelY) > Math.abs(data.pixelX)) delta = -data.pixelY;else return true;
- } else {
- delta = Math.abs(data.pixelX) > Math.abs(data.pixelY) ? -data.pixelX * rtlFactor : -data.pixelY;
- }
-
- if (delta === 0) return true;
- if (params.invert) delta = -delta; // Get the scroll positions
-
- let positions = swiper.getTranslate() + delta * params.sensitivity;
- if (positions >= swiper.minTranslate()) positions = swiper.minTranslate();
- if (positions <= swiper.maxTranslate()) positions = swiper.maxTranslate(); // When loop is true:
- // the disableParentSwiper will be true.
- // When loop is false:
- // if the scroll positions is not on edge,
- // then the disableParentSwiper will be true.
- // if the scroll on edge positions,
- // then the disableParentSwiper will be false.
-
- disableParentSwiper = swiper.params.loop ? true : !(positions === swiper.minTranslate() || positions === swiper.maxTranslate());
- if (disableParentSwiper && swiper.params.nested) e.stopPropagation();
-
- if (!swiper.params.freeMode || !swiper.params.freeMode.enabled) {
- // Register the new event in a variable which stores the relevant data
- const newEvent = {
- time: now(),
- delta: Math.abs(delta),
- direction: Math.sign(delta),
- raw: event
- }; // Keep the most recent events
-
- if (recentWheelEvents.length >= 2) {
- recentWheelEvents.shift(); // only store the last N events
- }
-
- const prevEvent = recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1] : undefined;
- recentWheelEvents.push(newEvent); // If there is at least one previous recorded event:
- // If direction has changed or
- // if the scroll is quicker than the previous one:
- // Animate the slider.
- // Else (this is the first time the wheel is moved):
- // Animate the slider.
-
- if (prevEvent) {
- if (newEvent.direction !== prevEvent.direction || newEvent.delta > prevEvent.delta || newEvent.time > prevEvent.time + 150) {
- animateSlider(newEvent);
- }
- } else {
- animateSlider(newEvent);
- } // If it's time to release the scroll:
- // Return now so you don't hit the preventDefault.
-
-
- if (releaseScroll(newEvent)) {
- return true;
- }
- } else {
- // Freemode or scrollContainer:
- // If we recently snapped after a momentum scroll, then ignore wheel events
- // to give time for the deceleration to finish. Stop ignoring after 500 msecs
- // or if it's a new scroll (larger delta or inverse sign as last event before
- // an end-of-momentum snap).
- const newEvent = {
- time: now(),
- delta: Math.abs(delta),
- direction: Math.sign(delta)
- };
- const ignoreWheelEvents = lastEventBeforeSnap && newEvent.time < lastEventBeforeSnap.time + 500 && newEvent.delta <= lastEventBeforeSnap.delta && newEvent.direction === lastEventBeforeSnap.direction;
-
- if (!ignoreWheelEvents) {
- lastEventBeforeSnap = undefined;
-
- if (swiper.params.loop) {
- swiper.loopFix();
- }
-
- let position = swiper.getTranslate() + delta * params.sensitivity;
- const wasBeginning = swiper.isBeginning;
- const wasEnd = swiper.isEnd;
- if (position >= swiper.minTranslate()) position = swiper.minTranslate();
- if (position <= swiper.maxTranslate()) position = swiper.maxTranslate();
- swiper.setTransition(0);
- swiper.setTranslate(position);
- swiper.updateProgress();
- swiper.updateActiveIndex();
- swiper.updateSlidesClasses();
-
- if (!wasBeginning && swiper.isBeginning || !wasEnd && swiper.isEnd) {
- swiper.updateSlidesClasses();
- }
-
- if (swiper.params.freeMode.sticky) {
- // When wheel scrolling starts with sticky (aka snap) enabled, then detect
- // the end of a momentum scroll by storing recent (N=15?) wheel events.
- // 1. do all N events have decreasing or same (absolute value) delta?
- // 2. did all N events arrive in the last M (M=500?) msecs?
- // 3. does the earliest event have an (absolute value) delta that's
- // at least P (P=1?) larger than the most recent event's delta?
- // 4. does the latest event have a delta that's smaller than Q (Q=6?) pixels?
- // If 1-4 are "yes" then we're near the end of a momentum scroll deceleration.
- // Snap immediately and ignore remaining wheel events in this scroll.
- // See comment above for "remaining wheel events in this scroll" determination.
- // If 1-4 aren't satisfied, then wait to snap until 500ms after the last event.
- clearTimeout(timeout);
- timeout = undefined;
-
- if (recentWheelEvents.length >= 15) {
- recentWheelEvents.shift(); // only store the last N events
- }
-
- const prevEvent = recentWheelEvents.length ? recentWheelEvents[recentWheelEvents.length - 1] : undefined;
- const firstEvent = recentWheelEvents[0];
- recentWheelEvents.push(newEvent);
-
- if (prevEvent && (newEvent.delta > prevEvent.delta || newEvent.direction !== prevEvent.direction)) {
- // Increasing or reverse-sign delta means the user started scrolling again. Clear the wheel event log.
- recentWheelEvents.splice(0);
- } else if (recentWheelEvents.length >= 15 && newEvent.time - firstEvent.time < 500 && firstEvent.delta - newEvent.delta >= 1 && newEvent.delta <= 6) {
- // We're at the end of the deceleration of a momentum scroll, so there's no need
- // to wait for more events. Snap ASAP on the next tick.
- // Also, because there's some remaining momentum we'll bias the snap in the
- // direction of the ongoing scroll because it's better UX for the scroll to snap
- // in the same direction as the scroll instead of reversing to snap. Therefore,
- // if it's already scrolled more than 20% in the current direction, keep going.
- const snapToThreshold = delta > 0 ? 0.8 : 0.2;
- lastEventBeforeSnap = newEvent;
- recentWheelEvents.splice(0);
- timeout = nextTick(() => {
- swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);
- }, 0); // no delay; move on next tick
- }
-
- if (!timeout) {
- // if we get here, then we haven't detected the end of a momentum scroll, so
- // we'll consider a scroll "complete" when there haven't been any wheel events
- // for 500ms.
- timeout = nextTick(() => {
- const snapToThreshold = 0.5;
- lastEventBeforeSnap = newEvent;
- recentWheelEvents.splice(0);
- swiper.slideToClosest(swiper.params.speed, true, undefined, snapToThreshold);
- }, 500);
- }
- } // Emit event
-
-
- if (!ignoreWheelEvents) emit('scroll', e); // Stop autoplay
-
- if (swiper.params.autoplay && swiper.params.autoplayDisableOnInteraction) swiper.autoplay.stop(); // Return page scroll on edge positions
-
- if (position === swiper.minTranslate() || position === swiper.maxTranslate()) return true;
- }
- }
-
- if (e.preventDefault) e.preventDefault();else e.returnValue = false;
- return false;
- }
-
- function events(method) {
- let target = swiper.$el;
-
- if (swiper.params.mousewheel.eventsTarget !== 'container') {
- target = $(swiper.params.mousewheel.eventsTarget);
- }
-
- target[method]('mouseenter', handleMouseEnter);
- target[method]('mouseleave', handleMouseLeave);
- target[method]('wheel', handle);
- }
-
- function enable() {
- if (swiper.params.cssMode) {
- swiper.wrapperEl.removeEventListener('wheel', handle);
- return true;
- }
-
- if (swiper.mousewheel.enabled) return false;
- events('on');
- swiper.mousewheel.enabled = true;
- return true;
- }
-
- function disable() {
- if (swiper.params.cssMode) {
- swiper.wrapperEl.addEventListener(event, handle);
- return true;
- }
-
- if (!swiper.mousewheel.enabled) return false;
- events('off');
- swiper.mousewheel.enabled = false;
- return true;
- }
-
- on('init', () => {
- if (!swiper.params.mousewheel.enabled && swiper.params.cssMode) {
- disable();
- }
-
- if (swiper.params.mousewheel.enabled) enable();
- });
- on('destroy', () => {
- if (swiper.params.cssMode) {
- enable();
- }
-
- if (swiper.mousewheel.enabled) disable();
- });
- Object.assign(swiper.mousewheel, {
- enable,
- disable
- });
- }
-
- function createElementIfNotDefined(swiper, originalParams, params, checkProps) {
- const document = getDocument();
-
- if (swiper.params.createElements) {
- Object.keys(checkProps).forEach(key => {
- if (!params[key] && params.auto === true) {
- let element = swiper.$el.children(`.${checkProps[key]}`)[0];
-
- if (!element) {
- element = document.createElement('div');
- element.className = checkProps[key];
- swiper.$el.append(element);
- }
-
- params[key] = element;
- originalParams[key] = element;
- }
- });
- }
-
- return params;
- }
-
- function Navigation(_ref) {
- let {
- swiper,
- extendParams,
- on,
- emit
- } = _ref;
- extendParams({
- navigation: {
- nextEl: null,
- prevEl: null,
- hideOnClick: false,
- disabledClass: 'swiper-button-disabled',
- hiddenClass: 'swiper-button-hidden',
- lockClass: 'swiper-button-lock'
- }
- });
- swiper.navigation = {
- nextEl: null,
- $nextEl: null,
- prevEl: null,
- $prevEl: null
- };
-
- function getEl(el) {
- let $el;
-
- if (el) {
- $el = $(el);
-
- if (swiper.params.uniqueNavElements && typeof el === 'string' && $el.length > 1 && swiper.$el.find(el).length === 1) {
- $el = swiper.$el.find(el);
- }
- }
-
- return $el;
- }
-
- function toggleEl($el, disabled) {
- const params = swiper.params.navigation;
-
- if ($el && $el.length > 0) {
- $el[disabled ? 'addClass' : 'removeClass'](params.disabledClass);
- if ($el[0] && $el[0].tagName === 'BUTTON') $el[0].disabled = disabled;
-
- if (swiper.params.watchOverflow && swiper.enabled) {
- $el[swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);
- }
- }
- }
-
- function update() {
- // Update Navigation Buttons
- if (swiper.params.loop) return;
- const {
- $nextEl,
- $prevEl
- } = swiper.navigation;
- toggleEl($prevEl, swiper.isBeginning && !swiper.params.rewind);
- toggleEl($nextEl, swiper.isEnd && !swiper.params.rewind);
- }
-
- function onPrevClick(e) {
- e.preventDefault();
- if (swiper.isBeginning && !swiper.params.loop && !swiper.params.rewind) return;
- swiper.slidePrev();
- }
-
- function onNextClick(e) {
- e.preventDefault();
- if (swiper.isEnd && !swiper.params.loop && !swiper.params.rewind) return;
- swiper.slideNext();
- }
-
- function init() {
- const params = swiper.params.navigation;
- swiper.params.navigation = createElementIfNotDefined(swiper, swiper.originalParams.navigation, swiper.params.navigation, {
- nextEl: 'swiper-button-next',
- prevEl: 'swiper-button-prev'
- });
- if (!(params.nextEl || params.prevEl)) return;
- const $nextEl = getEl(params.nextEl);
- const $prevEl = getEl(params.prevEl);
-
- if ($nextEl && $nextEl.length > 0) {
- $nextEl.on('click', onNextClick);
- }
-
- if ($prevEl && $prevEl.length > 0) {
- $prevEl.on('click', onPrevClick);
- }
-
- Object.assign(swiper.navigation, {
- $nextEl,
- nextEl: $nextEl && $nextEl[0],
- $prevEl,
- prevEl: $prevEl && $prevEl[0]
- });
-
- if (!swiper.enabled) {
- if ($nextEl) $nextEl.addClass(params.lockClass);
- if ($prevEl) $prevEl.addClass(params.lockClass);
- }
- }
-
- function destroy() {
- const {
- $nextEl,
- $prevEl
- } = swiper.navigation;
-
- if ($nextEl && $nextEl.length) {
- $nextEl.off('click', onNextClick);
- $nextEl.removeClass(swiper.params.navigation.disabledClass);
- }
-
- if ($prevEl && $prevEl.length) {
- $prevEl.off('click', onPrevClick);
- $prevEl.removeClass(swiper.params.navigation.disabledClass);
- }
- }
-
- on('init', () => {
- init();
- update();
- });
- on('toEdge fromEdge lock unlock', () => {
- update();
- });
- on('destroy', () => {
- destroy();
- });
- on('enable disable', () => {
- const {
- $nextEl,
- $prevEl
- } = swiper.navigation;
-
- if ($nextEl) {
- $nextEl[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.navigation.lockClass);
- }
-
- if ($prevEl) {
- $prevEl[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.navigation.lockClass);
- }
- });
- on('click', (_s, e) => {
- const {
- $nextEl,
- $prevEl
- } = swiper.navigation;
- const targetEl = e.target;
-
- if (swiper.params.navigation.hideOnClick && !$(targetEl).is($prevEl) && !$(targetEl).is($nextEl)) {
- if (swiper.pagination && swiper.params.pagination && swiper.params.pagination.clickable && (swiper.pagination.el === targetEl || swiper.pagination.el.contains(targetEl))) return;
- let isHidden;
-
- if ($nextEl) {
- isHidden = $nextEl.hasClass(swiper.params.navigation.hiddenClass);
- } else if ($prevEl) {
- isHidden = $prevEl.hasClass(swiper.params.navigation.hiddenClass);
- }
-
- if (isHidden === true) {
- emit('navigationShow');
- } else {
- emit('navigationHide');
- }
-
- if ($nextEl) {
- $nextEl.toggleClass(swiper.params.navigation.hiddenClass);
- }
-
- if ($prevEl) {
- $prevEl.toggleClass(swiper.params.navigation.hiddenClass);
- }
- }
- });
- Object.assign(swiper.navigation, {
- update,
- init,
- destroy
- });
- }
-
- function classesToSelector(classes) {
- if (classes === void 0) {
- classes = '';
- }
-
- return `.${classes.trim().replace(/([\.:!\/])/g, '\\$1') // eslint-disable-line
- .replace(/ /g, '.')}`;
- }
-
- function Pagination(_ref) {
- let {
- swiper,
- extendParams,
- on,
- emit
- } = _ref;
- const pfx = 'swiper-pagination';
- extendParams({
- pagination: {
- el: null,
- bulletElement: 'span',
- clickable: false,
- hideOnClick: false,
- renderBullet: null,
- renderProgressbar: null,
- renderFraction: null,
- renderCustom: null,
- progressbarOpposite: false,
- type: 'bullets',
- // 'bullets' or 'progressbar' or 'fraction' or 'custom'
- dynamicBullets: false,
- dynamicMainBullets: 1,
- formatFractionCurrent: number => number,
- formatFractionTotal: number => number,
- bulletClass: `${pfx}-bullet`,
- bulletActiveClass: `${pfx}-bullet-active`,
- modifierClass: `${pfx}-`,
- currentClass: `${pfx}-current`,
- totalClass: `${pfx}-total`,
- hiddenClass: `${pfx}-hidden`,
- progressbarFillClass: `${pfx}-progressbar-fill`,
- progressbarOppositeClass: `${pfx}-progressbar-opposite`,
- clickableClass: `${pfx}-clickable`,
- lockClass: `${pfx}-lock`,
- horizontalClass: `${pfx}-horizontal`,
- verticalClass: `${pfx}-vertical`
- }
- });
- swiper.pagination = {
- el: null,
- $el: null,
- bullets: []
- };
- let bulletSize;
- let dynamicBulletIndex = 0;
-
- function isPaginationDisabled() {
- return !swiper.params.pagination.el || !swiper.pagination.el || !swiper.pagination.$el || swiper.pagination.$el.length === 0;
- }
-
- function setSideBullets($bulletEl, position) {
- const {
- bulletActiveClass
- } = swiper.params.pagination;
- $bulletEl[position]().addClass(`${bulletActiveClass}-${position}`)[position]().addClass(`${bulletActiveClass}-${position}-${position}`);
- }
-
- function update() {
- // Render || Update Pagination bullets/items
- const rtl = swiper.rtl;
- const params = swiper.params.pagination;
- if (isPaginationDisabled()) return;
- const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;
- const $el = swiper.pagination.$el; // Current/Total
-
- let current;
- const total = swiper.params.loop ? Math.ceil((slidesLength - swiper.loopedSlides * 2) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;
-
- if (swiper.params.loop) {
- current = Math.ceil((swiper.activeIndex - swiper.loopedSlides) / swiper.params.slidesPerGroup);
-
- if (current > slidesLength - 1 - swiper.loopedSlides * 2) {
- current -= slidesLength - swiper.loopedSlides * 2;
- }
-
- if (current > total - 1) current -= total;
- if (current < 0 && swiper.params.paginationType !== 'bullets') current = total + current;
- } else if (typeof swiper.snapIndex !== 'undefined') {
- current = swiper.snapIndex;
- } else {
- current = swiper.activeIndex || 0;
- } // Types
-
-
- if (params.type === 'bullets' && swiper.pagination.bullets && swiper.pagination.bullets.length > 0) {
- const bullets = swiper.pagination.bullets;
- let firstIndex;
- let lastIndex;
- let midIndex;
-
- if (params.dynamicBullets) {
- bulletSize = bullets.eq(0)[swiper.isHorizontal() ? 'outerWidth' : 'outerHeight'](true);
- $el.css(swiper.isHorizontal() ? 'width' : 'height', `${bulletSize * (params.dynamicMainBullets + 4)}px`);
-
- if (params.dynamicMainBullets > 1 && swiper.previousIndex !== undefined) {
- dynamicBulletIndex += current - (swiper.previousIndex - swiper.loopedSlides || 0);
-
- if (dynamicBulletIndex > params.dynamicMainBullets - 1) {
- dynamicBulletIndex = params.dynamicMainBullets - 1;
- } else if (dynamicBulletIndex < 0) {
- dynamicBulletIndex = 0;
- }
- }
-
- firstIndex = Math.max(current - dynamicBulletIndex, 0);
- lastIndex = firstIndex + (Math.min(bullets.length, params.dynamicMainBullets) - 1);
- midIndex = (lastIndex + firstIndex) / 2;
- }
-
- bullets.removeClass(['', '-next', '-next-next', '-prev', '-prev-prev', '-main'].map(suffix => `${params.bulletActiveClass}${suffix}`).join(' '));
-
- if ($el.length > 1) {
- bullets.each(bullet => {
- const $bullet = $(bullet);
- const bulletIndex = $bullet.index();
-
- if (bulletIndex === current) {
- $bullet.addClass(params.bulletActiveClass);
- }
-
- if (params.dynamicBullets) {
- if (bulletIndex >= firstIndex && bulletIndex <= lastIndex) {
- $bullet.addClass(`${params.bulletActiveClass}-main`);
- }
-
- if (bulletIndex === firstIndex) {
- setSideBullets($bullet, 'prev');
- }
-
- if (bulletIndex === lastIndex) {
- setSideBullets($bullet, 'next');
- }
- }
- });
- } else {
- const $bullet = bullets.eq(current);
- const bulletIndex = $bullet.index();
- $bullet.addClass(params.bulletActiveClass);
-
- if (params.dynamicBullets) {
- const $firstDisplayedBullet = bullets.eq(firstIndex);
- const $lastDisplayedBullet = bullets.eq(lastIndex);
-
- for (let i = firstIndex; i <= lastIndex; i += 1) {
- bullets.eq(i).addClass(`${params.bulletActiveClass}-main`);
- }
-
- if (swiper.params.loop) {
- if (bulletIndex >= bullets.length) {
- for (let i = params.dynamicMainBullets; i >= 0; i -= 1) {
- bullets.eq(bullets.length - i).addClass(`${params.bulletActiveClass}-main`);
- }
-
- bullets.eq(bullets.length - params.dynamicMainBullets - 1).addClass(`${params.bulletActiveClass}-prev`);
- } else {
- setSideBullets($firstDisplayedBullet, 'prev');
- setSideBullets($lastDisplayedBullet, 'next');
- }
- } else {
- setSideBullets($firstDisplayedBullet, 'prev');
- setSideBullets($lastDisplayedBullet, 'next');
- }
- }
- }
-
- if (params.dynamicBullets) {
- const dynamicBulletsLength = Math.min(bullets.length, params.dynamicMainBullets + 4);
- const bulletsOffset = (bulletSize * dynamicBulletsLength - bulletSize) / 2 - midIndex * bulletSize;
- const offsetProp = rtl ? 'right' : 'left';
- bullets.css(swiper.isHorizontal() ? offsetProp : 'top', `${bulletsOffset}px`);
- }
- }
-
- if (params.type === 'fraction') {
- $el.find(classesToSelector(params.currentClass)).text(params.formatFractionCurrent(current + 1));
- $el.find(classesToSelector(params.totalClass)).text(params.formatFractionTotal(total));
- }
-
- if (params.type === 'progressbar') {
- let progressbarDirection;
-
- if (params.progressbarOpposite) {
- progressbarDirection = swiper.isHorizontal() ? 'vertical' : 'horizontal';
- } else {
- progressbarDirection = swiper.isHorizontal() ? 'horizontal' : 'vertical';
- }
-
- const scale = (current + 1) / total;
- let scaleX = 1;
- let scaleY = 1;
-
- if (progressbarDirection === 'horizontal') {
- scaleX = scale;
- } else {
- scaleY = scale;
- }
-
- $el.find(classesToSelector(params.progressbarFillClass)).transform(`translate3d(0,0,0) scaleX(${scaleX}) scaleY(${scaleY})`).transition(swiper.params.speed);
- }
-
- if (params.type === 'custom' && params.renderCustom) {
- $el.html(params.renderCustom(swiper, current + 1, total));
- emit('paginationRender', $el[0]);
- } else {
- emit('paginationUpdate', $el[0]);
- }
-
- if (swiper.params.watchOverflow && swiper.enabled) {
- $el[swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);
- }
- }
-
- function render() {
- // Render Container
- const params = swiper.params.pagination;
- if (isPaginationDisabled()) return;
- const slidesLength = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.slides.length : swiper.slides.length;
- const $el = swiper.pagination.$el;
- let paginationHTML = '';
-
- if (params.type === 'bullets') {
- let numberOfBullets = swiper.params.loop ? Math.ceil((slidesLength - swiper.loopedSlides * 2) / swiper.params.slidesPerGroup) : swiper.snapGrid.length;
-
- if (swiper.params.freeMode && swiper.params.freeMode.enabled && !swiper.params.loop && numberOfBullets > slidesLength) {
- numberOfBullets = slidesLength;
- }
-
- for (let i = 0; i < numberOfBullets; i += 1) {
- if (params.renderBullet) {
- paginationHTML += params.renderBullet.call(swiper, i, params.bulletClass);
- } else {
- paginationHTML += `<${params.bulletElement} class="${params.bulletClass}">${params.bulletElement}>`;
- }
- }
-
- $el.html(paginationHTML);
- swiper.pagination.bullets = $el.find(classesToSelector(params.bulletClass));
- }
-
- if (params.type === 'fraction') {
- if (params.renderFraction) {
- paginationHTML = params.renderFraction.call(swiper, params.currentClass, params.totalClass);
- } else {
- paginationHTML = ` ` + ' / ' + ` `;
- }
-
- $el.html(paginationHTML);
- }
-
- if (params.type === 'progressbar') {
- if (params.renderProgressbar) {
- paginationHTML = params.renderProgressbar.call(swiper, params.progressbarFillClass);
- } else {
- paginationHTML = ` `;
- }
-
- $el.html(paginationHTML);
- }
-
- if (params.type !== 'custom') {
- emit('paginationRender', swiper.pagination.$el[0]);
- }
- }
-
- function init() {
- swiper.params.pagination = createElementIfNotDefined(swiper, swiper.originalParams.pagination, swiper.params.pagination, {
- el: 'swiper-pagination'
- });
- const params = swiper.params.pagination;
- if (!params.el) return;
- let $el = $(params.el);
- if ($el.length === 0) return;
-
- if (swiper.params.uniqueNavElements && typeof params.el === 'string' && $el.length > 1) {
- $el = swiper.$el.find(params.el); // check if it belongs to another nested Swiper
-
- if ($el.length > 1) {
- $el = $el.filter(el => {
- if ($(el).parents('.swiper')[0] !== swiper.el) return false;
- return true;
- });
- }
- }
-
- if (params.type === 'bullets' && params.clickable) {
- $el.addClass(params.clickableClass);
- }
-
- $el.addClass(params.modifierClass + params.type);
- $el.addClass(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);
-
- if (params.type === 'bullets' && params.dynamicBullets) {
- $el.addClass(`${params.modifierClass}${params.type}-dynamic`);
- dynamicBulletIndex = 0;
-
- if (params.dynamicMainBullets < 1) {
- params.dynamicMainBullets = 1;
- }
- }
-
- if (params.type === 'progressbar' && params.progressbarOpposite) {
- $el.addClass(params.progressbarOppositeClass);
- }
-
- if (params.clickable) {
- $el.on('click', classesToSelector(params.bulletClass), function onClick(e) {
- e.preventDefault();
- let index = $(this).index() * swiper.params.slidesPerGroup;
- if (swiper.params.loop) index += swiper.loopedSlides;
- swiper.slideTo(index);
- });
- }
-
- Object.assign(swiper.pagination, {
- $el,
- el: $el[0]
- });
-
- if (!swiper.enabled) {
- $el.addClass(params.lockClass);
- }
- }
-
- function destroy() {
- const params = swiper.params.pagination;
- if (isPaginationDisabled()) return;
- const $el = swiper.pagination.$el;
- $el.removeClass(params.hiddenClass);
- $el.removeClass(params.modifierClass + params.type);
- $el.removeClass(swiper.isHorizontal() ? params.horizontalClass : params.verticalClass);
- if (swiper.pagination.bullets && swiper.pagination.bullets.removeClass) swiper.pagination.bullets.removeClass(params.bulletActiveClass);
-
- if (params.clickable) {
- $el.off('click', classesToSelector(params.bulletClass));
- }
- }
-
- on('init', () => {
- init();
- render();
- update();
- });
- on('activeIndexChange', () => {
- if (swiper.params.loop) {
- update();
- } else if (typeof swiper.snapIndex === 'undefined') {
- update();
- }
- });
- on('snapIndexChange', () => {
- if (!swiper.params.loop) {
- update();
- }
- });
- on('slidesLengthChange', () => {
- if (swiper.params.loop) {
- render();
- update();
- }
- });
- on('snapGridLengthChange', () => {
- if (!swiper.params.loop) {
- render();
- update();
- }
- });
- on('destroy', () => {
- destroy();
- });
- on('enable disable', () => {
- const {
- $el
- } = swiper.pagination;
-
- if ($el) {
- $el[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.pagination.lockClass);
- }
- });
- on('lock unlock', () => {
- update();
- });
- on('click', (_s, e) => {
- const targetEl = e.target;
- const {
- $el
- } = swiper.pagination;
-
- if (swiper.params.pagination.el && swiper.params.pagination.hideOnClick && $el.length > 0 && !$(targetEl).hasClass(swiper.params.pagination.bulletClass)) {
- if (swiper.navigation && (swiper.navigation.nextEl && targetEl === swiper.navigation.nextEl || swiper.navigation.prevEl && targetEl === swiper.navigation.prevEl)) return;
- const isHidden = $el.hasClass(swiper.params.pagination.hiddenClass);
-
- if (isHidden === true) {
- emit('paginationShow');
- } else {
- emit('paginationHide');
- }
-
- $el.toggleClass(swiper.params.pagination.hiddenClass);
- }
- });
- Object.assign(swiper.pagination, {
- render,
- update,
- init,
- destroy
- });
- }
-
- function Scrollbar(_ref) {
- let {
- swiper,
- extendParams,
- on,
- emit
- } = _ref;
- const document = getDocument();
- let isTouched = false;
- let timeout = null;
- let dragTimeout = null;
- let dragStartPos;
- let dragSize;
- let trackSize;
- let divider;
- extendParams({
- scrollbar: {
- el: null,
- dragSize: 'auto',
- hide: false,
- draggable: false,
- snapOnRelease: true,
- lockClass: 'swiper-scrollbar-lock',
- dragClass: 'swiper-scrollbar-drag'
- }
- });
- swiper.scrollbar = {
- el: null,
- dragEl: null,
- $el: null,
- $dragEl: null
- };
-
- function setTranslate() {
- if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;
- const {
- scrollbar,
- rtlTranslate: rtl,
- progress
- } = swiper;
- const {
- $dragEl,
- $el
- } = scrollbar;
- const params = swiper.params.scrollbar;
- let newSize = dragSize;
- let newPos = (trackSize - dragSize) * progress;
-
- if (rtl) {
- newPos = -newPos;
-
- if (newPos > 0) {
- newSize = dragSize - newPos;
- newPos = 0;
- } else if (-newPos + dragSize > trackSize) {
- newSize = trackSize + newPos;
- }
- } else if (newPos < 0) {
- newSize = dragSize + newPos;
- newPos = 0;
- } else if (newPos + dragSize > trackSize) {
- newSize = trackSize - newPos;
- }
-
- if (swiper.isHorizontal()) {
- $dragEl.transform(`translate3d(${newPos}px, 0, 0)`);
- $dragEl[0].style.width = `${newSize}px`;
- } else {
- $dragEl.transform(`translate3d(0px, ${newPos}px, 0)`);
- $dragEl[0].style.height = `${newSize}px`;
- }
-
- if (params.hide) {
- clearTimeout(timeout);
- $el[0].style.opacity = 1;
- timeout = setTimeout(() => {
- $el[0].style.opacity = 0;
- $el.transition(400);
- }, 1000);
- }
- }
-
- function setTransition(duration) {
- if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;
- swiper.scrollbar.$dragEl.transition(duration);
- }
-
- function updateSize() {
- if (!swiper.params.scrollbar.el || !swiper.scrollbar.el) return;
- const {
- scrollbar
- } = swiper;
- const {
- $dragEl,
- $el
- } = scrollbar;
- $dragEl[0].style.width = '';
- $dragEl[0].style.height = '';
- trackSize = swiper.isHorizontal() ? $el[0].offsetWidth : $el[0].offsetHeight;
- divider = swiper.size / (swiper.virtualSize + swiper.params.slidesOffsetBefore - (swiper.params.centeredSlides ? swiper.snapGrid[0] : 0));
-
- if (swiper.params.scrollbar.dragSize === 'auto') {
- dragSize = trackSize * divider;
- } else {
- dragSize = parseInt(swiper.params.scrollbar.dragSize, 10);
- }
-
- if (swiper.isHorizontal()) {
- $dragEl[0].style.width = `${dragSize}px`;
- } else {
- $dragEl[0].style.height = `${dragSize}px`;
- }
-
- if (divider >= 1) {
- $el[0].style.display = 'none';
- } else {
- $el[0].style.display = '';
- }
-
- if (swiper.params.scrollbar.hide) {
- $el[0].style.opacity = 0;
- }
-
- if (swiper.params.watchOverflow && swiper.enabled) {
- scrollbar.$el[swiper.isLocked ? 'addClass' : 'removeClass'](swiper.params.scrollbar.lockClass);
- }
- }
-
- function getPointerPosition(e) {
- if (swiper.isHorizontal()) {
- return e.type === 'touchstart' || e.type === 'touchmove' ? e.targetTouches[0].clientX : e.clientX;
- }
-
- return e.type === 'touchstart' || e.type === 'touchmove' ? e.targetTouches[0].clientY : e.clientY;
- }
-
- function setDragPosition(e) {
- const {
- scrollbar,
- rtlTranslate: rtl
- } = swiper;
- const {
- $el
- } = scrollbar;
- let positionRatio;
- positionRatio = (getPointerPosition(e) - $el.offset()[swiper.isHorizontal() ? 'left' : 'top'] - (dragStartPos !== null ? dragStartPos : dragSize / 2)) / (trackSize - dragSize);
- positionRatio = Math.max(Math.min(positionRatio, 1), 0);
-
- if (rtl) {
- positionRatio = 1 - positionRatio;
- }
-
- const position = swiper.minTranslate() + (swiper.maxTranslate() - swiper.minTranslate()) * positionRatio;
- swiper.updateProgress(position);
- swiper.setTranslate(position);
- swiper.updateActiveIndex();
- swiper.updateSlidesClasses();
- }
-
- function onDragStart(e) {
- const params = swiper.params.scrollbar;
- const {
- scrollbar,
- $wrapperEl
- } = swiper;
- const {
- $el,
- $dragEl
- } = scrollbar;
- isTouched = true;
- dragStartPos = e.target === $dragEl[0] || e.target === $dragEl ? getPointerPosition(e) - e.target.getBoundingClientRect()[swiper.isHorizontal() ? 'left' : 'top'] : null;
- e.preventDefault();
- e.stopPropagation();
- $wrapperEl.transition(100);
- $dragEl.transition(100);
- setDragPosition(e);
- clearTimeout(dragTimeout);
- $el.transition(0);
-
- if (params.hide) {
- $el.css('opacity', 1);
- }
-
- if (swiper.params.cssMode) {
- swiper.$wrapperEl.css('scroll-snap-type', 'none');
- }
-
- emit('scrollbarDragStart', e);
- }
-
- function onDragMove(e) {
- const {
- scrollbar,
- $wrapperEl
- } = swiper;
- const {
- $el,
- $dragEl
- } = scrollbar;
- if (!isTouched) return;
- if (e.preventDefault) e.preventDefault();else e.returnValue = false;
- setDragPosition(e);
- $wrapperEl.transition(0);
- $el.transition(0);
- $dragEl.transition(0);
- emit('scrollbarDragMove', e);
- }
-
- function onDragEnd(e) {
- const params = swiper.params.scrollbar;
- const {
- scrollbar,
- $wrapperEl
- } = swiper;
- const {
- $el
- } = scrollbar;
- if (!isTouched) return;
- isTouched = false;
-
- if (swiper.params.cssMode) {
- swiper.$wrapperEl.css('scroll-snap-type', '');
- $wrapperEl.transition('');
- }
-
- if (params.hide) {
- clearTimeout(dragTimeout);
- dragTimeout = nextTick(() => {
- $el.css('opacity', 0);
- $el.transition(400);
- }, 1000);
- }
-
- emit('scrollbarDragEnd', e);
-
- if (params.snapOnRelease) {
- swiper.slideToClosest();
- }
- }
-
- function events(method) {
- const {
- scrollbar,
- touchEventsTouch,
- touchEventsDesktop,
- params,
- support
- } = swiper;
- const $el = scrollbar.$el;
- const target = $el[0];
- const activeListener = support.passiveListener && params.passiveListeners ? {
- passive: false,
- capture: false
- } : false;
- const passiveListener = support.passiveListener && params.passiveListeners ? {
- passive: true,
- capture: false
- } : false;
- if (!target) return;
- const eventMethod = method === 'on' ? 'addEventListener' : 'removeEventListener';
-
- if (!support.touch) {
- target[eventMethod](touchEventsDesktop.start, onDragStart, activeListener);
- document[eventMethod](touchEventsDesktop.move, onDragMove, activeListener);
- document[eventMethod](touchEventsDesktop.end, onDragEnd, passiveListener);
- } else {
- target[eventMethod](touchEventsTouch.start, onDragStart, activeListener);
- target[eventMethod](touchEventsTouch.move, onDragMove, activeListener);
- target[eventMethod](touchEventsTouch.end, onDragEnd, passiveListener);
- }
- }
-
- function enableDraggable() {
- if (!swiper.params.scrollbar.el) return;
- events('on');
- }
-
- function disableDraggable() {
- if (!swiper.params.scrollbar.el) return;
- events('off');
- }
-
- function init() {
- const {
- scrollbar,
- $el: $swiperEl
- } = swiper;
- swiper.params.scrollbar = createElementIfNotDefined(swiper, swiper.originalParams.scrollbar, swiper.params.scrollbar, {
- el: 'swiper-scrollbar'
- });
- const params = swiper.params.scrollbar;
- if (!params.el) return;
- let $el = $(params.el);
-
- if (swiper.params.uniqueNavElements && typeof params.el === 'string' && $el.length > 1 && $swiperEl.find(params.el).length === 1) {
- $el = $swiperEl.find(params.el);
- }
-
- let $dragEl = $el.find(`.${swiper.params.scrollbar.dragClass}`);
-
- if ($dragEl.length === 0) {
- $dragEl = $(`
`);
- $el.append($dragEl);
- }
-
- Object.assign(scrollbar, {
- $el,
- el: $el[0],
- $dragEl,
- dragEl: $dragEl[0]
- });
-
- if (params.draggable) {
- enableDraggable();
- }
-
- if ($el) {
- $el[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.scrollbar.lockClass);
- }
- }
-
- function destroy() {
- disableDraggable();
- }
-
- on('init', () => {
- init();
- updateSize();
- setTranslate();
- });
- on('update resize observerUpdate lock unlock', () => {
- updateSize();
- });
- on('setTranslate', () => {
- setTranslate();
- });
- on('setTransition', (_s, duration) => {
- setTransition(duration);
- });
- on('enable disable', () => {
- const {
- $el
- } = swiper.scrollbar;
-
- if ($el) {
- $el[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.scrollbar.lockClass);
- }
- });
- on('destroy', () => {
- destroy();
- });
- Object.assign(swiper.scrollbar, {
- updateSize,
- setTranslate,
- init,
- destroy
- });
- }
-
- function Parallax(_ref) {
- let {
- swiper,
- extendParams,
- on
- } = _ref;
- extendParams({
- parallax: {
- enabled: false
- }
- });
-
- const setTransform = (el, progress) => {
- const {
- rtl
- } = swiper;
- const $el = $(el);
- const rtlFactor = rtl ? -1 : 1;
- const p = $el.attr('data-swiper-parallax') || '0';
- let x = $el.attr('data-swiper-parallax-x');
- let y = $el.attr('data-swiper-parallax-y');
- const scale = $el.attr('data-swiper-parallax-scale');
- const opacity = $el.attr('data-swiper-parallax-opacity');
-
- if (x || y) {
- x = x || '0';
- y = y || '0';
- } else if (swiper.isHorizontal()) {
- x = p;
- y = '0';
- } else {
- y = p;
- x = '0';
- }
-
- if (x.indexOf('%') >= 0) {
- x = `${parseInt(x, 10) * progress * rtlFactor}%`;
- } else {
- x = `${x * progress * rtlFactor}px`;
- }
-
- if (y.indexOf('%') >= 0) {
- y = `${parseInt(y, 10) * progress}%`;
- } else {
- y = `${y * progress}px`;
- }
-
- if (typeof opacity !== 'undefined' && opacity !== null) {
- const currentOpacity = opacity - (opacity - 1) * (1 - Math.abs(progress));
- $el[0].style.opacity = currentOpacity;
- }
-
- if (typeof scale === 'undefined' || scale === null) {
- $el.transform(`translate3d(${x}, ${y}, 0px)`);
- } else {
- const currentScale = scale - (scale - 1) * (1 - Math.abs(progress));
- $el.transform(`translate3d(${x}, ${y}, 0px) scale(${currentScale})`);
- }
- };
-
- const setTranslate = () => {
- const {
- $el,
- slides,
- progress,
- snapGrid
- } = swiper;
- $el.children('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(el => {
- setTransform(el, progress);
- });
- slides.each((slideEl, slideIndex) => {
- let slideProgress = slideEl.progress;
-
- if (swiper.params.slidesPerGroup > 1 && swiper.params.slidesPerView !== 'auto') {
- slideProgress += Math.ceil(slideIndex / 2) - progress * (snapGrid.length - 1);
- }
-
- slideProgress = Math.min(Math.max(slideProgress, -1), 1);
- $(slideEl).find('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(el => {
- setTransform(el, slideProgress);
- });
- });
- };
-
- const setTransition = function (duration) {
- if (duration === void 0) {
- duration = swiper.params.speed;
- }
-
- const {
- $el
- } = swiper;
- $el.find('[data-swiper-parallax], [data-swiper-parallax-x], [data-swiper-parallax-y], [data-swiper-parallax-opacity], [data-swiper-parallax-scale]').each(parallaxEl => {
- const $parallaxEl = $(parallaxEl);
- let parallaxDuration = parseInt($parallaxEl.attr('data-swiper-parallax-duration'), 10) || duration;
- if (duration === 0) parallaxDuration = 0;
- $parallaxEl.transition(parallaxDuration);
- });
- };
-
- on('beforeInit', () => {
- if (!swiper.params.parallax.enabled) return;
- swiper.params.watchSlidesProgress = true;
- swiper.originalParams.watchSlidesProgress = true;
- });
- on('init', () => {
- if (!swiper.params.parallax.enabled) return;
- setTranslate();
- });
- on('setTranslate', () => {
- if (!swiper.params.parallax.enabled) return;
- setTranslate();
- });
- on('setTransition', (_swiper, duration) => {
- if (!swiper.params.parallax.enabled) return;
- setTransition(duration);
- });
- }
-
- function Zoom(_ref) {
- let {
- swiper,
- extendParams,
- on,
- emit
- } = _ref;
- const window = getWindow();
- extendParams({
- zoom: {
- enabled: false,
- maxRatio: 3,
- minRatio: 1,
- toggle: true,
- containerClass: 'swiper-zoom-container',
- zoomedSlideClass: 'swiper-slide-zoomed'
- }
- });
- swiper.zoom = {
- enabled: false
- };
- let currentScale = 1;
- let isScaling = false;
- let gesturesEnabled;
- let fakeGestureTouched;
- let fakeGestureMoved;
- const gesture = {
- $slideEl: undefined,
- slideWidth: undefined,
- slideHeight: undefined,
- $imageEl: undefined,
- $imageWrapEl: undefined,
- maxRatio: 3
- };
- const image = {
- isTouched: undefined,
- isMoved: undefined,
- currentX: undefined,
- currentY: undefined,
- minX: undefined,
- minY: undefined,
- maxX: undefined,
- maxY: undefined,
- width: undefined,
- height: undefined,
- startX: undefined,
- startY: undefined,
- touchesStart: {},
- touchesCurrent: {}
- };
- const velocity = {
- x: undefined,
- y: undefined,
- prevPositionX: undefined,
- prevPositionY: undefined,
- prevTime: undefined
- };
- let scale = 1;
- Object.defineProperty(swiper.zoom, 'scale', {
- get() {
- return scale;
- },
-
- set(value) {
- if (scale !== value) {
- const imageEl = gesture.$imageEl ? gesture.$imageEl[0] : undefined;
- const slideEl = gesture.$slideEl ? gesture.$slideEl[0] : undefined;
- emit('zoomChange', value, imageEl, slideEl);
- }
-
- scale = value;
- }
-
- });
-
- function getDistanceBetweenTouches(e) {
- if (e.targetTouches.length < 2) return 1;
- const x1 = e.targetTouches[0].pageX;
- const y1 = e.targetTouches[0].pageY;
- const x2 = e.targetTouches[1].pageX;
- const y2 = e.targetTouches[1].pageY;
- const distance = Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2);
- return distance;
- } // Events
-
-
- function onGestureStart(e) {
- const support = swiper.support;
- const params = swiper.params.zoom;
- fakeGestureTouched = false;
- fakeGestureMoved = false;
-
- if (!support.gestures) {
- if (e.type !== 'touchstart' || e.type === 'touchstart' && e.targetTouches.length < 2) {
- return;
- }
-
- fakeGestureTouched = true;
- gesture.scaleStart = getDistanceBetweenTouches(e);
- }
-
- if (!gesture.$slideEl || !gesture.$slideEl.length) {
- gesture.$slideEl = $(e.target).closest(`.${swiper.params.slideClass}`);
- if (gesture.$slideEl.length === 0) gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);
- gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);
- gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);
- gesture.maxRatio = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;
-
- if (gesture.$imageWrapEl.length === 0) {
- gesture.$imageEl = undefined;
- return;
- }
- }
-
- if (gesture.$imageEl) {
- gesture.$imageEl.transition(0);
- }
-
- isScaling = true;
- }
-
- function onGestureChange(e) {
- const support = swiper.support;
- const params = swiper.params.zoom;
- const zoom = swiper.zoom;
-
- if (!support.gestures) {
- if (e.type !== 'touchmove' || e.type === 'touchmove' && e.targetTouches.length < 2) {
- return;
- }
-
- fakeGestureMoved = true;
- gesture.scaleMove = getDistanceBetweenTouches(e);
- }
-
- if (!gesture.$imageEl || gesture.$imageEl.length === 0) {
- if (e.type === 'gesturechange') onGestureStart(e);
- return;
- }
-
- if (support.gestures) {
- zoom.scale = e.scale * currentScale;
- } else {
- zoom.scale = gesture.scaleMove / gesture.scaleStart * currentScale;
- }
-
- if (zoom.scale > gesture.maxRatio) {
- zoom.scale = gesture.maxRatio - 1 + (zoom.scale - gesture.maxRatio + 1) ** 0.5;
- }
-
- if (zoom.scale < params.minRatio) {
- zoom.scale = params.minRatio + 1 - (params.minRatio - zoom.scale + 1) ** 0.5;
- }
-
- gesture.$imageEl.transform(`translate3d(0,0,0) scale(${zoom.scale})`);
- }
-
- function onGestureEnd(e) {
- const device = swiper.device;
- const support = swiper.support;
- const params = swiper.params.zoom;
- const zoom = swiper.zoom;
-
- if (!support.gestures) {
- if (!fakeGestureTouched || !fakeGestureMoved) {
- return;
- }
-
- if (e.type !== 'touchend' || e.type === 'touchend' && e.changedTouches.length < 2 && !device.android) {
- return;
- }
-
- fakeGestureTouched = false;
- fakeGestureMoved = false;
- }
-
- if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;
- zoom.scale = Math.max(Math.min(zoom.scale, gesture.maxRatio), params.minRatio);
- gesture.$imageEl.transition(swiper.params.speed).transform(`translate3d(0,0,0) scale(${zoom.scale})`);
- currentScale = zoom.scale;
- isScaling = false;
- if (zoom.scale === 1) gesture.$slideEl = undefined;
- }
-
- function onTouchStart(e) {
- const device = swiper.device;
- if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;
- if (image.isTouched) return;
- if (device.android && e.cancelable) e.preventDefault();
- image.isTouched = true;
- image.touchesStart.x = e.type === 'touchstart' ? e.targetTouches[0].pageX : e.pageX;
- image.touchesStart.y = e.type === 'touchstart' ? e.targetTouches[0].pageY : e.pageY;
- }
-
- function onTouchMove(e) {
- const zoom = swiper.zoom;
- if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;
- swiper.allowClick = false;
- if (!image.isTouched || !gesture.$slideEl) return;
-
- if (!image.isMoved) {
- image.width = gesture.$imageEl[0].offsetWidth;
- image.height = gesture.$imageEl[0].offsetHeight;
- image.startX = getTranslate(gesture.$imageWrapEl[0], 'x') || 0;
- image.startY = getTranslate(gesture.$imageWrapEl[0], 'y') || 0;
- gesture.slideWidth = gesture.$slideEl[0].offsetWidth;
- gesture.slideHeight = gesture.$slideEl[0].offsetHeight;
- gesture.$imageWrapEl.transition(0);
- } // Define if we need image drag
-
-
- const scaledWidth = image.width * zoom.scale;
- const scaledHeight = image.height * zoom.scale;
- if (scaledWidth < gesture.slideWidth && scaledHeight < gesture.slideHeight) return;
- image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);
- image.maxX = -image.minX;
- image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);
- image.maxY = -image.minY;
- image.touchesCurrent.x = e.type === 'touchmove' ? e.targetTouches[0].pageX : e.pageX;
- image.touchesCurrent.y = e.type === 'touchmove' ? e.targetTouches[0].pageY : e.pageY;
-
- if (!image.isMoved && !isScaling) {
- if (swiper.isHorizontal() && (Math.floor(image.minX) === Math.floor(image.startX) && image.touchesCurrent.x < image.touchesStart.x || Math.floor(image.maxX) === Math.floor(image.startX) && image.touchesCurrent.x > image.touchesStart.x)) {
- image.isTouched = false;
- return;
- }
-
- if (!swiper.isHorizontal() && (Math.floor(image.minY) === Math.floor(image.startY) && image.touchesCurrent.y < image.touchesStart.y || Math.floor(image.maxY) === Math.floor(image.startY) && image.touchesCurrent.y > image.touchesStart.y)) {
- image.isTouched = false;
- return;
- }
- }
-
- if (e.cancelable) {
- e.preventDefault();
- }
-
- e.stopPropagation();
- image.isMoved = true;
- image.currentX = image.touchesCurrent.x - image.touchesStart.x + image.startX;
- image.currentY = image.touchesCurrent.y - image.touchesStart.y + image.startY;
-
- if (image.currentX < image.minX) {
- image.currentX = image.minX + 1 - (image.minX - image.currentX + 1) ** 0.8;
- }
-
- if (image.currentX > image.maxX) {
- image.currentX = image.maxX - 1 + (image.currentX - image.maxX + 1) ** 0.8;
- }
-
- if (image.currentY < image.minY) {
- image.currentY = image.minY + 1 - (image.minY - image.currentY + 1) ** 0.8;
- }
-
- if (image.currentY > image.maxY) {
- image.currentY = image.maxY - 1 + (image.currentY - image.maxY + 1) ** 0.8;
- } // Velocity
-
-
- if (!velocity.prevPositionX) velocity.prevPositionX = image.touchesCurrent.x;
- if (!velocity.prevPositionY) velocity.prevPositionY = image.touchesCurrent.y;
- if (!velocity.prevTime) velocity.prevTime = Date.now();
- velocity.x = (image.touchesCurrent.x - velocity.prevPositionX) / (Date.now() - velocity.prevTime) / 2;
- velocity.y = (image.touchesCurrent.y - velocity.prevPositionY) / (Date.now() - velocity.prevTime) / 2;
- if (Math.abs(image.touchesCurrent.x - velocity.prevPositionX) < 2) velocity.x = 0;
- if (Math.abs(image.touchesCurrent.y - velocity.prevPositionY) < 2) velocity.y = 0;
- velocity.prevPositionX = image.touchesCurrent.x;
- velocity.prevPositionY = image.touchesCurrent.y;
- velocity.prevTime = Date.now();
- gesture.$imageWrapEl.transform(`translate3d(${image.currentX}px, ${image.currentY}px,0)`);
- }
-
- function onTouchEnd() {
- const zoom = swiper.zoom;
- if (!gesture.$imageEl || gesture.$imageEl.length === 0) return;
-
- if (!image.isTouched || !image.isMoved) {
- image.isTouched = false;
- image.isMoved = false;
- return;
- }
-
- image.isTouched = false;
- image.isMoved = false;
- let momentumDurationX = 300;
- let momentumDurationY = 300;
- const momentumDistanceX = velocity.x * momentumDurationX;
- const newPositionX = image.currentX + momentumDistanceX;
- const momentumDistanceY = velocity.y * momentumDurationY;
- const newPositionY = image.currentY + momentumDistanceY; // Fix duration
-
- if (velocity.x !== 0) momentumDurationX = Math.abs((newPositionX - image.currentX) / velocity.x);
- if (velocity.y !== 0) momentumDurationY = Math.abs((newPositionY - image.currentY) / velocity.y);
- const momentumDuration = Math.max(momentumDurationX, momentumDurationY);
- image.currentX = newPositionX;
- image.currentY = newPositionY; // Define if we need image drag
-
- const scaledWidth = image.width * zoom.scale;
- const scaledHeight = image.height * zoom.scale;
- image.minX = Math.min(gesture.slideWidth / 2 - scaledWidth / 2, 0);
- image.maxX = -image.minX;
- image.minY = Math.min(gesture.slideHeight / 2 - scaledHeight / 2, 0);
- image.maxY = -image.minY;
- image.currentX = Math.max(Math.min(image.currentX, image.maxX), image.minX);
- image.currentY = Math.max(Math.min(image.currentY, image.maxY), image.minY);
- gesture.$imageWrapEl.transition(momentumDuration).transform(`translate3d(${image.currentX}px, ${image.currentY}px,0)`);
- }
-
- function onTransitionEnd() {
- const zoom = swiper.zoom;
-
- if (gesture.$slideEl && swiper.previousIndex !== swiper.activeIndex) {
- if (gesture.$imageEl) {
- gesture.$imageEl.transform('translate3d(0,0,0) scale(1)');
- }
-
- if (gesture.$imageWrapEl) {
- gesture.$imageWrapEl.transform('translate3d(0,0,0)');
- }
-
- zoom.scale = 1;
- currentScale = 1;
- gesture.$slideEl = undefined;
- gesture.$imageEl = undefined;
- gesture.$imageWrapEl = undefined;
- }
- }
-
- function zoomIn(e) {
- const zoom = swiper.zoom;
- const params = swiper.params.zoom;
-
- if (!gesture.$slideEl) {
- if (e && e.target) {
- gesture.$slideEl = $(e.target).closest(`.${swiper.params.slideClass}`);
- }
-
- if (!gesture.$slideEl) {
- if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) {
- gesture.$slideEl = swiper.$wrapperEl.children(`.${swiper.params.slideActiveClass}`);
- } else {
- gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);
- }
- }
-
- gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);
- gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);
- }
-
- if (!gesture.$imageEl || gesture.$imageEl.length === 0 || !gesture.$imageWrapEl || gesture.$imageWrapEl.length === 0) return;
-
- if (swiper.params.cssMode) {
- swiper.wrapperEl.style.overflow = 'hidden';
- swiper.wrapperEl.style.touchAction = 'none';
- }
-
- gesture.$slideEl.addClass(`${params.zoomedSlideClass}`);
- let touchX;
- let touchY;
- let offsetX;
- let offsetY;
- let diffX;
- let diffY;
- let translateX;
- let translateY;
- let imageWidth;
- let imageHeight;
- let scaledWidth;
- let scaledHeight;
- let translateMinX;
- let translateMinY;
- let translateMaxX;
- let translateMaxY;
- let slideWidth;
- let slideHeight;
-
- if (typeof image.touchesStart.x === 'undefined' && e) {
- touchX = e.type === 'touchend' ? e.changedTouches[0].pageX : e.pageX;
- touchY = e.type === 'touchend' ? e.changedTouches[0].pageY : e.pageY;
- } else {
- touchX = image.touchesStart.x;
- touchY = image.touchesStart.y;
- }
-
- zoom.scale = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;
- currentScale = gesture.$imageWrapEl.attr('data-swiper-zoom') || params.maxRatio;
-
- if (e) {
- slideWidth = gesture.$slideEl[0].offsetWidth;
- slideHeight = gesture.$slideEl[0].offsetHeight;
- offsetX = gesture.$slideEl.offset().left + window.scrollX;
- offsetY = gesture.$slideEl.offset().top + window.scrollY;
- diffX = offsetX + slideWidth / 2 - touchX;
- diffY = offsetY + slideHeight / 2 - touchY;
- imageWidth = gesture.$imageEl[0].offsetWidth;
- imageHeight = gesture.$imageEl[0].offsetHeight;
- scaledWidth = imageWidth * zoom.scale;
- scaledHeight = imageHeight * zoom.scale;
- translateMinX = Math.min(slideWidth / 2 - scaledWidth / 2, 0);
- translateMinY = Math.min(slideHeight / 2 - scaledHeight / 2, 0);
- translateMaxX = -translateMinX;
- translateMaxY = -translateMinY;
- translateX = diffX * zoom.scale;
- translateY = diffY * zoom.scale;
-
- if (translateX < translateMinX) {
- translateX = translateMinX;
- }
-
- if (translateX > translateMaxX) {
- translateX = translateMaxX;
- }
-
- if (translateY < translateMinY) {
- translateY = translateMinY;
- }
-
- if (translateY > translateMaxY) {
- translateY = translateMaxY;
- }
- } else {
- translateX = 0;
- translateY = 0;
- }
-
- gesture.$imageWrapEl.transition(300).transform(`translate3d(${translateX}px, ${translateY}px,0)`);
- gesture.$imageEl.transition(300).transform(`translate3d(0,0,0) scale(${zoom.scale})`);
- }
-
- function zoomOut() {
- const zoom = swiper.zoom;
- const params = swiper.params.zoom;
-
- if (!gesture.$slideEl) {
- if (swiper.params.virtual && swiper.params.virtual.enabled && swiper.virtual) {
- gesture.$slideEl = swiper.$wrapperEl.children(`.${swiper.params.slideActiveClass}`);
- } else {
- gesture.$slideEl = swiper.slides.eq(swiper.activeIndex);
- }
-
- gesture.$imageEl = gesture.$slideEl.find(`.${params.containerClass}`).eq(0).find('picture, img, svg, canvas, .swiper-zoom-target').eq(0);
- gesture.$imageWrapEl = gesture.$imageEl.parent(`.${params.containerClass}`);
- }
-
- if (!gesture.$imageEl || gesture.$imageEl.length === 0 || !gesture.$imageWrapEl || gesture.$imageWrapEl.length === 0) return;
-
- if (swiper.params.cssMode) {
- swiper.wrapperEl.style.overflow = '';
- swiper.wrapperEl.style.touchAction = '';
- }
-
- zoom.scale = 1;
- currentScale = 1;
- gesture.$imageWrapEl.transition(300).transform('translate3d(0,0,0)');
- gesture.$imageEl.transition(300).transform('translate3d(0,0,0) scale(1)');
- gesture.$slideEl.removeClass(`${params.zoomedSlideClass}`);
- gesture.$slideEl = undefined;
- } // Toggle Zoom
-
-
- function zoomToggle(e) {
- const zoom = swiper.zoom;
-
- if (zoom.scale && zoom.scale !== 1) {
- // Zoom Out
- zoomOut();
- } else {
- // Zoom In
- zoomIn(e);
- }
- }
-
- function getListeners() {
- const support = swiper.support;
- const passiveListener = swiper.touchEvents.start === 'touchstart' && support.passiveListener && swiper.params.passiveListeners ? {
- passive: true,
- capture: false
- } : false;
- const activeListenerWithCapture = support.passiveListener ? {
- passive: false,
- capture: true
- } : true;
- return {
- passiveListener,
- activeListenerWithCapture
- };
- }
-
- function getSlideSelector() {
- return `.${swiper.params.slideClass}`;
- }
-
- function toggleGestures(method) {
- const {
- passiveListener
- } = getListeners();
- const slideSelector = getSlideSelector();
- swiper.$wrapperEl[method]('gesturestart', slideSelector, onGestureStart, passiveListener);
- swiper.$wrapperEl[method]('gesturechange', slideSelector, onGestureChange, passiveListener);
- swiper.$wrapperEl[method]('gestureend', slideSelector, onGestureEnd, passiveListener);
- }
-
- function enableGestures() {
- if (gesturesEnabled) return;
- gesturesEnabled = true;
- toggleGestures('on');
- }
-
- function disableGestures() {
- if (!gesturesEnabled) return;
- gesturesEnabled = false;
- toggleGestures('off');
- } // Attach/Detach Events
-
-
- function enable() {
- const zoom = swiper.zoom;
- if (zoom.enabled) return;
- zoom.enabled = true;
- const support = swiper.support;
- const {
- passiveListener,
- activeListenerWithCapture
- } = getListeners();
- const slideSelector = getSlideSelector(); // Scale image
-
- if (support.gestures) {
- swiper.$wrapperEl.on(swiper.touchEvents.start, enableGestures, passiveListener);
- swiper.$wrapperEl.on(swiper.touchEvents.end, disableGestures, passiveListener);
- } else if (swiper.touchEvents.start === 'touchstart') {
- swiper.$wrapperEl.on(swiper.touchEvents.start, slideSelector, onGestureStart, passiveListener);
- swiper.$wrapperEl.on(swiper.touchEvents.move, slideSelector, onGestureChange, activeListenerWithCapture);
- swiper.$wrapperEl.on(swiper.touchEvents.end, slideSelector, onGestureEnd, passiveListener);
-
- if (swiper.touchEvents.cancel) {
- swiper.$wrapperEl.on(swiper.touchEvents.cancel, slideSelector, onGestureEnd, passiveListener);
- }
- } // Move image
-
-
- swiper.$wrapperEl.on(swiper.touchEvents.move, `.${swiper.params.zoom.containerClass}`, onTouchMove, activeListenerWithCapture);
- }
-
- function disable() {
- const zoom = swiper.zoom;
- if (!zoom.enabled) return;
- const support = swiper.support;
- zoom.enabled = false;
- const {
- passiveListener,
- activeListenerWithCapture
- } = getListeners();
- const slideSelector = getSlideSelector(); // Scale image
-
- if (support.gestures) {
- swiper.$wrapperEl.off(swiper.touchEvents.start, enableGestures, passiveListener);
- swiper.$wrapperEl.off(swiper.touchEvents.end, disableGestures, passiveListener);
- } else if (swiper.touchEvents.start === 'touchstart') {
- swiper.$wrapperEl.off(swiper.touchEvents.start, slideSelector, onGestureStart, passiveListener);
- swiper.$wrapperEl.off(swiper.touchEvents.move, slideSelector, onGestureChange, activeListenerWithCapture);
- swiper.$wrapperEl.off(swiper.touchEvents.end, slideSelector, onGestureEnd, passiveListener);
-
- if (swiper.touchEvents.cancel) {
- swiper.$wrapperEl.off(swiper.touchEvents.cancel, slideSelector, onGestureEnd, passiveListener);
- }
- } // Move image
-
-
- swiper.$wrapperEl.off(swiper.touchEvents.move, `.${swiper.params.zoom.containerClass}`, onTouchMove, activeListenerWithCapture);
- }
-
- on('init', () => {
- if (swiper.params.zoom.enabled) {
- enable();
- }
- });
- on('destroy', () => {
- disable();
- });
- on('touchStart', (_s, e) => {
- if (!swiper.zoom.enabled) return;
- onTouchStart(e);
- });
- on('touchEnd', (_s, e) => {
- if (!swiper.zoom.enabled) return;
- onTouchEnd();
- });
- on('doubleTap', (_s, e) => {
- if (!swiper.animating && swiper.params.zoom.enabled && swiper.zoom.enabled && swiper.params.zoom.toggle) {
- zoomToggle(e);
- }
- });
- on('transitionEnd', () => {
- if (swiper.zoom.enabled && swiper.params.zoom.enabled) {
- onTransitionEnd();
- }
- });
- on('slideChange', () => {
- if (swiper.zoom.enabled && swiper.params.zoom.enabled && swiper.params.cssMode) {
- onTransitionEnd();
- }
- });
- Object.assign(swiper.zoom, {
- enable,
- disable,
- in: zoomIn,
- out: zoomOut,
- toggle: zoomToggle
- });
- }
-
- function Lazy(_ref) {
- let {
- swiper,
- extendParams,
- on,
- emit
- } = _ref;
- extendParams({
- lazy: {
- checkInView: false,
- enabled: false,
- loadPrevNext: false,
- loadPrevNextAmount: 1,
- loadOnTransitionStart: false,
- scrollingElement: '',
- elementClass: 'swiper-lazy',
- loadingClass: 'swiper-lazy-loading',
- loadedClass: 'swiper-lazy-loaded',
- preloaderClass: 'swiper-lazy-preloader'
- }
- });
- swiper.lazy = {};
- let scrollHandlerAttached = false;
- let initialImageLoaded = false;
-
- function loadInSlide(index, loadInDuplicate) {
- if (loadInDuplicate === void 0) {
- loadInDuplicate = true;
- }
-
- const params = swiper.params.lazy;
- if (typeof index === 'undefined') return;
- if (swiper.slides.length === 0) return;
- const isVirtual = swiper.virtual && swiper.params.virtual.enabled;
- const $slideEl = isVirtual ? swiper.$wrapperEl.children(`.${swiper.params.slideClass}[data-swiper-slide-index="${index}"]`) : swiper.slides.eq(index);
- const $images = $slideEl.find(`.${params.elementClass}:not(.${params.loadedClass}):not(.${params.loadingClass})`);
-
- if ($slideEl.hasClass(params.elementClass) && !$slideEl.hasClass(params.loadedClass) && !$slideEl.hasClass(params.loadingClass)) {
- $images.push($slideEl[0]);
- }
-
- if ($images.length === 0) return;
- $images.each(imageEl => {
- const $imageEl = $(imageEl);
- $imageEl.addClass(params.loadingClass);
- const background = $imageEl.attr('data-background');
- const src = $imageEl.attr('data-src');
- const srcset = $imageEl.attr('data-srcset');
- const sizes = $imageEl.attr('data-sizes');
- const $pictureEl = $imageEl.parent('picture');
- swiper.loadImage($imageEl[0], src || background, srcset, sizes, false, () => {
- if (typeof swiper === 'undefined' || swiper === null || !swiper || swiper && !swiper.params || swiper.destroyed) return;
-
- if (background) {
- $imageEl.css('background-image', `url("${background}")`);
- $imageEl.removeAttr('data-background');
- } else {
- if (srcset) {
- $imageEl.attr('srcset', srcset);
- $imageEl.removeAttr('data-srcset');
- }
-
- if (sizes) {
- $imageEl.attr('sizes', sizes);
- $imageEl.removeAttr('data-sizes');
- }
-
- if ($pictureEl.length) {
- $pictureEl.children('source').each(sourceEl => {
- const $source = $(sourceEl);
-
- if ($source.attr('data-srcset')) {
- $source.attr('srcset', $source.attr('data-srcset'));
- $source.removeAttr('data-srcset');
- }
- });
- }
-
- if (src) {
- $imageEl.attr('src', src);
- $imageEl.removeAttr('data-src');
- }
- }
-
- $imageEl.addClass(params.loadedClass).removeClass(params.loadingClass);
- $slideEl.find(`.${params.preloaderClass}`).remove();
-
- if (swiper.params.loop && loadInDuplicate) {
- const slideOriginalIndex = $slideEl.attr('data-swiper-slide-index');
-
- if ($slideEl.hasClass(swiper.params.slideDuplicateClass)) {
- const originalSlide = swiper.$wrapperEl.children(`[data-swiper-slide-index="${slideOriginalIndex}"]:not(.${swiper.params.slideDuplicateClass})`);
- loadInSlide(originalSlide.index(), false);
- } else {
- const duplicatedSlide = swiper.$wrapperEl.children(`.${swiper.params.slideDuplicateClass}[data-swiper-slide-index="${slideOriginalIndex}"]`);
- loadInSlide(duplicatedSlide.index(), false);
- }
- }
-
- emit('lazyImageReady', $slideEl[0], $imageEl[0]);
-
- if (swiper.params.autoHeight) {
- swiper.updateAutoHeight();
- }
- });
- emit('lazyImageLoad', $slideEl[0], $imageEl[0]);
- });
- }
-
- function load() {
- const {
- $wrapperEl,
- params: swiperParams,
- slides,
- activeIndex
- } = swiper;
- const isVirtual = swiper.virtual && swiperParams.virtual.enabled;
- const params = swiperParams.lazy;
- let slidesPerView = swiperParams.slidesPerView;
-
- if (slidesPerView === 'auto') {
- slidesPerView = 0;
- }
-
- function slideExist(index) {
- if (isVirtual) {
- if ($wrapperEl.children(`.${swiperParams.slideClass}[data-swiper-slide-index="${index}"]`).length) {
- return true;
- }
- } else if (slides[index]) return true;
-
- return false;
- }
-
- function slideIndex(slideEl) {
- if (isVirtual) {
- return $(slideEl).attr('data-swiper-slide-index');
- }
-
- return $(slideEl).index();
- }
-
- if (!initialImageLoaded) initialImageLoaded = true;
-
- if (swiper.params.watchSlidesProgress) {
- $wrapperEl.children(`.${swiperParams.slideVisibleClass}`).each(slideEl => {
- const index = isVirtual ? $(slideEl).attr('data-swiper-slide-index') : $(slideEl).index();
- loadInSlide(index);
- });
- } else if (slidesPerView > 1) {
- for (let i = activeIndex; i < activeIndex + slidesPerView; i += 1) {
- if (slideExist(i)) loadInSlide(i);
- }
- } else {
- loadInSlide(activeIndex);
- }
-
- if (params.loadPrevNext) {
- if (slidesPerView > 1 || params.loadPrevNextAmount && params.loadPrevNextAmount > 1) {
- const amount = params.loadPrevNextAmount;
- const spv = slidesPerView;
- const maxIndex = Math.min(activeIndex + spv + Math.max(amount, spv), slides.length);
- const minIndex = Math.max(activeIndex - Math.max(spv, amount), 0); // Next Slides
-
- for (let i = activeIndex + slidesPerView; i < maxIndex; i += 1) {
- if (slideExist(i)) loadInSlide(i);
- } // Prev Slides
-
-
- for (let i = minIndex; i < activeIndex; i += 1) {
- if (slideExist(i)) loadInSlide(i);
- }
- } else {
- const nextSlide = $wrapperEl.children(`.${swiperParams.slideNextClass}`);
- if (nextSlide.length > 0) loadInSlide(slideIndex(nextSlide));
- const prevSlide = $wrapperEl.children(`.${swiperParams.slidePrevClass}`);
- if (prevSlide.length > 0) loadInSlide(slideIndex(prevSlide));
- }
- }
- }
-
- function checkInViewOnLoad() {
- const window = getWindow();
- if (!swiper || swiper.destroyed) return;
- const $scrollElement = swiper.params.lazy.scrollingElement ? $(swiper.params.lazy.scrollingElement) : $(window);
- const isWindow = $scrollElement[0] === window;
- const scrollElementWidth = isWindow ? window.innerWidth : $scrollElement[0].offsetWidth;
- const scrollElementHeight = isWindow ? window.innerHeight : $scrollElement[0].offsetHeight;
- const swiperOffset = swiper.$el.offset();
- const {
- rtlTranslate: rtl
- } = swiper;
- let inView = false;
- if (rtl) swiperOffset.left -= swiper.$el[0].scrollLeft;
- const swiperCoord = [[swiperOffset.left, swiperOffset.top], [swiperOffset.left + swiper.width, swiperOffset.top], [swiperOffset.left, swiperOffset.top + swiper.height], [swiperOffset.left + swiper.width, swiperOffset.top + swiper.height]];
-
- for (let i = 0; i < swiperCoord.length; i += 1) {
- const point = swiperCoord[i];
-
- if (point[0] >= 0 && point[0] <= scrollElementWidth && point[1] >= 0 && point[1] <= scrollElementHeight) {
- if (point[0] === 0 && point[1] === 0) continue; // eslint-disable-line
-
- inView = true;
- }
- }
-
- const passiveListener = swiper.touchEvents.start === 'touchstart' && swiper.support.passiveListener && swiper.params.passiveListeners ? {
- passive: true,
- capture: false
- } : false;
-
- if (inView) {
- load();
- $scrollElement.off('scroll', checkInViewOnLoad, passiveListener);
- } else if (!scrollHandlerAttached) {
- scrollHandlerAttached = true;
- $scrollElement.on('scroll', checkInViewOnLoad, passiveListener);
- }
- }
-
- on('beforeInit', () => {
- if (swiper.params.lazy.enabled && swiper.params.preloadImages) {
- swiper.params.preloadImages = false;
- }
- });
- on('init', () => {
- if (swiper.params.lazy.enabled) {
- if (swiper.params.lazy.checkInView) {
- checkInViewOnLoad();
- } else {
- load();
- }
- }
- });
- on('scroll', () => {
- if (swiper.params.freeMode && swiper.params.freeMode.enabled && !swiper.params.freeMode.sticky) {
- load();
- }
- });
- on('scrollbarDragMove resize _freeModeNoMomentumRelease', () => {
- if (swiper.params.lazy.enabled) {
- if (swiper.params.lazy.checkInView) {
- checkInViewOnLoad();
- } else {
- load();
- }
- }
- });
- on('transitionStart', () => {
- if (swiper.params.lazy.enabled) {
- if (swiper.params.lazy.loadOnTransitionStart || !swiper.params.lazy.loadOnTransitionStart && !initialImageLoaded) {
- if (swiper.params.lazy.checkInView) {
- checkInViewOnLoad();
- } else {
- load();
- }
- }
- }
- });
- on('transitionEnd', () => {
- if (swiper.params.lazy.enabled && !swiper.params.lazy.loadOnTransitionStart) {
- if (swiper.params.lazy.checkInView) {
- checkInViewOnLoad();
- } else {
- load();
- }
- }
- });
- on('slideChange', () => {
- const {
- lazy,
- cssMode,
- watchSlidesProgress,
- touchReleaseOnEdges,
- resistanceRatio
- } = swiper.params;
-
- if (lazy.enabled && (cssMode || watchSlidesProgress && (touchReleaseOnEdges || resistanceRatio === 0))) {
- load();
- }
- });
- Object.assign(swiper.lazy, {
- load,
- loadInSlide
- });
- }
-
- /* eslint no-bitwise: ["error", { "allow": [">>"] }] */
- function Controller(_ref) {
- let {
- swiper,
- extendParams,
- on
- } = _ref;
- extendParams({
- controller: {
- control: undefined,
- inverse: false,
- by: 'slide' // or 'container'
-
- }
- });
- swiper.controller = {
- control: undefined
- };
-
- function LinearSpline(x, y) {
- const binarySearch = function search() {
- let maxIndex;
- let minIndex;
- let guess;
- return (array, val) => {
- minIndex = -1;
- maxIndex = array.length;
-
- while (maxIndex - minIndex > 1) {
- guess = maxIndex + minIndex >> 1;
-
- if (array[guess] <= val) {
- minIndex = guess;
- } else {
- maxIndex = guess;
- }
- }
-
- return maxIndex;
- };
- }();
-
- this.x = x;
- this.y = y;
- this.lastIndex = x.length - 1; // Given an x value (x2), return the expected y2 value:
- // (x1,y1) is the known point before given value,
- // (x3,y3) is the known point after given value.
-
- let i1;
- let i3;
-
- this.interpolate = function interpolate(x2) {
- if (!x2) return 0; // Get the indexes of x1 and x3 (the array indexes before and after given x2):
-
- i3 = binarySearch(this.x, x2);
- i1 = i3 - 1; // We have our indexes i1 & i3, so we can calculate already:
- // y2 := ((x2−x1) × (y3−y1)) ÷ (x3−x1) + y1
-
- return (x2 - this.x[i1]) * (this.y[i3] - this.y[i1]) / (this.x[i3] - this.x[i1]) + this.y[i1];
- };
-
- return this;
- } // xxx: for now i will just save one spline function to to
-
-
- function getInterpolateFunction(c) {
- if (!swiper.controller.spline) {
- swiper.controller.spline = swiper.params.loop ? new LinearSpline(swiper.slidesGrid, c.slidesGrid) : new LinearSpline(swiper.snapGrid, c.snapGrid);
- }
- }
-
- function setTranslate(_t, byController) {
- const controlled = swiper.controller.control;
- let multiplier;
- let controlledTranslate;
- const Swiper = swiper.constructor;
-
- function setControlledTranslate(c) {
- // this will create an Interpolate function based on the snapGrids
- // x is the Grid of the scrolled scroller and y will be the controlled scroller
- // it makes sense to create this only once and recall it for the interpolation
- // the function does a lot of value caching for performance
- const translate = swiper.rtlTranslate ? -swiper.translate : swiper.translate;
-
- if (swiper.params.controller.by === 'slide') {
- getInterpolateFunction(c); // i am not sure why the values have to be multiplicated this way, tried to invert the snapGrid
- // but it did not work out
-
- controlledTranslate = -swiper.controller.spline.interpolate(-translate);
- }
-
- if (!controlledTranslate || swiper.params.controller.by === 'container') {
- multiplier = (c.maxTranslate() - c.minTranslate()) / (swiper.maxTranslate() - swiper.minTranslate());
- controlledTranslate = (translate - swiper.minTranslate()) * multiplier + c.minTranslate();
- }
-
- if (swiper.params.controller.inverse) {
- controlledTranslate = c.maxTranslate() - controlledTranslate;
- }
-
- c.updateProgress(controlledTranslate);
- c.setTranslate(controlledTranslate, swiper);
- c.updateActiveIndex();
- c.updateSlidesClasses();
- }
-
- if (Array.isArray(controlled)) {
- for (let i = 0; i < controlled.length; i += 1) {
- if (controlled[i] !== byController && controlled[i] instanceof Swiper) {
- setControlledTranslate(controlled[i]);
- }
- }
- } else if (controlled instanceof Swiper && byController !== controlled) {
- setControlledTranslate(controlled);
- }
- }
-
- function setTransition(duration, byController) {
- const Swiper = swiper.constructor;
- const controlled = swiper.controller.control;
- let i;
-
- function setControlledTransition(c) {
- c.setTransition(duration, swiper);
-
- if (duration !== 0) {
- c.transitionStart();
-
- if (c.params.autoHeight) {
- nextTick(() => {
- c.updateAutoHeight();
- });
- }
-
- c.$wrapperEl.transitionEnd(() => {
- if (!controlled) return;
-
- if (c.params.loop && swiper.params.controller.by === 'slide') {
- c.loopFix();
- }
-
- c.transitionEnd();
- });
- }
- }
-
- if (Array.isArray(controlled)) {
- for (i = 0; i < controlled.length; i += 1) {
- if (controlled[i] !== byController && controlled[i] instanceof Swiper) {
- setControlledTransition(controlled[i]);
- }
- }
- } else if (controlled instanceof Swiper && byController !== controlled) {
- setControlledTransition(controlled);
- }
- }
-
- function removeSpline() {
- if (!swiper.controller.control) return;
-
- if (swiper.controller.spline) {
- swiper.controller.spline = undefined;
- delete swiper.controller.spline;
- }
- }
-
- on('beforeInit', () => {
- swiper.controller.control = swiper.params.controller.control;
- });
- on('update', () => {
- removeSpline();
- });
- on('resize', () => {
- removeSpline();
- });
- on('observerUpdate', () => {
- removeSpline();
- });
- on('setTranslate', (_s, translate, byController) => {
- if (!swiper.controller.control) return;
- swiper.controller.setTranslate(translate, byController);
- });
- on('setTransition', (_s, duration, byController) => {
- if (!swiper.controller.control) return;
- swiper.controller.setTransition(duration, byController);
- });
- Object.assign(swiper.controller, {
- setTranslate,
- setTransition
- });
- }
-
- function A11y(_ref) {
- let {
- swiper,
- extendParams,
- on
- } = _ref;
- extendParams({
- a11y: {
- enabled: true,
- notificationClass: 'swiper-notification',
- prevSlideMessage: 'Previous slide',
- nextSlideMessage: 'Next slide',
- firstSlideMessage: 'This is the first slide',
- lastSlideMessage: 'This is the last slide',
- paginationBulletMessage: 'Go to slide {{index}}',
- slideLabelMessage: '{{index}} / {{slidesLength}}',
- containerMessage: null,
- containerRoleDescriptionMessage: null,
- itemRoleDescriptionMessage: null,
- slideRole: 'group'
- }
- });
- let liveRegion = null;
-
- function notify(message) {
- const notification = liveRegion;
- if (notification.length === 0) return;
- notification.html('');
- notification.html(message);
- }
-
- function getRandomNumber(size) {
- if (size === void 0) {
- size = 16;
- }
-
- const randomChar = () => Math.round(16 * Math.random()).toString(16);
-
- return 'x'.repeat(size).replace(/x/g, randomChar);
- }
-
- function makeElFocusable($el) {
- $el.attr('tabIndex', '0');
- }
-
- function makeElNotFocusable($el) {
- $el.attr('tabIndex', '-1');
- }
-
- function addElRole($el, role) {
- $el.attr('role', role);
- }
-
- function addElRoleDescription($el, description) {
- $el.attr('aria-roledescription', description);
- }
-
- function addElControls($el, controls) {
- $el.attr('aria-controls', controls);
- }
-
- function addElLabel($el, label) {
- $el.attr('aria-label', label);
- }
-
- function addElId($el, id) {
- $el.attr('id', id);
- }
-
- function addElLive($el, live) {
- $el.attr('aria-live', live);
- }
-
- function disableEl($el) {
- $el.attr('aria-disabled', true);
- }
-
- function enableEl($el) {
- $el.attr('aria-disabled', false);
- }
-
- function onEnterOrSpaceKey(e) {
- if (e.keyCode !== 13 && e.keyCode !== 32) return;
- const params = swiper.params.a11y;
- const $targetEl = $(e.target);
-
- if (swiper.navigation && swiper.navigation.$nextEl && $targetEl.is(swiper.navigation.$nextEl)) {
- if (!(swiper.isEnd && !swiper.params.loop)) {
- swiper.slideNext();
- }
-
- if (swiper.isEnd) {
- notify(params.lastSlideMessage);
- } else {
- notify(params.nextSlideMessage);
- }
- }
-
- if (swiper.navigation && swiper.navigation.$prevEl && $targetEl.is(swiper.navigation.$prevEl)) {
- if (!(swiper.isBeginning && !swiper.params.loop)) {
- swiper.slidePrev();
- }
-
- if (swiper.isBeginning) {
- notify(params.firstSlideMessage);
- } else {
- notify(params.prevSlideMessage);
- }
- }
-
- if (swiper.pagination && $targetEl.is(classesToSelector(swiper.params.pagination.bulletClass))) {
- $targetEl[0].click();
- }
- }
-
- function updateNavigation() {
- if (swiper.params.loop || swiper.params.rewind || !swiper.navigation) return;
- const {
- $nextEl,
- $prevEl
- } = swiper.navigation;
-
- if ($prevEl && $prevEl.length > 0) {
- if (swiper.isBeginning) {
- disableEl($prevEl);
- makeElNotFocusable($prevEl);
- } else {
- enableEl($prevEl);
- makeElFocusable($prevEl);
- }
- }
-
- if ($nextEl && $nextEl.length > 0) {
- if (swiper.isEnd) {
- disableEl($nextEl);
- makeElNotFocusable($nextEl);
- } else {
- enableEl($nextEl);
- makeElFocusable($nextEl);
- }
- }
- }
-
- function hasPagination() {
- return swiper.pagination && swiper.pagination.bullets && swiper.pagination.bullets.length;
- }
-
- function hasClickablePagination() {
- return hasPagination() && swiper.params.pagination.clickable;
- }
-
- function updatePagination() {
- const params = swiper.params.a11y;
- if (!hasPagination()) return;
- swiper.pagination.bullets.each(bulletEl => {
- const $bulletEl = $(bulletEl);
-
- if (swiper.params.pagination.clickable) {
- makeElFocusable($bulletEl);
-
- if (!swiper.params.pagination.renderBullet) {
- addElRole($bulletEl, 'button');
- addElLabel($bulletEl, params.paginationBulletMessage.replace(/\{\{index\}\}/, $bulletEl.index() + 1));
- }
- }
-
- if ($bulletEl.is(`.${swiper.params.pagination.bulletActiveClass}`)) {
- $bulletEl.attr('aria-current', 'true');
- } else {
- $bulletEl.removeAttr('aria-current');
- }
- });
- }
-
- const initNavEl = ($el, wrapperId, message) => {
- makeElFocusable($el);
-
- if ($el[0].tagName !== 'BUTTON') {
- addElRole($el, 'button');
- $el.on('keydown', onEnterOrSpaceKey);
- }
-
- addElLabel($el, message);
- addElControls($el, wrapperId);
- };
-
- const handleFocus = e => {
- const slideEl = e.target.closest(`.${swiper.params.slideClass}`);
- if (!slideEl || !swiper.slides.includes(slideEl)) return;
- const isActive = swiper.slides.indexOf(slideEl) === swiper.activeIndex;
- const isVisible = swiper.params.watchSlidesProgress && swiper.visibleSlides && swiper.visibleSlides.includes(slideEl);
- if (isActive || isVisible) return;
- swiper.slideTo(swiper.slides.indexOf(slideEl), 0);
- };
-
- function init() {
- const params = swiper.params.a11y;
- swiper.$el.append(liveRegion); // Container
-
- const $containerEl = swiper.$el;
-
- if (params.containerRoleDescriptionMessage) {
- addElRoleDescription($containerEl, params.containerRoleDescriptionMessage);
- }
-
- if (params.containerMessage) {
- addElLabel($containerEl, params.containerMessage);
- } // Wrapper
-
-
- const $wrapperEl = swiper.$wrapperEl;
- const wrapperId = $wrapperEl.attr('id') || `swiper-wrapper-${getRandomNumber(16)}`;
- const live = swiper.params.autoplay && swiper.params.autoplay.enabled ? 'off' : 'polite';
- addElId($wrapperEl, wrapperId);
- addElLive($wrapperEl, live); // Slide
-
- if (params.itemRoleDescriptionMessage) {
- addElRoleDescription($(swiper.slides), params.itemRoleDescriptionMessage);
- }
-
- addElRole($(swiper.slides), params.slideRole);
- const slidesLength = swiper.params.loop ? swiper.slides.filter(el => !el.classList.contains(swiper.params.slideDuplicateClass)).length : swiper.slides.length;
- swiper.slides.each((slideEl, index) => {
- const $slideEl = $(slideEl);
- const slideIndex = swiper.params.loop ? parseInt($slideEl.attr('data-swiper-slide-index'), 10) : index;
- const ariaLabelMessage = params.slideLabelMessage.replace(/\{\{index\}\}/, slideIndex + 1).replace(/\{\{slidesLength\}\}/, slidesLength);
- addElLabel($slideEl, ariaLabelMessage);
- }); // Navigation
-
- let $nextEl;
- let $prevEl;
-
- if (swiper.navigation && swiper.navigation.$nextEl) {
- $nextEl = swiper.navigation.$nextEl;
- }
-
- if (swiper.navigation && swiper.navigation.$prevEl) {
- $prevEl = swiper.navigation.$prevEl;
- }
-
- if ($nextEl && $nextEl.length) {
- initNavEl($nextEl, wrapperId, params.nextSlideMessage);
- }
-
- if ($prevEl && $prevEl.length) {
- initNavEl($prevEl, wrapperId, params.prevSlideMessage);
- } // Pagination
-
-
- if (hasClickablePagination()) {
- swiper.pagination.$el.on('keydown', classesToSelector(swiper.params.pagination.bulletClass), onEnterOrSpaceKey);
- } // Tab focus
-
-
- swiper.$el.on('focus', handleFocus, true);
- }
-
- function destroy() {
- if (liveRegion && liveRegion.length > 0) liveRegion.remove();
- let $nextEl;
- let $prevEl;
-
- if (swiper.navigation && swiper.navigation.$nextEl) {
- $nextEl = swiper.navigation.$nextEl;
- }
-
- if (swiper.navigation && swiper.navigation.$prevEl) {
- $prevEl = swiper.navigation.$prevEl;
- }
-
- if ($nextEl) {
- $nextEl.off('keydown', onEnterOrSpaceKey);
- }
-
- if ($prevEl) {
- $prevEl.off('keydown', onEnterOrSpaceKey);
- } // Pagination
-
-
- if (hasClickablePagination()) {
- swiper.pagination.$el.off('keydown', classesToSelector(swiper.params.pagination.bulletClass), onEnterOrSpaceKey);
- } // Tab focus
-
-
- swiper.$el.off('focus', handleFocus, true);
- }
-
- on('beforeInit', () => {
- liveRegion = $(` `);
- });
- on('afterInit', () => {
- if (!swiper.params.a11y.enabled) return;
- init();
- });
- on('fromEdge toEdge afterInit lock unlock', () => {
- if (!swiper.params.a11y.enabled) return;
- updateNavigation();
- });
- on('paginationUpdate', () => {
- if (!swiper.params.a11y.enabled) return;
- updatePagination();
- });
- on('destroy', () => {
- if (!swiper.params.a11y.enabled) return;
- destroy();
- });
- }
-
- function History(_ref) {
- let {
- swiper,
- extendParams,
- on
- } = _ref;
- extendParams({
- history: {
- enabled: false,
- root: '',
- replaceState: false,
- key: 'slides'
- }
- });
- let initialized = false;
- let paths = {};
-
- const slugify = text => {
- return text.toString().replace(/\s+/g, '-').replace(/[^\w-]+/g, '').replace(/--+/g, '-').replace(/^-+/, '').replace(/-+$/, '');
- };
-
- const getPathValues = urlOverride => {
- const window = getWindow();
- let location;
-
- if (urlOverride) {
- location = new URL(urlOverride);
- } else {
- location = window.location;
- }
-
- const pathArray = location.pathname.slice(1).split('/').filter(part => part !== '');
- const total = pathArray.length;
- const key = pathArray[total - 2];
- const value = pathArray[total - 1];
- return {
- key,
- value
- };
- };
-
- const setHistory = (key, index) => {
- const window = getWindow();
- if (!initialized || !swiper.params.history.enabled) return;
- let location;
-
- if (swiper.params.url) {
- location = new URL(swiper.params.url);
- } else {
- location = window.location;
- }
-
- const slide = swiper.slides.eq(index);
- let value = slugify(slide.attr('data-history'));
-
- if (swiper.params.history.root.length > 0) {
- let root = swiper.params.history.root;
- if (root[root.length - 1] === '/') root = root.slice(0, root.length - 1);
- value = `${root}/${key}/${value}`;
- } else if (!location.pathname.includes(key)) {
- value = `${key}/${value}`;
- }
-
- const currentState = window.history.state;
-
- if (currentState && currentState.value === value) {
- return;
- }
-
- if (swiper.params.history.replaceState) {
- window.history.replaceState({
- value
- }, null, value);
- } else {
- window.history.pushState({
- value
- }, null, value);
- }
- };
-
- const scrollToSlide = (speed, value, runCallbacks) => {
- if (value) {
- for (let i = 0, length = swiper.slides.length; i < length; i += 1) {
- const slide = swiper.slides.eq(i);
- const slideHistory = slugify(slide.attr('data-history'));
-
- if (slideHistory === value && !slide.hasClass(swiper.params.slideDuplicateClass)) {
- const index = slide.index();
- swiper.slideTo(index, speed, runCallbacks);
- }
- }
- } else {
- swiper.slideTo(0, speed, runCallbacks);
- }
- };
-
- const setHistoryPopState = () => {
- paths = getPathValues(swiper.params.url);
- scrollToSlide(swiper.params.speed, swiper.paths.value, false);
- };
-
- const init = () => {
- const window = getWindow();
- if (!swiper.params.history) return;
-
- if (!window.history || !window.history.pushState) {
- swiper.params.history.enabled = false;
- swiper.params.hashNavigation.enabled = true;
- return;
- }
-
- initialized = true;
- paths = getPathValues(swiper.params.url);
- if (!paths.key && !paths.value) return;
- scrollToSlide(0, paths.value, swiper.params.runCallbacksOnInit);
-
- if (!swiper.params.history.replaceState) {
- window.addEventListener('popstate', setHistoryPopState);
- }
- };
-
- const destroy = () => {
- const window = getWindow();
-
- if (!swiper.params.history.replaceState) {
- window.removeEventListener('popstate', setHistoryPopState);
- }
- };
-
- on('init', () => {
- if (swiper.params.history.enabled) {
- init();
- }
- });
- on('destroy', () => {
- if (swiper.params.history.enabled) {
- destroy();
- }
- });
- on('transitionEnd _freeModeNoMomentumRelease', () => {
- if (initialized) {
- setHistory(swiper.params.history.key, swiper.activeIndex);
- }
- });
- on('slideChange', () => {
- if (initialized && swiper.params.cssMode) {
- setHistory(swiper.params.history.key, swiper.activeIndex);
- }
- });
- }
-
- function HashNavigation(_ref) {
- let {
- swiper,
- extendParams,
- emit,
- on
- } = _ref;
- let initialized = false;
- const document = getDocument();
- const window = getWindow();
- extendParams({
- hashNavigation: {
- enabled: false,
- replaceState: false,
- watchState: false
- }
- });
-
- const onHashChange = () => {
- emit('hashChange');
- const newHash = document.location.hash.replace('#', '');
- const activeSlideHash = swiper.slides.eq(swiper.activeIndex).attr('data-hash');
-
- if (newHash !== activeSlideHash) {
- const newIndex = swiper.$wrapperEl.children(`.${swiper.params.slideClass}[data-hash="${newHash}"]`).index();
- if (typeof newIndex === 'undefined') return;
- swiper.slideTo(newIndex);
- }
- };
-
- const setHash = () => {
- if (!initialized || !swiper.params.hashNavigation.enabled) return;
-
- if (swiper.params.hashNavigation.replaceState && window.history && window.history.replaceState) {
- window.history.replaceState(null, null, `#${swiper.slides.eq(swiper.activeIndex).attr('data-hash')}` || '');
- emit('hashSet');
- } else {
- const slide = swiper.slides.eq(swiper.activeIndex);
- const hash = slide.attr('data-hash') || slide.attr('data-history');
- document.location.hash = hash || '';
- emit('hashSet');
- }
- };
-
- const init = () => {
- if (!swiper.params.hashNavigation.enabled || swiper.params.history && swiper.params.history.enabled) return;
- initialized = true;
- const hash = document.location.hash.replace('#', '');
-
- if (hash) {
- const speed = 0;
-
- for (let i = 0, length = swiper.slides.length; i < length; i += 1) {
- const slide = swiper.slides.eq(i);
- const slideHash = slide.attr('data-hash') || slide.attr('data-history');
-
- if (slideHash === hash && !slide.hasClass(swiper.params.slideDuplicateClass)) {
- const index = slide.index();
- swiper.slideTo(index, speed, swiper.params.runCallbacksOnInit, true);
- }
- }
- }
-
- if (swiper.params.hashNavigation.watchState) {
- $(window).on('hashchange', onHashChange);
- }
- };
-
- const destroy = () => {
- if (swiper.params.hashNavigation.watchState) {
- $(window).off('hashchange', onHashChange);
- }
- };
-
- on('init', () => {
- if (swiper.params.hashNavigation.enabled) {
- init();
- }
- });
- on('destroy', () => {
- if (swiper.params.hashNavigation.enabled) {
- destroy();
- }
- });
- on('transitionEnd _freeModeNoMomentumRelease', () => {
- if (initialized) {
- setHash();
- }
- });
- on('slideChange', () => {
- if (initialized && swiper.params.cssMode) {
- setHash();
- }
- });
- }
-
- /* eslint no-underscore-dangle: "off" */
- function Autoplay(_ref) {
- let {
- swiper,
- extendParams,
- on,
- emit
- } = _ref;
- let timeout;
- swiper.autoplay = {
- running: false,
- paused: false
- };
- extendParams({
- autoplay: {
- enabled: false,
- delay: 3000,
- waitForTransition: true,
- disableOnInteraction: true,
- stopOnLastSlide: false,
- reverseDirection: false,
- pauseOnMouseEnter: false
- }
- });
-
- function run() {
- const $activeSlideEl = swiper.slides.eq(swiper.activeIndex);
- let delay = swiper.params.autoplay.delay;
-
- if ($activeSlideEl.attr('data-swiper-autoplay')) {
- delay = $activeSlideEl.attr('data-swiper-autoplay') || swiper.params.autoplay.delay;
- }
-
- clearTimeout(timeout);
- timeout = nextTick(() => {
- let autoplayResult;
-
- if (swiper.params.autoplay.reverseDirection) {
- if (swiper.params.loop) {
- swiper.loopFix();
- autoplayResult = swiper.slidePrev(swiper.params.speed, true, true);
- emit('autoplay');
- } else if (!swiper.isBeginning) {
- autoplayResult = swiper.slidePrev(swiper.params.speed, true, true);
- emit('autoplay');
- } else if (!swiper.params.autoplay.stopOnLastSlide) {
- autoplayResult = swiper.slideTo(swiper.slides.length - 1, swiper.params.speed, true, true);
- emit('autoplay');
- } else {
- stop();
- }
- } else if (swiper.params.loop) {
- swiper.loopFix();
- autoplayResult = swiper.slideNext(swiper.params.speed, true, true);
- emit('autoplay');
- } else if (!swiper.isEnd) {
- autoplayResult = swiper.slideNext(swiper.params.speed, true, true);
- emit('autoplay');
- } else if (!swiper.params.autoplay.stopOnLastSlide) {
- autoplayResult = swiper.slideTo(0, swiper.params.speed, true, true);
- emit('autoplay');
- } else {
- stop();
- }
-
- if (swiper.params.cssMode && swiper.autoplay.running) run();else if (autoplayResult === false) {
- run();
- }
- }, delay);
- }
-
- function start() {
- if (typeof timeout !== 'undefined') return false;
- if (swiper.autoplay.running) return false;
- swiper.autoplay.running = true;
- emit('autoplayStart');
- run();
- return true;
- }
-
- function stop() {
- if (!swiper.autoplay.running) return false;
- if (typeof timeout === 'undefined') return false;
-
- if (timeout) {
- clearTimeout(timeout);
- timeout = undefined;
- }
-
- swiper.autoplay.running = false;
- emit('autoplayStop');
- return true;
- }
-
- function pause(speed) {
- if (!swiper.autoplay.running) return;
- if (swiper.autoplay.paused) return;
- if (timeout) clearTimeout(timeout);
- swiper.autoplay.paused = true;
-
- if (speed === 0 || !swiper.params.autoplay.waitForTransition) {
- swiper.autoplay.paused = false;
- run();
- } else {
- ['transitionend', 'webkitTransitionEnd'].forEach(event => {
- swiper.$wrapperEl[0].addEventListener(event, onTransitionEnd);
- });
- }
- }
-
- function onVisibilityChange() {
- const document = getDocument();
-
- if (document.visibilityState === 'hidden' && swiper.autoplay.running) {
- pause();
- }
-
- if (document.visibilityState === 'visible' && swiper.autoplay.paused) {
- run();
- swiper.autoplay.paused = false;
- }
- }
-
- function onTransitionEnd(e) {
- if (!swiper || swiper.destroyed || !swiper.$wrapperEl) return;
- if (e.target !== swiper.$wrapperEl[0]) return;
- ['transitionend', 'webkitTransitionEnd'].forEach(event => {
- swiper.$wrapperEl[0].removeEventListener(event, onTransitionEnd);
- });
- swiper.autoplay.paused = false;
-
- if (!swiper.autoplay.running) {
- stop();
- } else {
- run();
- }
- }
-
- function onMouseEnter() {
- if (swiper.params.autoplay.disableOnInteraction) {
- stop();
- } else {
- emit('autoplayPause');
- pause();
- }
-
- ['transitionend', 'webkitTransitionEnd'].forEach(event => {
- swiper.$wrapperEl[0].removeEventListener(event, onTransitionEnd);
- });
- }
-
- function onMouseLeave() {
- if (swiper.params.autoplay.disableOnInteraction) {
- return;
- }
-
- swiper.autoplay.paused = false;
- emit('autoplayResume');
- run();
- }
-
- function attachMouseEvents() {
- if (swiper.params.autoplay.pauseOnMouseEnter) {
- swiper.$el.on('mouseenter', onMouseEnter);
- swiper.$el.on('mouseleave', onMouseLeave);
- }
- }
-
- function detachMouseEvents() {
- swiper.$el.off('mouseenter', onMouseEnter);
- swiper.$el.off('mouseleave', onMouseLeave);
- }
-
- on('init', () => {
- if (swiper.params.autoplay.enabled) {
- start();
- const document = getDocument();
- document.addEventListener('visibilitychange', onVisibilityChange);
- attachMouseEvents();
- }
- });
- on('beforeTransitionStart', (_s, speed, internal) => {
- if (swiper.autoplay.running) {
- if (internal || !swiper.params.autoplay.disableOnInteraction) {
- swiper.autoplay.pause(speed);
- } else {
- stop();
- }
- }
- });
- on('sliderFirstMove', () => {
- if (swiper.autoplay.running) {
- if (swiper.params.autoplay.disableOnInteraction) {
- stop();
- } else {
- pause();
- }
- }
- });
- on('touchEnd', () => {
- if (swiper.params.cssMode && swiper.autoplay.paused && !swiper.params.autoplay.disableOnInteraction) {
- run();
- }
- });
- on('destroy', () => {
- detachMouseEvents();
-
- if (swiper.autoplay.running) {
- stop();
- }
-
- const document = getDocument();
- document.removeEventListener('visibilitychange', onVisibilityChange);
- });
- Object.assign(swiper.autoplay, {
- pause,
- run,
- start,
- stop
- });
- }
-
- function Thumb(_ref) {
- let {
- swiper,
- extendParams,
- on
- } = _ref;
- extendParams({
- thumbs: {
- swiper: null,
- multipleActiveThumbs: true,
- autoScrollOffset: 0,
- slideThumbActiveClass: 'swiper-slide-thumb-active',
- thumbsContainerClass: 'swiper-thumbs'
- }
- });
- let initialized = false;
- let swiperCreated = false;
- swiper.thumbs = {
- swiper: null
- };
-
- function onThumbClick() {
- const thumbsSwiper = swiper.thumbs.swiper;
- if (!thumbsSwiper) return;
- const clickedIndex = thumbsSwiper.clickedIndex;
- const clickedSlide = thumbsSwiper.clickedSlide;
- if (clickedSlide && $(clickedSlide).hasClass(swiper.params.thumbs.slideThumbActiveClass)) return;
- if (typeof clickedIndex === 'undefined' || clickedIndex === null) return;
- let slideToIndex;
-
- if (thumbsSwiper.params.loop) {
- slideToIndex = parseInt($(thumbsSwiper.clickedSlide).attr('data-swiper-slide-index'), 10);
- } else {
- slideToIndex = clickedIndex;
- }
-
- if (swiper.params.loop) {
- let currentIndex = swiper.activeIndex;
-
- if (swiper.slides.eq(currentIndex).hasClass(swiper.params.slideDuplicateClass)) {
- swiper.loopFix(); // eslint-disable-next-line
-
- swiper._clientLeft = swiper.$wrapperEl[0].clientLeft;
- currentIndex = swiper.activeIndex;
- }
-
- const prevIndex = swiper.slides.eq(currentIndex).prevAll(`[data-swiper-slide-index="${slideToIndex}"]`).eq(0).index();
- const nextIndex = swiper.slides.eq(currentIndex).nextAll(`[data-swiper-slide-index="${slideToIndex}"]`).eq(0).index();
- if (typeof prevIndex === 'undefined') slideToIndex = nextIndex;else if (typeof nextIndex === 'undefined') slideToIndex = prevIndex;else if (nextIndex - currentIndex < currentIndex - prevIndex) slideToIndex = nextIndex;else slideToIndex = prevIndex;
- }
-
- swiper.slideTo(slideToIndex);
- }
-
- function init() {
- const {
- thumbs: thumbsParams
- } = swiper.params;
- if (initialized) return false;
- initialized = true;
- const SwiperClass = swiper.constructor;
-
- if (thumbsParams.swiper instanceof SwiperClass) {
- swiper.thumbs.swiper = thumbsParams.swiper;
- Object.assign(swiper.thumbs.swiper.originalParams, {
- watchSlidesProgress: true,
- slideToClickedSlide: false
- });
- Object.assign(swiper.thumbs.swiper.params, {
- watchSlidesProgress: true,
- slideToClickedSlide: false
- });
- } else if (isObject(thumbsParams.swiper)) {
- const thumbsSwiperParams = Object.assign({}, thumbsParams.swiper);
- Object.assign(thumbsSwiperParams, {
- watchSlidesProgress: true,
- slideToClickedSlide: false
- });
- swiper.thumbs.swiper = new SwiperClass(thumbsSwiperParams);
- swiperCreated = true;
- }
-
- swiper.thumbs.swiper.$el.addClass(swiper.params.thumbs.thumbsContainerClass);
- swiper.thumbs.swiper.on('tap', onThumbClick);
- return true;
- }
-
- function update(initial) {
- const thumbsSwiper = swiper.thumbs.swiper;
- if (!thumbsSwiper) return;
- const slidesPerView = thumbsSwiper.params.slidesPerView === 'auto' ? thumbsSwiper.slidesPerViewDynamic() : thumbsSwiper.params.slidesPerView;
- const autoScrollOffset = swiper.params.thumbs.autoScrollOffset;
- const useOffset = autoScrollOffset && !thumbsSwiper.params.loop;
-
- if (swiper.realIndex !== thumbsSwiper.realIndex || useOffset) {
- let currentThumbsIndex = thumbsSwiper.activeIndex;
- let newThumbsIndex;
- let direction;
-
- if (thumbsSwiper.params.loop) {
- if (thumbsSwiper.slides.eq(currentThumbsIndex).hasClass(thumbsSwiper.params.slideDuplicateClass)) {
- thumbsSwiper.loopFix(); // eslint-disable-next-line
-
- thumbsSwiper._clientLeft = thumbsSwiper.$wrapperEl[0].clientLeft;
- currentThumbsIndex = thumbsSwiper.activeIndex;
- } // Find actual thumbs index to slide to
-
-
- const prevThumbsIndex = thumbsSwiper.slides.eq(currentThumbsIndex).prevAll(`[data-swiper-slide-index="${swiper.realIndex}"]`).eq(0).index();
- const nextThumbsIndex = thumbsSwiper.slides.eq(currentThumbsIndex).nextAll(`[data-swiper-slide-index="${swiper.realIndex}"]`).eq(0).index();
-
- if (typeof prevThumbsIndex === 'undefined') {
- newThumbsIndex = nextThumbsIndex;
- } else if (typeof nextThumbsIndex === 'undefined') {
- newThumbsIndex = prevThumbsIndex;
- } else if (nextThumbsIndex - currentThumbsIndex === currentThumbsIndex - prevThumbsIndex) {
- newThumbsIndex = thumbsSwiper.params.slidesPerGroup > 1 ? nextThumbsIndex : currentThumbsIndex;
- } else if (nextThumbsIndex - currentThumbsIndex < currentThumbsIndex - prevThumbsIndex) {
- newThumbsIndex = nextThumbsIndex;
- } else {
- newThumbsIndex = prevThumbsIndex;
- }
-
- direction = swiper.activeIndex > swiper.previousIndex ? 'next' : 'prev';
- } else {
- newThumbsIndex = swiper.realIndex;
- direction = newThumbsIndex > swiper.previousIndex ? 'next' : 'prev';
- }
-
- if (useOffset) {
- newThumbsIndex += direction === 'next' ? autoScrollOffset : -1 * autoScrollOffset;
- }
-
- if (thumbsSwiper.visibleSlidesIndexes && thumbsSwiper.visibleSlidesIndexes.indexOf(newThumbsIndex) < 0) {
- if (thumbsSwiper.params.centeredSlides) {
- if (newThumbsIndex > currentThumbsIndex) {
- newThumbsIndex = newThumbsIndex - Math.floor(slidesPerView / 2) + 1;
- } else {
- newThumbsIndex = newThumbsIndex + Math.floor(slidesPerView / 2) - 1;
- }
- } else if (newThumbsIndex > currentThumbsIndex && thumbsSwiper.params.slidesPerGroup === 1) ;
-
- thumbsSwiper.slideTo(newThumbsIndex, initial ? 0 : undefined);
- }
- } // Activate thumbs
-
-
- let thumbsToActivate = 1;
- const thumbActiveClass = swiper.params.thumbs.slideThumbActiveClass;
-
- if (swiper.params.slidesPerView > 1 && !swiper.params.centeredSlides) {
- thumbsToActivate = swiper.params.slidesPerView;
- }
-
- if (!swiper.params.thumbs.multipleActiveThumbs) {
- thumbsToActivate = 1;
- }
-
- thumbsToActivate = Math.floor(thumbsToActivate);
- thumbsSwiper.slides.removeClass(thumbActiveClass);
-
- if (thumbsSwiper.params.loop || thumbsSwiper.params.virtual && thumbsSwiper.params.virtual.enabled) {
- for (let i = 0; i < thumbsToActivate; i += 1) {
- thumbsSwiper.$wrapperEl.children(`[data-swiper-slide-index="${swiper.realIndex + i}"]`).addClass(thumbActiveClass);
- }
- } else {
- for (let i = 0; i < thumbsToActivate; i += 1) {
- thumbsSwiper.slides.eq(swiper.realIndex + i).addClass(thumbActiveClass);
- }
- }
- }
-
- on('beforeInit', () => {
- const {
- thumbs
- } = swiper.params;
- if (!thumbs || !thumbs.swiper) return;
- init();
- update(true);
- });
- on('slideChange update resize observerUpdate', () => {
- if (!swiper.thumbs.swiper) return;
- update();
- });
- on('setTransition', (_s, duration) => {
- const thumbsSwiper = swiper.thumbs.swiper;
- if (!thumbsSwiper) return;
- thumbsSwiper.setTransition(duration);
- });
- on('beforeDestroy', () => {
- const thumbsSwiper = swiper.thumbs.swiper;
- if (!thumbsSwiper) return;
-
- if (swiperCreated && thumbsSwiper) {
- thumbsSwiper.destroy();
- }
- });
- Object.assign(swiper.thumbs, {
- init,
- update
- });
- }
-
- function freeMode(_ref) {
- let {
- swiper,
- extendParams,
- emit,
- once
- } = _ref;
- extendParams({
- freeMode: {
- enabled: false,
- momentum: true,
- momentumRatio: 1,
- momentumBounce: true,
- momentumBounceRatio: 1,
- momentumVelocityRatio: 1,
- sticky: false,
- minimumVelocity: 0.02
- }
- });
-
- function onTouchStart() {
- const translate = swiper.getTranslate();
- swiper.setTranslate(translate);
- swiper.setTransition(0);
- swiper.touchEventsData.velocities.length = 0;
- swiper.freeMode.onTouchEnd({
- currentPos: swiper.rtl ? swiper.translate : -swiper.translate
- });
- }
-
- function onTouchMove() {
- const {
- touchEventsData: data,
- touches
- } = swiper; // Velocity
-
- if (data.velocities.length === 0) {
- data.velocities.push({
- position: touches[swiper.isHorizontal() ? 'startX' : 'startY'],
- time: data.touchStartTime
- });
- }
-
- data.velocities.push({
- position: touches[swiper.isHorizontal() ? 'currentX' : 'currentY'],
- time: now()
- });
- }
-
- function onTouchEnd(_ref2) {
- let {
- currentPos
- } = _ref2;
- const {
- params,
- $wrapperEl,
- rtlTranslate: rtl,
- snapGrid,
- touchEventsData: data
- } = swiper; // Time diff
-
- const touchEndTime = now();
- const timeDiff = touchEndTime - data.touchStartTime;
-
- if (currentPos < -swiper.minTranslate()) {
- swiper.slideTo(swiper.activeIndex);
- return;
- }
-
- if (currentPos > -swiper.maxTranslate()) {
- if (swiper.slides.length < snapGrid.length) {
- swiper.slideTo(snapGrid.length - 1);
- } else {
- swiper.slideTo(swiper.slides.length - 1);
- }
-
- return;
- }
-
- if (params.freeMode.momentum) {
- if (data.velocities.length > 1) {
- const lastMoveEvent = data.velocities.pop();
- const velocityEvent = data.velocities.pop();
- const distance = lastMoveEvent.position - velocityEvent.position;
- const time = lastMoveEvent.time - velocityEvent.time;
- swiper.velocity = distance / time;
- swiper.velocity /= 2;
-
- if (Math.abs(swiper.velocity) < params.freeMode.minimumVelocity) {
- swiper.velocity = 0;
- } // this implies that the user stopped moving a finger then released.
- // There would be no events with distance zero, so the last event is stale.
-
-
- if (time > 150 || now() - lastMoveEvent.time > 300) {
- swiper.velocity = 0;
- }
- } else {
- swiper.velocity = 0;
- }
-
- swiper.velocity *= params.freeMode.momentumVelocityRatio;
- data.velocities.length = 0;
- let momentumDuration = 1000 * params.freeMode.momentumRatio;
- const momentumDistance = swiper.velocity * momentumDuration;
- let newPosition = swiper.translate + momentumDistance;
- if (rtl) newPosition = -newPosition;
- let doBounce = false;
- let afterBouncePosition;
- const bounceAmount = Math.abs(swiper.velocity) * 20 * params.freeMode.momentumBounceRatio;
- let needsLoopFix;
-
- if (newPosition < swiper.maxTranslate()) {
- if (params.freeMode.momentumBounce) {
- if (newPosition + swiper.maxTranslate() < -bounceAmount) {
- newPosition = swiper.maxTranslate() - bounceAmount;
- }
-
- afterBouncePosition = swiper.maxTranslate();
- doBounce = true;
- data.allowMomentumBounce = true;
- } else {
- newPosition = swiper.maxTranslate();
- }
-
- if (params.loop && params.centeredSlides) needsLoopFix = true;
- } else if (newPosition > swiper.minTranslate()) {
- if (params.freeMode.momentumBounce) {
- if (newPosition - swiper.minTranslate() > bounceAmount) {
- newPosition = swiper.minTranslate() + bounceAmount;
- }
-
- afterBouncePosition = swiper.minTranslate();
- doBounce = true;
- data.allowMomentumBounce = true;
- } else {
- newPosition = swiper.minTranslate();
- }
-
- if (params.loop && params.centeredSlides) needsLoopFix = true;
- } else if (params.freeMode.sticky) {
- let nextSlide;
-
- for (let j = 0; j < snapGrid.length; j += 1) {
- if (snapGrid[j] > -newPosition) {
- nextSlide = j;
- break;
- }
- }
-
- if (Math.abs(snapGrid[nextSlide] - newPosition) < Math.abs(snapGrid[nextSlide - 1] - newPosition) || swiper.swipeDirection === 'next') {
- newPosition = snapGrid[nextSlide];
- } else {
- newPosition = snapGrid[nextSlide - 1];
- }
-
- newPosition = -newPosition;
- }
-
- if (needsLoopFix) {
- once('transitionEnd', () => {
- swiper.loopFix();
- });
- } // Fix duration
-
-
- if (swiper.velocity !== 0) {
- if (rtl) {
- momentumDuration = Math.abs((-newPosition - swiper.translate) / swiper.velocity);
- } else {
- momentumDuration = Math.abs((newPosition - swiper.translate) / swiper.velocity);
- }
-
- if (params.freeMode.sticky) {
- // If freeMode.sticky is active and the user ends a swipe with a slow-velocity
- // event, then durations can be 20+ seconds to slide one (or zero!) slides.
- // It's easy to see this when simulating touch with mouse events. To fix this,
- // limit single-slide swipes to the default slide duration. This also has the
- // nice side effect of matching slide speed if the user stopped moving before
- // lifting finger or mouse vs. moving slowly before lifting the finger/mouse.
- // For faster swipes, also apply limits (albeit higher ones).
- const moveDistance = Math.abs((rtl ? -newPosition : newPosition) - swiper.translate);
- const currentSlideSize = swiper.slidesSizesGrid[swiper.activeIndex];
-
- if (moveDistance < currentSlideSize) {
- momentumDuration = params.speed;
- } else if (moveDistance < 2 * currentSlideSize) {
- momentumDuration = params.speed * 1.5;
- } else {
- momentumDuration = params.speed * 2.5;
- }
- }
- } else if (params.freeMode.sticky) {
- swiper.slideToClosest();
- return;
- }
-
- if (params.freeMode.momentumBounce && doBounce) {
- swiper.updateProgress(afterBouncePosition);
- swiper.setTransition(momentumDuration);
- swiper.setTranslate(newPosition);
- swiper.transitionStart(true, swiper.swipeDirection);
- swiper.animating = true;
- $wrapperEl.transitionEnd(() => {
- if (!swiper || swiper.destroyed || !data.allowMomentumBounce) return;
- emit('momentumBounce');
- swiper.setTransition(params.speed);
- setTimeout(() => {
- swiper.setTranslate(afterBouncePosition);
- $wrapperEl.transitionEnd(() => {
- if (!swiper || swiper.destroyed) return;
- swiper.transitionEnd();
- });
- }, 0);
- });
- } else if (swiper.velocity) {
- emit('_freeModeNoMomentumRelease');
- swiper.updateProgress(newPosition);
- swiper.setTransition(momentumDuration);
- swiper.setTranslate(newPosition);
- swiper.transitionStart(true, swiper.swipeDirection);
-
- if (!swiper.animating) {
- swiper.animating = true;
- $wrapperEl.transitionEnd(() => {
- if (!swiper || swiper.destroyed) return;
- swiper.transitionEnd();
- });
- }
- } else {
- swiper.updateProgress(newPosition);
- }
-
- swiper.updateActiveIndex();
- swiper.updateSlidesClasses();
- } else if (params.freeMode.sticky) {
- swiper.slideToClosest();
- return;
- } else if (params.freeMode) {
- emit('_freeModeNoMomentumRelease');
- }
-
- if (!params.freeMode.momentum || timeDiff >= params.longSwipesMs) {
- swiper.updateProgress();
- swiper.updateActiveIndex();
- swiper.updateSlidesClasses();
- }
- }
-
- Object.assign(swiper, {
- freeMode: {
- onTouchStart,
- onTouchMove,
- onTouchEnd
- }
- });
- }
-
- function Grid(_ref) {
- let {
- swiper,
- extendParams
- } = _ref;
- extendParams({
- grid: {
- rows: 1,
- fill: 'column'
- }
- });
- let slidesNumberEvenToRows;
- let slidesPerRow;
- let numFullColumns;
-
- const initSlides = slidesLength => {
- const {
- slidesPerView
- } = swiper.params;
- const {
- rows,
- fill
- } = swiper.params.grid;
- slidesPerRow = slidesNumberEvenToRows / rows;
- numFullColumns = Math.floor(slidesLength / rows);
-
- if (Math.floor(slidesLength / rows) === slidesLength / rows) {
- slidesNumberEvenToRows = slidesLength;
- } else {
- slidesNumberEvenToRows = Math.ceil(slidesLength / rows) * rows;
- }
-
- if (slidesPerView !== 'auto' && fill === 'row') {
- slidesNumberEvenToRows = Math.max(slidesNumberEvenToRows, slidesPerView * rows);
- }
- };
-
- const updateSlide = (i, slide, slidesLength, getDirectionLabel) => {
- const {
- slidesPerGroup,
- spaceBetween
- } = swiper.params;
- const {
- rows,
- fill
- } = swiper.params.grid; // Set slides order
-
- let newSlideOrderIndex;
- let column;
- let row;
-
- if (fill === 'row' && slidesPerGroup > 1) {
- const groupIndex = Math.floor(i / (slidesPerGroup * rows));
- const slideIndexInGroup = i - rows * slidesPerGroup * groupIndex;
- const columnsInGroup = groupIndex === 0 ? slidesPerGroup : Math.min(Math.ceil((slidesLength - groupIndex * rows * slidesPerGroup) / rows), slidesPerGroup);
- row = Math.floor(slideIndexInGroup / columnsInGroup);
- column = slideIndexInGroup - row * columnsInGroup + groupIndex * slidesPerGroup;
- newSlideOrderIndex = column + row * slidesNumberEvenToRows / rows;
- slide.css({
- '-webkit-order': newSlideOrderIndex,
- order: newSlideOrderIndex
- });
- } else if (fill === 'column') {
- column = Math.floor(i / rows);
- row = i - column * rows;
-
- if (column > numFullColumns || column === numFullColumns && row === rows - 1) {
- row += 1;
-
- if (row >= rows) {
- row = 0;
- column += 1;
- }
- }
- } else {
- row = Math.floor(i / slidesPerRow);
- column = i - row * slidesPerRow;
- }
-
- slide.css(getDirectionLabel('margin-top'), row !== 0 ? spaceBetween && `${spaceBetween}px` : '');
- };
-
- const updateWrapperSize = (slideSize, snapGrid, getDirectionLabel) => {
- const {
- spaceBetween,
- centeredSlides,
- roundLengths
- } = swiper.params;
- const {
- rows
- } = swiper.params.grid;
- swiper.virtualSize = (slideSize + spaceBetween) * slidesNumberEvenToRows;
- swiper.virtualSize = Math.ceil(swiper.virtualSize / rows) - spaceBetween;
- swiper.$wrapperEl.css({
- [getDirectionLabel('width')]: `${swiper.virtualSize + spaceBetween}px`
- });
-
- if (centeredSlides) {
- snapGrid.splice(0, snapGrid.length);
- const newSlidesGrid = [];
-
- for (let i = 0; i < snapGrid.length; i += 1) {
- let slidesGridItem = snapGrid[i];
- if (roundLengths) slidesGridItem = Math.floor(slidesGridItem);
- if (snapGrid[i] < swiper.virtualSize + snapGrid[0]) newSlidesGrid.push(slidesGridItem);
- }
-
- snapGrid.push(...newSlidesGrid);
- }
- };
-
- swiper.grid = {
- initSlides,
- updateSlide,
- updateWrapperSize
- };
- }
-
- function appendSlide(slides) {
- const swiper = this;
- const {
- $wrapperEl,
- params
- } = swiper;
-
- if (params.loop) {
- swiper.loopDestroy();
- }
-
- if (typeof slides === 'object' && 'length' in slides) {
- for (let i = 0; i < slides.length; i += 1) {
- if (slides[i]) $wrapperEl.append(slides[i]);
- }
- } else {
- $wrapperEl.append(slides);
- }
-
- if (params.loop) {
- swiper.loopCreate();
- }
-
- if (!params.observer) {
- swiper.update();
- }
- }
-
- function prependSlide(slides) {
- const swiper = this;
- const {
- params,
- $wrapperEl,
- activeIndex
- } = swiper;
-
- if (params.loop) {
- swiper.loopDestroy();
- }
-
- let newActiveIndex = activeIndex + 1;
-
- if (typeof slides === 'object' && 'length' in slides) {
- for (let i = 0; i < slides.length; i += 1) {
- if (slides[i]) $wrapperEl.prepend(slides[i]);
- }
-
- newActiveIndex = activeIndex + slides.length;
- } else {
- $wrapperEl.prepend(slides);
- }
-
- if (params.loop) {
- swiper.loopCreate();
- }
-
- if (!params.observer) {
- swiper.update();
- }
-
- swiper.slideTo(newActiveIndex, 0, false);
- }
-
- function addSlide(index, slides) {
- const swiper = this;
- const {
- $wrapperEl,
- params,
- activeIndex
- } = swiper;
- let activeIndexBuffer = activeIndex;
-
- if (params.loop) {
- activeIndexBuffer -= swiper.loopedSlides;
- swiper.loopDestroy();
- swiper.slides = $wrapperEl.children(`.${params.slideClass}`);
- }
-
- const baseLength = swiper.slides.length;
-
- if (index <= 0) {
- swiper.prependSlide(slides);
- return;
- }
-
- if (index >= baseLength) {
- swiper.appendSlide(slides);
- return;
- }
-
- let newActiveIndex = activeIndexBuffer > index ? activeIndexBuffer + 1 : activeIndexBuffer;
- const slidesBuffer = [];
-
- for (let i = baseLength - 1; i >= index; i -= 1) {
- const currentSlide = swiper.slides.eq(i);
- currentSlide.remove();
- slidesBuffer.unshift(currentSlide);
- }
-
- if (typeof slides === 'object' && 'length' in slides) {
- for (let i = 0; i < slides.length; i += 1) {
- if (slides[i]) $wrapperEl.append(slides[i]);
- }
-
- newActiveIndex = activeIndexBuffer > index ? activeIndexBuffer + slides.length : activeIndexBuffer;
- } else {
- $wrapperEl.append(slides);
- }
-
- for (let i = 0; i < slidesBuffer.length; i += 1) {
- $wrapperEl.append(slidesBuffer[i]);
- }
-
- if (params.loop) {
- swiper.loopCreate();
- }
-
- if (!params.observer) {
- swiper.update();
- }
-
- if (params.loop) {
- swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);
- } else {
- swiper.slideTo(newActiveIndex, 0, false);
- }
- }
-
- function removeSlide(slidesIndexes) {
- const swiper = this;
- const {
- params,
- $wrapperEl,
- activeIndex
- } = swiper;
- let activeIndexBuffer = activeIndex;
-
- if (params.loop) {
- activeIndexBuffer -= swiper.loopedSlides;
- swiper.loopDestroy();
- swiper.slides = $wrapperEl.children(`.${params.slideClass}`);
- }
-
- let newActiveIndex = activeIndexBuffer;
- let indexToRemove;
-
- if (typeof slidesIndexes === 'object' && 'length' in slidesIndexes) {
- for (let i = 0; i < slidesIndexes.length; i += 1) {
- indexToRemove = slidesIndexes[i];
- if (swiper.slides[indexToRemove]) swiper.slides.eq(indexToRemove).remove();
- if (indexToRemove < newActiveIndex) newActiveIndex -= 1;
- }
-
- newActiveIndex = Math.max(newActiveIndex, 0);
- } else {
- indexToRemove = slidesIndexes;
- if (swiper.slides[indexToRemove]) swiper.slides.eq(indexToRemove).remove();
- if (indexToRemove < newActiveIndex) newActiveIndex -= 1;
- newActiveIndex = Math.max(newActiveIndex, 0);
- }
-
- if (params.loop) {
- swiper.loopCreate();
- }
-
- if (!params.observer) {
- swiper.update();
- }
-
- if (params.loop) {
- swiper.slideTo(newActiveIndex + swiper.loopedSlides, 0, false);
- } else {
- swiper.slideTo(newActiveIndex, 0, false);
- }
- }
-
- function removeAllSlides() {
- const swiper = this;
- const slidesIndexes = [];
-
- for (let i = 0; i < swiper.slides.length; i += 1) {
- slidesIndexes.push(i);
- }
-
- swiper.removeSlide(slidesIndexes);
- }
-
- function Manipulation(_ref) {
- let {
- swiper
- } = _ref;
- Object.assign(swiper, {
- appendSlide: appendSlide.bind(swiper),
- prependSlide: prependSlide.bind(swiper),
- addSlide: addSlide.bind(swiper),
- removeSlide: removeSlide.bind(swiper),
- removeAllSlides: removeAllSlides.bind(swiper)
- });
- }
-
- function effectInit(params) {
- const {
- effect,
- swiper,
- on,
- setTranslate,
- setTransition,
- overwriteParams,
- perspective
- } = params;
- on('beforeInit', () => {
- if (swiper.params.effect !== effect) return;
- swiper.classNames.push(`${swiper.params.containerModifierClass}${effect}`);
-
- if (perspective && perspective()) {
- swiper.classNames.push(`${swiper.params.containerModifierClass}3d`);
- }
-
- const overwriteParamsResult = overwriteParams ? overwriteParams() : {};
- Object.assign(swiper.params, overwriteParamsResult);
- Object.assign(swiper.originalParams, overwriteParamsResult);
- });
- on('setTranslate', () => {
- if (swiper.params.effect !== effect) return;
- setTranslate();
- });
- on('setTransition', (_s, duration) => {
- if (swiper.params.effect !== effect) return;
- setTransition(duration);
- });
- let requireUpdateOnVirtual;
- on('virtualUpdate', () => {
- if (!swiper.slides.length) {
- requireUpdateOnVirtual = true;
- }
-
- requestAnimationFrame(() => {
- if (requireUpdateOnVirtual && swiper.slides.length) {
- setTranslate();
- requireUpdateOnVirtual = false;
- }
- });
- });
- }
-
- function effectTarget(effectParams, $slideEl) {
- if (effectParams.transformEl) {
- return $slideEl.find(effectParams.transformEl).css({
- 'backface-visibility': 'hidden',
- '-webkit-backface-visibility': 'hidden'
- });
- }
-
- return $slideEl;
- }
-
- function effectVirtualTransitionEnd(_ref) {
- let {
- swiper,
- duration,
- transformEl,
- allSlides
- } = _ref;
- const {
- slides,
- activeIndex,
- $wrapperEl
- } = swiper;
-
- if (swiper.params.virtualTranslate && duration !== 0) {
- let eventTriggered = false;
- let $transitionEndTarget;
-
- if (allSlides) {
- $transitionEndTarget = transformEl ? slides.find(transformEl) : slides;
- } else {
- $transitionEndTarget = transformEl ? slides.eq(activeIndex).find(transformEl) : slides.eq(activeIndex);
- }
-
- $transitionEndTarget.transitionEnd(() => {
- if (eventTriggered) return;
- if (!swiper || swiper.destroyed) return;
- eventTriggered = true;
- swiper.animating = false;
- const triggerEvents = ['webkitTransitionEnd', 'transitionend'];
-
- for (let i = 0; i < triggerEvents.length; i += 1) {
- $wrapperEl.trigger(triggerEvents[i]);
- }
- });
- }
- }
-
- function EffectFade(_ref) {
- let {
- swiper,
- extendParams,
- on
- } = _ref;
- extendParams({
- fadeEffect: {
- crossFade: false,
- transformEl: null
- }
- });
-
- const setTranslate = () => {
- const {
- slides
- } = swiper;
- const params = swiper.params.fadeEffect;
-
- for (let i = 0; i < slides.length; i += 1) {
- const $slideEl = swiper.slides.eq(i);
- const offset = $slideEl[0].swiperSlideOffset;
- let tx = -offset;
- if (!swiper.params.virtualTranslate) tx -= swiper.translate;
- let ty = 0;
-
- if (!swiper.isHorizontal()) {
- ty = tx;
- tx = 0;
- }
-
- const slideOpacity = swiper.params.fadeEffect.crossFade ? Math.max(1 - Math.abs($slideEl[0].progress), 0) : 1 + Math.min(Math.max($slideEl[0].progress, -1), 0);
- const $targetEl = effectTarget(params, $slideEl);
- $targetEl.css({
- opacity: slideOpacity
- }).transform(`translate3d(${tx}px, ${ty}px, 0px)`);
- }
- };
-
- const setTransition = duration => {
- const {
- transformEl
- } = swiper.params.fadeEffect;
- const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;
- $transitionElements.transition(duration);
- effectVirtualTransitionEnd({
- swiper,
- duration,
- transformEl,
- allSlides: true
- });
- };
-
- effectInit({
- effect: 'fade',
- swiper,
- on,
- setTranslate,
- setTransition,
- overwriteParams: () => ({
- slidesPerView: 1,
- slidesPerGroup: 1,
- watchSlidesProgress: true,
- spaceBetween: 0,
- virtualTranslate: !swiper.params.cssMode
- })
- });
- }
-
- function EffectCube(_ref) {
- let {
- swiper,
- extendParams,
- on
- } = _ref;
- extendParams({
- cubeEffect: {
- slideShadows: true,
- shadow: true,
- shadowOffset: 20,
- shadowScale: 0.94
- }
- });
-
- const setTranslate = () => {
- const {
- $el,
- $wrapperEl,
- slides,
- width: swiperWidth,
- height: swiperHeight,
- rtlTranslate: rtl,
- size: swiperSize,
- browser
- } = swiper;
- const params = swiper.params.cubeEffect;
- const isHorizontal = swiper.isHorizontal();
- const isVirtual = swiper.virtual && swiper.params.virtual.enabled;
- let wrapperRotate = 0;
- let $cubeShadowEl;
-
- if (params.shadow) {
- if (isHorizontal) {
- $cubeShadowEl = $wrapperEl.find('.swiper-cube-shadow');
-
- if ($cubeShadowEl.length === 0) {
- $cubeShadowEl = $('
');
- $wrapperEl.append($cubeShadowEl);
- }
-
- $cubeShadowEl.css({
- height: `${swiperWidth}px`
- });
- } else {
- $cubeShadowEl = $el.find('.swiper-cube-shadow');
-
- if ($cubeShadowEl.length === 0) {
- $cubeShadowEl = $('
');
- $el.append($cubeShadowEl);
- }
- }
- }
-
- for (let i = 0; i < slides.length; i += 1) {
- const $slideEl = slides.eq(i);
- let slideIndex = i;
-
- if (isVirtual) {
- slideIndex = parseInt($slideEl.attr('data-swiper-slide-index'), 10);
- }
-
- let slideAngle = slideIndex * 90;
- let round = Math.floor(slideAngle / 360);
-
- if (rtl) {
- slideAngle = -slideAngle;
- round = Math.floor(-slideAngle / 360);
- }
-
- const progress = Math.max(Math.min($slideEl[0].progress, 1), -1);
- let tx = 0;
- let ty = 0;
- let tz = 0;
-
- if (slideIndex % 4 === 0) {
- tx = -round * 4 * swiperSize;
- tz = 0;
- } else if ((slideIndex - 1) % 4 === 0) {
- tx = 0;
- tz = -round * 4 * swiperSize;
- } else if ((slideIndex - 2) % 4 === 0) {
- tx = swiperSize + round * 4 * swiperSize;
- tz = swiperSize;
- } else if ((slideIndex - 3) % 4 === 0) {
- tx = -swiperSize;
- tz = 3 * swiperSize + swiperSize * 4 * round;
- }
-
- if (rtl) {
- tx = -tx;
- }
-
- if (!isHorizontal) {
- ty = tx;
- tx = 0;
- }
-
- const transform = `rotateX(${isHorizontal ? 0 : -slideAngle}deg) rotateY(${isHorizontal ? slideAngle : 0}deg) translate3d(${tx}px, ${ty}px, ${tz}px)`;
-
- if (progress <= 1 && progress > -1) {
- wrapperRotate = slideIndex * 90 + progress * 90;
- if (rtl) wrapperRotate = -slideIndex * 90 - progress * 90;
- }
-
- $slideEl.transform(transform);
-
- if (params.slideShadows) {
- // Set shadows
- let shadowBefore = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');
- let shadowAfter = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');
-
- if (shadowBefore.length === 0) {
- shadowBefore = $(`
`);
- $slideEl.append(shadowBefore);
- }
-
- if (shadowAfter.length === 0) {
- shadowAfter = $(`
`);
- $slideEl.append(shadowAfter);
- }
-
- if (shadowBefore.length) shadowBefore[0].style.opacity = Math.max(-progress, 0);
- if (shadowAfter.length) shadowAfter[0].style.opacity = Math.max(progress, 0);
- }
- }
-
- $wrapperEl.css({
- '-webkit-transform-origin': `50% 50% -${swiperSize / 2}px`,
- 'transform-origin': `50% 50% -${swiperSize / 2}px`
- });
-
- if (params.shadow) {
- if (isHorizontal) {
- $cubeShadowEl.transform(`translate3d(0px, ${swiperWidth / 2 + params.shadowOffset}px, ${-swiperWidth / 2}px) rotateX(90deg) rotateZ(0deg) scale(${params.shadowScale})`);
- } else {
- const shadowAngle = Math.abs(wrapperRotate) - Math.floor(Math.abs(wrapperRotate) / 90) * 90;
- const multiplier = 1.5 - (Math.sin(shadowAngle * 2 * Math.PI / 360) / 2 + Math.cos(shadowAngle * 2 * Math.PI / 360) / 2);
- const scale1 = params.shadowScale;
- const scale2 = params.shadowScale / multiplier;
- const offset = params.shadowOffset;
- $cubeShadowEl.transform(`scale3d(${scale1}, 1, ${scale2}) translate3d(0px, ${swiperHeight / 2 + offset}px, ${-swiperHeight / 2 / scale2}px) rotateX(-90deg)`);
- }
- }
-
- const zFactor = browser.isSafari || browser.isWebView ? -swiperSize / 2 : 0;
- $wrapperEl.transform(`translate3d(0px,0,${zFactor}px) rotateX(${swiper.isHorizontal() ? 0 : wrapperRotate}deg) rotateY(${swiper.isHorizontal() ? -wrapperRotate : 0}deg)`);
- };
-
- const setTransition = duration => {
- const {
- $el,
- slides
- } = swiper;
- slides.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);
-
- if (swiper.params.cubeEffect.shadow && !swiper.isHorizontal()) {
- $el.find('.swiper-cube-shadow').transition(duration);
- }
- };
-
- effectInit({
- effect: 'cube',
- swiper,
- on,
- setTranslate,
- setTransition,
- perspective: () => true,
- overwriteParams: () => ({
- slidesPerView: 1,
- slidesPerGroup: 1,
- watchSlidesProgress: true,
- resistanceRatio: 0,
- spaceBetween: 0,
- centeredSlides: false,
- virtualTranslate: true
- })
- });
- }
-
- function createShadow(params, $slideEl, side) {
- const shadowClass = `swiper-slide-shadow${side ? `-${side}` : ''}`;
- const $shadowContainer = params.transformEl ? $slideEl.find(params.transformEl) : $slideEl;
- let $shadowEl = $shadowContainer.children(`.${shadowClass}`);
-
- if (!$shadowEl.length) {
- $shadowEl = $(`
`);
- $shadowContainer.append($shadowEl);
- }
-
- return $shadowEl;
- }
-
- function EffectFlip(_ref) {
- let {
- swiper,
- extendParams,
- on
- } = _ref;
- extendParams({
- flipEffect: {
- slideShadows: true,
- limitRotation: true,
- transformEl: null
- }
- });
-
- const setTranslate = () => {
- const {
- slides,
- rtlTranslate: rtl
- } = swiper;
- const params = swiper.params.flipEffect;
-
- for (let i = 0; i < slides.length; i += 1) {
- const $slideEl = slides.eq(i);
- let progress = $slideEl[0].progress;
-
- if (swiper.params.flipEffect.limitRotation) {
- progress = Math.max(Math.min($slideEl[0].progress, 1), -1);
- }
-
- const offset = $slideEl[0].swiperSlideOffset;
- const rotate = -180 * progress;
- let rotateY = rotate;
- let rotateX = 0;
- let tx = swiper.params.cssMode ? -offset - swiper.translate : -offset;
- let ty = 0;
-
- if (!swiper.isHorizontal()) {
- ty = tx;
- tx = 0;
- rotateX = -rotateY;
- rotateY = 0;
- } else if (rtl) {
- rotateY = -rotateY;
- }
-
- $slideEl[0].style.zIndex = -Math.abs(Math.round(progress)) + slides.length;
-
- if (params.slideShadows) {
- // Set shadows
- let shadowBefore = swiper.isHorizontal() ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');
- let shadowAfter = swiper.isHorizontal() ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');
-
- if (shadowBefore.length === 0) {
- shadowBefore = createShadow(params, $slideEl, swiper.isHorizontal() ? 'left' : 'top');
- }
-
- if (shadowAfter.length === 0) {
- shadowAfter = createShadow(params, $slideEl, swiper.isHorizontal() ? 'right' : 'bottom');
- }
-
- if (shadowBefore.length) shadowBefore[0].style.opacity = Math.max(-progress, 0);
- if (shadowAfter.length) shadowAfter[0].style.opacity = Math.max(progress, 0);
- }
-
- const transform = `translate3d(${tx}px, ${ty}px, 0px) rotateX(${rotateX}deg) rotateY(${rotateY}deg)`;
- const $targetEl = effectTarget(params, $slideEl);
- $targetEl.transform(transform);
- }
- };
-
- const setTransition = duration => {
- const {
- transformEl
- } = swiper.params.flipEffect;
- const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;
- $transitionElements.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);
- effectVirtualTransitionEnd({
- swiper,
- duration,
- transformEl
- });
- };
-
- effectInit({
- effect: 'flip',
- swiper,
- on,
- setTranslate,
- setTransition,
- perspective: () => true,
- overwriteParams: () => ({
- slidesPerView: 1,
- slidesPerGroup: 1,
- watchSlidesProgress: true,
- spaceBetween: 0,
- virtualTranslate: !swiper.params.cssMode
- })
- });
- }
-
- function EffectCoverflow(_ref) {
- let {
- swiper,
- extendParams,
- on
- } = _ref;
- extendParams({
- coverflowEffect: {
- rotate: 50,
- stretch: 0,
- depth: 100,
- scale: 1,
- modifier: 1,
- slideShadows: true,
- transformEl: null
- }
- });
-
- const setTranslate = () => {
- const {
- width: swiperWidth,
- height: swiperHeight,
- slides,
- slidesSizesGrid
- } = swiper;
- const params = swiper.params.coverflowEffect;
- const isHorizontal = swiper.isHorizontal();
- const transform = swiper.translate;
- const center = isHorizontal ? -transform + swiperWidth / 2 : -transform + swiperHeight / 2;
- const rotate = isHorizontal ? params.rotate : -params.rotate;
- const translate = params.depth; // Each slide offset from center
-
- for (let i = 0, length = slides.length; i < length; i += 1) {
- const $slideEl = slides.eq(i);
- const slideSize = slidesSizesGrid[i];
- const slideOffset = $slideEl[0].swiperSlideOffset;
- const centerOffset = (center - slideOffset - slideSize / 2) / slideSize;
- const offsetMultiplier = typeof params.modifier === 'function' ? params.modifier(centerOffset) : centerOffset * params.modifier;
- let rotateY = isHorizontal ? rotate * offsetMultiplier : 0;
- let rotateX = isHorizontal ? 0 : rotate * offsetMultiplier; // var rotateZ = 0
-
- let translateZ = -translate * Math.abs(offsetMultiplier);
- let stretch = params.stretch; // Allow percentage to make a relative stretch for responsive sliders
-
- if (typeof stretch === 'string' && stretch.indexOf('%') !== -1) {
- stretch = parseFloat(params.stretch) / 100 * slideSize;
- }
-
- let translateY = isHorizontal ? 0 : stretch * offsetMultiplier;
- let translateX = isHorizontal ? stretch * offsetMultiplier : 0;
- let scale = 1 - (1 - params.scale) * Math.abs(offsetMultiplier); // Fix for ultra small values
-
- if (Math.abs(translateX) < 0.001) translateX = 0;
- if (Math.abs(translateY) < 0.001) translateY = 0;
- if (Math.abs(translateZ) < 0.001) translateZ = 0;
- if (Math.abs(rotateY) < 0.001) rotateY = 0;
- if (Math.abs(rotateX) < 0.001) rotateX = 0;
- if (Math.abs(scale) < 0.001) scale = 0;
- const slideTransform = `translate3d(${translateX}px,${translateY}px,${translateZ}px) rotateX(${rotateX}deg) rotateY(${rotateY}deg) scale(${scale})`;
- const $targetEl = effectTarget(params, $slideEl);
- $targetEl.transform(slideTransform);
- $slideEl[0].style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1;
-
- if (params.slideShadows) {
- // Set shadows
- let $shadowBeforeEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');
- let $shadowAfterEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');
-
- if ($shadowBeforeEl.length === 0) {
- $shadowBeforeEl = createShadow(params, $slideEl, isHorizontal ? 'left' : 'top');
- }
-
- if ($shadowAfterEl.length === 0) {
- $shadowAfterEl = createShadow(params, $slideEl, isHorizontal ? 'right' : 'bottom');
- }
-
- if ($shadowBeforeEl.length) $shadowBeforeEl[0].style.opacity = offsetMultiplier > 0 ? offsetMultiplier : 0;
- if ($shadowAfterEl.length) $shadowAfterEl[0].style.opacity = -offsetMultiplier > 0 ? -offsetMultiplier : 0;
- }
- }
- };
-
- const setTransition = duration => {
- const {
- transformEl
- } = swiper.params.coverflowEffect;
- const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;
- $transitionElements.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);
- };
-
- effectInit({
- effect: 'coverflow',
- swiper,
- on,
- setTranslate,
- setTransition,
- perspective: () => true,
- overwriteParams: () => ({
- watchSlidesProgress: true
- })
- });
- }
-
- function EffectCreative(_ref) {
- let {
- swiper,
- extendParams,
- on
- } = _ref;
- extendParams({
- creativeEffect: {
- transformEl: null,
- limitProgress: 1,
- shadowPerProgress: false,
- progressMultiplier: 1,
- perspective: true,
- prev: {
- translate: [0, 0, 0],
- rotate: [0, 0, 0],
- opacity: 1,
- scale: 1
- },
- next: {
- translate: [0, 0, 0],
- rotate: [0, 0, 0],
- opacity: 1,
- scale: 1
- }
- }
- });
-
- const getTranslateValue = value => {
- if (typeof value === 'string') return value;
- return `${value}px`;
- };
-
- const setTranslate = () => {
- const {
- slides,
- $wrapperEl,
- slidesSizesGrid
- } = swiper;
- const params = swiper.params.creativeEffect;
- const {
- progressMultiplier: multiplier
- } = params;
- const isCenteredSlides = swiper.params.centeredSlides;
-
- if (isCenteredSlides) {
- const margin = slidesSizesGrid[0] / 2 - swiper.params.slidesOffsetBefore || 0;
- $wrapperEl.transform(`translateX(calc(50% - ${margin}px))`);
- }
-
- for (let i = 0; i < slides.length; i += 1) {
- const $slideEl = slides.eq(i);
- const slideProgress = $slideEl[0].progress;
- const progress = Math.min(Math.max($slideEl[0].progress, -params.limitProgress), params.limitProgress);
- let originalProgress = progress;
-
- if (!isCenteredSlides) {
- originalProgress = Math.min(Math.max($slideEl[0].originalProgress, -params.limitProgress), params.limitProgress);
- }
-
- const offset = $slideEl[0].swiperSlideOffset;
- const t = [swiper.params.cssMode ? -offset - swiper.translate : -offset, 0, 0];
- const r = [0, 0, 0];
- let custom = false;
-
- if (!swiper.isHorizontal()) {
- t[1] = t[0];
- t[0] = 0;
- }
-
- let data = {
- translate: [0, 0, 0],
- rotate: [0, 0, 0],
- scale: 1,
- opacity: 1
- };
-
- if (progress < 0) {
- data = params.next;
- custom = true;
- } else if (progress > 0) {
- data = params.prev;
- custom = true;
- } // set translate
-
-
- t.forEach((value, index) => {
- t[index] = `calc(${value}px + (${getTranslateValue(data.translate[index])} * ${Math.abs(progress * multiplier)}))`;
- }); // set rotates
-
- r.forEach((value, index) => {
- r[index] = data.rotate[index] * Math.abs(progress * multiplier);
- });
- $slideEl[0].style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;
- const translateString = t.join(', ');
- const rotateString = `rotateX(${r[0]}deg) rotateY(${r[1]}deg) rotateZ(${r[2]}deg)`;
- const scaleString = originalProgress < 0 ? `scale(${1 + (1 - data.scale) * originalProgress * multiplier})` : `scale(${1 - (1 - data.scale) * originalProgress * multiplier})`;
- const opacityString = originalProgress < 0 ? 1 + (1 - data.opacity) * originalProgress * multiplier : 1 - (1 - data.opacity) * originalProgress * multiplier;
- const transform = `translate3d(${translateString}) ${rotateString} ${scaleString}`; // Set shadows
-
- if (custom && data.shadow || !custom) {
- let $shadowEl = $slideEl.children('.swiper-slide-shadow');
-
- if ($shadowEl.length === 0 && data.shadow) {
- $shadowEl = createShadow(params, $slideEl);
- }
-
- if ($shadowEl.length) {
- const shadowOpacity = params.shadowPerProgress ? progress * (1 / params.limitProgress) : progress;
- $shadowEl[0].style.opacity = Math.min(Math.max(Math.abs(shadowOpacity), 0), 1);
- }
- }
-
- const $targetEl = effectTarget(params, $slideEl);
- $targetEl.transform(transform).css({
- opacity: opacityString
- });
-
- if (data.origin) {
- $targetEl.css('transform-origin', data.origin);
- }
- }
- };
-
- const setTransition = duration => {
- const {
- transformEl
- } = swiper.params.creativeEffect;
- const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;
- $transitionElements.transition(duration).find('.swiper-slide-shadow').transition(duration);
- effectVirtualTransitionEnd({
- swiper,
- duration,
- transformEl,
- allSlides: true
- });
- };
-
- effectInit({
- effect: 'creative',
- swiper,
- on,
- setTranslate,
- setTransition,
- perspective: () => swiper.params.creativeEffect.perspective,
- overwriteParams: () => ({
- watchSlidesProgress: true,
- virtualTranslate: !swiper.params.cssMode
- })
- });
- }
-
- function EffectCards(_ref) {
- let {
- swiper,
- extendParams,
- on
- } = _ref;
- extendParams({
- cardsEffect: {
- slideShadows: true,
- transformEl: null
- }
- });
-
- const setTranslate = () => {
- const {
- slides,
- activeIndex
- } = swiper;
- const params = swiper.params.cardsEffect;
- const {
- startTranslate,
- isTouched
- } = swiper.touchEventsData;
- const currentTranslate = swiper.translate;
-
- for (let i = 0; i < slides.length; i += 1) {
- const $slideEl = slides.eq(i);
- const slideProgress = $slideEl[0].progress;
- const progress = Math.min(Math.max(slideProgress, -4), 4);
- let offset = $slideEl[0].swiperSlideOffset;
-
- if (swiper.params.centeredSlides && !swiper.params.cssMode) {
- swiper.$wrapperEl.transform(`translateX(${swiper.minTranslate()}px)`);
- }
-
- if (swiper.params.centeredSlides && swiper.params.cssMode) {
- offset -= slides[0].swiperSlideOffset;
- }
-
- let tX = swiper.params.cssMode ? -offset - swiper.translate : -offset;
- let tY = 0;
- const tZ = -100 * Math.abs(progress);
- let scale = 1;
- let rotate = -2 * progress;
- let tXAdd = 8 - Math.abs(progress) * 0.75;
- const slideIndex = swiper.virtual && swiper.params.virtual.enabled ? swiper.virtual.from + i : i;
- const isSwipeToNext = (slideIndex === activeIndex || slideIndex === activeIndex - 1) && progress > 0 && progress < 1 && (isTouched || swiper.params.cssMode) && currentTranslate < startTranslate;
- const isSwipeToPrev = (slideIndex === activeIndex || slideIndex === activeIndex + 1) && progress < 0 && progress > -1 && (isTouched || swiper.params.cssMode) && currentTranslate > startTranslate;
-
- if (isSwipeToNext || isSwipeToPrev) {
- const subProgress = (1 - Math.abs((Math.abs(progress) - 0.5) / 0.5)) ** 0.5;
- rotate += -28 * progress * subProgress;
- scale += -0.5 * subProgress;
- tXAdd += 96 * subProgress;
- tY = `${-25 * subProgress * Math.abs(progress)}%`;
- }
-
- if (progress < 0) {
- // next
- tX = `calc(${tX}px + (${tXAdd * Math.abs(progress)}%))`;
- } else if (progress > 0) {
- // prev
- tX = `calc(${tX}px + (-${tXAdd * Math.abs(progress)}%))`;
- } else {
- tX = `${tX}px`;
- }
-
- if (!swiper.isHorizontal()) {
- const prevY = tY;
- tY = tX;
- tX = prevY;
- }
-
- const scaleString = progress < 0 ? `${1 + (1 - scale) * progress}` : `${1 - (1 - scale) * progress}`;
- const transform = `
- translate3d(${tX}, ${tY}, ${tZ}px)
- rotateZ(${rotate}deg)
- scale(${scaleString})
- `;
-
- if (params.slideShadows) {
- // Set shadows
- let $shadowEl = $slideEl.find('.swiper-slide-shadow');
-
- if ($shadowEl.length === 0) {
- $shadowEl = createShadow(params, $slideEl);
- }
-
- if ($shadowEl.length) $shadowEl[0].style.opacity = Math.min(Math.max((Math.abs(progress) - 0.5) / 0.5, 0), 1);
- }
-
- $slideEl[0].style.zIndex = -Math.abs(Math.round(slideProgress)) + slides.length;
- const $targetEl = effectTarget(params, $slideEl);
- $targetEl.transform(transform);
- }
- };
-
- const setTransition = duration => {
- const {
- transformEl
- } = swiper.params.cardsEffect;
- const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;
- $transitionElements.transition(duration).find('.swiper-slide-shadow').transition(duration);
- effectVirtualTransitionEnd({
- swiper,
- duration,
- transformEl
- });
- };
-
- effectInit({
- effect: 'cards',
- swiper,
- on,
- setTranslate,
- setTransition,
- perspective: () => true,
- overwriteParams: () => ({
- watchSlidesProgress: true,
- virtualTranslate: !swiper.params.cssMode
- })
- });
- }
-
- // Swiper Class
- const modules = [Virtual, Keyboard, Mousewheel, Navigation, Pagination, Scrollbar, Parallax, Zoom, Lazy, Controller, A11y, History, HashNavigation, Autoplay, Thumb, freeMode, Grid, Manipulation, EffectFade, EffectCube, EffectFlip, EffectCoverflow, EffectCreative, EffectCards];
- Swiper.use(modules);
-
- return Swiper;
-
-}));
-//# sourceMappingURL=swiper-bundle.js.map
diff --git a/site/templates/layout/func.php b/site/templates/layout/func.php
index 5034fb7..b071e3b 100644
--- a/site/templates/layout/func.php
+++ b/site/templates/layout/func.php
@@ -1,5 +1,10 @@
parametro_mantemento==1)
{
$configuracion['mantemento'] = array(
- "activo" => true,
- "titular" => $config->titular,
- "artigo" => $config->artigo,
- "imaxe" => $config->imaxe
+ 'activo' => true,
+ 'titular' => $config->titular,
+ 'artigo' => $config->artigo,
+ 'imaxe' => $config->imaxe
);
}
else
{
- $configuracion['mantemento'] = array("activo" => false);
+ $configuracion['mantemento'] = array('activo' => false);
+ }
+ break;
+ case 'logo':
+ foreach($config->imaxes as $logo)
+ {
+ $configuracion['logo'][$logo->tags] = array(
+ 'url' => $logo->url,
+ 'alt' => $logo->description
+ );
}
break;
}
-
}
return $configuracion;
}
-function getTextoLimpo($texto)
-{
- $texto = preg_replace ('/<[^>]*>/', ' ', $texto);
- $texto = str_replace("\r", '', $texto);
- $texto = str_replace("\n", ' ', $texto);
- $texto = str_replace("\t", ' ', $texto);
- $texto = trim(preg_replace('/ {2,}/', ' ', $texto));
-
- return $texto;
-}
+/**
+ * @param array|PageArray $seccions
+ * @return string
+ */
function getSeccions($seccions)
{
$saida = '';
+ $posicion = 0;
foreach($seccions as $seccion)
{
+ $posicion++;
switch($seccion->template)
{
case 'repeater_seccions':
switch ($seccion->seccion_tipo->value)
{
- case 'texto':
- $saida .= renderTexto($seccion->titular, $seccion->artigo);
+ case 'deslizante':
+ $saida .= renderDeslizante($seccion);
break;
- case 'galeria':
- $saida .= renderGaleria($seccion->titular, $seccion->imaxes_galeria);
+ case 'destacados':
+ $saida .= renderDestacado($seccion);
break;
- case 'reixa':
- $saida .= renderReixa($seccion->titular, $seccion->imaxes_reixa);
+ case 'columnas':
+ $saida .= renderColumna($seccion);
break;
case 'imaxe_texto_lateral':
- $saida .= renderTextoImaxe($seccion->titular, $seccion->artigo, $seccion->imaxe, $seccion->imaxe_posicion->value);
+ $saida .= renderImaxeTexto($seccion);
+ break;
+ case 'opinions':
+ $saida .= renderOpinions($seccion);
+ break;
+ case 'empresas':
+ $saida .= renderEmpresas($seccion);
+ break;
+ case 'texto':
+ $saida .= renderTexto($seccion);
+ break;
+ case 'galeria':
+ $saida .= renderGaleria($seccion);
+ break;
+ case 'reixa':
+ $saida .= renderReixa($seccion);
break;
}
break;
- case 'repeater_imaxe_ligazon':
- $saida .= renderImaxeLigazon($seccion->titular, $seccion->imaxe, $seccion->ligazon);
+ case 'repeater_deslizante':
+ $saida .= renderDiapositiva($seccion, $posicion);
+ break;
+ case 'repeater_botons':
+ $saida .= renderBoton($seccion);
+ break;
+ case 'repeater_ligazon_imaxe':
+ $saida .= renderLigazonImaxe($seccion);
+ break;
+ case 'repeater_destacados':
+ case 'repeater_columnas':
+ $saida .= renderElemento($seccion, $posicion);
+ break;
+ case 'repeater_opinions':
+ $saida .= renderCita($seccion);
break;
}
}
return $saida;
}
-function renderMenu($paxinas, $maxDepth = 0, $id = 'nav', $clases = '')
+/**
+ * @param PageArray $paxinas
+ * @param string $clase
+ * @return string
+ */
+
+function renderMenu($paxinas, $clase = 'navbar-nav')
{
+ $saida = '';
+ $inicio = wire('pages')->get('/');
+ $actual = wire('page');
+
if($paxinas instanceof Page)
{
$paxinas = array($paxinas);
}
- $saida = '';
+ $saida .= '' . "\n";
return $saida;
}
+
+/**
+ * @param array|PageArray $paxina
+* @param string $separador
+* @return string
+*/
function renderMigasPan($paxina, $separador = ' ')
{
@@ -130,7 +164,7 @@ function renderMigasPan($paxina, $separador = '
switch ($paxina->template)
{
- case 'portada':
+ case 'inicio':
$icono = 'home';
break;
case 'paxina':
@@ -154,302 +188,303 @@ function renderMigasPan($paxina, $separador = '
break;
}
- $saida .= '' . "\n";
- $saida .= $separador;
+ $saida .= '
' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= '' . "\n";
+
foreach($paxina->parents() as $pai)
{
- $saida .= '' . $pai->title . ' ' . $separador . ' ';
+ $saida .= '' . $separador . '' . $pai->title . ' ' . "\n";
}
- $saida .= ($icono != '')? ' ' : '';
- $saida .= '' . $paxina->title . ' ';
+ $saida .= '' . $separador . ' ' . (($icono != '')? ' ' : '') . '' . $paxina->title . ' ';
if($paxina->editable()):
$saida .= ' [ ' . _x('Edit', 'Edit page') . ' ]';
endif;
- $saida .= "\n";
+ $saida .= ' ' . "\n";
+
+ $saida .= ' ' . "\n";
+ $saida .= ' ' . "\n";
$saida .= '
';
return $saida;
}
-function renderPaxinacion($artigos, $posicion)
-{
- $paxinacion = $artigos->renderPager(array(
- 'listMarkup' => '
',
- 'itemMarkup' => '
{out} ',
- 'linkMarkup' => '
{out} ',
- 'nextItemLabel' => '
',
- 'previousItemLabel' => '
',
- 'separatorItemClass' => 'separador',
- 'nextItemClass' => 'seguinte',
- 'previousItemClass' => 'anterior',
- 'lastItemClass' => 'derradeiro',
- 'currentItemClass' => 'actual'
- ));
-
- return $paxinacion;
-}
-
-function renderTexto($titulo, $texto)
-{
- $saida = '';
-
- $saida .= '
' . "\n";
- $saida .= $texto . "\n";
- $saida .= '
' . "\n";
-
- if($titulo)
- {
- $saida = '
' . "\n" . '' . $titulo . ' ' . "\n" . $texto . "\n" . ' ';
- }
-
- return $saida;
-}
-
-function renderGaleria($titulo, $galeria)
-{
- $saida = '';
-
- $saida .= '
' . "\n";
- $saida .= '';
- if($titulo)
- {
- $saida .= $titulo;
- }
- else
- {
- $saida .= 'Galeria';
- }
- $saida .= ' ' . "\n";
- $saida .= '' . "\n";
- foreach($galeria as $imaxe)
- {
- $saida .= '
' . "\n";
- $saida .= '
' . "\n";
- $saida .= ' ' . "\n";
- $saida .= '' . $imaxe->description . ' ' . "\n";
- $saida .= ' ' . "\n";
- $saida .= '
' . "\n";
- }
- $saida .= '
' . "\n";
- $saida .= '
' . "\n";
- $saida .= '
' . "\n";
- $saida .= '
' . "\n";
- $saida .= ' ';
-
- return $saida;
-}
-
-function renderReixa($titulo, $reixa)
-{
- $saida = '';
-
- $saida .= '
' . "\n";
- $saida .= '';
- if($titulo)
- {
- $saida .= $titulo;
- }
- else
- {
- $saida .= 'Reixa de imaxes';
- }
- $saida .= ' ' . "\n";
- $saida .= '' . "\n";
- foreach($reixa as $imaxe)
- {
- $saida .= '
' . "\n";
- $saida .= ' ' . "\n";
- $saida .= '' . $imaxe->description . ' ' . "\n";
- $saida .= ' ' . "\n";
- }
- $saida .= '
' . "\n";
- $saida .= ' ';
-
- return $saida;
-}
-
-function renderTextoImaxe($titulo, $texto, $imaxe, $posicion)
-{
- $saida = '';
-
- $saida .= '
' . "\n";
- $saida .= '
' . "\n";
- $saida .= ' ' . "\n";
- $saida .= '' . $imaxe->description . ' ' . "\n";
- $saida .= ' ' . "\n";
- if($texto)
- {
- $saida .= $texto . "\n";
- }
- $saida .= '
' . "\n";
-
- if($titulo)
- {
- $saida = '
' . "\n" . '' . $titulo . ' ' . "\n" . $saida . ' ';
- }
-
- return $saida;
-}
+/**
+ * @param string $titulo
+ * @param string $texto
+ * @param array|PageArray $imaxe
+ * @return string
+ */
function renderTextoMantemento($titulo, $texto, $imaxe)
{
$saida = '';
- $saida .= '
' . "\n";
- $saida .= '' . $titulo . ' ' . "\n";
- if($imaxe)
- {
- $saida .= '' . "\n";
- $saida .= ' ' . "\n";
- $saida .= '' . $texto . ' ' . "\n";
- $saida .= ' ' . "\n";
- }
- else
- {
- $saida .= $texto . "\n";
- }
- $saida .= ' ';
-
- return $saida;
-}
-
-function renderImaxeLigazon($titular, $imaxe, $ligazon)
-{
- $saida = '';
-
- $saida .= '
' . "\n";
- $saida .= '
' . "\n";
- $saida .= ' ' . "\n";
- $saida .= '' . "\n";
- $saida .= '' . $ligazon->title . ' ' . "\n";
- $saida .= ' ' . "\n";
- $saida .= ' ' . "\n";
- $saida .= '
' . "\n";
-
- return $saida;
-}
-
-function renderCategoriasEtiquetas($data)
-{
- $saida = '';
-
- switch ($data->first()->template->name)
- {
- case 'categoria':
- $icono = 'folder';
- $nome = 'categorias';
- break;
-
- case 'etiqueta':
- $icono = 'tag';
- $nome = 'etiquetas';
- break;
- default:
- $icono = 'sn';
- $nome = 'sin';
- break;
- }
-
- $saida .= '
' . "\n";
- $saida .= '' . pages()->get('/noticias/' . $nome)->title . ' ' . "\n";
- $saida .= '' . "\n";
- foreach($data as $item)
- {
- $numPosts = pages()->count('template=publicacion, ' . $nome . '=' . $item->name);
-
- $saida .= '' . "\n";
- $saida .= ' ' . $item->title . ' ' . "\n";
- $saida .= '(' . sprintf(_n('%d post', '%d posts', $numPosts), $numPosts) . ') ' . "\n";
- $saida .= ' ' . "\n";
- }
- $saida .= ' ' . "\n";
+ $saida .= '' . "\n";
+ $saida .= '' . "\n";
+ $saida .= '
' . $titulo . ' ' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= $texto . "\n";
+ $saida .= '
' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= '
' . "\n";
$saida .= '' . "\n";
return $saida;
}
-function renderResumen($texto = '', $limite = 120, $fin = '...')
+/**
+ * @param array|PageArray $seccion
+ * @return string
+ */
+
+function renderGaleria($seccion)
{
$saida = '';
- if($texto == '') return '';
-
- if(strlen($texto) <= $limite) return $texto;
-
- $saida = substr($texto, 0, $limite);
- $pos = strrpos($saida, " ");
- if($pos>0)
+ $saida .= '
' . "\n";
+ $saida .= '' . (($seccion->titular) ? $seccion->titular : 'Galeria') . ' ' . "\n";
+ $saida .= '' . "\n";
+ foreach($seccion->imaxes as $imaxe)
{
- $saida = substr($saida, 0, $pos);
+ $saida .= '
' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= ' ' . "\n";
+ $saida .= '' . $imaxe->description . ' ' . "\n";
+ $saida .= ' ' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= '
' . "\n";
}
- $saida .= $fin;
- return $saida;
-
-}
-
-function renderArtigos($publicacion, $locale, $resumen = true)
-{
- $saida = '';
-
- $data = strtotime($publicacion->fecha_publicacion);
-
- $dateFormatter = \IntlDateFormatter::create(
- $locale,
- \IntlDateFormatter::NONE,
- \IntlDateFormatter::NONE,
- \date_default_timezone_get(),
- \IntlDateFormatter::GREGORIAN
- );
-
- $saida .= '
' . "\n";
- $saida .= '' . "\n";
- $saida .= '' ."\n";
- $dateFormatter->setPattern('EEEE');
- $saida .= '' . ucfirst(datefmt_format($dateFormatter, $data)) . ' ' . "\n";
- $dateFormatter->setPattern('MMMM');
- $saida .= '' . ucfirst(datefmt_format($dateFormatter, $data)) . ' ' . "\n";
- $dateFormatter->setPattern('dd');
- $saida .= '' . datefmt_format($dateFormatter, $data) . ' ' . "\n";
- $saida .= ' ' . "\n";
- $saida .= '' . "\n";
- $saida .= '
' . "\n";
- $saida .= '
' . "\n";
- $saida .= ' ' . _x('Author', 'Post author') . ' ' . "\n";
- $saida .= '' . ucfirst($publicacion->createdUser->name) . ' ' . "\n";
- $saida .= ' ' . pages()->get('/noticias/categorias/')->title . ' ' . "\n";
- $saida .= '' . $publicacion->categorias->title . ' ' . "\n";
- $saida .= ' ' . pages()->get('/noticias/etiquetas/')->title . ' ' . "\n";
- $saida .= '' . $publicacion->etiquetas->each("{title} ") . ' ' . "\n";
- $saida .= ' ' . "\n";
$saida .= '
' . "\n";
- $saida .= ' ' . "\n";
- if($resumen)
- {
- if($publicacion->imaxe)
- {
- $thumb = $publicacion->imaxe->size(466, 260);
- $saida .= ' ' . "\n";
- }
- $saida .= '' . "\n";
- }
- else
- {
- if($publicacion->imaxe)
- {
- $thumb = $publicacion->imaxe->size(466, 260);
- $saida .= ' ' . "\n";
- }
- $saida .= '' . "\n";
- $saida .= getSeccions($publicacion->seccions) . "\n";
- $saida .= '
' . "\n";
- }
- $saida .= ' ' . "\n";
+ $saida .= '
Previous
' . "\n";
+ $saida .= '
Next
' . "\n";
+ $saida .= '' . "\n";
+ $saida .= '' . "\n";
+ $saida .= '';
return $saida;
}
+
+/**
+ * @param array|PageArray $seccion
+ * @return string
+ */
+
+function renderReixa($seccion)
+{
+ $saida = '';
+
+ $saida .= '
' . "\n";
+ $saida .= '' . (($seccion->titular) ? $seccion->titular : 'Reixa') . ' ' . "\n";
+ $saida .= '' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= '
' . "\n";
+ foreach($seccion->imaxes as $imaxe)
+ {
+ $saida .= '
' . "\n";
+ $saida .= $imaxe->url . "\n";
+ $saida .= '
'. "\n";
+ }
+ $saida .= '
' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= '' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= ' ';
+
+ return $saida;
+}
+
+/**
+ * @param array|PageArray $seccion
+ * @return string
+ */
+
+function renderImaxeTexto($seccion)
+{
+ $saida = '';
+ $imaxe = '';
+ $texto = '';
+ $botons = '';
+
+ if($seccion->imaxe)
+ {
+ $imaxe .= renderImaxe($seccion);
+ }
+
+ $texto .= renderTexto($seccion);
+
+ if($seccion->botons->isEmpty())
+ {
+ $botons .= '
' . "\n";
+ $botons .= getSeccions($seccion->botons) . "\n";
+ $botons .= '
' . "\n";
+ }
+
+ switch ($seccion->imaxe_posicion->value)
+ {
+ case 'superior':
+ $saida .= '
' . "\n";
+ $saida .= '' . "\n";
+ $saida .= $imaxe . "\n";
+ $saida .= '
' . "\n";
+ $saida .= '' . "\n";
+ $saida .= $texto . "\n";
+ $saida .= '
' . "\n";
+ $saida .= $botons . "\n";
+ break;
+ case 'esquerda':
+ $saida .= '' . "\n";
+ $saida .= '' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= $imaxe . "\n";
+ $saida .= '
' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= $texto . "\n";
+ $saida .= $botons . "\n";
+ $saida .= '
' . "\n";
+ $saida .= '
' . "\n";
+ break;
+ case 'dereita':
+ $saida .= '' . "\n";
+ $saida .= '' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= $texto . "\n";
+ $saida .= $botons . "\n";
+ $saida .= '
' . "\n";
+ $saida .= '
' . "\n";
+ $saida .= $imaxe . "\n";
+ $saida .= '
' . "\n";
+ $saida .= '
' . "\n";
+ break;
+ }
+ $saida .= ' ' . "\n";
+
+ return $saida;
+}
+
+/**
+ * @param array|PageArray $seccion
+ * @return string
+ */
+
+function renderImaxe($seccion)
+{
+ $saida = '';
+
+ $saida .= ' ' . "\n";
+
+ return $saida;
+}
+
+/**
+ * @param array|PageArray $seccion
+ * @return string
+ */
+
+function renderTexto($seccion)
+{
+ $saida = '';
+
+ if($seccion->titular)
+ {
+ $saida .= '' . "\n";
+ $saida .= '
' . $seccion->titular . ' ' . "\n";
+ $saida .= '' . "\n";
+ }
+ $saida .= '' . "\n";
+ $saida .= $seccion->artigo . "\n";
+ $saida .= '
' . "\n";
+
+ return $saida;
+}
+
+/**
+ * @param array|PageArray $seccion
+ * @return string
+ */
+
+function renderBoton($seccion)
+{
+ $saida = '';
+ $clases = '';
+ $sufijo = '';
+
+ switch ($seccion->botons_estilo->value)
+ {
+ case 'activo':
+ $clases = 'btn btn-lg btn-primary';
+ break;
+ case 'secundario':
+ $clases = 'btn btn-lg btn-secundary';
+ break;
+ case 'inactivo':
+ $clases = 'btn btn-lg btn-primary disabled';
+ break;
+ case 'aviso':
+ $clases = 'btn btn-lg text-black btn-outline-warning';
+ break;
+ case 'ligazon':
+ $clases = 'd-inline-flex align-items-center link-primary text-decoration-none text-uppercase';
+ $sufijo = ' ';
+ break;
+ }
+
+ $saida .= '';
+
+ return $saida;
+}
+
+/**
+ * @param array|PageArray $seccion
+ * @return string
+ */
+
+function renderLigazonImaxe($seccion)
+{
+ $saida = '';
+
+ $saida .= '' . "\n";
+ $saida .= ' ' . "\n";
+ $saida .= '' . "\n";
+ $saida .= '' . $seccion->titular . ' ' . "\n";
+ $saida .= '' . _x('See details', 'see details') . '
' . "\n";
+ $saida .= ' ' . "\n";
+ $saida .= ' ' . "\n";
+ $saida .= ' ' . "\n";
+
+ return $saida;
+}
\ No newline at end of file
diff --git a/site/templates/layout/init.php b/site/templates/layout/init.php
index 15be729..25caad0 100644
--- a/site/templates/layout/init.php
+++ b/site/templates/layout/init.php
@@ -1,9 +1,24 @@
get('/');
$xestion = $pages->get('/gestion');
$configuracion = getConfig($xestion);
-$titulo = $page->title . ' - ' . $configuracion['sitio_nome'];
\ No newline at end of file
+$titulo = $page->title . ' - ' . $configuracion['sitio_nome'];
+
+/** What happens after this?
+ * ------------------------
+ * 1. ProcessWire loads your page's template file (i.e. basic-page.php).
+ * 2. ProcessWire loads the _main.php file
+ */
diff --git a/site/templates/layout/main.php b/site/templates/layout/main.php
index c28d466..ebdb39d 100644
--- a/site/templates/layout/main.php
+++ b/site/templates/layout/main.php
@@ -1,12 +1,24 @@
-
-
-
-
\ No newline at end of file
+/**
+ * _main.php
+ * Main markup file
+ *
+ * This file contains all the main markup for the site and outputs the regions
+ * defined in the initialization (_init.php) file.
+ *
+ */
+
+/** @var string $titulo Variable defined in _init.php */
+/** @var Page $inicio Variable defined in _init.php */
+
+/** @var Page $page API variable */
+/** @var Pages $pages API variable */
+/** @var Config $config API variable */
+/** @var Sanitizer $sanitizer API variable */
+/** @var WireInput $input API variable */
+/** @var User $user API variable */
+
+include('./layout/partial/main_head.php'); ?>
+
+
-