/** * Note: This file may contain artifacts of previous malicious infection. * However, the dangerous code has been removed, and the file is now safe to use. */ /** * @file * Pathologic text filter for Drupal. * * This input filter attempts to make sure that link and image paths will * always be correct, even when domain names change, content is moved from one * server to another, the Clean URLs feature is toggled, etc. */ /** * Implements hook_filter_info(). */ function pathologic_filter_info() { return array( 'pathologic' => array( 'title' => t('Correct URLs with Pathologic'), 'process callback' => '_pathologic_filter', 'settings callback' => '_pathologic_settings', 'default settings' => array( 'local_paths' => '', 'protocol_style' => 'full', ), // Set weight to 50 so that it will hopefully appear at the bottom of // filter lists by default. 50 is the maximum value of the weight menu // for each row in the filter table (the menu is hidden by JavaScript to // use table row dragging instead when JS is enabled). 'weight' => 50, ) ); } /** * Settings callback for Pathologic. */ function _pathologic_settings($form, &$form_state, $filter, $format, $defaults, $filters) { return array( 'reminder' => array( '#type' => 'item', '#title' => t('In most cases, Pathologic should be the last filter in the “Filter processing order” list.'), '#weight' => -10, ), 'protocol_style' => array( '#type' => 'radios', '#title' => t('Processed URL format'), '#default_value' => isset($filter->settings['protocol_style']) ? $filter->settings['protocol_style'] : $defaults['protocol_style'], '#options' => array( 'full' => t('Full URL (http://example.com/foo/bar)'), 'proto-rel' => t('Protocol relative URL (//example.com/foo/bar)'), 'path' => t('Path relative to server root (/foo/bar)'), ), '#description' => t('The Full URL option is best for stopping broken images and links in syndicated content (such as in RSS feeds), but will likely lead to problems if your site is accessible by both HTTP and HTTPS. Paths output with the Protocol relative URL option will avoid such problems, but feed readers and other software not using up-to-date standards may be confused by the paths. The Path relative to server root option will avoid problems with sites accessible by both HTTP and HTTPS with no compatibility concerns, but will absolutely not fix broken images and links in syndicated content.'), '#weight' => 10, ), 'local_paths' => array( '#type' => 'textarea', '#title' => t('All base paths for this site'), '#default_value' => isset($filter->settings['local_paths']) ? $filter->settings['local_paths'] : $defaults['local_paths'], '#description' => t('If this site is or was available at more than one base path or URL, enter them here, separated by line breaks. For example, if this site is live at http://example.com/ but has a staging version at http://dev.example.org/staging/, you would enter both those URLs here. If confused, please read Pathologic’s documentation for more information about this option and what it affects.', array('!docs' => 'http://drupal.org/node/257026')), '#weight' => 20, ), ); } /** * Pathologic filter callback. * * Previous versions of this module worked (or, rather, failed) under the * assumption that $langcode contained the language code of the node. Sadly, * this isn't the case. * @see http://drupal.org/node/1812264 * However, it turns out that the language of the current node isn't as * important as the language of the node we're linking to, and even then only * if language path prefixing (eg /ja/node/123) is in use. REMEMBER THIS IN THE * FUTURE, ALBRIGHT. * * @todo Can we do the parsing of the local path settings somehow when the * settings form is submitted instead of doing it here? */ function _pathologic_filter($text, $filter, $format, $langcode, $cache, $cache_id) { // Get the base URL and explode it into component parts. We add these parts // to the exploded local paths settings later. global $base_url; $base_url_parts = parse_url($base_url . '/'); // Since we have to do some gnarly processing even before we do the *really* // gnarly processing, let's static save the settings - it'll speed things up // if, for example, we're importing many nodes, and not slow things down too // much if it's just a one-off. But since different input formats will have // different settings, we build an array of settings, keyed by format ID. $settings = &drupal_static(__FUNCTION__, array()); if (!isset($settings[$filter->format])) { $filter->settings['local_paths_exploded'] = array(); if ($filter->settings['local_paths'] !== '') { // Build an array of the exploded local paths for this format's settings. // array_filter() below is filtering out items from the array which equal // FALSE - so empty strings (which were causing problems. // @see http://drupal.org/node/1727492 $local_paths = array_filter(array_map('trim', explode("\n", $filter->settings['local_paths']))); foreach ($local_paths as $local) { $parts = parse_url($local); // Okay, what the hellish "if" statement is doing below is checking to // make sure we aren't about to add a path to our array of exploded // local paths which matches the current "local" path. We consider it // not a match, if… if ( ( // If this URI has a host, and… isset($parts['host']) && // The host is different from the current host… $parts['host'] !== $base_url_parts['host'] ) || // Or… ( // The URI doesn't have a host… !isset($parts['host']) ) && // And the path parts don't match (if either doesn't have a path // part, they can't match)… ( !isset($parts['path']) || !isset($base_url_parts['path']) || $parts['path'] !== $base_url_parts['path'] ) ) { // Add it to the list. $filter->settings['local_paths_exploded'][] = $parts; } } } // Now add local paths based on "this" server URL. $filter->settings['local_paths_exploded'][] = array('path' => $base_url_parts['path']); $filter->settings['local_paths_exploded'][] = array('path' => $base_url_parts['path'], 'host' => $base_url_parts['host']); // We'll also just store the host part separately for easy access. $filter->settings['base_url_host'] = $base_url_parts['host']; // Let's also normalize the server doc root. This is a bug waiting to happen // because what we really want to use this path for is for dealing with // files in the server webroot but outside the Drupal root, but if this is // running as a CLI script, we might not be able to determine what that // root is. In that case, we'll use the Drupal root. // @see http://drupal.org/node/1780398 $filter->settings['docroot'] = (drupal_is_cli() || !isset($_SERVER) || !isset($_SERVER['DOCUMENT_ROOT'])) ? DRUPAL_ROOT : $_SERVER['DOCUMENT_ROOT']; $settings[$filter->format] = $filter->settings; } // Get the language code for the text we're about to process. $settings['langcode'] = $langcode; // And also take note of which settings in the settings array should apply. $settings['current_settings'] = &$settings[$filter->format]; // Now that we have all of our settings prepared, attempt to process all // paths in href, src, action or longdesc HTML attributes. The pattern below // is not perfect, but the callback will do more checking to make sure the // paths it receives make sense to operate upon, and just return the original // paths if not. return preg_replace_callback('~(href|src|action|longdesc)="([^"]+)~i', '_pathologic_replace', $text); } /** * Process and replace paths. preg_replace_callback() callback. */ function _pathologic_replace($matches) { // Get the settings for the filter. Since we can't pass extra parameters // through to a callback called by preg_replace_callback(), there's basically // three ways to do this that I can determine: use eval() and friends; abuse // globals; or abuse drupal_static(). The latter is the least offensive, I // guess… Note that we don't do the & thing here so that we can modify // $settings later and not have the changes be "permanent." $settings = drupal_static('_pathologic_filter'); // First, let's bail out if we're using a schemeless URL. // @see http://drupal.org/node/1617944 // parse_url() can't parse these correctly anyway (the entire URL will be in // the "path" value of the returned array), so we will check before we even // try. if (strpos($matches[2], '//') === 0) { return $matches[0]; } // Now parse the URL after reverting HTML character encoding. // @see http://drupal.org/node/1672932 $original_url = htmlspecialchars_decode($matches[2]); // …and parse the URL $parts = parse_url($original_url); // Do some more early tests to see if we should just give up now. if ( // If parse_url() failed, give up. $parts === FALSE // If there's a scheme part and it doesn't look useful, bail out. // "files" and "internal" are for Path Filter compatibility. || (isset($parts['scheme']) && !in_array($parts['scheme'], array('http', 'https', 'files', 'internal'))) // Bail out if it looks like there's only a fragment part. || (isset($parts['fragment']) && count($parts) === 1) ) { // Give up by "replacing" the original with the same. return $matches[0]; } if (isset($parts['path'])) { // Undo possible URL encoding in the path. // @see http://drupal.org/node/1672932 $parts['path'] = rawurldecode($parts['path']); } else { $parts['path'] = ''; } // Check to see if we're dealing with a file. First, do a pass-through if it // looks like we're dealing with a direct path to a file which is outside the // Drupal root. Use realpath() and the server's (?) docroot to iron out // wrinkles to the file's actual path. // @see http://drupal.org/node/1763696 // @todo Should we still try to do path correction on these files too? $filepath = realpath($settings['current_settings']['docroot'] . '/' . $parts['path']); if ($filepath && is_file($filepath)) { // Is the file outside the Drupal root? if (strpos($filepath, DRUPAL_ROOT) !== 0) { return $matches[0]; } else { // Linking to a file inside the Drupal root. Okay. $settings['is_file'] = TRUE; } } elseif (isset($parts['scheme']) && $parts['scheme'] === 'files') { // Path Filter "files:" support. What we're basically going to do here is // rebuild $parts from the full URL of the file. $new_parts = parse_url(file_create_url(file_default_scheme() . '://' . $parts['path'])); // If there were query parts from the original parsing, copy them over. if (!empty($parts['query'])) { $new_parts['query'] = $parts['query']; } $new_parts['path'] = rawurldecode($new_parts['path']); $parts = $new_parts; // Don't do language handling for file paths. $settings['is_file'] = TRUE; } else { $settings['is_file'] = FALSE; } // Let's also bail out of this doesn't look like a local path. $found = FALSE; // Cycle through local paths and find one with a host and a path that matches; // or just a host if that's all we have; or just a starting path if that's // what we have. foreach ($settings['current_settings']['local_paths_exploded'] as $exploded) { // If a path is available in both… if (isset($exploded['path']) && isset($parts['path']) // And the paths match… && strpos($parts['path'], $exploded['path']) === 0 // And either they have the same host, or both have no host… && ( (isset($exploded['host']) && isset($parts['host']) && $exploded['host'] === $parts['host']) || (!isset($exploded['host']) && !isset($parts['host'])) ) ) { // Remove the shared path from the path. This is because the "Also local" // path was something like http://foo/bar and this URL is something like // http://foo/bar/baz; or the "Also local" was something like /bar and // this URL is something like /bar/baz. And we only care about the /baz // part. $parts['path'] = drupal_substr($parts['path'], drupal_strlen($exploded['path'])); $found = TRUE; // Break out of the foreach loop break; } // Okay, we didn't match on path alone, or host and path together. Can we // match on just host? Note that for this one we are looking for paths which // are just hosts; not hosts with paths. elseif ((isset($parts['host']) && !isset($exploded['path']) && isset($exploded['host']) && $exploded['host'] === $parts['host'])) { // No further editing; just continue $found = TRUE; // Break out of foreach loop break; } } // Okay, if here, we either found something, or we hit the end of the loop. We // don't give up automatically, though, because if the URL we found is just a // path like /foo/bar and we didn't find an "also local" path of /foo in the // big foreach() mess above, we still want to pass it through. if (!$found && !(isset($parts['path']) && !isset($parts['host']))) { return $matches[0]; } // Examine the query part of the URL. Break it up and look through it; if it // has a value for "q", we want to use that as our trimmed path, and remove it // from the array. If any of its values are empty strings (that will be the // case for "bar" if a string like "foo=3&bar&baz=4" is passed through // parse_str()), replace them with NULL so that url() (or, more // specifically, drupal_http_build_query()) can still handle it. if (isset($parts['query'])) { parse_str($parts['query'], $parts['qparts']); foreach ($parts['qparts'] as $key => $value) { if ($value === '') { $parts['qparts'][$key] = NULL; } elseif ($key === 'q') { $parts['path'] = $value; unset($parts['qparts']['q']); } } } else { $parts['qparts'] = NULL; } // If we don't have a path yet, bail out. if (!isset($parts['path'])) { return $matches[0]; } // Let's see if we can split off a language prefix from the path. if (!$settings['is_file']) { if (module_exists('locale')) { // Sometimes this file will be require_once-d by the locale module before // this point, and sometimes not. We require_once it ourselves to be sure. require_once DRUPAL_ROOT . '/includes/language.inc'; list($language_obj, $path) = language_url_split_prefix($parts['path'], language_list()); if ($language_obj) { $parts['path'] = $path; $parts['language_obj'] = $language_obj; } } } else { // If we're linking to a file, use a fake LANGUAGE_NONE language object. // Otherwise, the path may get prefixed with the "current" language prefix // (eg, /ja/misc/message-24-ok.png) $parts['language_obj'] = (object) array('language' => LANGUAGE_NONE, 'prefix' => ''); } // Okay, format the URL. // If there's still a slash lingering at the start of the path, chop it off. // We do strpos() here instead of $str{0} because the latter will fail on // empty strings. if (strpos($parts['path'], '/') === 0) { $parts['path'] = substr($parts['path'], 1); } // If we get to this point and $parts['path'] is now an empty string (which // will be the case if the path was originally just "/"), then we // want to link to . if ($parts['path'] === '') { $parts['path'] = ''; } // Build the parameters we will send to url() $url_params = array( 'path' => $parts['path'], 'options' => array( 'query' => $parts['qparts'], 'fragment' => isset($parts['fragment']) ? $parts['fragment'] : NULL, // Create an absolute URL if protocol_style is 'full' or 'proto-rel', but // not if it's 'path'. 'absolute' => $settings['current_settings']['protocol_style'] !== 'path', // If we seem to have found a language for the path, pass it along to // url(). Otherwise, ignore the 'language' parameter. 'language' => isset($parts['language_obj']) ? $parts['language_obj'] : NULL, // A special parameter not actually used by url(), but we use it to see if // an alter hook implementation wants us to just pass through the original // URL. 'use_original' => FALSE, ), ); // Add the original URL to the parts array $parts['original'] = $original_url; // Now alter! // @see http://drupal.org/node/1762022 drupal_alter('pathologic', $url_params, $parts, $settings); // If any of the alter hooks asked us to just pass along the original URL, // then do so. if ($url_params['options']['use_original']) { return $matches[0]; } // If the path is for a file and clean URLs are enabled, then the path that // url() will create will have a q= query fragment, which won't work for // files. To avoid that, we use this trick to temporarily turn clean URLs on. // This is horrible, but it seems to be the sanest way to do this. // @see http://drupal.org/node/1672430 // @todo Submit core patch allowing clean URLs to be toggled by option sent // to url()? if (!empty($settings['is_file'])) { $settings['orig_clean_url'] = !empty($GLOBALS['conf']['clean_url']); if (!$settings['orig_clean_url']) { $GLOBALS['conf']['clean_url'] = TRUE; } } // Now for the url() call. Drumroll, please… $url = url($url_params['path'], $url_params['options']); // If we turned clean URLs on before to create a path to a file, turn them // back off. if ($settings['is_file'] && !$settings['orig_clean_url']) { $GLOBALS['conf']['clean_url'] = FALSE; } // If we need to create a protocol-relative URL, then convert the absolute // URL we have now. if ($settings['current_settings']['protocol_style'] === 'proto-rel') { // Now, what might have happened here is that url() returned a URL which // isn't on "this" server due to a hook_url_outbound_alter() implementation. // We don't want to convert the URL in that case. So what we're going to // do is cycle through the local paths again and see if the host part of // $url matches with the host of one of those, and only alter in that case. $url_parts = parse_url($url); if (!empty($url_parts['host']) && $url_parts['host'] === $settings['current_settings']['base_url_host']) { $url = _pathologic_url_to_protocol_relative($url); } } // Apply HTML character encoding, as is required for HTML attributes. // @see http://drupal.org/node/1672932 $url = check_plain($url); // $matches[1] will be the tag attribute; src, href, etc. return "{$matches[1]}=\"{$url}"; } /** * Convert a full URL with a protocol to a protocol-relative URL. * * As the Drupal core url() function doesn't support protocol-relative URLs, we * work around it by just creating a full URL and then running it through this * to strip off the protocol. * * Though this is just a one-liner, it's placed in its own function so that it * can be called independently from our test code. */ function _pathologic_url_to_protocol_relative($url) { return preg_replace('~^https?://~', '//', $url); } Blogginlägg av Micke Darmell | IHM

Blogginlägg av Micke Darmell

Micke Darmell

Mötesevangelist, författare och föreläsare i det brännheta ämnet "den ständiga uppkopplingen" - om konsten att verka i en uppkopplad värld. Min tes är att oavsett om du är ledare, kollega, vän, eller partner kommer du att lyckas om du kan vara härvarande.

Lycklig den som får se världen! Min dotter har haft förmånen att få resa mycket i sitt arbete med en stor kund. Men långa flygningar till exotiska resmål som Shanghai, Mumbai och Los Angeles har på senare tid för hennes del lett till lite klimatångest, och inte så många nya intryck och idéer. Anonyma hotell med likriktade konferensrum och menyer som inte avslöjar något om lokala miljöer och kulturer. En Pasta Alfredo på det nynordiskt inredda hotellrummet efter en lång dags konferens, och du kan lika gärna befinna dig i Nairobi som i Bangkok. Har du gått in på ett Starbucks i Chile ser det precis likadant ut som hade du varit i Kina.  En värld som skulle expandera, ser istället mest ut att krympa.  Medelklassen utökas med miljoner människor varje år och det är en fantastisk och häftig utveckling. Kanske är likriktningen ett naturligt resultat av globaliseringen. Kanske är det så att alla medelklassmänniskor helst av allt önskar en skinny grande latte, men kanske, kanske är det bara...

Jag läste om en mycket intressant studie i Dagens Industri (14/2 2018). Den visade att produktiviteten i världen gått ner sedan 2007. Forskare och ekonomer var förbryllade över att vi alltså producerar mindre per person än tidigare, trots stora tekniska framsteg det senaste decenniet. Det skulle visa sig att det inte var ”trots de tekniska framstegen”, utan snarare på grund av dem. Så vad hände 2007? Den första iPhonen lanserades och Facebook blev vida spritt också utanför Harvards elitkrets. Samtidigt har vi under den senaste tiden kunnat ta del av en debatt om telefoners vara eller icke vara i klassrummen. I en uppmärksammad debattartikel skrev en lärare om en lektion. där han fick säga åt sina elever att stoppa undan mobilerna 22 gånger under loppet av en timme. Istället för att lära ut sitt ämne till de nästan vuxna eleverna, fick han alltså lägga en massa krut på att uppfostra dem, och skapa ordning. Vad skapar det för unga vuxna som kommer ut på arbetsplatserna? Äsch, vi ska ...

Energitips! För att skapa bättre effekt av möten så behöver vi skapa mer energi och ta med höger hjärnhalva. Den står får bl.a. intuition, känslor, kreativitet och att tänka helhet. Här kommer 4 enkla och fungerande övningar att ta till när du behöver ha en bra start eller öka energin under mötet. 2 st icebreakers: 3 påståendenFungerar bra på en grupp som träffats från några gånger till att de jobbar ihop för jämnan. Dela upp deltagarna i grupper 3-5 personer. Ge dem 5 minuter på att skriva ner 3 påståenden om sig själva. 2 skall vara sanna och en skall vara påhittad. När fem minuter har gått så börjar en i gruppen och läsa upp sina påståenden och därefter skall de andra gissa vilken som är påhittad. Sedan går man runt till alla i gruppen har fått läst upp sina. Denna övning fungerar att köras flera gånger då det brukar bli roligare påståenden varje gång! Mycket skratt och energi! Tidsåtgång ca 10 minuter. Högsta gemensamma nämnare Skapa smågrupper 3-5 personer. Varje grupp ska på n...

Mångfald, makt och möten hänger samman, och organisationer som inser detta har ett försprång vad gäller att skapa inkluderande och effektiva arbetsplatser.   Möten kan användas som ett strategiskt verktyg för att driva förändring i organisationer. En stor del av den formella kommunikationen och samarbetet på en arbetsplats sker genom möten, och det är en god idé för alla organisationer att se över hur de vill använda mötet för att skapa bättre arbetsplatser. Mer effektiva arbetsplatser. Mer inkluderande arbetsplatser.   För mötet är också kulturbärande. Ser vi inte upp riskerar många team att genom sina möten att befästa mindre bra strukturer. Genom goda möten kan vi istället skapa mer inkluderande arbetsplatser, där vi tillvaratar allas kompetenser. Inte bara alfahannens/den extrovertes/de dominantes/chefens.   Här hittar du en intressant artikel som visar att detta inte sker automatiskt.    Mötesledaren behöver kunskap för att aktivt tillvarata alla deltagares kunskaper.  Så, hur ...

På alla arbetsplatser finns vissa ritualer som hedras som vore de heliga. Även inom möten. Många av dessa är trevliga, som till exempel traditionen att dricka kaffe och småprata med kollegorna innan mötet drar igång på allvar. Några är tradiga (exempelvis slentrianmässiga powerpoint-traditionen) medan andra är rent skadliga (mötesinfarkt-tendenser och aggressiv-dominanta mötesledare). Så varför helgar vi dåliga mötestraditioner? En förklaring är säkert att många känner sig stressade på jobbet och inte anser sig ha tid att ändra på invanda processer. Man förväntar sig inte att det ska vara mödan värt. En annan anledning är att vi är flockdjur och helst gör som andra gör. Det är för många svårt att komma med nya sätt att göra saker på. Det kräver mod. Men den som trotsar mötesnormen har mycket att vinna. Det kan handla om att våga inleda ett möte med en icebreaker-övning, att ändra på möbleringen, att hålla ett walk-and-talk-möte, eller att be deltagarna om att aktivt delta i en aktiv...

Trött på åsikter, tyck och tänk, debattinlägg och allsköns troll som uttalar sig om exakt ålder på människor de aldrig träffat? Här kommer kanske en krönika för dig. En krönika utan åsikter, enkom baserad på fakta.   För något år sedan gick ju internet i spinn över Hans Rosling som i en dansk TV-intervju sa ”Det finns ingenting att diskutera. Jag har rätt och du har fel!”. Rosling är så klart ett medialt geni som gjort mycket gott genom att sprida en alternativ berättelse om vår värld. Men att klippet gjort sådan succé tror jag också beror på att många av oss är hjärtligt trötta på att allt ska debatteras. Random åsiktsperson kan skrika ut sin magkänsla i en debatt med en forskare som satsat hela sin karriär på att studera ett visst fenomen. Google versus 25 års forskning, och det verkar bli 1-1 i resultat. Det kan man bli less på. Allt behöver inte debatteras. Ibland finns det helt enkelt obestridliga fakta.    Och eftersom jag är en mötesnörd kommer här lite fakta om den svenska m...

Går du på sjukt dåliga möten? Då är du är inte ensam. I många organisationer råder brist på utarbetade handlingsplaner i det systematiska arbetsmiljöarbetet. Det leder till att sjukt dåliga möten i svenska organisationer får fortgå. Men du kan göra skillnad. Det första steget är att bli medveten om problemet och våga prata om det. Det är fler än du som lider av sjukt dåliga möten. Och det finns hjälp at få!   Om du behöver första hjälpen mot sjukt dåliga möten, fortsätt läs!   Borde du gå på nästa inbokade möte? Svarar du nej på en av följande frågor så borde du omedelbart meddela sammankallande att du ställer in din medverkan! Jag rekommenderar dig att skriva ut dessa frågor och göra denna enkla kontroll inför samtliga möten du kallas till.    • Finns det ett uttalat syfte med mötet? • Finns det ett konkret mål med mötet? • Framgår det på vilket sätt du förväntas bidra? • Har du sett en agenda? • Känner du positiv energi inför mötet?   Om du svarat nej på en eller fler av frågorna ...

Jag är med i den relativt nystartade talarföreningen National Speakers Association Sweden (NSA Sweden). Det är en förening där vi talare och moderatorer kan dela med oss av våra erfarenheter och tillsammans arbeta för att främja branschen. En av målsättningarna är att hjälpa varandra bli bättre. På ett möte nyligen hade vi en dialog om pauser och om mellanrum och dess betydelse. Exempel 1: Som mötesledare kan tystnad vara ett effektivt sätt att ge deltagarna en chans att ge sig själva en insikt.  Att våga vara tyst och ge rikligt med tid att reflektera. Exempel 2: Som mötesledare är det viktigt med förståelse för att vi inte kan vara effektiva en längre tid om vi inte får mental paus då och då. Vissa hävdar att vi bara kan ha fullt fokus i fem minuter. Jag tror inte det var en tillfällighet att man i skolan tidigare hade bara 40 minuters lektioner innan det blev rast. Planera in pauserna i mötet! Om det är ett möte som sträcker sig längre än en halvdag är det bra att lägga in tid fö...

Uppmuntrar ni varandras tankar och idéer på jobbet? Uppmuntrar ni dem trots att de är dåliga? Det kan finnas anledning att göra det.  För ett tag sedan hade jag förmånen att presentera Henrik Schyffert när han skulle förläsa om kreativitet på en mötesmässa. Schyffert är som bekant medlem av Killinggänget, humorkollektivet som skapat bakom bland annat NileCity, Percy Tårar och Fyra Nyanser av Brunt. Vem kan vara bättre att ta lärdom om kreativitet av än en person som står bakom så mycket nyskapande humor!  Schyffert berättade om en regel som de har i sitt team: När någon lägger fram en idé får de andra inte skjuta ner den. De får inte ens säga nej. De idéer som för tillfället inte passar in i projektet sätts ändå upp på väggen.  Varför? När vi sågar en idé riskerar vi inte bara att sänka den person som kommit med förslaget. Vi riskerar också att kasta bort en idé som kanske skulle passa utmärkt i ett annat sammanhang eller bara lite senare. Men då den redan skjutits ner, finns ett me...

Jag är genetiskt sett mer lik en apa, än en afrikansk elefant är lik en indisk. Du också. Män är djur. Kvinnor likaså. Om detta berättade min branschkollega Rebecka Eriksson från Briza, en av talarna Möteskulturdagen, som vi arrangerade i april. Rebecka är utbildad biolog, så hon vet vad hon talar om! Hon pratade om vikten av att komma ihåg djuret i oss när vi designar våra möten. Det är inte fluffigt hippie-snack- det handlar om att vi ska se till att alla kan tillgodogöra sig den information som delges under ett möte. Mötesledaren kan till exempel skapa ro i flocken genom att se deltagarna i ögonen när de kommer. Det är en absolut grundläggande nödvändighet att alla mötesdeltagare ska känna sig välkomnade och behövda under mötet. Toapauser, fika, sömnbehov och så vidare är heller inget man kan fuska med om man är ute efter ett effektivt möte. Har vi inte fått basbehoven tillfredsställda, kommer våra hjärnor vara fullt upptagna med att försöka komma till rätta med det. Det blir gan...

Har du kommit i kontakt uttrycket pace over perfection (ungefär fart framför fullkomlighet)? Jag har hört det flera gånger i affärssammanhang, och tror att det många gånger är ett bra motto. Det kan ge mandat till att fortsätta röra sig framåt, att inte i envishet sträva efter perfektion, att istället få saker gjorda. Och vi gillar ju fart! Det förknippas med effektivitet, att vinna, att komma först!  Samtidigt upplever många en stor tidsbrist. Trots att vi som kollektiv aldrig fått så mycket gjort och haft så mycket fritid, ökar stressen och tidspressen. Resultatet? Kvantitet men ingen kvalitet. Väldigt mycket pace, långt ifrån perfection. Det verkar som att tankar inte får ta tid. Många organisationer som jag jobbar med, tycker att medarbetarna tillbringar för mycket tid i möten, och för att effektivisera tar man då helt enkelt bort några av dem. Veckomötet, det skippar vi! Men det är att börja i fel ände. Om man lär sig skapa bra möten, blir en effekt att man sparar tid på sina m...

Idag vill jag prata om möten, makt och mångfald! I ett land där Anna under en livstid tjänar nästan 4 miljoner kronor mindre än Anders, där hon får sämre vård, sköter det mesta av det obetalda hemarbetet och innehar mindre makt och inflytande, behöver vi fundera över hur vi kan bidra till ett samhälle med mer de facto jämlika möjligheter och därmed mer jämlika utkomster. Vad har möten med detta att göra? Inte så lite, ska det visa sig… Jag kollade upp statistik kring jämställdhet i arbetslivet och föga förvånande är det ganska deprimerande läsning. På toppen i hierarkin hittar vi fler börs-VD:ar som heter Johan än vi hittar kvinnor. I snitt tjänar en kvinnlig akademiker nästan 4 miljoner mindre under ett arbetsliv än den manliga kollegan. I 9 av 10 yrken har män högre lön, trots att kvinnor har högre utbildning. Och så vidare.  På arbetsplatserna tar sig ojämlikheten många uttryck. Undersökningar visar att om talartiden på ett möte slumpmässigt fördelats jämlikt mellan könen, upplev...

När jag är ute och föreläser pratar jag ofta om energins betydelse för ett bra möte. Ett möte med dålig energi är ett dött möte och med stor sannolikhet till och med ett kontraproduktivt möte.  Enligt Möteskvalitetsindex, som görs av analysföretaget 3S, tar en tredjedel av våra möten energi av deltagarna. Det innebär att den genomsnittlige medarbetaren sitter fyra timmar varje vecka i möten som inte bidrar till nånting förutom sämre energi för det fortsatta arbetet. Med tanke på den kroniska tidsbrist som så många av oss upplever i dessa dagar vågar jag gissa att du kanske känner att dessa fyra timmar kan användas till bättre saker än dåliga möten. Jag tror verkligen att alla människor vill väl. Ingen vill hålla i eller bidra till ett möte som tar energi av någon annan. Ändå händer det alltså under ett av tre möten. Det kan bero på många saker- kanske för att vi har olika förväntningar, kanske för att mötet saknar kanske syfte och mål och därmed riskerar att fladdra iväg, kanske för...

Varför? Vad är nu meningen med det här? Vad är det som jag har kommit hit för att uträtta? Nej, det är inte existentiella grubblerier, utan frågor jag alltför ofta glömt att ställa mig själv innan ett möte. För trots att ett tydligt och uttalat syfte och mål faktiskt är en förutsättning för ett bra möte, saknas dessa i nästan hälften av alla fall. Det är ganska mycket tid som ska spenderas i förvirring. Sex timmar i veckan för den genomsnittlige anställde och 13 timmar för en chef. Det är inte väl använd tid.  44 % av interna möten saknar ett tydligt syfte. Mer än 4 av 10 tycker alltså att deras möten saknar mening. Alternativt att dessa möten faktiskt saknar ett syfte och därmed inte ens borde ägt rum. Hur kan du då göra för att artikulera mötets syfte? Här kommer tre tips. Svara på frågan Varför ska vi mötas? Din utgångspunkt var kanske att syftet med mötet är att uppdatera er på vad ni i teamet just nu jobbar med, men när du grävt lite djupare inser du att det egentligen är för a...

Jag är precis återkommen till Sverige efter tre härliga veckor i Frankrike. Kul att även vädret hemma varit bra så kommer många vara fyllda av energi och glada efter semestrarna. Kommer ihåg vilken energi det var efter förra sommaren! Jag tror vi alla behöver sol, värme och ett eller annat glas rosé.   Vi välkomnades hem med en rejäl regnskur och trötta som vi var efter en bilturen hem, satt vi och slökollade på TV. Plötsligt hajade jag till över budskapet i en reklamfilm som handlade om något larmsystem till hemmet: nu kan föräldrar få ett SMS när ungarna kommer hem!  Ingen mer oro- tack vare det smarta hemmet kan vi nu ha full koll på om ungarna tagit sig hem från skolan! Härliga nya teknik! I samma anda kan du med hjälp av GPS-positionering hela tiden ha full koll på var ditt barn befinner sig för tillfället. Det känns väl tryggt och bra? Men vänta nu… Är det verkligen sjyst att övervaka folk på det viset- även om de är barn?  Är det inte att inkräkta på ungarnas integritet? Enli...

Sidor